Darbuotojų priskaitymų/atskaitymų sąrašas
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
: GET_A11_LIST
params
:
fil
: filtravimo sąlyga. T-SQL tipo where sąlygos užklausa iš lentelės A02 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ę.
Kadangi darbuotojų kortelėse gali būti saugoma konfidenciali informacija, jau egzistuojančių įrašų nuskaitymui ir koregavimui būtinas papildomas leidimas per Rivile Gama parametrą RGI_A06_FIL
. Šiame parametre įvedamas papildomas filtravimas, galimų reikšmių pavyzdžiai: 1=1
(visos darbuotojų kortelės), A11_KODAS_TB='004'
(tik darbuotojų kortelės su tabeliniu kodu '004'). Filtravimo sąlygose galima naudoti visus lentelės A11 laukus.
pvz application/xml
:
<body>
<method>GET_A11_LIST</method>
<params>
<fil>a11_kodas_is='999999999999'</fil>
<pageNumber>1</pageNumber>
</params>
</body>
pvz application/json
:
{
"method": "GET_A11_LIST",
"params": {
"fil": "a11_kodas_is='999999999999'",
"pageNumber": 1
}
}
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ą A11_KODAS_LP
Jeigu įrašų nerasta pagal užduotas sąlygas, tuomet gražinama status=200 bei tuščias
<A11>
<Row_number>1</Row_number>
<A11_KODAS_LP>000000000100</A11_KODAS_LP>
<A11_TIPAS>1</A11_TIPAS>
<A11_KODAS_TB>004 </A11_KODAS_TB>
<A11_KODAS_IS>999999999999</A11_KODAS_IS>
<A11_EIL_NR>2</A11_EIL_NR>
<A11_PAV> Etatinis atlyginimas var pav</A11_PAV>
<A11_ATS_IP>0</A11_ATS_IP>
<A11_IP_DOK> </A11_IP_DOK>
<A11_IP_SUMA>0.00</A11_IP_SUMA>
<A11_POZ_DATE>0</A11_POZ_DATE>
<A11_BEG_DATE>2025-01-21T00:00:00</A11_BEG_DATE>
<A11_END_DATE>2025-01-21T00:00:00</A11_END_DATE>
<A11_USERIS>WS </A11_USERIS>
<A11_R_DATE>2025-01-21T00:00:00</A11_R_DATE>
<A11_KODAS_SS> </A11_KODAS_SS>
<A11_KODAS_KS> </A11_KODAS_KS>
</A11>
<A11>
<Row_number>2</Row_number>
<A11_KODAS_LP>000000000100</A11_KODAS_LP>
<A11_TIPAS>1</A11_TIPAS>
<A11_KODAS_TB>004 </A11_KODAS_TB>
<A11_KODAS_IS>999999999999</A11_KODAS_IS>
<A11_EIL_NR>4</A11_EIL_NR>
<A11_PAV> Etatinis atlyginimas var pav</A11_PAV>
<A11_ATS_IP>0</A11_ATS_IP>
<A11_IP_DOK> </A11_IP_DOK>
<A11_IP_SUMA>0.00</A11_IP_SUMA>
<A11_POZ_DATE>0</A11_POZ_DATE>
<A11_BEG_DATE>2025-01-22T00:00:00</A11_BEG_DATE>
<A11_END_DATE>2025-01-22T00:00:00</A11_END_DATE>
<A11_USERIS>WS </A11_USERIS>
<A11_R_DATE>2025-01-22T00:00:00</A11_R_DATE>
<A11_KODAS_SS> </A11_KODAS_SS>
<A11_KODAS_KS> </A11_KODAS_KS>
</A11>
<A11>
<Row_number>3</Row_number>
<A11_KODAS_LP>000000000100</A11_KODAS_LP>
<A11_TIPAS>1</A11_TIPAS>
<A11_KODAS_TB>004 </A11_KODAS_TB>
<A11_KODAS_IS>999999999999</A11_KODAS_IS>
<A11_EIL_NR>5</A11_EIL_NR>
<A11_PAV> Etatinis atlyginimas var pav</A11_PAV>
<A11_ATS_IP>0</A11_ATS_IP>
<A11_IP_DOK> </A11_IP_DOK>
<A11_IP_SUMA>0.00</A11_IP_SUMA>
<A11_POZ_DATE>0</A11_POZ_DATE>
<A11_BEG_DATE>2025-01-28T00:00:00</A11_BEG_DATE>
<A11_END_DATE>2025-01-28T00:00:00</A11_END_DATE>
<A11_USERIS>WS </A11_USERIS>
<A11_R_DATE>2025-01-28T00:00:00</A11_R_DATE>
<A11_KODAS_SS> </A11_KODAS_SS>
<A11_KODAS_KS> </A11_KODAS_KS>
</A11>
...
</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 'a11_kodas_lf'.</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: *******.*******',
'Content-Type: application/json',
]);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, '{
"method": "GET_A11_LIST",
"params": {
"fil": "a11_kodas_is = \'999999999999\'",
"pageNumber": 1
}
}');
$response = curl_exec($ch);
curl_close($ch);
Nuoroda į lentelės aprašymą: A11