Personalo priėmimo operacijų dokumentų nuskaitymas
POST https://api.manorivile.lt/client/v2
ApiKey
: Privalomas. Unikalus API raktas išduodamas užsakant paslaugąContent-Type
: Privalomas. Kokiu formatu paduodami parametrai ir duomenys (request):
application/xml
application/json
Accept
: Neprivalomas. Gražinamo rezultato (response) formatas
application/xml
(default)application/json
(veikia nuo Manorivile-Gateway-1.1.0 versijos)method
: MGAMA_GET_K16_PRIEM_LIST
params
:
fil
: filtravimo sąlyga. T-SQL tipo where sąlygos užklausa iš lentelės K16 nenurodant pačio where tag'o. Neprivalomapagenumber
: įrašų puslapio numeris. GET_LIST metodai rezultatus grąžina puslapiais po 100 įrašų, pagenumber
parametras nurodo kelintą puslapį grąžinti. Jei nenurodomas, tuomet grąžinamas pirmas puslapis su 100 naujausių įrašų. NeprivalomaSąraše su daugiau nei 1 įrašu informacija visada grąžinama surūšiuota pagal atitinkamos lentelės raktą (Primary Key)
GET_LIST metodų apribojima 100 įrašų, todėl norint gauti visą sąrašą, turite naudoti filtrus, kurie grąžins rezultatą dalimis per kelis kartus, filtruojant pagal paskutinio gauto įrašo rakto reikšmę.
pvz application/xml
:
<body>
<method>MGAMA_GET_K16_PRIEM_LIST</method>
<params>
<fil>k16_kodas_6a='000R00001252'</fil>
<pageNumber>2</pageNumber>
</params>
</body>
pvz application/json
:
{
"method": "MGAMA_GET_K16_PRIEM_LIST",
"params": {
"fil": "k16_kodas_6a='000R00001252'",
"pageNumber": 2
}
}
Grąžinama informacija XML formate tarp tag'ų <RET_DOK>..</RET_DOK>
.
Esant daugiau nei vienam įrašui informacija rūšiuojama (order) pagal lentelės raktinį lauką K16_KODAS_6A
Jeigu įrašų nerasta pagal užduotas sąlygas, tuomet gražinama status=200 bei tuščias
<?xml version='1.0' encoding='UTF-8'?>
<RET_DOK>
<K16>
<ROW_NUMBER>1</ROW_NUMBER>
<K16_KODAS_6A>000000000001</K16_KODAS_6A>
<K16_BEG_DATE>2023-01-01T00:00:00</K16_BEG_DATE>
<K16_BEG_UZ>1900-01-01T00:00:00</K16_BEG_UZ>
<K16_DARBO_UZM>1200</K16_DARBO_UZM>
<K16_DOK_NR>6A0000000001</K16_DOK_NR>
<K16_END_DATE>1900-01-01T00:00:00</K16_END_DATE>
<K16_END_UZ>1900-01-01T00:00:00</K16_END_UZ>
<K16_ET_DALIS>0.000</K16_ET_DALIS>
<K16_KODAS_0A>555 </K16_KODAS_0A>
<K16_KODAS_1A_01> </K16_KODAS_1A_01>
<K16_KODAS_1A_03> </K16_KODAS_1A_03>
<K16_KODAS_1A_15> </K16_KODAS_1A_15>
<K16_KODAS_1A_16> </K16_KODAS_1A_16>
<K16_KODAS_1A_25> </K16_KODAS_1A_25>
<K16_KODAS_4A>001 </K16_KODAS_4A>
<K16_KODAS_5A> </K16_KODAS_5A>
<K16_KODAS_6A_S> </K16_KODAS_6A_S>
<K16_KODAS_8A>F20 </K16_KODAS_8A>
<K16_KODAS_IS>999999999999</K16_KODAS_IS>
<K16_KODAS_LA>S_SISTEMINIS</K16_KODAS_LA>
<K16_KOR_POZ>0</K16_KOR_POZ>
<K16_OP_DATE>2023-11-14T00:00:00</K16_OP_DATE>
<K16_PAV>Vardenis Pavardenis </K16_PAV>
<K16_RUSIS>1</K16_RUSIS>
<K16_SUT_NR> </K16_SUT_NR>
<K16_SUT_TIPAS>1</K16_SUT_TIPAS>
<K16_PERKELTA>2</K16_PERKELTA>
<K16_ADDUSR>MASTER </K16_ADDUSR>
<K16_R_DATE>2023-11-28T10:08:15</K16_R_DATE>
<K16_USERIS>MASTER </K16_USERIS>
</K16>
<K16>
...
</K16>
...
</RET_DOK>
Klaida paduodant duomenis / SQL sintaksės klaidos / kitos DB klaidos
<?xml version='1.0' encoding='UTF-8'?>
<RET_DOK>
<id>3451ded.be556121580910178112</id>
<durationMs>25</durationMs>
<errorMessage>Invalid column name 'k16_kodas_a6'.</errorMessage>
</RET_DOK>
Blogai nurodytas adresas / neteisingai nurodytas API raktas / nenurodytas API raktas / pasibaigęs API rakto galiojimas, pvz
<?xml version='1.0' encoding='UTF-8'?>
<RET_DOK>
<id/>
<durationMs>0</durationMs>
<errorMessage>Api key is not valid</errorMessage>
</RET_DOK>
Nepaleistas MANO Rivile Gateway arba kitaip sutrikusi jo veikla
<?xml version='1.0' encoding='UTF-8'?>
<RET_DOK>
<id/>
<durationMs>0</durationMs>
<errorMessage>Rivile GAMA database is unavailable. Please check if the gateway is running and is set up correctly.</errorMessage>
</RET_DOK>
Laiku nebuvo gautas Rivile API užklausos atsakymas, pavyzdžiui, apkrauta GAMA duomenų bazė
<?xml version='1.0' encoding='UTF-8'?>
<RET_DOK>
<id/>
<durationMs>0</durationMs>
<errorMessage>No response received from client gateway</errorMessage>
</RET_DOK>
Bendrinė sistemos klaida, pvz
<?xml version='1.0' encoding='UTF-8'?>
<Map>
<timestamp>2020-02-05T12:34:26.890+0000</timestamp>
<status>500</status>
<error>Internal Server Error</error>
<message>No message available</message>
<path>/v1</path>
</Map>
<?php
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_HTTPHEADER, [
'ApiKey: 1234567.sssssssssssssssssssssssssssssssssssssssss',
'Content-Type: application/json',
]);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, '{
"method": "MGAMA_GET_K16_PRIEM_LIST",
"params": {
"fil": "k16_kodas_6a=\'000R00001252\'",
"pageNumber": 2
}
}');
$response = curl_exec($ch);
curl_close($ch);
Nuoroda į lentelės aprašymą: K16