EDIT_I29

Aprašymas

Perkainavimo detalios eilutės (bazinė kaina) koregavimas

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_I29
  • params :
    • oper :
      • I - naujo įrašo sukūrimas (numatytasis)
      • U - įrašo koregavimas
      • D - įrašo ištrynimas
    • user : vartotojo vardas (naudojamas dokumentų skaitliukams, parametrams ir kt.), veikia tik rakto prefix'ui įjungus parametrą RGI_USR_EDIT
  • data: perduodami duomenys:
    • I29 - atitinkamos lentelės laukai (I29)

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

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

Jei naudojate du tagus <KIEKIS_U> ir <BAR_KODAS>, tuomet nereikia naudoti šių tagų: <I29_KODAS_PS>, <I29_KODAS_US>, <I29_KIEKIS>, <I29_FRAKCIJA>

XML request
<body>
    <method>EDIT_I29</method>
    <params>
        <oper>I</oper>
    </params>
    <data>
        <I29>
            <I29_KODAS_PK>010R00000001</I29_KODAS_PK>
            <I29_KODAS_PS>PREKE1</I29_KODAS_PS>
            <I29_KAINA_N>1.1900</I29_KAINA_N>
            <I29_POZ_K>1</I29_POZ_K>
            <I29_POZ>A1</I29_POZ>
        </I29>    
    </data>
</body>
JSON request
{
    "method": "EDIT_I29",
    "params": {
        "oper": "I"
    },
    "data": {
        "I29": {
            "I29_KODAS_PK": "010R00000001",
            "I29_KODAS_PS": "PREKE1",
            "I29_KAINA_N": 1.1900,
            "I29_POZ_K": 1,
            "I29_POZ": "A1"
        }
    }
}
Response (status 200 OK)
XML response
<RET_DOK>
    <I29>
        <I29_KODAS_PK>010R00000001</I29_KODAS_PK>
        <I29_EIL_NR>1</I29_EIL_NR>
        <I29_KODAS_PS>PREKE1</I29_KODAS_PS>
        <I29_KODAS_US>VNT</I29_KODAS_US>
        <I29_FRAKCIJA>1</I29_FRAKCIJA>
        <I29_KIEKIS>0</I29_KIEKIS>
        <I29_KAINA_S>0.0000</I29_KAINA_S>
        <I29_KAINA_N>1.1900</I29_KAINA_N>
        <I29_PERKELTA>1</I29_PERKELTA>
        <I29_USERIS>WS</I29_USERIS>
        <I29_R_DATE>2024-01-01T00:00:01</I29_R_DATE>
        <I29_ADDUSR>WS</I29_ADDUSR>
        <I29_POZ_K>1</I29_POZ_K>
        <I29_POZ>A1</I29_POZ>
    </I29>
</RET_DOK>
JSON response
{
    "I29": {
        "I29_KODAS_PK": "010R00000001",
        "I29_EIL_NR": 1,
        "I29_KODAS_PS": "PREKE1",
        "I29_KODAS_US": "VNT",
        "I29_FRAKCIJA": 1,
        "I29_KIEKIS": 0,
        "I29_KAINA_S": 0,
        "I29_KAINA_N": 1.19,
        "I29_PERKELTA": 1,
        "I29_USERIS": "WS",
        "I29_R_DATE": "2024-01-01T00:00:01",
        "I29_ADDUSR": "WS",
        "I29_POZ_K": 1,
        "I29_POZ": "A1"
    }
}
Response (status 400)

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

<?xml version='1.0' encoding='UTF-8'?>
<RET_DOK>
    <id/>
    <durationMs>0</durationMs>
    <errorMessage>Nepavyko įvykdyti metodo</errorMessage>
    <document/>
    <errors>
        <error>
            <data></data>
            <dataErrors>
                <dataError>
                    <tag>I29_POZ_K</tag>
                    <code>15012</code>
                    <message>Bloga reiksmė</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>2024-01-01T00:00:01.001+0000</timestamp>
    <status>500</status>
    <error>Internal Server Error</error>
    <message>No message available</message>
    <path>/v2</path>
</Map>
Koregavimas, trynimas ir perkėlimas

Koregavimas, trynimas ir perkėlimas vyksta pagal atitinkamos lentelės raktą (Primary Key)

Koreguojant informaciją bus koreguojami tik perduodami laukai.

pvz koregavimas:

<body>
    <method>EDIT_I29</method>
    <params>
        <oper>U</oper>
    </params>
    <data>
        <I29>
            <I29_KODAS_PK>010R00000001</I29_KODAS_PK>
            <I29_EIL_NR>1</I29_EIL_NR>
            <I29_KAINA_N>1.0900</I29_KAINA_N>
        </I29>    
    </data>
</body>

pvz trynimas:

<body>
    <method>EDIT_I29</method>
    <params>
        <oper>D</oper>
    </params>
    <data>
        <I29>
            <I29_KODAS_PK>010R00000001</I29_KODAS_PK>
            <I29_EIL_NR>1</I29_EIL_NR>
        </I29> 
    </data>
</body>

PHP pvz

<?php
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_HTTPHEADER, [
      'ApiKey: uUCz7UY.sKVrjaWRDJAH1c7l4qL272ng2K0jARgkkHDdYTso',
      'Content-Type: application/json',
      ]);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, '{
    "method": "EDIT_I28",
    "params": {
        "oper": "I"
    },
    "data": {
        "I29": {
            "I29_KODAS_PK": "010R00000001",
            "I29_KODAS_PS": "PREKE1",
            "I29_KAINA_N": 1.1900,
            "I29_POZ_K": 1,
            "I29_POZ": "A1"
        }
    }
}');
$response = curl_exec($ch);
curl_close($ch);

Lentelės

I29

Perkainavimo detali informacija - bazinė kaina

Laukas Tipas Aprašymas Pastabos naudojant EDIT metodus
I29_KODAS_PK C(12) Operacijos numeris Privalomas
I29_EIL_NR N(6) Eilės numeris Privalomas , kai oper=U,D
I29_KODAS_PS C(12) Prekės kodas Privalomas, kai oper=I
I29_KODAS_US C(12) Matavimo vienetas
I29_FRAKCIJA N(4) Frakcija
I29_KIEKIS N(14) Perkainuojamas Kiekis
I29_KAINA_S N(12,4) Sena kaina
I29_KAINA_N N(12,4) Nauja kaina
I29_PERKELTA N(1) Perkėlimo požymis:1-neperkelta,2-perkelta
I29_USERIS C(12) Kas koregavo Neperduodamas. Pildomas automatiškai, ApiKey - pirmi 7 simboliai
I29_ADDUSR C(12) Kas sukūrė Neperduodamas. Pildomas automatiškai, ApiKey - pirmi 7 simboliai
I29_R_DATE T(8) Kada koregavo Neperduodamas. Pildomas automatiškai, Current Datetime
I29_POZ_K N(1) Koreguoti Požymį
I29_POZ C(3) Požymis
bar_kodas C(25) Barkodas
kiekis_u N(14,3) Kiekis dešimtainėje išraiškoje