EDIT_N51_FULL

Aprašymas

Naujos sutarties sukūrimas (kartu su detaliomis eilutėmis).

Specifikacija

Address

POST https://api.manorivile.lt/client/v2

Header
  • 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)
Body
  • method : EDIT_N51_FULL
  • params :
    • errorAction - klaidos parametras nurodantis koks veiksmas bus atliekamas įvykus klaidai sutarties formavimo metu, kai yra sukuriama sutartis (N51) ir gaunama klaida vykdant veiksmus su sutarties priedais (N52). Parametras gali turėti tris reikšmes: EXIT, CONTINUE, ROLLBACK (default reikšmė). Reikšmė turi būti paduodama dydžiosiomis raidėmis!
  • data: perduodami duomenys:
    • N51 - atitinkamos lentelės laukai (n51)
    • N52 - atitinkamos lentelės laukai (n52)

errorAction reikšmė turi būti paduodama didžiosiomis raidėmis!

errorAction reikšmių aprašymai:

Reikšmė Aprašymas
ROLLBACK (default reikšmė) Įvykus klaidai tolimesnės procedūros nebus vykdamos, bus ištrinamas dokumentas (I06) ir grąžinama klaida. Klaidos statusas 400
EXIT Įvykus klaidai tolimesnės procedūros nebus vykdamos, bus grąžinamas sukurtas dokumentas (I06) ir klaidų sąrašas. Klaidos statusas 207
CONTINUE Įvykus klaidai procedūros bus vykdamos iki pabaigos, o klaidos dedamos į sąrašą. Grąžinamas sukurtas dokumentas (I06) ir klaidų sąrašas pabaigoje. Klaidos statusas 207

Vienu metu veiksmai atliekami tik su vienu įrašu.

Pirmi 7 ApiKey simboliai (pvz USERABC.JQKPG1d7Pkjxj37ObsgdfEkvfEfvF1oL7h7UMOLo -> USERABC) yra vartotojo vardas Rivile GAMA programoje, kuriuo bus kuriami ar koreguojami įrašai.

XML request
<body>
    <method>EDIT_N51_FULL</method>
    <data>
        <N51>
            <N51_KODAS_KT>SUT01</N51_KODAS_KT>
            <N51_KODAS_KS>121411842</N51_KODAS_KS>
            <N51_TIPAS>2</N51_TIPAS>
            <N51_OP_DATA>2023-12-31</N51_OP_DATA>
            <N52>
                <N52_KODAS_K0>SP001</N52_KODAS_K0>
                <N52_RUSIS>1</N52_RUSIS>
                <N52_KODAS>PREKE1</N52_KODAS>
                <N52_POZ_KAINA>1</N52_POZ_KAINA>
                <N52_KODAS_US2>VNT</N52_KODAS_US2>
                <N52_KAINA>0.99</N52_KAINA>
            </N52>
            <N52>
                <N52_KODAS_K0>SP002</N52_KODAS_K0>
                <N52_RUSIS>1</N52_RUSIS>
                <N52_KODAS>PREKE2</N52_KODAS>
                <N52_POZ_KAINA>1</N52_POZ_KAINA>
                <N52_KODAS_US2>VNT</N52_KODAS_US2>
                <N52_KAINA>0.89</N52_KAINA>
            </N52>
        </N51>
    </data>
</body>
JSON request
{
    "method": "EDIT_N51_FULL",
    "params": {
        "errorAction": "CONTINUE"
    },
    "data": {
        "N51": {
            "N51_KODAS_KT": "SUT01",
            "N51_KODAS_KS": "121411842",
            "N51_TIPAS": "2",
            "N51_OP_DATA": "2023-12-31",
            "N52":[
                {
                "N52_KODAS_K0": "SP001",
                "N52_RUSIS": "1",
                "N52_KODAS": "PREKE1",
                "N52_POZ_KAINA": "1",
                "N52_KODAS_US2": "VNT",
                "N52_KAINA": "0.99"
                },
                {
                "N52_KODAS_K0": "SP002",
                "N52_RUSIS": "1",
                "N52_KODAS": "PREKE2",
                "N52_POZ_KAINA": "1",
                "N52_KODAS_US2": "VNT",
                "N52_KAINA": "0.89"
                }
            ]
        }
    }
}
Response (status 200 OK)
XML response
<RET_DOK>
    <N51>
        <N51_KODAS_KT>SUT01</N51_KODAS_KT>
        <N51_PRIORITETAS>1.000</N51_PRIORITETAS>
        <N51_DOK_NR></N51_DOK_NR>
        <N51_OP_DATA>2023-12-31T00:00:00</N51_OP_DATA>
        <N51_PAV></N51_PAV>
        <N51_KODAS_KS>121411842</N51_KODAS_KS>
        <N51_TIPAS>2</N51_TIPAS>
        ...
        <N52>
            <N52_KODAS_KT>SUT01</N52_KODAS_KT>
            <N52_KODAS_K0>SP001</N52_KODAS_K0>
            <N52_DOK_NR></N52_DOK_NR>
            <N52_OP_DATA>2023-12-31T00:00:00</N52_OP_DATA>
            <N52_PAV></N52_PAV>
            <N52_POZ_SKOL>0</N52_POZ_SKOL>
            <N52_PRIORITETAS>1.000</N52_PRIORITETAS>
            <N52_RUSIS>1</N52_RUSIS>
            <N52_KODAS>PREKE1</N52_KODAS>
            ...
        </N52>
        <N52>
            <N52_KODAS_KT>SUT01</N52_KODAS_KT>
            <N52_KODAS_K0>SP002</N52_KODAS_K0>
            ...
        </N52>
    </N51>
</RET_DOK>
Response (status 207)

207 statusas gaunamas, kai procedūros yra vykdamos perduodant parametrą errorAction su reikšme EXIT arba CONTINUE ir gaunama klaida kažkurioje iš procedūrų, pvz.:

<RET_DOK>
    <N51>
        <N51_KODAS_KT>SUT01</N51_KODAS_KT>
        <N51_PRIORITETAS>1.000</N51_PRIORITETAS>
        <N51_DOK_NR></N51_DOK_NR>
        <N51_OP_DATA>2023-12-31T00:00:00</N51_OP_DATA>
        <N51_PAV></N51_PAV>
        <N51_KODAS_KS>121411842</N51_KODAS_KS>
        <N51_TIPAS>2</N51_TIPAS>
        ...
        <N52>
            <N52_KODAS_KT>SUT01</N52_KODAS_KT>
            <N52_KODAS_K0>SP001</N52_KODAS_K0>
            <N52_DOK_NR></N52_DOK_NR>
            <N52_OP_DATA>2023-12-31T00:00:00</N52_OP_DATA>
            <N52_PAV></N52_PAV>
            <N52_POZ_SKOL>0</N52_POZ_SKOL>
            <N52_PRIORITETAS>1.000</N52_PRIORITETAS>
            <N52_RUSIS>1</N52_RUSIS>
            <N52_KODAS>PREKE1</N52_KODAS>
            ...
        </N52>
    </N51>
    <errors>
        <error>
            <data>&lt;N51>&lt;n52_rusis>1&lt;/n52_rusis>&lt;n52_kodas_kt>SUT01&lt;/n52_kodas_kt>&lt;Id_h>14&lt;/Id_h>&lt;n52_useris>WS&lt;/n52_useris>&lt;n52_kodas_k0>SP002&lt;/n52_kodas_k0>&lt;response_type>2&lt;/response_type>&lt;Id>25&lt;/Id>&lt;Oper>I&lt;/Oper>&lt;n52_addusr>WS&lt;/n52_addusr>&lt;n52_kodas>PREKE6A&lt;/n52_kodas>&lt;/N51></data>
            <dataErrors>
                <dataError>
                    <tag>N52_KODAS</tag>
                    <code>19014</code>
                    <message>Nerastas prekės/paslaugos kodas</message>
                </dataError>
            </dataErrors>
        </error>
    </errors>
</RET_DOK>
Response (status 400)

Klaida paduodant duomenis / SQL sintaksės klaidos / kitos duomenų klaidos

<?xml version='1.0' encoding='UTF-8'?>
<RET_DOK>
    <id/>
    <durationMs>4</durationMs>
    <errorMessage>Nepavyko įvykdyti metodo</errorMessage>
    <document/>
    <errors>
        <error>
            <data>&lt;N51>&lt;n51_addusr>WS&lt;/n51_addusr>&lt;n51_useris>WS&lt;/n51_useris>&lt;response_type>1&lt;/response_type>&lt;Id>1&lt;/Id>&lt;Oper>I&lt;/Oper>&lt;errorAction>EXIT&lt;/errorAction>&lt;n51_kodas_kt>SUT01&lt;/n51_kodas_kt>&lt;/N51></data>
            <dataErrors>
                <dataError>
                    <tag>N51_KODAS_KS</tag>
                    <code>3004</code>
                    <message>Nenurodytas kliento kodas</message>
                </dataError>
            </dataErrors>
        </error>
    </errors>
</RET_DOK>
Response (status 401)

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>
Response (status 502)

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>
Response (status 504)

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>
Response (status 500)

Bendrinė sistemos klaida, pvz

<?xml version='1.0' encoding='UTF-8'?>
<Map>
    <timestamp>2023-12-31T23:59:59.999+0000</timestamp>
    <status>500</status>
    <error>Internal Server Error</error>
    <message>No message available</message>
    <path>/v2</path>
</Map>

PHP pvz

<?php
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_HTTPHEADER, [
      'ApiKey: uUCz6Hh.sKVrjWWRDJAH1c7l4qL2nOoN2K0jARkvuHDdYsYT',
      'Content-Type: application/json',
      ]);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, $payload);
$response = curl_exec($ch);
curl_close($ch);

Lentelės

N51

Nuoroda į lentelės aprašymą: (n51)

N52

Nuoroda į lentelės aprašymą: (n52)