Odpovědi na často kladené otázky
         

Číslo otázky:
483   Datum:   10.5.2024
Otázka:API - Autonomní režim
 Odpověď:

Autonomní režim účetního systému MRP-K/S

V autonomním režimu funguje klientská část účetního systému MRP-K/S jako webový server (je tudíž nutné, abyste vyhradili jednu klientskou licenci účetního systému MRP-K/S trvale pro tuto komunikaci), který zpracovává příchozí požadavky odeslané metodou HTTP POST a reaguje na ně odpovědí. Požadavek i odpověď jsou soubory ve formátu xml s předepsanou strukturou. Komunikace může být volitelně kódovaná, s možností komprese, autentizace a šifrování.

Využívá se pro napojení na internetové obchody i od jiných poskytovatelů, případně pro generování dat z databáze a import některých dokladů.


1. Spuštění MRP-K/S v autonomním režimu

2. Obecná struktura xml dotazu a odpovědi

3. Kódovaná komunikace
Funkce Hmac_Sha256
Odvození klíčů
Autentizace
Šifrování
Komprese
Struktura obálky
Postup kódování na straně odesílatele
Postup dekódování na straně příjemce
Příklad struktury kódovaného dotazu a odpovědi
Příklad výpočtu šifrování a autentizace

4. Stránkování

5. Podporované příkazy
EXPEO0 Export skladových karet
EXPEO1 Export skladových karet
IMPEO0 Import objednávek přijatých
CENEO0 Export ceníku
ADREO0 Export adres
EXPADR20 Export adres ve formátu XML MRP-K/S v. 2.0
EXPFV0 Export seznamu faktur vydaných s adresou odběratele
EXPFV1 Export seznamu faktur vydaných s adresou odběratele, položkami a úhradami
EXPFV2 Export seznamu faktur vydaných s uloženým PDF opisem
EXPFVPDF Export faktury vydané s online vygenerovanou PDF fakturou
EXPFP0 Export seznamu faktur přijatých s adresou dodavatele
EXPFP1 Export seznamu faktur přijatých s adresou dodavatele, položkami a úhradami
EXPOP0 Export seznamu stavu objednávek přijatých
IMPFV0 Import faktury vydané
IMPFP0 Import faktury přijaté
SV2FV0 Vytvoření faktury vydané z existující skladové výdejky
EXPSTR0 Export číselníku středisek
EXPZAK0 Export číselníku zakázek
EXPOSN0 Export číselníku účtová osnova
EXCISRAD0 Export číselných řad
IMPSP0 Import skladových pohybů
OP2SV0 Vytvoření skladové výdejky z objednávky přijaté
EXPUCDE Export účetního deníku ve formátu XML MRP-K/S v. 2.0
IMPUCDE Import účetního deníku ve formátu XML MRP-K/S v. 2.0

1. Spuštění MRP-K/S v autonomním režimu

Spuštění MRP-K/S v autonomním režimu se provádí zadáním parametrů příkazového řádku. Komunikace se odehrává v jedné, předem zvolené firmě.

-A Spouští autonomní režim
-Fx Určuje číslo firmy (x), se kterou bude autonomní režim pracovat
-Y Uživatelské jméno a heslo, oddělené čárkou bez mezer

Příklad spuštění autonomního režimu ve firmě č.1:
  MRPKS.EXE -A -F1 -Ymrpdba,mrpdba

Při prvním spuštění autonomního režimu je potřeba v Nastavení vybrat číslo TCP portu, na kterém bude program očekávat požadavky. Pokud je vyžadována šifrovaná komunikace, lze zadat též šifrovací klíč. Na záložce profily je také třeba nakonfigurovat, které příkazy budou pro komunikaci povoleny a nastavit jejich další parametry.

2. Obecná struktura xml dotazu a odpovědi

Databáze MRP-K/S pracuje v kódové stránce Windows-1250. Přestože je tedy xml zpravidla kódováno v UTF-8, dokument by neměl obsahovat znaky, které se v kódování Windows-1250 nevyskytují.

Kořenovým elementem dotazu i odpovědi je obálka <mrpEnvelope>. V té je v případě nekódované komunikace obsažen element <body>, který zahrnuje vlastní dotaz nebo odpověď. V případě kódované komunikace je obsah vložen do elementu <encodedBody> , jak je popsáno dále v části kódovaná komunikace. Dotazy, které mění obsah databáze, obsahují povinný atribut requestId. Jeho obsah určuje dotazující se aplikace a slouží k jednoznačné identifikaci daného dotazu. V případě opakovaného příkazu se shodným requestId jej program znovu nevykonává, místo toho jen vrátí kopii dříve odeslané odpovědi. Záznamy provedených příkazů jsou v databázi evidovány po omezenou dobu (momentálně cca půl dne), poté jsou smazány a jejich requestId je uvolněno pro nové použití.
Dotaz může taktéž obsahovat element <data>, ve kterém mohou být např. výběrové podmínky (v případě příkazu, požadujícího údaje z databáze), nebo samotná data příkazu, nad kterými má program vykonat požadovanou operaci.

Odpověď obsahuje v části <status> identifikaci příkazu, na který reaguje. V případě, že provádění příkazu skončí libovolnou chybou, je tato skutečnost signalizována přítomností elementu <error> s jejím podrobnějším popisem.

Příklad nekódovaného dotazu:

  <?xml version="1.0" encoding="windows-1250"?>
  <mrpEnvelope>
    <body>
      <mrpRequest command="IMPEO0" requestId="1234">
        ....
        <data>
          <!-- Výběrové podmínky -->
          <!-- ... nebo ... -->
          <!-- data příkazu -->
        </data>
      </mrpRequest>
    </body> 
  </mrpEnvelope>

Příklad nekódované odpovědi:

  <mrpEnvelope>
    <body>
      <mrpResponse>
        <status>
          <!-- Blok s parametry prevzatymi z mrpRequest -->
          <request command="IMPEO0" requestId="1234"/>

          <!-- V pripade chyby blok s popisem chyboveho hlaseni -->
          <error errorCode="" errorClass="">
            <!-- errorCode - Ciselny chybovy kod -->
            <!-- errorClass - Trida vyjimky -->
            <errorMessage>
              <!-- Text chyboveho hlaseni -->
            </errorMessage>
          </error>
        </status>

        <data>
          .....
        </data>
      </mrpResponse>
    </body>
  </mrpEnvelope>

3. Kódovaná komunikace

Kódovaná komunikace umožňuje kompresi a/nebo autentizaci a šifrování xml dotazů a odpovědí. Základním elementem xml v těchto případech zůstává obálka <mrpEnvelope> , samotný obsah je ovšem místo elementu <body> vložen v elementu <encodedBody>, spolu s dalšími parametry, které určují použitou kompresi a šifrování. V případě, že je v nastavení autonomního režimu na straně MRP-K/S zaškrtnuta volba Vyžadovat šifrování, aplikace odmítne veškeré neautentizované požadavky. Pro šifrování a autentizaci je použit symetrický tajný klíč o délce 32 B, který se v nastavení autonomního režimu MRP-K/S zadává jako base64 sekvence. Klíč by měl být řadou spolehlivě náhodných čísel, program jej na požádání umí vytvořit tlačítkem Generovat.

Funkce Hmac_Sha256

Autentizační funkce Hmac se v dalších pokynech používá spolu s hash funkcí Sha256 standardním postupem: https://en.wikipedia.org/wiki/Hash-based_message_authentication_code

Funkce je definována jako

  Autentizační sekvence = Hmac_Sha256(Klíč, Podepisovaná sekvence)

Odvození klíčů

Vstupem je tajný klíč (32 B).

Z tajného klíče aplikace odvodí nezávislé klíče pro autentizaci a šifrování následujícím postupem, s využitím funkce Hmac_Sha256:

  Klíč1 = Hmac_Sha256(Tajný klíč, 0x01)
  Klíč2 = Hmac_Sha256(Tajný klíč, Klíč1 || 0x02)

0x01 a 0x02 jsou 1B konstanty (s pevnou hodnotou 1 a 2), || znamená zřetězení

Nadále se takto získaný Klíč1 používá jako tajný šifrovací klíč (32 B) a Klíč2 jako tajný autentizační klíč (32 B).

Autentizace

Autentizace se provádí algoritmem Hmac_Sha256.

Do algoritmu vstupuje tajný autentizační klíč (32 B) a podepisovaná sekvence bez dalších úprav.

  Autentizační kód = Hmac_Sha256(Autentizační klíč, Podepisovaná sekvence)

Podepsána je až finální odeslaná sekvence, po případné kompresi a šifrování. Přijímající strana tedy může provést autentizaci dat jako první krok, a pokud kódy nesouhlasí, vrátí jen chybové hlášení o neplatném autentizačním kódu a požadavkem se dále nezabývá.

Šifrování

Šifrování se provádí algoritmem AES s délkou klíče 256 bitů. Vstupem je tajný šifrovací klíč (32 B) a sekvence, která se má zašifrovat.

Postup šifrování je na odesílající straně následující:

  • Vygenerování náhodné sekvence 32 B, která se nesmí (s velkou pravděpodobností) u dalších požadavků opakovat, a to ani mezi různými stanicemi používajícími stejný šifrovací klíč. Algoritmus získání této sekvence je libovolný, doporučeným postupem je využít spolehlivý generátor náhodných čísel, jeho výstup spojit s jedinečnými identifikátory daného počítače a časem výpočtu a následně provést hash celé sekvence např. funkcí Sha 256. Tato sekvence se dále označuje jako variantní klíč.
  • Pomocí funkce Hmac_Sha256, kde klíčem Hmac je tajný šifrovací klíč (32 B) a podepisovanou sekvencí je variantní klíč (32 B), se získá finální šifrovací klíč (32 B).
  • Pomocí funkce Sha256 aplikované na variantní klíč (32 B) se získá jiná 32 B sekvence, jejíž prvních 16 B se použije jako inicializační vektor (16 B).
  • Na sekvenci určenou k zašifrování se aplikuje šifra AES v proudovém režimu CTR, přičemž šifrovacím klíčem je finální šifrovací klíč (32 B) a inicializačním vektorem prvního bloku dat (16 B) je inicializační vektor získaný v předchozím kroku (16 B). Pro další 16 B bloky se v režimu CTR inicializační vektor vždy zvyšuje o 1 (počínaje posledním bajtem, při přetečení se zvyšuje vždy předchozí bajt, s výjimkou prvního).

Postup dešifrování na přijímající straně je shodný, jako variantní klíč se použije sekvence obsažená v přijatém požadavku.

Režim CTR funguje jako proudová šifra a nevyžaduje tak zarovnání zprávy do 16 B bloků. Když není režim CTR k dospozici, lze jej realizovat pomocí základního režimu ECB.

Komprese

Volitelná komprese a dekomprese se provádí funkcemi zlib deflate a inflate.

Struktura obálky

Kódovaná obálka řeší možnosti komprese, šifrování a autentizace. V části <encodingParams> je uloženo pomocné xml s parametry, v elementu <encodedData> pak xml se samotným obsahem (obsah elementu <body> z nekódované obálky, kořenovým elementem je tedy <mrpRequest> nebo <mrpResponse>), obojí je zakódováno v base64. Když je požadována autentizace, je v dalším elementu <authCode> uveden kontrolní Hmac_Sha256 hash celkového obsahu, příčemž podepisovanou sekvencí je sekvence složená z obsahu elementu <encodingParams>, za který se připojí obsah elementu <encodedData>. Obsah elementů <encodingParams> a <encodedData> je vhodné zapouzdřit do xml sekce CDATA, aby v případě rozsáhlých xml dokumentů nedocházelo k potížím při jejich zpracování.

Kompletní struktura kódované obálky vypadá takto:

  <mrpEnvelope>
    <encodedBody authentication="hmac_sha256">
      <encodingParams>
         ... base64 - vložené xml s parametry šifrování a komprese ...
      </encodingParams>
      <encodedData>
         ... base64 - vložené xml s obsahem obálky ...
      </encodedData>
      <authCode>
         ... base64 - hmac sha256 hash hodnota obsahu encodingParams+encodedData ...
      </authCode>
    </encodedBody>
  </mrpEnvelope>

Xml s parametry šifrování a komprese, které se (převedené do base64) ukládá do <encodingParams> je následující:

  <mrpEncodingParams compression="zlib" encryption="aes">
    <varKey>
      ... jen při šifrování - base64 variantní klíč 32 B ...
    </varkey>
  </mrpEncodingParams>

Postup kódování na straně odesílatele

  • Případné parametry šifry a komprese se uloží do pomocného xml s kořenovým elementem <mrpEncodingParams>, které se následně uloží do sekce <encodingParams> zakódované v base64.
  • Odesílané xml (s kořenovým elementem <mrpRequest> nebo <mrpResponse>) se převede na sekvenci bajtů.
  • Ta se volitelně zkomprimuje.
  • Pokud je požadováno šifrování, sekvence se zašifruje.
  • Výsledná sekvence se uloží do sekce <encodedData> zakódovaná v base64.
  • Pokud je požadována autentizace (při šifrování povinně), vypočítá se autentizační kód sekvence složené ze zřetězeného obsahu <encodingParams> a <encodedData> (v binárním tvaru ještě před převedením na base64), a ten se následně uloží do elementu <authCode>, opět zakódovaný v base64.

Postup dekódování na straně příjemce

  • Příjemce si přečte způsob autentizace. Když vyžaduje autentizaci a ta v atributu authentication uvedena není, zpracování končí chybou.
  • Je-li vyžadována autentizace, ověří se autentizační kód. Když nesouhlasí, zpracování končí chybou.
  • Načte se xml s parametry šifry a komprese uložený v <encodingParams>, způsob šifrování se porovná s nastavením programu (když je vyžadováno šifrování a v parametrech není, požadavek se odmítne).
  • Načte se datová sekvence obsažená v sekci <encodedData>.
  • Je-li komunikace šifrovaná, sekvence se dešifruje podle parametrů zvolené šifry.
  • Je-li komunikace komprimovaná, sekvence se rozbalí podle zvolené metody komprese.

Příklad struktury kódovaného dotazu a odpovědi

Obsah některých části kódované obálky je nepovinný, podle způsobu komprese, šifrování a autentizace:

S autentizaci, šifrováním a volitelnou kompresí:

  <mrpEnvelope>
    <encodedBody authentication="hmac_sha256">
      <encodingParams>
         ... base64 - vložené xml s parametry šifrování a komprese ...
      </encodingParams>
      <encodedData>
         ... base64 - vložené xml s obsahem obálky ...
      </encodedData>
      <authCode>
         ... base64 - hmac sha256 hash hodnota obsahu encodingParams+encodedData ...
      </authCode>
    </encodedBody>
  </mrpEnvelope>

Xml s parametry šifrování a komprese, které se ukládá do <encodingParams> je následující (compression="zlib" znamená kompresi):

   <mrpEncodingParams compression="zlib" encryption="aes">
     <varKey>
      ... base64 variantní klíč 32 B ...
     </varkey>
   </mrpEncodingParams>

Komprese bez autentizace a šifrování:

  <mrpEnvelope>
    <encodedBody>
      <encodingParams>
         ... base64 - vložené xml s parametry komprese ...
      </encodingParams>
      <encodedData>
         ... base64 - vložené xml s obsahem obálky ...
      </encodedData>
    </encodedBody>
  </mrpEnvelope>

Vložené xml s parametry komprese:

  <mrpEncodingParams compression="zlib">
  </mrpEncodingParams>

Příklad výpočtu šifrování a autentizace

Na následující krátké sekvenci bajtů je možno otestovat shodu výsledků algoritmu šifrování a autentizace při použití konkrétního tajného a variantního klíče. Pokud bude vše souhlasit, je možno následně tento algoritmus použít pro sestavení elementu <encodedBody> podle výše uvedeného návodu.

Tajný klíč (zvolený uživatelem, base64):
bRtFEufmEgrJyhai6ltDSV9svtpN3Jb/5oWBBYhDJ30=

Tajný klíč (hex):
6D 1B 45 12 E7 E6 12 0A C9 CA 16 A2 EA 5B 43 49
5F 6C BE DA 4D DC 96 FF E6 85 81 05 88 43 27 7D

Variantní klíč (náhodně generovaný): 
1F 5A C7 7E D3 0C C0 A5 F7 5B B0 35 FF 05 66 A5
0D B2 12 7A AB 32 D8 62 4E 0D A4 D4 18 6E 7F 2F

Tajný šifrovací klíč (Hmac_Sha256(Tajný klíč, 0x01)):
DE B5 81 AB EC C4 A5 A5 5D C7 6C 08 A9 75 49 62
BD A0 54 10 E1 A3 0D 5E 99 05 AD FA 65 6C F2 C9

Tajný autentizační klíč (Hmac_Sha256(Tajný klíč, Tajný šifrovací klíč || 0x02)):
5B DF 74 9A 16 63 DF 20 6A 1E 9E 36 03 96 33 75
92 FD D8 2F 66 05 CF 3A F8 D4 D4 54 6B 64 05 06

Finální šifrovací klíč (Hmac_Sha256(Tajný Šifrovací klíč, Variantní klíč)):
00 06 29 E3 9E 79 F3 F5 2B 05 D8 58 72 40 C3 81
CA 14 A0 EC 17 27 A9 5A FA D4 80 EB D5 6E 1C 40

AES inicializační vektor (prvních 16 B z Sha256(Variantní klíč)):
09 18 29 E9 98 18 6D 9F B0 78 72 2E 0B 91 44 06

Příklad proudového AES šifrování v CTR módu:
Otevřený text:
01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F 10
11 12 13 14
Šifrovaný text:
01 EC 4D BE B1 04 CD 38 E9 0A 4E CC C5 C5 35 9C
D0 AA D8 AF

Příklad autentizace:
Podepisovaná sekvence:
01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F 10
11 12 13 14
Autentizační kód (Hmac_Sha256(Autentizační klíč, Podepisovaná sekvence)):
B5 75 94 6C 75 DC A6 5C E0 DA 8A C2 AC F4 73 72
34 09 68 99 53 6E 88 05 51 CA D1 AE 99 DE F3 6A


4. Stránkování

Některé příkazy pro export podporují tzv. stránkování, kdy umožňují omezit počet záznamů v odpovědi, případně označit výřez z množiny dat. Stránkování se řeší v části <paging>. Použité elementy jsou <RowFrom> a <RowTo>. Elementy jsou nepovinné. Výchozí hodnoty jsou pro <RowFrom> 1 a pro <RowTo> 999999. Aktuálně stránkování podporují příkazy EXPFV0, EXPFV1, EXPFV2, EXPFP0, EXPFP1.

Příklad požadavku:
 <mrpEnvelope>
  <body>
    <mrpRequest>
      <request command="EXPFV0" requestId=""> 
      </request>
      <data>
        <paging>
          <!-- Stránkování - omezení počtu záznamů -->
          <RowFrom>1</RowFrom>
          <RowTo>200</RowTo>
        </paging>
        <filter>
          <!-- Doklady s datem vystavení  -->
          <fltvalue name="IssueDate">01.01.2018..31.12.2018</fltvalue>
        </filter>
      </data>
    </mrpRequest>
  </body>
</mrpEnvelope>

5. Podporované příkazy

Příklady jsou v nekódovaném tvaru. Pokud se v některých příkazech zadávají filtrovací podmínky, pak se používá uživatelská syntaxe programu MRP K/S. Vyjímkou jsou pouze filtry, které nabízí uživateli výběrové podmínky. V těchto případech bude v poznámce uveden jejich možný rozsah.

Odpovědi vracející datovou část mají následující strukturu.

      <data>
        <datasets>
          <jmeno_tabulky>
            <rows> 1..n
              <row>
                <fields> 1..n
                  <jmeno_fieldu>hodnota</jmeno_fieldu>
                </fields>
              </row>
            </rows>
          </jmeno_tabulky>
        </datasets>
      </data>
 


EXPEO0

Export skladových karet do e-obchodu. Datový element obsahuje filtrovací podmínky <fltvalue name="jmeno_filtru">podminka</fltvalue>.

Požadavek

Atributy elementu <fltvalue>nepovinný
name O/M Typ Délka DM VýznamOd verze
stavy O L 1 0 Jsou požadovány pouze stavy karet. [T|F]
cisloSkladu O N 3 0 Číslo jednoho skladu, ze kterého se bude brát stav karty. [1..999]
Tuto podmínku lze omezit nastavením "Vždy přidat omezující podmínky"
cisloCeny O N 1 0 Číslo jedné prodejní ceny. [0,1..5]
malObraz O L 1 0 Malý obrázek. [T|F]
velObraz O L 1 0 Velký obrázek. [T|F]
polePoznamka1 O L 1 0 Doplňková poznámka. [T|F]
poleDetail2 O L 1 0 Popisy z druhého detailu karty. [T|F]
mena O T X 0 Požadavek na ceny v cizích měnách. Uvádí se výčet požadovaných měn. [EUR|USD|...]6.43.001
sql O T X X Výběrové podmínky pomocí SQL syntaxe databazového serveru. Název pole musí být uveden včetně názvu tabulky skladových karet.6.40.011
Seznam volitelných filtrovacích polí, které se přibližují filtrovacím podmínkám skladových karet. Jméno filtru se skládá ze jména tabulky, oddělovače a jména datového pole.
Výraz se zapisuje a vyhodnocuje stejným způsobem, jaku u filtru v programu MRP K/S, tedy při použití číselných a datumových výrazů musí tyto výrazy respektovat nastavení desetinných oddělovačů a tvaru data nastavených na klientské stanici.
Jsou uváděny pouze typy jednotlivých polí kvůli konstrukci dotazu.
name O/M Typ Délka DM VýznamOd verze
SKKAR.CISLO O N X X Číslo skladové karty.
Tuto podmínku lze omezit nastavením "Vždy přidat omezující podmínky"
SKKAR.NAZOV O T X X Název skladové karty.
SKKAR.KOD O T X X EAN skladové karty.
SKKAR.KOD1 O T X X Uživatelský kód skladové karty.
SKKAR.KOD2 O T X X Uživatelský kód skladové karty.
SKKAR.KOD3 O T X X Uživatelský kód skladové karty.
SKKAR.SKUPINA O T X X Kód skupiny skladových karet.
Tuto podmínku lze omezit nastavením "Vždy přidat omezující podmínky"
SKKAR.CISKAT O N X X Kód katalogu skladových karet.
Tuto podmínku lze omezit nastavením "Vždy přidat omezující podmínky"
SKKAR.TYP_POL O T X X Kód typu položky skladové karty.
Tuto podmínku lze omezit nastavením "Vždy přidat omezující podmínky"
SKKAR.SADZBADPH O N X X Sazba DPH skladové karty.
SKKAR.BEZDPH O L X X Rozlišení mezi mimo DPH a nulovou sazbou [T|F].
SKKAR.POZNAMKA O T X X Poznámka skladové karty.
SKKAR.ZAKAZSLEVYO L X X Zákaz slevy skladové karty [T|F].
SKKAR.DODAVATEL O T X X IČ obchodníka (není to záložka dodavatelů).
SKKAR.POZNAMKA1 O T X X Rozšířená poznámka skladové karty.
SKKAR.DAT_ZAR O D X X Datum zařazení skladové karty.
SKKAR.UPD_DATE O DTX X Datum a čas změny některých polí skladové karty.
Typ karty, Číslo, Název, EAN, Skupina, Katalog, Sazba DPH, Typ položky, Měrná jednotka, Je-li používaná, Datum zařazení, Hmotnost, Uživatelské pole 1..5, Počáteční skl.cena, Aktuální skl.cena, Aktuální počet MJ, Počet rezervovaných MJ
6.42.001
SKKAR.POUZIVANA O L X X Příznak používání skladové karty [T|F].
SKKAR.TLAC O L X X Příznak zařazení karty do "tisku" [T|F].
SKKAR.USRFLD1 O T X X Uživatelské pole skladové karty.
SKKAR.USRFLD2 O T X X Uživatelské pole skladové karty.
SKKAR.USRFLD3 O T X X Uživatelské pole skladové karty.
SKKAR.USRFLD4 O T X X Uživatelské pole skladové karty.
SKKAR.USRFLD5 O T X X Uživatelské pole skladové karty.
SKKARSTA.POCETMJ O N X X Počet MJ na zvoleném skladu.
SKKARSTA.POCREZMJO N X X Počet rezervovaných MJ na zvoleném skladu.
SKKARSTA.POCOBJMJO N X X Počet objednaných MJ u dodavatelů na zvoleném skladu.
SKKARSTA.POZICE O T X X Umístění ve zvoleném skladu.
SKKARSTA.MINIMUM O N X X Nastavené minimum MJ na zvoleném skladu.
SKKARSTA.NORMA O N X X Nastavená norma MJ na zvoleném skladu.
SKKARSTA.MAXIMUM O N X X Nastavené maximum MJ na zvoleném skladu.

 <mrpEnvelope>
  <body>
    <mrpRequest>
      <request command="EXPEO1" requestId=""> 
      </request>
      <data>
        <filter>
          <fltvalue name="cisloSkladu">1</fltvalue>
          <fltvalue name="cisloCeny">2</fltvalue>
          <fltvalue name="malObraz">T</fltvalue>
          <fltvalue name="velObraz">T</fltvalue>
          <fltvalue name="stavy">F</fltvalue>
          <fltvalue name="meny">EUR|USD|HUF</fltvalue>
          <!-- Nepovinny blok s pripadnymi daty, zalezi na prikazu, zdali je potrebuje -->
          <!-- Číslo karty v rozsahu 1 až 10 -->
          <fltvalue name="SKKAR.CISLO">1..10</fltvalue>
          <!-- Kód skupiny skladových karet A nebo B -->
          <fltvalue name="SKKAR.SKUPINA">A|B</fltvalue>
          <!-- Typ položky Z -->
          <fltvalue name="SKKAR.TYP_POL">Z</fltvalue>
          <!-- Změna ve skladových kartách od 1.1.2022 12:34 nebo nové skladové karty -->
          <fltvalue name="SKKAR.UPD_DATE">&gt;1.1.2022 12:34|null</fltvalue>
          <!-- ^ Není vhodné přímo použít znak > (větší), protože je to řídící znak formátu xml. Pro zápis takových znaků může být potřeba použít tzv entitu. -->
        </filter>
      </data>
    </mrpRequest>
  </body>
</mrpEnvelope>

Odpověď

Element <karty>Vždy
fields stavy Typ Délka DM Význam
cislo X N 10 2 Číslo karty
nazev F T 64 0 Název karty
jednotka F T 3 0 Měrná jednotka
cena F N 17 6 Cena určená podmínkou cisloCeny
cenasdph F N 17 6 Tato cena s DPH
sazbadph F N 5 2 Sazba DPH
ciskat F N 8 0 Číslo v katalogu
ciskatlist F T X 0 Seznam čísel katalogu oddělených znakem "svislítko"(pipe, "|")
kod F T 14 0 EAN kód
kod1 F T 30 0 Uživatelský kód 1
skupina F T 10 0 Kód skupiny skl. karet
hmotnost F N 13 6 Hmotnost v kg
delka F N 12 3 Délka v metrech
sirka F N 12 3 Šířka v metrech
vyska F N 12 3 Výška v metrech
baleni F N 12 3 Množství MJ v balení
usrfld1 F T 40 0 Uživatelské pole 1
usrfld2 F T 40 0 Uživatelské pole 2
usrfld3 F T 40 0 Uživatelské pole 3
usrfld4 F T 40 0 Uživatelské pole 4
usrfld5 F T 40 0 Uživatelské pole 5
poznamka F T 50 0 Poznámka
poznamka1 F M X 0 Doplňující poznámka (musí být nastaveno polePoznamka1)
nazev2 F T 64 0 Název 2 karty
maxslevap F N 6 2 Maximální sleva karty
variantgrp F N 10 0 Číslo skupiny variant
pocetmj X N 15 6 Počet MJ na požadovaném skladu
pocrezmj X N 15 6 Počet rezervovaných MJ na požadovaném skladu
pocobjmj X N 15 6 Počet objednaných MJ u dodavatelů na zvoleném skladu.
cena1 F N 17 6 Prodejní cena 1
cena1sdph F N 17 6 Prodejní cena 1 s DPH
cena2 F N 17 6 Prodejní cena 2
cena2sdph F N 17 6 Prodejní cena 2 s DPH
cena3 F N 17 6 Prodejní cena 3
cena3sdph F N 17 6 Prodejní cena 2 s DPH
cena4 F N 17 6 Prodejní cena 4
cena4sdph F N 17 6 Prodejní cena 4 s DPH
cena5 F N 17 6 Prodejní cena 5
cena5sdph F N 17 6 Prodejní cena 5 s DPH
pozice F T 10 0 Pozice na požadovaném skladu
malpopis F T 80 0 Malý popis
velpopis F M X 0 Velký popis
malpopis2 F T 80 0 Malý popis 2 (musí být nastaveno poleDetail2)
velpopis2 F M X 0 Velký popis 2 (musí být nastaveno poleDetail2)
malobr F T 40 0 Název malého obrázku
velobr F T 40 0 Název velkého obrázku
malobraz F B X 0 Malý obrázek (musí být nastaveno malObraz)
velobraz F B X 0 Velký obrázek (musí být nastaveno velObraz)
skupnazev F T 50 0 Název katalogové skupiny
mena F T 3 0 Měna
phe_kod F T 15 0 Kód recyklačního poplatku
phe_popis F T 30 0 Název recyklačního poplatku
phe_castka F N 9 2 Recyklační poplatek z číselníku
phe_zakg F T 1 0 Je-li recyklační poplatek za kilogram (T|F)
minprodmj F N 15 6 Minimální prodávaný počet MJ. Pouze informace.
datdostup X D 10 0 Datum, od kdy bude zboží dostupné.
Element <katalog>(pouze stavy=F)
fields stavy Typ Délka DM Význam
idr F N 9 0
ciskat F N 8 0 Číslo katalogové skupiny
uciskat F N 8 0 Číslo nadřazené katalogové skupiny
popis F T 45 0 Popis katalogové skupiny
poradi F N 8 0 Pořadí ve stromové struktuře
Element <nahrady>(pouze stavy=F)
fields stavy Typ Délka DM Význam
cislo F N 10 2 Číslo skladové karty
kod F T 14 0 EAN skladové karty
kod1 F T 30 0 Uživatelský kód 1 skladové karty
cislo_z F N 10 2 Číslo zaměnitelné skladové karty
kod_z F T 14 0 EAN zaměnitelné skladové karty
kod1_z F T 30 0 Uživatelský kód 1 zaměnitelné skladové karty
Element <doplnky>(pouze stavy=F)
fields stavy Typ Délka DM Význam
cislo F N 10 2 Číslo skladové karty
kod F T 14 0 EAN skladové karty
kod1 F T 30 0 Uživatelský kód 1 skladové karty
cislo_r F N 10 2 Číslo doplňkové skladové karty
kod_r F T 14 0 EAN doplňkové skladové karty
kod1_r F T 30 0 Uživatelský kód 1 doplňkové skladové karty
Element <navazujici>(pouze stavy=F)
fields stavy Typ Délka DM Význam
cislo F N 10 2 Číslo hlavní skladové karty
pocetmj F N 15 3 Počet MJ hlavní karty. Výchozí hodnota 1.
cislo_s F N 10 2 Číslo navazující skladové karty
pocetmj_s F N 15 3 Počet MJ navazující karty k zadanému počtu MJ hlavní karty
Element <zahrceny>(pouze stavy=F)
fields stavy Typ Délka DM Význam
cislo F N 10 2 Číslo skladové karty
cisloskl F N 3 0 Číslo skladu
mena F T 3 0 Kód měny
cena1 F N 15 3 Prodejní cena 1 v zahraniční měně
cena2 F N 15 3 Prodejní cena 2 v zahraniční měně
cena3 F N 15 3 Prodejní cena 3 v zahraniční měně
cena4 F N 15 3 Prodejní cena 4 v zahraniční měně
cena5 F N 15 3 Prodejní cena 5 v zahraniční měně

<mrpEnvelope>
  <body>
    <mrpResponse>
      <status>
        <request command="EXPEO0"/>
      </status>
      <data>
        <datasets>
          <karty>
            <rows>
              <row>
                <fields>
                  <cislo>1</cislo>
                  <nazev>Kladivo</nazev>
                  <jednotka>ks</jednotka>
                  <cena>223.97</cena>
                  <cenasdph>271</cenasdph>
                  <sazbadph>21</sazbadph>
                  <ciskat>2</ciskat>
                  <ciskatlist>2|21|22</ciskatlist>
                  <kod>8595008803359</kod>
                  <kod1></kod1>
                  <skupina>6</skupina>
                  <hmotnost>0</hmotnost>
                  <delka>0</delka>
                  <sirka>0</sirka>
                  <vyska>0</vyska>
                  <baleni>12</baleni>
                  <usrfld1></usrfld1>
                  <usrfld2></usrfld2>
                  <usrfld3></usrfld3>
                  <usrfld4></usrfld4>
                  <usrfld5></usrfld5>
                  <poznamka></poznamka>
                  <nazev2></nazev2>
                  <pocetmj>10</pocetmj>
                  <pocrezmj>2</pocrezmj>
                  <cena1>223.97</cena1>
                  <cena1sdph>271</cena1sdph>
                  <cena2>0</cena2>
                  <cena2sdph>0</cena2sdph>
                  <cena3>0</cena3>
                  <cena3sdph>0</cena3sdph>
                  <cena4>0</cena4>
                  <cena4sdph>0</cena4sdph>
                  <cena5>0</cena5>
                  <cena5sdph>0</cena5sdph>
                  <pozice></pozice>
                  <skupnazev>Skupina 6</skupnazev>
                  <mena>CZK</mena>
                  <phe_kod>AA-213-x-56</phe_kod>
                  <phe_popis>Test RP</phe_popis>
                  <phe_castka>1234.56</phe_castka>
                  <phe_zakg>F</phe_zakg>
                  <minprodmj>10</minprodmj>
                  <datdostup>2022-07-28</datdostup>
                </fields>
              </row>
              <row>
                ....
              </row>
            </rows>
          </karty>

          <katalog>
            <rows>
              <row>
                <fields>
                  <idr>321232</idr>
                  <ciskat>1</ciskat>
                  <popis>Nářadí</popis>
                  <poradi>0</poradi>
                </fields>
              </row>
              <row>
                ....
              </row>
            </rows>
          </katalog>

          <nahrady>
            <rows>
              <row>
                <fields>
                  <cislo>1</cislo>
                  <kod>8595008803359</kod>
                  <kod1></kod1>
                  <cislo_z>1.1</cislo_z>
                  <kod_z>8594007132571</kod_z>
                  <kod1_z></kod1_z>
                </fields>
              </row>
              <row>
                ....
              </row>
            </rows>
          </nahrady>

          <doplnky>
            <rows>
              <row>
                <fields>
                  <cislo>1</cislo>
                  <kod>8595008803359</kod>
                  <kod1></kod1>
                  <cislo_r>1.1</cislo_z>
                  <kod_r>8594007132571</kod_z>
                  <kod1_r></kod1_z>
                </fields>
              </row>
              <row>
                ....
              </row>
            </rows>
          </doplnky>

          <zahrceny>
            <rows>
              <row>
                <fields>
                  <cislo>1</cislo>
                  <cisloskl>1</cisloskl>
                  <mena>EUR</mena>
                  <cena1>1.23</cena1>
                  <cena2>0</cena2>
                  <cena3>0</cena3>
                  <cena4>0</cena4>
                  <cena5>0</cena5>
                </fields>
              </row>
              <row>
                ....
              </row>
            </rows>
          </zahrceny>

        </datasets>
      </data>
    </mrpResponse>
  </body>
</mrpEnvelope>

EXPEO1

Export skladových karet do e-obchodu. Datový element obsahuje filtrovací podmínky <fltvalue name="jmeno_filtru">podminka</fltvalue>.

Požadavek

Filtrovací podmínky jsou stejné jak u příkazu EXPEO0. Jediným rozdílem je filtr pro číslo skladu, kde může být zadán rozsah v rámci platných filtrovacích podmínek.

 <mrpEnvelope>
  <body>
    <mrpRequest>
      <request command="EXPEO1" requestId=""> 
      </request>
      <data>
        <filter>
          <fltvalue name="cisloSkladu">1..3</fltvalue>
          <fltvalue name="cisloCeny">2</fltvalue>
          <fltvalue name="malObraz">T</fltvalue>
          <fltvalue name="velObraz">T</fltvalue>
          <fltvalue name="stavy">F</fltvalue>
          <fltvalue name="meny">EUR|USD|HUF</fltvalue>
          <fltvalue name="SKKAR.CISLO">1..10</fltvalue>
        </filter>
      </data>
    </mrpRequest>
  </body>
</mrpEnvelope>

Odpověď

Element <sklady>Vždy
fields stavy Typ Délka DM Význam
cisloskl X N 3 0 Číslo skladu
nazevskl X T 30 0 Název skladu
Element <stavy>Vždy
fields stavy Typ Délka DM Význam
cisloskl X N 3 0 Číslo skladu
cislokar X N 10 2 Číslo karty
datdostup X D 10 0 Datum, od kdy bude zboží dostupné.
pocetmj X N 15 6 Počet MJ ve skladu
pocrezmj X N 15 6 Počet rezervovaných MJ na požadovaném skladu
pocobjmj X N 15 6 Počet objednaných MJ u dodavatelů na zvoleném skladu.
cena F N 17 6 Cena určená podmínkou cisloCeny
cenasdph F N 17 6 Tato cena s DPH
cena1 F N 17 6 Prodejní cena 1
cena1sdph F N 17 6 Prodejní cena 1 s DPH
cena2 F N 17 6 Prodejní cena 2
cena2sdph F N 17 6 Prodejní cena 2 s DPH
cena3 F N 17 6 Prodejní cena 3
cena3sdph F N 17 6 Prodejní cena 2 s DPH
cena4 F N 17 6 Prodejní cena 4
cena4sdph F N 17 6 Prodejní cena 4 s DPH
cena5 F N 17 6 Prodejní cena 5
cena5sdph F N 17 6 Prodejní cena 5 s DPH
pozice F T 10 0 Pozice na požadovaném skladu
mena F T 3 0 Měna
Element <karty>(pouze stavy=F)
fields stavy Typ Délka DM Význam
cislo F N 10 2 Číslo karty
nazev F T 64 0 Název karty
jednotka F T 3 0 Měrná jednotka
sazbadph F N 5 2 Sazba DPH
ciskat F N 8 0 Číslo v katalogu
ciskatlist F T X 0 Seznam čísel katalogu oddělených znakem "svislítko"(pipe, "|")
kod F T 14 0 EAN kód
kod1 F T 30 0 Uživatelský kód 1
skupina F T 10 0 Kód skupiny skl. karet
hmotnost F N 13 6 Hmotnost v kg
delka F N 12 3 Délka v metrech
sirka F N 12 3 Šířka v metrech
vyska F N 12 3 Výška v metrech
baleni F N 12 3 Množství MJ v balení
usrfld1 F T 40 0 Uživatelské pole 1
usrfld2 F T 40 0 Uživatelské pole 2
usrfld3 F T 40 0 Uživatelské pole 3
usrfld4 F T 40 0 Uživatelské pole 4
usrfld5 F T 40 0 Uživatelské pole 5
poznamka F T 50 0 Poznámka
poznamka1 F M X 0 Doplňující poznámka (musí být nastaveno polePoznamka1)
nazev2 F T 64 0 Název 2 karty
maxslevap F N 6 2 Maximální sleva karty
variantgrp F N 10 0 Číslo skupiny variant
malpopis F T 80 0 Malý popis
velpopis F M X 0 Velký popis
malpopis2 F T 80 0 Malý popis 2 (musí být nastaveno poleDetail2)
velpopis2 F M X 0 Velký popis 2 (musí být nastaveno poleDetail2)
malobr F T 40 0 Název malého obrázku
velobr F T 40 0 Název velkého obrázku
malobraz F B X 0 Malý obrázek (musí být nastaveno malObraz)
velobraz F B X 0 Velký obrázek (musí být nastaveno velObraz)
skupnazev F T 50 0 Název katalogové skupiny
phe_kod F T 15 0 Kód recyklačního poplatku
phe_popis F T 30 0 Název recyklačního poplatku
phe_castka F N 9 2 Recyklační poplatek z číselníku
phe_zakg F T 1 0 Je-li recyklační poplatek za kilogram (T|F)
minprodmj F N 15 6 Minimální prodávaný počet MJ. Pouze informace.
Element <katalog>(pouze stavy=F)
fields stavy Typ Délka DM Význam
idr F N 9 0
ciskat F N 8 0 Číslo katalogové skupiny
uciskat F N 8 0 Číslo nadřazené katalogové skupiny
popis F T 45 0 Popis katalogové skupiny
poradi F N 8 0 Pořadí ve stromové struktuře
Element <nahrady>(pouze stavy=F)
fields stavy Typ Délka DM Význam
cislo F N 10 2 Číslo skladové karty
kod F T 14 0 EAN skladové karty
kod1 F T 30 0 Uživatelský kód 1 skladové karty
cislo_z F N 10 2 Číslo zaměnitelné skladové karty
kod_z F T 14 0 EAN zaměnitelné skladové karty
kod1_z F T 30 0 Uživatelský kód 1 zaměnitelné skladové karty
Element <doplnky>(pouze stavy=F)
fields stavy Typ Délka DM Význam
cislo F N 10 2 Číslo skladové karty
kod F T 14 0 EAN skladové karty
kod1 F T 30 0 Uživatelský kód 1 skladové karty
cislo_r F N 10 2 Číslo doplňkové skladové karty
kod_r F T 14 0 EAN doplňkové skladové karty
kod1_r F T 30 0 Uživatelský kód 1 doplňkové skladové karty
Element <navazujici>(pouze stavy=F)
fields stavy Typ Délka DM Význam
cislo F N 10 2 Číslo hlavní skladové karty
pocetmj F N 15 3 Počet MJ hlavní karty. Výchozí hodnota 1.
cislo_s F N 10 2 Číslo navazující skladové karty
pocetmj_s F N 15 3 Počet MJ navazující karty k zadanému počtu MJ hlavní karty
Element <zahrceny>(pouze stavy=F)
fields stavy Typ Délka DM Význam
cislo F N 10 2 Číslo skladové karty
cisloskl F N 3 0 Číslo skladu
mena F T 3 0 Kód měny
cena1 F N 15 3 Prodejní cena 1 v zahraniční měně
cena2 F N 15 3 Prodejní cena 2 v zahraniční měně
cena3 F N 15 3 Prodejní cena 3 v zahraniční měně
cena4 F N 15 3 Prodejní cena 4 v zahraniční měně
cena5 F N 15 3 Prodejní cena 5 v zahraniční měně

<mrpEnvelope>
  <body>
    <mrpResponse>
      <status>
        <request command="EXPEO1"/>
      </status>
      <data>
        <datasets>
          <sklady>
            <rows>
              <row>
                <fields>
                  <cisloskl>1</cisloskl>
                  <nazevskl>Sklad 1</nazevskl>
                </fields>
              </row>
            </rows>
          </sklady>

          <stavy>
            <rows>
              <row>
                <fields>
                  <cisloskl>1</cisloskl>
                  <cislo>1</cislo>
                  <datdostup>2022-07-28</datdostup>
                  <pocetmj>10</pocetmj>
                  <pocrezmj>2</pocrezmj>
                  <cena>223.97</cena>
                  <cenasdph>271</cenasdph>
                  <cena1>223.97</cena1>
                  <cena1sdph>271</cena1sdph>
                  <cena2>0</cena2>
                  <cena2sdph>0</cena2sdph>
                  <cena3>0</cena3>
                  <cena3sdph>0</cena3sdph>
                  <cena4>0</cena4>
                  <cena4sdph>0</cena4sdph>
                  <cena5>0</cena5>
                  <cena5sdph>0</cena5sdph>
                  <pozice></pozice>
                  <mena>CZK</mena>
                </fields>
              </row>
            </rows>
          </stavy>

          <karty>
            <rows>
              <row>
                <fields>
                  <cislo>1</cislo>
                  <nazev>Kladivo</nazev>
                  <jednotka>ks</jednotka>
                  <sazbadph>21</sazbadph>
                  <ciskat>2</ciskat>
                  <ciskatlist>2|21|22</ciskatlist>
                  <kod>8595008803359</kod>
                  <kod1></kod1>
                  <skupina>6</skupina>
                  <hmotnost>0</hmotnost>
                  <delka>0</delka>
                  <sirka>0</sirka>
                  <vyska>0</vyska>
                  <baleni>12</baleni>
                  <usrfld1>Text, UsrFld25_yyyyy</usrfld1>
                  <usrfld2></usrfld2>
                  <usrfld3></usrfld3>
                  <usrfld4></usrfld4>
                  <usrfld5></usrfld5>
                  <poznamka></poznamka>
                  <nazev2></nazev2>
                  <skupnazev>Skupina 6</skupnazev>
                  <minprodmj>10</minprodmj>
                </fields>
              </row>
            </rows>
          </karty>

          <katalog>
            <rows>
              <row>
                <fields>
                  <idr>321232</idr>
                  <ciskat>1</ciskat>
                  <popis>Nářadí</popis>
                  <poradi>0</poradi>
                </fields>
              </row>
            </rows>
          </katalog>

          <nahrady>
            <rows>
              <row>
                <fields>
                  <cislo>1</cislo>
                  <kod>8595008803359</kod>
                  <kod1></kod1>
                  <cislo_z>1.1</cislo_z>
                  <kod_z>8594007132571</kod_z>
                  <kod1_z></kod1_z>
                </fields>
              </row>
              <row>
                ....
              </row>
            </rows>
          </nahrady>

          <doplnky>
            <rows>
              <row>
                <fields>
                  <cislo>1</cislo>
                  <kod>8595008803359</kod>
                  <kod1></kod1>
                  <cislo_r>1.1</cislo_z>
                  <kod_r>8594007132571</kod_z>
                  <kod1_r></kod1_z>
                </fields>
              </row>
              <row>
                ....
              </row>
            </rows>
          </doplnky>

          <zahrceny>
            <rows>
              <row>
                <fields>
                  <cislo>1</cislo>
                  <cisloskl>1</cisloskl>
                  <mena>EUR</mena>
                  <cena1>1.23</cena1>
                  <cena2>0</cena2>
                  <cena3>0</cena3>
                  <cena4>0</cena4>
                  <cena5>0</cena5>
                </fields>
              </row>
              <row>
                ....
              </row>
            </rows>
          </zahrceny>

        </datasets>
      </data>
    </mrpResponse>
  </body>
</mrpEnvelope>

IMPEO0

Import objednávek z e-obchodu. Datový element obsahuje jednak globální parametry <paramvalue name="jmeno_parametru">hodnota_parametru</paramvalue>, které jsou nepovinné, tak vlastní objednávky.

Požadavek

  <params>
    <paramvalue name="cisloSkladu">1</paramvalue>
    ...
  </params>
  <objednavka ...>
    <parametryDokladu .../>
    <mena .../>
    <rezimDPH .../>
    <adresa ...> 
      <firma .../>
      <osoba .../>
      <!-- Email se sklada az do delky pole v databazi -->
      <email>ja_1@xyz.cz</email>
      ...
      <email>ja_n@xyz.cz</email>
      <!-- Telefon muze obsahovat tri polozky -->
      <tel>123456781</tel>
      <tel>123 456 789</tel>
      <uzivatelskaPole>
        <!-- Celkem muze byt pet uzivatelkych poli s cislem pole v nazvu tagu -->
        <uzivatelskePole1>hodnota uzivatelskeho pole</uzivatelskePole1>
        ...
      </uzivatelskaPole>
    </adresa>
    <adresa_dod ...> 
      <firma .../>
      <osoba .../>
      <!-- Email se sklada az do delky pole v databazi -->
      <email>ja1@xyz.cz</email>
      ...
      <email>ja3@xyz.cz</email>
      <!-- Telefon muze obsahovat tri polozky -->
      <uzivatelskaPole>
        <!-- Celkem muze byt pet uzivatelkych poli s cislem pole v nazvu tagu -->
        <uzivatelskePole1>hodnota uzivatelskeho pole</uzivatelskePole1>
        ...
      </uzivatelskaPole>
    </adresa_dod>
    <polozky>
      <polozka .../>
    </polozky>
    <poznamka>
      ...
    </poznamka>
    <uzivatelskaPole>
      <!-- Celkem muze byt pet uzivatelkych poli s cislem pole v nazvu tagu -->
      <uzivatelskePole1>hodnota uzivatelskeho pole</uzivatelskePole1>
      ...
    </uzivatelskaPole>
  </objednavka>

Atributy elementu <paramvalue>nepovinný
name O/M Typ Délka DM Význam Od verze
cisloSkladu O N 3 0 Číslo skladu pro objednávky. Pokud nebude uvedeno, bere se z konfigurace programu.
stredisko O T 6 0 Číslo střediska pro objednávky. Pokud nebude uvedeno, bere se z konfigurace programu.
cisloZakazky O T 15 0 Číslo zakázky pro objednávky. Pokud nebude uvedeno, bere se z konfigurace programu.
prefixRadyObj O T 10 0 Prefix číselné řady pro objednávky. Pokud nebude uvedeno, bere se z konfigurace programu.
Atributy elementu <objednavka>povinný
name O/M Typ Délka DM Význam Od verze
stredisko O T 6 0 Číslo střediska pro objednávku. Pokud nebude uvedeno, bere se z <paramvalue> nebo z konfigurace programu.5.55.005
cisloZakazky O T 15 0 Číslo zakázky pro objednávku. Pokud nebude uvedeno, bere se z <paramvalue> nebo z konfigurace programu.5.55.005
formaUhrady O T 10 0 Forma úhrady
zpusobDopravy O T 10 0 Způsob dopravy
variabilniSymbolO N 10 0 Variabilní symbol
puvodniCislo O T 50 0 Původní číslo objednávky
datum O D 10 0 Datum objednávky RRRR-MM-DD
datumDodani O D 10 0 Dodací lhůta objednávky RRRR-MM-DD5.55.005
cenySDPH O L 1 0 Ceny v objednávce jsou/nejsou s DPH
fixniCena O T 1 0 Ceny v objednávce jsou neměnné[T|F|X]
typDPH O N 2 0 Typ DPH dle číselníku typů DPH pro uskutečněná plnění6.30.001
Pořadí ve vyhodnocování zadání střediska:
  1. Středisko uvedené v objednávce
  2. Pokud je to v konfiguraci povoleno, středisko uvedené v adrese
  3. Středisko uvedené v <paramvalue>
  4. Středisko uvedené v konfiguraci importu
Atributy elementu <adresa>povinný
name O/M Typ Délka DM Význam Od verze
id O T 10 0 Identifikace zákazníka v e-obchodu
ulice O T 30 0 Ulice a číslo popisné
mesto O T 30 0 Město
psc O T 15 0 PSČ
kodStatu O T 2 0 ISO kód státu5.35.005
fyzickaOsoba O L 1 0 Příznak, zda adresa je fyzickou osobou.[T|F]5.72.001
Atributy elementu <firma>nepovinný
name O/M Typ Délka DM Význam Od verze
nazev O T 100 0 Název firmy
ico O T 12 0
dic O T 17 0 DIČ
ic_dph O T 14 0 IČ DPH (pouze ve slovenské verzi)5.60.003
Atributy elementu <osoba>nepovinný
name O/M Typ Délka DM Význam Od verze
jmeno O T 30 0 Jméno
prijmeni O T 30 0 Příjmení
Součet délek obou atributů musí být menší jak 30 znaků
Element <email>nepovinný
name O/M Typ Délka DM Význam Od verze
email O T 256 0 Email
E-mail adresy se skládají až do délky pole v databázi
Element <tel>nepovinný
name O/M Typ Délka DM Význam Od verze
tel O T 30 0 Telefon
Mohou být uvedeny maximálně tři elementy
Element <uzivatelskaPole>nepovinný
element O/M Typ Délka DM Význam Od verze
uzivatelskePole1O T 40 0 Hodnota uživatelského pole 16.29.002
uzivatelskePole2O T 40 0 Hodnota uživatelského pole 26.29.002
uzivatelskePole3O T 40 0 Hodnota uživatelského pole 36.29.002
uzivatelskePole4O T 40 0 Hodnota uživatelského pole 46.29.002
uzivatelskePole5O T 40 0 Hodnota uživatelského pole 56.29.002
Atributy elementu <parametryDokladu>nepovinný
name O/M Typ Délka DM Význam Od verze
UPDP O N 1 0 UnitPriceDecimalPlaces
Počet desetinných míst Ceny za měrnou jednotku (rozsah 1..4, pro SK verzi 1..6)
6.50.001
VATRU O N 6 2 VATRoundingUnit
Zaokrouhlování DPH - jednotky (např. 1.00, 0.10, 0.01).
Pouze pro CZ verzi.
6.50.001
TRU O N 6 2 TotalRoundingUnit
Zaokrouhlování celkové částky dokladu - jednotky (např. 1.00, 0.10, 0.01)
6.50.001
TRM O N 1 0 TotalRoundingMethod
Zaokrouhlování celkové částky - způsob (0 - přirozeně, 1 - dolů, 2 - nahoru, 3 - bankéřské zaokrouhlení)
6.50.001
VATCA O N 1 0 VATCoefficientApplication
Pro výpočet celkové DPH použít Koeficient DPH (0 - nepoužít, 1 - použít).
Pouze pro CZ verzi.
6.50.001
VATCUPA O N 1 0 VATCoefficientUnitPriceApplication
Pro výpočet jednotkové DPH použít Koeficient DPH (0 - nepoužít, 1 - použít).
Pouze pro CZ verzi.
6.50.001
TRD O N 1 0 TotalRoundingDissolving
Rozpuštění celkového zaokrouhlení (0 - rozpustit do částky MIMODPH, 1 - rozpustit do ZAKLAD+DPH)
6.50.001
TRDCA O N 1 0 TotalRoundingDissolvingCoefficientApplication
Pro rozpuštění zaokrouhlení použít Koeficient DPH (0 - podle způsobu výpočtu dokladu, 1 - vždy použít koeficient).
Pouze pro CZ verzi a TRD=1.
6.50.001
VATFRB O N 1 0 VATFromRoundedBase
Celkovou DPH počítat ze zaokrouhleného základu (0 - z nezaokrouhleného, 1 - ze zaokrouhleného).
Pouze SK verze.
6.50.001
Parametry výpočtu dokladu.
Atributy elementu <mena>nepovinný
name O/M Typ Délka DM Význam Od verze
kod O T 3 0 ISO kód měny
kurz O N 13 6 Kurz
mnozstvi O N 13 6 k množství účetní měny
Atributy elementu <rezimDPH>nepovinný
name O/M Typ Délka DM Význam Od verze
kod O N 1 0 Kód režimu DPH
0 - Běžný tuzemský režim
1 - Režim registrace EU
2 - Režim OSS (MOSS)
6.30.001
statDPH O T 2 0 Stát DPH6.30.001
vatDPH O T 17 0 VAT reg.č. (DIČ)6.30.001
Element <poznamka>nepovinný
name O/M Typ Délka DM Význam Od verze
poznamka O T X 0 Poznámka jako dlouhý text
Element <uzivatelskaPole>nepovinný
element O/M Typ Délka DM Význam Od verze
uzivatelskePole1O T 40 0 Hodnota uživatelského pole 1
uzivatelskePole2O T 40 0 Hodnota uživatelského pole 2
uzivatelskePole3O T 40 0 Hodnota uživatelského pole 3
uzivatelskePole4O T 40 0 Hodnota uživatelského pole 4
uzivatelskePole5O T 40 0 Hodnota uživatelského pole 5
Atributy elementu <polozka>povinný
name O/M Typ Delka DM Význam Od verze
cisloKarty O N 10 2 Číslo skladové karty
eanKarty O T 13 0 EAN skladové karty (pro identifikaci)
kodKarty O T 30 0 Uživatelský kód skladové karty (pro identifikaci)
text O T 50 0 Text objednávky
pocetMJ M N 15 6 Počet MJ
cenaMJ M N 17 6 Cena za MJ
slevaMJ O N 17 6 Sleva v měně dokladu za MJ. Částka slevy je uváděna buď s DPH nebo bez DPH v závislosti na nastavení tohoto atributu v hlavičce objednávky. Pokud je uvedena, má přednost před slevou uvedenou v procentech.5.55.005
sleva O N 6 2 Sleva v procentech za MJ5.55.005
sazbaDPH O N 5 2 Sazba DPH
typPolozky O T 2 0 Typ položky dle číselníku Typy položek
fixniCena O L 1 0 Ceny v řádku objednávky jsou neměnné.
Záleží na nastavení v hlavičce dokladu.[T|F]
poznamkaPolozky O T 20 0 Poznámka položky
Pokud je uveden pouze text, nemusí být atributy pocetMJ a cenaMJ uvedeny.
Podle atributů eanKarty a kodKarty se vyhledává pouze v případě, že má program nastavno hlídání jedinečnosti těchto polí. Vyhledávání skladové položky probíhá v pořadí cisloKarty, eanKarty a nakonec kodKarty.

Přidávání adres

Z e-shopu chodí dva identifikátory:

  • id
  • ico
Pro určení adresy je v tomto případě primární id, které se ukládá do databáze informačního systému (IS). Samotné adresy pro jeden doklad jsou v datasetu (DS) a ukládají se před dokladem.
id generuje e-shop při založení nového uživatele. Nemá nic společného s primárním klíčem tabulky v účetnictví. Je jasné, že pokud je k IS připojeno více e-shopů, musí mít organizačně zajištěno zamezení duplicity id mezi obchody u různých adres.
Hledací funkce přes id a ico vrací vždy ten druhý identifikátor z databáze (plus něco navíc). V tomto textu jsou jako isID a isIČO.
Dokladem se v textu myslí samotná objednávka, ...

Hlavní (fakturační) adresa
V IS se hledá adresa podle id.
Pokud je nalezena, aktualizuje se ico podle isIČO a toto ico je použito do dokladu. Adresa se neukládá.
Pokud nebyla nalezena adresa podle id, hledá se podle ico. Pokud adresu je nalezena, pak se testuje, zda je isID prázdné.
Pokud je prázdné a id je vyplněno, pak je provedena aktualizace isID v databázi. Pokud není isID prázdné a id je vyplněno (z předchozího vyplývá, že je různé), pak je založena nová adresa pro toto ico, ale s lomítkem. Toto ico se použije pro doklad.
Pokud není isID prázdné a id není vyplněno, pak se nic nedělá.
Pokud nebyla nalezena adresa ani podle id, ani podle ico, pak je založena nová adresa.

Vedlejší (doručovací) adresa
V IS se hledá adresa podle id.
Pokud je nalezena, aktualizuje se ico podle isIČO a toto ico se použije do dokladu. Adresa se neukládá.
Pokud nebyla nalezena v IS, hledá se adresa podle id v DS. Pokud je nalezena, aktualizuje se ico podle dsIČO a toto ico je použito do dokladu. Adresa se neukládá.
Pokud nebyla nalezena adresa podle id, hledá se v IS podle ico. Pokud je adresa nalezena, tak se pak testuje, zda je vrácené isID prázdné. Pokud je isID prázdné a id je vyplněno, pak je provedena aktualizace isID v databázi.
Pokud není isID prázdné a id je vyplněno (z předchozího vyplývá, že je různé), pak je založena nová adresa pro toto ico, ale s lomítkem. Toto ico se použije pro doklad.
Pokud není isID prázdné a id není vyplněno, pak se nic nedělá. Pokud nebyla nalezena adresa v IS, hledáme se podle ico v DS. Pokud je adresa nalezena, tak se pak testuje, zda je dsID prázdné. Pokud je prázdné a id je vyplněno, pak je provedena aktualizace dsID v datasetu. Pokud není dsID prázdné a id je vyplněno (z předchozího vyplývá, že je různé), pak je založena nová adresa pro toto ico, ale s lomítkem. Toto ico se použije pro doklad. Pokud není dsID prázdné a id není vyplněno, pak nic neděláme. Pokud nebyla nalezena adresa ani podle id, ani podle ico, pak je založena nová adresa. Použije se pro to ico fakturační adresy a přidá se lomítko.

 <mrpEnvelope>
  <body>
    <mrpRequest>
      <!-- Povinny blok pro definici prikazu -->
      <request command="IMPEO0" requestId="20121203140300033"> 
        <!-- requestId je ID spojeni (treba TIMESTAMP 20121120093530125) -->
      </request>
      <data>
        <params>
          <paramvalue name="cisloSkladu">1</paramvalue>
          <paramvalue name="stredisko">0</paramvalue>
          <paramvalue name="cisloZakazky">0</paramvalue>
          <!-- paramvalue name="prefixRadyObj">EO001</paramvalue> -->
        </params>
        <objednavka formaUhrady="Hotovost" puvodniCislo="22" datum="2014-01-01" cenySDPH="T">
          <!-- Parametry výpočtu dokladu. Zaokrouhlování hlavičky dokladu na koruny. -->
          <parametryDokladu TRU="1.00"/>
          <mena kod="CZK" kurz="1" mnozstvi="1"/>
          <rezimDPH kod="1" statDPH="AT" vatDPH="AT12345678"/>
          <adresa id="22" ulice="Vonaskova 123" mesto="Zlín" psc="76001"> 
            <firma nazev="" ico="" dic=""/>
            <osoba jmeno="Jan" prijmeni="Vonásek"/>
            <!-- Email se sklada az do delky pole v databazi -->
            <email>ja1@xyz.cz</email>
            <email>ja2@xyz.cz</email>
            <email>ja3@xyz.cz</email>
            <email>ja4@xyz.cz</email>
            <!-- Telefon muze obsahovat tri polozky -->
            <tel>123456781</tel>
            <tel>123 456 789</tel>
          </adresa>
          <adresa_dod id="" ulice="Vonaskova 123" mesto="Zlín" psc="760  01"> 
            <firma nazev="" ico="" dic=""/>
            <osoba jmeno="Jan" prijmeni="Vonásek"/>
            <!-- Email se sklada az do delky pole v databazi -->
            <email>ja1@mrp.cz</email>
            <email>ja2@mrp.cz</email>
            <email>ja3@mrp.cz</email>
            <!-- Telefon muze obsahovat tri polozky -->
          </adresa_dod>
          <polozky>
            <polozka cisloKarty="9" text="" cenaMJ="10" pocetMJ="1" sazbaDPH="21"/>
          </polozky>
          <poznamka>
            <!-- Je to jako element, protoze to je memo -->
            Toto je poznamka
            na vice radek.
            Alespon na tri.
          </poznamka>
          <uzivatelskaPole>
            <uzivatelskePole1>uzivatelskePole1</uzivatelskePole1>
            <uzivatelskePole2>uzivatelskePole2</uzivatelskePole2>
            <uzivatelskePole3>uzivatelskePole3</uzivatelskePole3>
            <uzivatelskePole4>uzivatelskePole4</uzivatelskePole4>
            <uzivatelskePole5>uzivatelskePole5</uzivatelskePole5>
          </uzivatelskaPole>
        </objednavka>
        <objednavka puvodniCislo="23" datum="2012-12-03" cenySDPH="T">
          <!-- Parametry výpočtu dokladu. Zaokrouhlování hlavičky dokladu na koruny. -->
          <parametryDokladu TRU="1.00"/>
          <mena kod="CZK" mnozstvi="1" kurz="1"/>
          <adresa id="22" ulice="Vonaskova 123" mesto="Zlín" psc="760  01"> 
            <firma nazev="" ico="" dic=""/>
            <osoba jmeno="Jan" prijmeni="Vonásek"/>
            <email></email>
            <tel></tel>
          </adresa>
          <polozky>
            <polozka cisloKarty="" text="Sluzby" cenaMJ="10" pocetMJ="1" sazbaDPH="14"/>
            <polozka cisloKarty="1" text="" cenaMJ="10" pocetMJ="1" sazbaDPH="14"/>
          </polozky>
          <poznamka>
            Toto je poznamka
            na vice radek.
            Alespon na dve.
          </poznamka>
        </objednavka>
      </data>
    </mrpRequest>
  </body>  
</mrpEnvelope>

Odpověď

Kladná odpověď obsahuje v datové části seznam originálních čísel objednávek a programem nově přiřazených čísel. Datová část se generuje pouze tehdy, pokud je posíláno původní číslo objednávky.

Atributy elementu <objednavka>nepovinný
name Typ Délka DM Význam
puvodnicislo T 50 0 Původní číslo objednávky
cislo T 10 0 Číslo objednávky přiřazené programem

<mrpEnvelope>
  <body>
    <mrpResponse>
      <status>
        <request command="IMPEO0" requestId="20140101140300033"/>
      </status>
      <data>
        <datasets>
          <objednavka>
            <rows>
              <row>
                <fields>
                  <puvodnicislo>1</puvodnicislo>
                  <cislo>OP20140001</cislo>
                </fields>
              </row>
              <row>
                ....
              </row>
            </rows>
          </objednavka>
        </datasets>
      </data>
    </mrpResponse>
  </body>
</mrpEnvelope>

CENEO0

Příkaz slouží pro zjištění cen pro konkrétní cenovou skupinu.

Požadavek

Atributy elementu <fltvalue>nepovinný
name O/M Typ Délka DM VýznamOd verze
cisloSkladu O N 3 0 Číslo jednoho skladu, ze kterého se bude brát případná cena. [1..999]
Tuto podmínku lze omezit nastavením "Vždy přidat omezující podmínky"
cisloCeny O N 1 0 Číslo výchozí prodejní ceny. [0,1..5]
cenovaSkupina O N 4 0 Číslo cenové skupiny. [1..9999].
cenovaSkupina O T X X Čísla cenových skupin (1..9999) zadaných pomocí svislítka (|) nebo rozsahu (..).
Např. 1|2|4..6
6.40.011
datum O D 10 0 Datum platnosti cenové skupiny (XML formát)
cenySDPH O L 1 0 Zda budou ceny s/bez DPH [T|F]
sql O T X X Výběrové podmínky pomocí SQL syntaxe databazového serveru. Název pole musí být uveden včetně názvu tabulky skladových karet.6.40.011
Seznam volitelných filtrovacích polí, které se přibližují filtrovacím podmínkám skladových karet. Jméno filtru se skládá ze jména tabulky, oddělovače a jména datového pole.
Výraz se zapisuje a vyhodnocuje stejným způsobem, jaku u filtru v programu MRP K/S, tedy při použití číselných a datumových výrazů musí tyto výrazy respektovat nastavení desetinných oddělovačů a tvaru data nastavených na klientské stanici.
Jsou uváděny pouze typy jednotlivých polí kvůli konstrukci dotazu.
name O/M Typ Délka DM Význam
SKKAR.CISLO O N X X Číslo skladové karty.
Tuto podmínku lze omezit nastavením "Vždy přidat omezující podmínky"
SKKAR.NAZOV O T X X Název skladové karty.
SKKAR.KOD O T X X EAN skladové karty.
SKKAR.KOD1 O T X X Uživatelský kód skladové karty.
SKKAR.KOD2 O T X X Uživatelský kód skladové karty.
SKKAR.KOD3 O T X X Uživatelský kód skladové karty.
SKKAR.SKUPINA O T X X Kód skupiny skladových karet.
Tuto podmínku lze omezit nastavením "Vždy přidat omezující podmínky"
SKKAR.CISKAT O N X X Kód katalogu skladových karet.
Tuto podmínku lze omezit nastavením "Vždy přidat omezující podmínky"
SKKAR.TYP_POL O T X X Kód typu položky skladové karty.
Tuto podmínku lze omezit nastavením "Vždy přidat omezující podmínky"
SKKAR.SADZBADPH O N X X Sazba DPH skladové karty.
SKKAR.BEZDPH O L X X Rozlišení mezi mimo DPH a nulovou sazbou [T|F].
SKKAR.POZNAMKA O T X X Poznámka skladové karty.
SKKAR.ZAKAZSLEVYO L X X Zákaz slevy skladové karty [T|F].
SKKAR.DODAVATEL O T X X IČ obchodníka (není to záložka dodavatelů).
SKKAR.POZNAMKA1 O T X X Rozšířená poznámka skladové karty.
SKKAR.DAT_ZAR O D X X Datum zařazení skladové karty.
SKKAR.POUZIVANA O L X X Příznak používání skladové karty [T|F].
SKKAR.TLAC O L X X Příznak zařazení karty do "tisku" [T|F].
SKKAR.USRFLD1 O T X X Uživatelské pole skladové karty.
SKKAR.USRFLD2 O T X X Uživatelské pole skladové karty.
SKKAR.USRFLD3 O T X X Uživatelské pole skladové karty.
SKKAR.USRFLD4 O T X X Uživatelské pole skladové karty.
SKKAR.USRFLD5 O T X X Uživatelské pole skladové karty.
SKKARSTA.POCETMJ O N X X Počet MJ na zvoleném skladu.
SKKARSTA.POCREZMJO N X X Počet rezervovaných MJ na zvoleném skladu.
SKKARSTA.POCOBJMJO N X X Počet objednaných MJ u dodavatelů na zvoleném skladu.
SKKARSTA.POZICE O T X X Umístění ve zvoleném skladu.
SKKARSTA.MINIMUM O N X X Nastavené minimum MJ na zvoleném skladu.
SKKARSTA.NORMA O N X X Nastavená norma MJ na zvoleném skladu.
SKKARSTA.MAXIMUM O N X X Nastavené maximum MJ na zvoleném skladu.

 <mrpEnvelope>
  <body>
    <mrpRequest>
      <request command="CENEO0" requestId=""> 
      </request>
      <data>
        <filter>
          <fltvalue name="cisloSkladu">1</fltvalue>
          <fltvalue name="cisloCeny">2</fltvalue>
          <fltvalue name="cenovaSkupina">1|2|4..6</fltvalue>
          <fltvalue name="datum">2014-01-01</fltvalue>
          <fltvalue name="cenySDPH">F</fltvalue>
          <!-- Nepovinny blok s pripadnymi daty, zalezi na prikazu, zdali je potrebuje -->
          <!-- Číslo karty v rozsahu 1 až 10 -->
          <fltvalue name="SKKAR.CISLO">1..10</fltvalue>
          <!-- Kód skupiny skladových karet A nebo B -->
          <fltvalue name="SKKAR.SKUPINA">A|B</fltvalue>
          <!-- Typ položky Z -->
          <fltvalue name="SKKAR.TYP_POL">Z</fltvalue>
        </filter>
      </data>
    </mrpRequest>
  </body>
</mrpEnvelope>

Odpověď

Element <ceny>povinný
name Typ Délka DM Význam
cislo N 10 2 Číslo karty
censkup N 4 0 Číslo cenové skupiny
cisloceny N 1 0 Číslo použité ceny
mena T 3 0 Měna
cenamj N 17 6 Cena určená podmínkou číslo ceny
sleva_p N 5 2 Jednotková sleva procentem
slevamj N 17 6 Jednotková sleva částkou

<mrpEnvelope>
  <body>
    <mrpResponse>
      <status>
        <request command="CENEO0"/>
      </status>
      <data>
        <datasets>
          <ceny>
            <rows>
              <row>
                <fields>
                  <cislo>1</cislo>
                  <censkup>1</censkup>
                  <cisloceny>1</cisloskl>
                  <mena>CZK</mena>
                  <cenamj>1000</cenamj>
                  <sleva_p>10</sleva_p>
                  <slevamj>100</slevamj>
                </fields>
              </row>
              <row>
                ....
              </row>
            </rows>
          </ceny>
        </datasets>
      </data>
    </mrpResponse>
  </body>
</mrpEnvelope>

ADREO0

Požadavek

Atributy elementu <fltvalue>nepovinný
Seznam volitelných filtrovacích polí, které se přibližují filtrovacím podmínkám adres. Jméno filtru se skládá ze jména tabulky, oddělovače a jména datového pole.
Výraz se zapisuje a vyhodnocuje stejným způsobem, jaku u filtru v programu MRP K/S, tedy při použití číselných a datumových výrazů musí tyto výrazy respektovat nastavení desetinných oddělovačů a tvaru data nastavených na klientské stanici.
Jsou uváděny pouze typy jednotlivých polí kvůli konstrukci dotazu.
name Typ Význam
ADRES.FIRMA T Firma
ADRES.MENO T Jméno
ADRES.ULICA T Ulice
ADRES.MESTO T Město
ADRES.PSC T PSČ
ADRES.KODSTAT T Kód státu
ADRES.ICO T
ADRES.DIC T DIČ
ADRES.TELEFON T Telefon
ADRES.FAX T Fax
ADRES.EMAIL T E-mail
ADRES.DAT_ZAR D Datum zařazení
ADRES.POZNAMKA T Poznámka
ADRES.CENSKUP N Cenová skupina
ADRES.EANKOD T EAN adresy
ADRES.FYZOSOB L Fyzická osoba [T|F]
ADRES.TLAC T Označeno do tisku [T|F]
ADRES.UCET T Výchozí bankovní účet
ADRES.USRFLD1 T Uživatelské pole 1 adresy
ADRES.USRFLD2 T Uživatelské pole 2 adresy
ADRES.USRFLD3 T Uživatelské pole 3 adresy
ADRES.USRFLD4 T Uživatelské pole 4 adresy
ADRES.USRFLD5 T Uživatelské pole 5 adresy
ADRES.SPLATNOST N Jiná splatnost faktury
ADRES.KREDIT N Částka kreditu
ADRES.CRPSTATUS T CRP-status
ADRES.FAKSTRED T Kód fakturačního střediska
KONTAKTY.IDENTIFT Obchodní zástupce

 <mrpEnvelope>
  <body>
    <mrpRequest>
      <request command="ADREO0" requestId=""> 
      </request>
      <data>
        <filter>
          <!-- Adresy s PSČ začínající na 100 -->
          <fltvalue name="ADRES.PSC">100*</fltvalue>
          <!-- Cenová skupina nastavena -->
          <fltvalue name="ADRES.CENSKUP">not null</fltvalue>
        </filter>
      </data>
    </mrpRequest>
  </body>
</mrpEnvelope>

Odpověď

Element <adres>Vždy
fields Typ Délka DM Význam
ico T 12 0
dic T 17 0 DIČ
ic_dph T 14 0 IČ DPH
id T 10 0 Identifikátor adresy v e-obchodu
firma T 50 0 Název firmy
meno T 30 0 Jméno
ulica T 30 0 Ulice a číslo popisné
mesto T 30 0 Město
psc T 15 0 PSČ
kodstat T 2 0 Kód státu
telefon T 30 0 Telefon
telefon1 T 30 0 Telefon
telefon2 T 30 0 Telefon
fax T 30 0 Fax
email T 256 0 E-mailová adresa
censkup N 4 0 Číslo cenové skupiny
stat T 30 0 Název státu

<mrpEnvelope>
  <body>
    <mrpResponse>
      <status>
        <request command="ADREO0"/>
      </status>
      <data>
        <datasets>
          <adres>
            <rows>
              <row>
                <fields>
                  <ico>A00001</ico>
                  <dic></dic>
                  <ic_dph></ic_dph>
                  <id>122</id>
                  <firma>Ferda Mravenec;</firma>
                  <meno>Pytlík</meno>
                  <ulica>K mraveništi 1</ulica>
                  <mesto>Borový les</mesto>
                  <psc>00000</psc>
                  <kodstat>CZ</kodstat>
                  <telefon>123 456 789</telefon>
                  <telefon1></telefon1>
                  <telefon2></telefon2>
                  <fax></fax>
                  <email></email>
                  <censkup>1</censkup>
                  <stat>Česká republika</stat>
                </fields>
              </row>
              <row>
                ....
              </row>
            </rows>
          </ceny>
        </datasets>
      </data>
    </mrpResponse>
  </body>
</mrpEnvelope>


EXPFV0 Export seznamu faktur vydaných s adresou odběratele

Požadavek

Příkaz umožňuje vyexportovat doklady s použitím filtrovacích podmínek (nepovinných) uvedených v části <filter>. Příkaz podporuje stránkování. Podporované filtrovací atributy elementu <fltvalue>:

  • UUID - UUID
  • DocumentNumber - číslo dokladu
  • CompanyId - IČO odběratele
  • PaymentState - stav zaplacení : 0-Všechny, 1-Všechny s úhradami ke dni (PaymentsToDate), 2-Zaplacené (úhrady=celkem), 3-Nezaplacené, nevyrovnané(úhrady<>celkem), 4-Přeplacené (úhrady>celkem), 5-Nedoplacené (úhrady<celkem), 6-Zaplacené + přeplacené
  • PaymentsToDate - Datum úhrad Do. Pro zjištění Stavu zaplacení se přihlíží jen k úhradám s datem menším nebo rovným PaymentsToDate. Nelze zadat intervalem či výrazem jako u jiných filtrovacích tagů. Hodnotou může být pouze konkrétní datum např. "31.12.2018"
  • IssueDate - Datum vystavení. Např. "01.01.2018..31.12.2018"
  • TaxPointDate - Datum plnění
  • PaymentDueDate - Datum splatnosti
  • CostCentre - Středisko. Např. "10|20"
  • ContractNumber - Číslo zakázky
  • OrderNumber - Číslo objednávky
  • OriginalOrderNumber - Původní číslo objednávky (filtrovací podmínku nelze použít pro exporty faktur přijatých)

 <mrpEnvelope>
  <body>
    <mrpRequest>
      <request command="EXPFV0" requestId=""> 
      </request>
      <data>
        <paging>
          <!-- Stránkování - omezení počtu záznamů -->
          <RowFrom>1</RowFrom>
          <RowTo>200</RowTo>
        </paging>
        <filter>
          <!-- Doklady s datem vystavení  -->
          <fltvalue name="IssueDate">01.01.2018..31.12.2018</fltvalue>
        </filter>
      </data>
    </mrpRequest>
  </body>
</mrpEnvelope>

Odpověď

V elementu <data> je vráceno XML formátu XML MRP-K/S verze 2.0.
Seznam a popis polí XML MRP-K/S verze 2.0 pro faktury vydané
Ukázkový soubor XML MRP-K/S verze 2.0 pro faktury vydané
Příkaz vrací zjednodušené XML obsahující údaje z hlaviček dokladů a dále pak adresu obchodního partnera v části Company. Neobsahuje části Items, Payments , SumValues a PaymentSchedule.

Příklad vrácené odpovědi:
<mrpEnvelope>
  <body>
    <mrpResponse>
      <status>
        <request command="EXPFV0"/>
      </status>
      <data>
        <MRPKSData version="2.0" countryCode="CZ" currencyCode="CZK">
        <!--Source AppVendor="MRP" AppName="MRP-K/S" AppVersion="5.67(001)" AppSerial="UC010001"-->
          <IssuedInvoices>
            <Invoice>
              <DocumentNumber>55002</DocumentNumber>
              <IssueDate>2018-03-29</IssueDate>
              <CurrencyCode>CZK</CurrencyCode>
              <ValuesWithTax>F</ValuesWithTax>
              <TaxCode>19</TaxCode>
              <ZeroTaxRateAmount>0.00</ZeroTaxRateAmount>
              <Company>
                <CompanyId>99999999</CompanyId>
                <AddressId>X000001</AddressId>
                <Name>Nábytek a.s.</Name>
                <Street>K městu 10</Street>
                <City>Vrchlabí 1</City>
                <Country>Česká republika</Country>
                <CountryCode>CZ</CountryCode>
                <ZipCode>54301</ZipCode>
                <VatNumber>CZ99999999</VatNumber>
              </Company>
              ..
            </Invoice>
            ..
            <Invoice>
            </Invoice>
          </IssuedInvoices>
        </MRPKSData>
      </data>
    </mrpResponse>
  </body>
</mrpEnvelope>


EXPFV1 Export seznamu faktur vydaných s adresou odběratele, položkami a úhradami

Příkaz se chová podobně jako příkaz EXPFV0. Rozdíl je ve vrácené odpovědi, kdy XML navíc obsahuje i část Items s položkami faktur a část Payments s úhradami.


EXPFV2 Export seznamu faktur vydaných s uloženým opisem faktury ve formátu PDF

Příkaz se chová podobně jako příkaz EXPFV0. Rozdíl je ve vrácené odpovědi, kdy XML navíc obsahuje i část Attachments s PDF opisem faktury. Příkaz jako PDF opis exportuje soubor/dokument, který je u faktury uložen na záložce Přílohy. Pro správné fungování příkazu je třeba nastavit ukládání PDF jako přílohy.
Ukázkový XML soubor faktury s vloženou přílohou PDF



EXPFVPDF Export faktury vydané s online vygenerovanou PDF fakturou

Požadavek

Příkaz umožňuje vygenerovat PDF podobu faktury. Program pro vygenerování použije předlohy, které jsou specifikované v profilu pro export. Pokud v profilu nebude předloha uvedena, použije se výchozí předloha "01 - Faktura". Vygenerované PDF bude v XML uloženo ve větvi Attachments. XML nebude ve větvi Attachments obsahovat další přílohy(soubory JPG, DOC, PDF, ...) u dokladu uložené (uložené na záložce Přílohy). Pro vykonání příkazu je povinné v rámci filtrovacích podmínek uvést číslo dokladu/faktury ve filtrovacím tagu DocumentNumber. Filtr musí obsahovat pouze číslo jedné faktury, není povolen rozsah dokladů či výčet dokladů. Tisková předloha (předlohy) je povolena pouze pro tiskový modul FastReport. Předloha musí být pro generování PDF odladěna - nesmí zobrazovat žádné uživatelské dialogy či hlášení. Tyto by "zablokovaly" Autonomní režim.

 <mrpEnvelope>
  <body>
    <mrpRequest>
      <request command="EXPFVPDF" requestId=""> 
      </request>
      <data>
        <filter>
          <!-- Doklad s číslem  -->
          <fltvalue name="DocumentNumber">240153</fltvalue>
        </filter>
      </data>
    </mrpRequest>
  </body>
</mrpEnvelope>

Odpověď

V elementu <data> je vráceno XML formátu XML MRP-K/S verze 2.0.
Seznam a popis polí XML MRP-K/S verze 2.0 pro faktury vydané
Ukázkový soubor XML MRP-K/S verze 2.0 pro fakturu vydanou s pdf přílohou



EXPFP0 Export seznamu faktur přijatých s adresou dodavatele

Příkaz je ekvivalentem příkazu EXPFP0 pro agendu faktur přijatých
Seznam a popis polí XML MRP-K/S verze 2.0 pro faktury přijaté
Ukázkový soubor XML MRP-K/S verze 2.0 pro faktury přijaté


EXPFP1 Export seznamu faktur přijatých s adresou dodavatele, položkami a úhradami

Příkaz se chová podobně jako příkaz EXPFP0. Rozdíl je ve vrácené odpovědi, kdy XML navíc obsahuje i část Items s položkami faktur a část Payments s úhradami.

EXPOP0

Požadavek

Atributy elementu <fltvalue>nepovinný
Seznam volitelných filtrovacích polí, které se přibližují filtrovacím podmínkám objednávek. Jméno filtru se skládá ze jména tabulky, oddělovače a jména datového pole.
Výraz se zapisuje a vyhodnocuje stejným způsobem, jaku u filtru v programu MRP K/S, tedy při použití číselných a datumových výrazů musí tyto výrazy respektovat nastavení desetinných oddělovačů a tvaru data nastavených na klientské stanici.
Jsou uváděny pouze typy jednotlivých polí kvůli konstrukci dotazu.
name Typ Význam
OBJPR.CISLO T Číslo objednávky
OBJPR.DATUM D Datum objednávky
OBJPR.ORIGCISLO T Původní číslo objednávky
OBJPR.ICO T
polozky T Vrátit i stavy jednotlivých položek [T|F]
typDokladu T Vrátit požadovaný typ dokladu [O|N|X Objednávka|Nabídka|Cokoliv]
Pokud tato filtrovací podmínka není uvedena, příkaz vrací jen objednávky!

 <mrpEnvelope>
  <body>
    <mrpRequest>
      <request command="EXPOP0" requestId=""> 
      </request>
      <data>
        <filter>
          <!-- Objednávky s číslem začínajícím EO21 -->
          <fltvalue name="OBJPR.CISLO">EO21*</fltvalue>
          <!-- Objednávky s datem v rozmezí... -->
          <fltvalue name="OBJPR.DATUM">1.12.2021..31.12.2021</fltvalue>
          <!-- Vrátit i stavy jednotlivých položek -->
          <fltvalue name="polozky">T</fltvalue>
          <fltvalue name="typDokladu">X</fltvalue>
        </filter>
      </data>
    </mrpRequest>
  </body>
</mrpEnvelope>

Odpověď

Atributy elementu <objednavka>
name Typ Délka DM Význam Od verze
cisloObj T 10 0 Číslo objednávky6.30.001
puvodniCislo T 50 0 Původní číslo objednávky6.30.001
datum D 10 0 Datum objednávky RRRR-MM-DD6.30.001
stav N 1 0 Stav objednávky
<0 - blokované
0 - vybavené
1 - částečně vybavené
2 - nevybavené
6.30.001
usrLock T 1 0 Příznak uzamčené objednávky
T - uzamčena některým uživatelem
F - neuzamčena
6.39.006
ico T 14 0 IČ zákazníka6.30.001
nabidka T 1 0 T - nabídka, F - objednávka6.42.003
Atributy elementu <polozka>
fields Typ Délka DM Význam Od verze
stav N 1 0 Stav objednávky
<0 - blokované
0 - vybavené
1 - částečně vybavené
2 - nevybavené
6.30.001
vybavitMJ N 15 3 Kolik MJ ještě zbývá vybavit6.30.001
text T 100 0 Text řádku objednávky6.30.001
cisloKarty N 10 2 Číslo skladové karty6.30.001
eanKarty T 14 0 EAN skladové karty6.30.001
kodKarty T 30 0 Uživatelský kód skladové karty6.30.001

<mrpEnvelope>
  <body>
    <mrpResponse>
      <status>
        <request command="EXPOP0"/>
      </status>
      <data>
        <objednavka cisloObj="0000000029" puvodniCislo="22" datum="2015-01-01" stav="2" usrLock="F" ico="A00001">
          <polozky>
            <polozka stav="2" vybavitMJ="2" text="Zboží" cisloKarty="1" eanKarty="8595229909767" kodKarty="16060.01"/>
          </polozky>
        </objednavka>
      </data>
    </mrpResponse>
  </body>
</mrpEnvelope>


IMPFV0 Import faktury vydané

Požadavek

Příkaz importuje fakturu vydanou ve formátu XML MRP-K/S verze 2.0.
Seznam a popis polí XML MRP-K/S verze 2.0 pro faktury vydané
Ukázkový soubor XML MRP-K/S verze 2.0 pro faktury vydané. Pokud bude XML obsahovat více faktur, naimportuje se pouze první doklad.

<mrpEnvelope>
  <body>
    <mrpRequest>
      <request command="IMPFV0" requestId=""> 
      </request>
      <data>
        <MRPKSData version="2.0" countryCode="CZ" currencyCode="CZK">
          <IssuedInvoices>
            <Invoice>
              <DocumentNumberPrefix>242</DocumentNumberPrefix>
              <UUID>B8BFA790-C733-41B4-A9D5-694F95E760F0</UUID>
              <CurrencyCode>CZK</CurrencyCode>
              <ValuesWithTax>F</ValuesWithTax>
              <TaxCode>19</TaxCode>
              <ZeroTaxRateAmount>0.00</ZeroTaxRateAmount>
              <Company>
                <CompanyId>99999999</CompanyId>
                <AddressId>X000001</AddressId>
                <Name>Nábytek a.s.</Name>
                <Street>K městu 10</Street>
                <City>Vrchlabí 1</City>
                <Country>Česká republika</Country>
                <CountryCode>CZ</CountryCode>
                <ZipCode>54301</ZipCode>
                <VatNumber>CZ99999999</VatNumber>
              </Company>
              ..
            </Invoice>
          </IssuedInvoices>
        </MRPKSData>
      </data>
    </mrpRequest>
  </body>
</mrpEnvelope>

Odpověď

V elementu <data> jsou vráceny ve struktuře XML MRP-K/S verze 2.0 elementy <UUID> a <DocumentNumber>, pod kterými byl doklad naimportován.

Příklad vrácené odpovědi:
<mrpEnvelope>
  <body>
    <mrpResponse>
      <status>
        <request command="IMPFV0"/>
      </status>
      <data>
        <MRPKSData version="2.0" countryCode="CZ" currencyCode="CZK">
        <!--Source AppVendor="MRP" AppName="MRP-K/S" AppVersion="6.61(003)" AppSerial="UC010001"-->
          <IssuedInvoices>
            <Invoice>
              <DocumentNumber>24200058</DocumentNumber>
              <UUID>B8BFA790-C733-41B4-A9D5-694F95E760F0</UUID>
            </Invoice>
          </IssuedInvoices>
        </MRPKSData>
      </data>
    </mrpResponse>
  </body>
</mrpEnvelope>


IMPFP0 Import faktury přijaté

Požadavek

Příkaz importuje fakturu přijatou ve formátu XML MRP-K/S verze 2.0.
Seznam a popis polí XML MRP-K/S verze 2.0 pro faktury přijaté
Ukázkový soubor XML MRP-K/S verze 2.0 pro faktury přijaté. Pokud bude XML obsahovat více faktur, naimportuje se pouze první doklad.

<mrpEnvelope>
  <body>
    <mrpRequest>
      <request command="IMPFP0" requestId=""> 
      </request>
      <data>
        <MRPKSData version="2.0" countryCode="CZ" currencyCode="CZK">
          <IncomingInvoices>
            <Invoice>
              <DocumentNumberPrefix>249</DocumentNumberPrefix>
              <UUID>A8BFA790-C733-41B4-A9D5-694F95E760F0</UUID>
              <CurrencyCode>CZK</CurrencyCode>
              <ValuesWithTax>F</ValuesWithTax>
              <TaxCode>19</TaxCode>
              <ZeroTaxRateAmount>0.00</ZeroTaxRateAmount>
              <Company>
                <CompanyId>99999999</CompanyId>
                <AddressId>X000001</AddressId>
                <Name>Nábytek a.s.</Name>
                <Street>K městu 10</Street>
                <City>Vrchlabí 1</City>
                <Country>Česká republika</Country>
                <CountryCode>CZ</CountryCode>
                <ZipCode>54301</ZipCode>
                <VatNumber>CZ99999999</VatNumber>
              </Company>
              ..
            </Invoice>
          </IncomingInvoices>
        </MRPKSData>
      </data>
    </mrpRequest>
  </body>
</mrpEnvelope>

Odpověď

V elementu <data> jsou vráceny ve struktuře XML MRP-K/S verze 2.0 elementy <UUID> a <DocumentNumber>, pod kterými byl doklad naimportován.

Příklad vrácené odpovědi:
<mrpEnvelope>
  <body>
    <mrpResponse>
      <status>
        <request command="IMPFP0"/>
      </status>
      <data>
        <MRPKSData version="2.0" countryCode="CZ" currencyCode="CZK">
        <!--Source AppVendor="MRP" AppName="MRP-K/S" AppVersion="6.61(003)" AppSerial="UC010001"-->
          <IncomingInvoices>
            <Invoice>
              <DocumentNumber>24900630</DocumentNumber>
              <UUID>A8BFA790-C733-41B4-A9D5-694F95E760F0</UUID>
            </Invoice>
          </IncomingInvoices>
        </MRPKSData>
      </data>
    </mrpResponse>
  </body>
</mrpEnvelope>


SV2FV0 Vytvoření faktury vydané z existující skladové výdejky

Požadavek

Příkaz založí/vygeneruje v databázi fakturu vydanou na základě dat již existující skladové výdejky. Parametry příkazu:

  • WarehouseDocumentNumber - číslo zdrojového skladového pohybu. Jedná se o složeninu "Číslo skladu" + "V" + "Číslo pohybu", např. 001V000000158. Povinný parametr.
  • DocumentNumberPrefix - prefix číselné řady faktury, dle které má být doklad očíslován (přiřazeno číslo dokladu). Pokud není uveden jako parametr příkazu, musí být nastaven v profilu příkazu v Nastavení Autonomního režimu.
  • IssueDate - datum vystavení. Nepovinné. Pokud není uvedeno, použije se datum ze zdrojového pohybu.
  • TaxPointDate - datum plnění. Nepovinné. Pokud není uvedeno, použije se datum ze zdrojového pohybu.

<mrpEnvelope>
  <body>
    <mrpRequest>
      <!-- Povinny blok pro definici prikazu -->
      <request command="SV2FV0" requestId="20121203140300090"> 
      </request>
      <data>
        <params>
          <!-- Cislo pohybu. Povinny parametr. Slozenina 'Cislo skladu' + 'V' + 'Cislo pohybu' -->
          <paramvalue name="WarehouseDocumentNumber">001V000000158</paramvalue> 

          <!-- Prefix ciselne rady faktury. Nepovinne. Pokud je uveden, ma prioritu pred Prefixem rady z profilu -->
          <paramvalue name="DocumentNumberPrefix">ARG</paramvalue> 

          <!-- Datum vystaveni. Nepovinne. Pokud neni uvedeno, prebira se dle data ze zdrojoveho pohybu -->
          <paramvalue name="IssueDate">2024-02-01</paramvalue>

          <!-- Datum plneni. Nepovinne. Pokud neni uvedeno, prebira se dle data ze zdrojoveho pohybu -->
          <paramvalue name="TaxPointDate">2024-01-31</paramvalue>

        </params>
      </data>
    </mrpRequest>
  </body>
</mrpEnvelope>

Odpověď

V elementu <data> jsou vráceny ve struktuře XML MRP-K/S verze 2.0 elementy <UUID> a <DocumentNumber>, pod kterými byl doklad vytvořen/vygenerován.

Příklad vrácené odpovědi:
<mrpEnvelope>
  <body>
    <mrpResponse>
      <status>
        <request command="SV2FV0" requestId="20121203140300090"/>
      </status>
      <data>
        <MRPKSData version="2.0" countryCode="CZ" currencyCode="CZK">
          <!--Source AppVendor="MRP" AppName="MRP-K/S" AppVersion="6.55(002)" AppSerial="UC010001"-->
          <IssuedInvoices>
            <Invoice>
              <DocumentNumber>ARG00001</DocumentNumber>
              <UUID>D267D67B-F86F-4222-BA6E-1FFB4FAE78D5</UUID>
            </Invoice>
          </IssuedInvoices>
        </MRPKSData>
      </data>
    </mrpResponse>
  </body>
</mrpEnvelope>


EXPSTR0 Export číselníku středisek

Požadavek

Příkaz podporuje stránkování.

 <mrpEnvelope>
  <body>
    <mrpRequest>
      <request command="EXPSTR0" requestId=""> 
      </request>
      <data>
        <paging>
          <!-- Stránkování - omezení počtu záznamů -->
          <RowFrom>1</RowFrom>
          <RowTo>200</RowTo>
        </paging>
      </data>
    </mrpRequest>
  </body>
</mrpEnvelope>

Odpověď

V elementu <data> je vráceno XML formátu XML MRP-K/S verze 2.0.
Seznam a popis polí XML MRP-K/S verze 2.0 pro číselník středisek
Ukázkový soubor XML MRP-K/S verze 2.0 pro číselník středisek

Příklad vrácené odpovědi:
<mrpEnvelope>
  <body>
    <mrpResponse>
      <status>
        <request command="EXPSTR0"/>
      </status>
      <data>
       <MRPKSData version="2.0" countryCode="CZ" currencyCode="CZK">
         <!--Source AppVendor="MRP" AppName="MRP-K/S" AppVersion="6.61(003)" AppSerial="UC010001"-->
         <CostCentreList>
           <CostCentreListItem>
             <Code>0</Code>
           </CostCentreListItem>
           <CostCentreListItem>
             <Code>01</Code>
             <Text>Výroba</Text>
           </CostCentreListItem>
           <CostCentreListItem>
             <Code>02</Code>
             <Text>Velkoobchod</Text>
           </CostCentreListItem>
           <CostCentreListItem>
             <Code>03</Code>
             <Text>Maloobchod</Text>
           </CostCentreListItem>
         </CostCentreList>
        </MRPKSData>
      </data>
    </mrpResponse>
  </body>
</mrpEnvelope>


EXPZAK0 Export číselníku zakázek

Požadavek

Příkaz podporuje stránkování.

 <mrpEnvelope>
  <body>
    <mrpRequest>
      <request command="EXPZAK0" requestId=""> 
      </request>
      <data>
        <paging>
          <!-- Stránkování - omezení počtu záznamů -->
          <RowFrom>1</RowFrom>
          <RowTo>200</RowTo>
        </paging>
      </data>
    </mrpRequest>
  </body>
</mrpEnvelope>

Odpověď

V elementu <data> je vráceno XML formátu XML MRP-K/S verze 2.0.
Seznam a popis polí XML MRP-K/S verze 2.0 pro číselník zakázek
Ukázkový soubor XML MRP-K/S verze 2.0 pro číselník zakázek

Příklad vrácené odpovědi:
<mrpEnvelope>
  <body>
    <mrpResponse>
      <status>
        <request command="EXPZAK0"/>
      </status>
      <data>
        <MRPKSData version="2.0" countryCode="CZ" currencyCode="CZK">
          <!--Source AppVendor="MRP" AppName="MRP-K/S" AppVersion="6.61(003)" AppSerial="UC010001"-->
          <ContractList>
            <ContractListItem>
              <Code>0</Code>
              <ContractStatus>2</ContractStatus>
              <ContractPrice>0.00</ContractPrice>
              <InitialState>0.00</InitialState>
            </ContractListItem>
            <ContractListItem>
              <Code>Z24001</Code>
              <Text>Zakázka č. Z24001</Text>
              <StartDate>2024-02-08</StartDate>
              <EndDate>2024-02-08</EndDate>
              <ContractStatus>0</ContractStatus>
              <ContractPrice>0.00</ContractPrice>
              <InitialState>0.00</InitialState>
            </ContractListItem>
            ...
          </ContractList>
        </MRPKSData>
      </data>
    </mrpResponse>
  </body>
</mrpEnvelope>


EXPOSN0 Export účtové osnovy

Požadavek

Příkaz podporuje stránkování.

 <mrpEnvelope>
  <body>
    <mrpRequest>
      <request command="EXPOSN0" requestId=""> 
      </request>
      <data>
        <paging>
          <!-- Stránkování - omezení počtu záznamů -->
          <RowFrom>1</RowFrom>
          <RowTo>200</RowTo>
        </paging>
      </data>
    </mrpRequest>
  </body>
</mrpEnvelope>

Odpověď

V elementu <data> je vráceno XML formátu XML MRP-K/S verze 2.0.
Seznam a popis polí XML MRP-K/S verze 2.0 pro účtovou osnovu
Ukázkový soubor XML MRP-K/S verze 2.0 pro účtovou osnovu

Příklad vrácené odpovědi:
<mrpEnvelope>
  <body>
    <mrpResponse>
      <status>
        <request command="EXPOSN0"/>
      </status>
      <data>
        <MRPKSData version="2.0" countryCode="CZ" currencyCode="CZK">
          <!--Source AppVendor="MRP" AppName="MRP-K/S" AppVersion="6.61(003)" AppSerial="UC010001"-->
          <AccountList>
            <AccountListItem>
              <AccountSynth>011</AccountSynth>
              <Text>Zřizovací výdaje</Text>
              <Text2>Incorporation expenses</Text2>
              <Text3>Errichtungskosten</Text3>
              <AccountType>A</AccountType>
              <CurrencyCode>CZK</CurrencyCode>
              <ExcludedFromTax>F</ExcludedFromTax>
              <Balance>F</Balance>
              <EconomicActivity>F</EconomicActivity>
            </AccountListItem>
            <AccountListItem>
              <AccountSynth>012</AccountSynth>
              <Text>Nehmot. výsl.výzkumu a vývoje</Text>
              <Text2>Research and development</Text2>
              <Text3>Entwicklungskosten</Text3>
              <AccountType>A</AccountType>
              <CurrencyCode>CZK</CurrencyCode>
              <ExcludedFromTax>F</ExcludedFromTax>
              <Balance>F</Balance>
              <EconomicActivity>F</EconomicActivity>
            </AccountListItem>
            ...
          </AccountList>
        </MRPKSData>
      </data>
    </mrpResponse>
  </body>
</mrpEnvelope>


EXPCISRAD0 Export číselných řad

Požadavek

 <mrpEnvelope>
  <body>
    <mrpRequest>
      <request command="EXPCISRAD0" requestId=""> 
      </request>
      <data>
        <paging>
          <!-- Stránkování - omezení počtu záznamů -->
          <RowFrom>1</RowFrom>
          <RowTo>200</RowTo>
        </paging>
      </data>
    </mrpRequest>
  </body>
</mrpEnvelope>

Odpověď

V elementu <data> je vráceno XML formátu XML MRP-K/S verze 2.0.
Seznam a popis polí XML MRP-K/S verze 2.0 pro číselné řady
Ukázkový soubor XML MRP-K/S verze 2.0 pro číselné řady



EXPADR20 Export adres ve formátu XML MRP-K/S v. 2.0

Požadavek

Příkaz umožňuje vyexportovat adresy s použitím filtrovacích podmínek (nepovinných) uvedených v části <filter>. Podporované filtrovací atributy elementu <fltvalue>:

  • CompanyId - IČO odběratele
  • VatNumber - DIČ
  • VatNumberSK - IČ DPH - pro SK verzi programu
  • Name - Firma
  • CustomerName - Jméno
  • City - Město
  • ZipCode - PSČ
  • CountryCode - Kód státu
  • NaturalPerson - Příznak fyzické osoby
  • AddressFormationDate - Datum vytvoření/zaevidování adresy
  • UserField1 - Uživatelské pole 1
  • UserField2 - Uživatelské pole 2
  • UserField3 - Uživatelské pole 3
  • UserField4 - Uživatelské pole 4
  • UserField5 - Uživatelské pole 5

Příkaz podporuje stránkování.

 <mrpEnvelope>
  <body>
    <mrpRequest>
      <request command="EXPADR20" requestId=""> 
      </request>
      <data>
        <paging>
          <!-- Stránkování - omezení počtu záznamů -->
          <RowFrom>1</RowFrom>
          <RowTo>200</RowTo>
        </paging>
        <filter>
          <!-- Adresy zařazené/zaevidované   -->
          <fltvalue name="AddressFormationDate">01.01.2024..31.12.2024</fltvalue>
        </filter>
      </data>
    </mrpRequest>
  </body>
</mrpEnvelope>

Odpověď

V elementu <data> je vráceno XML formátu XML MRP-K/S verze 2.0.
Seznam a popis polí XML MRP-K/S verze 2.0 pro Adresy
Ukázkový soubor XML MRP-K/S verze 2.0 pro Adresy



IMPSP0 Import skladových pohybů

Požadavek

Seznam a popis polí XML MRP-K/S verze 2.0 pro skladové pohyby

<mrpEnvelope>
  <body>
    <mrpRequest>
      <request command="IMPSP0" requestId=""> 
      </request>
      <data>
        <MRPKSData version="2.0" countryCode="CZ" currencyCode="CZK">
          <WarehouseTransactions>
            <WarehouseTransaction>
              <WarehouseNumber>1</WarehouseNumber>
              <WarehouseIncomeDocument>F</WarehouseIncomeDocument>
              <WarehouseTransactionType>P</WarehouseTransactionType>
              <WarehouseTransactionType2>1</WarehouseTransactionType2>
              <IssueDate>2024-05-09</IssueDate>
              <CurrencyCode>EUR</CurrencyCode>
              <ValuesWithTax>F</ValuesWithTax>
              <TaxCode>10</TaxCode>
              <ZeroTaxRateAmount>0.00</ZeroTaxRateAmount>
              <ReducedTaxRateAmount>0.00</ReducedTaxRateAmount>
              <BaseTaxRateAmount>0.00</BaseTaxRateAmount>
              <RoundingAmount>0.00</RoundingAmount>
              <ReducedTaxRateTax>0.00</ReducedTaxRateTax>
              <BaseTaxRateTax>0.00</BaseTaxRateTax>
              <TotalWithTaxCurr>0.00</TotalWithTaxCurr>
              <OriginalDocumentNumber>1</OriginalDocumentNumber>
              <TotalWeight>0.000000</TotalWeight>
              <CostCentre>0</CostCentre>
              <ContractNumber>0</ContractNumber>
              <VatRegime>0</VatRegime>
              <VatCountry>SK</VatCountry>
              <EURExchangeRate>1.000000</EURExchangeRate>
              <EURExchangeRateAmount>1.000000</EURExchangeRateAmount>
              <CalcParams>UPDP=3;VATRU=0.10;VATRM=0;TRU=0.01;TRM=0;VATCA=1;VATCUPA=1;TRD=1;TRDCA=0;VATFRB=0</CalcParams>
              <VariableSymbol>55559</VariableSymbol>
              <CurrRateAmount>1.000000</CurrRateAmount>
              <CurrRate>1.000000</CurrRate>
              <PaymentMeansCode>příkazem</PaymentMeansCode>
              <Discount>0.00</Discount>
              <Items>
                <Item>
                  <Quantity>5.000000</Quantity>
                  <TaxPercent>20.00</TaxPercent>
                  <UnitPrice>1000</UnitPrice>
                  <TaxAmount>0.000000</TaxAmount>
                  <DiscountPercent>0.00</DiscountPercent>
                  <UnitDiscount>0.000000</UnitDiscount>
                  <StockCardNumber>20</StockCardNumber>
                  <CostCentre>0</CostCentre>
                  <ContractNumber>0</ContractNumber>
                </Item>
              </Items>
              ..
              <Company>
                <CompanyId>99999999</CompanyId>
                <AddressId>X000001</AddressId>
                <Name>Nábytek a.s.</Name>
                <Street>K městu 10</Street>
                <City>Vrchlabí 1</City>
                <Country>Česká republika</Country>
                <CountryCode>CZ</CountryCode>
                <ZipCode>54301</ZipCode>
                <VatNumber>CZ99999999</VatNumber>
              </Company>
            </WarehouseTransaction>
          </WarehouseTransactions>
        </MRPKSData>
      </data>
    </mrpRequest>
  </body>
</mrpEnvelope>

Odpověď

V elementu <data> jsou vráceny ve struktuře XML MRP-K/S verze 2.0 elementy <OriginalDocumentNumber> a <DocumentNumber>, pod kterými byl doklad naimportován.

Příklad vrácené odpovědi:
<mrpEnvelope>
  <body>
    <mrpResponse>
      <status>
        <request command="IMPEO0" requestId="20140101140300033"/>
      </status>
      <data>
        <datasets>
          <WarehouseTransaction>
            <rows>
              <row>
                <fields>
                  <OriginalDocumentNumber>1</OriginalDocumentNumber>
                  <DocumentNumber>001V202400002</DocumentNumber>
                </fields>
              </row>
              <row>
                ....
              </row>
            </rows>
          </WarehouseTransaction>
        </datasets>
      </data>
    </mrpResponse>
  </body>
</mrpEnvelope>

OP2SV0 Vytvoření skladové výdejky z objednávky přijaté

Požadavek

Příkaz umožňuje z určené objednávky vygenerovat skladový pohyb.

Atributy elementu <fltvalue>Jedno z polí pro určení objednávky je povinné
Seznam polí, které definují objednávku a mohou upřesnit parametry vygenerovaného skladového pohybu.
name Typ Význam
idObj N ID objednávky (vyhodnocuje se jako první)
cislo T Číslo objednávky (vyhodnocuje se jako druhé)
cisloSkladu T Číslo skladu, pokud by objednávka nebyla se skladem. Pokud není uvedeno, bere se z profilu.
druhPohybu N Druh skladového pohybu. Pokud není uveden, bere se z profilu.
datum D Jaké datum bude mít vygenerovaný skladový pohyb.
-1 - datum pohybu je aktuální datum, případný kurz dokladu je hledán pro toto datum
0 - datum pohybu je převzato z objednávky, kurz dokladu je taktéž převzat (výchozí)
RRRR-MM-DD - datum pohybu je určeno parametrem, případný kurz dokladu je hledán pro toto datum

<?xml version="1.0" encoding="windows-1250"?>
<mrpEnvelope>
  <body>
    <mrpRequest>
      <!-- Povinny blok pro definici prikazu -->
      <request command="OP2SV0" requestId="20121203140300002">
      <!-- requestId je ID spojeni (treba TIMESTAMP 20121120093530127) -->
      </request>
      <!-- Nepovinny blok s pripadnymi daty, zalezi na prikazu, zdali je potrebuje -->
      <data>
        <params>
          <paramvalue name="cislo">0000000208</paramvalue>
          <paramvalue name="cisloSkladu">2</paramvalue>
          <paramvalue name="datum">0</paramvalue>
        </params>
      </data>
    </mrpRequest>
  </body>
</mrpEnvelope>

Kladná odpověď

Kladná odpověď obsahuje element skladovaVydejka s polem scislo, ve kterém je uvedeno plné číslo skladové výdejky (<číslo_skladu><Příjem|Výdej><vlastní_číslo>)

<mrpEnvelope>
  <body>
    <mrpResponse>
      <status>
        <request command="OP2SV0" requestId="20121203140300003"/>
      </status>
      <data>
        <MRPKSData version="0.0" countryCode="CZ" currencyCode="CZK">
          <!--Source AppVendor="MRP" AppName="MRP-K/S" AppVersion="6.65(005)" AppSerial="UC010001"-->
          <skladoveVydejky>
            <skladovaVydejka>
              <scislo>001V000000340</scislo>
            </skladovaVydejka>
          </skladoveVydejky>
        </MRPKSData>
      </data>
    </mrpResponse>
  </body>
</mrpEnvelope>

Záporná odpověď

Záporná odpověď obsahuje element error s atributem errorCode, ve kterém je uvedeno číslo chyby.

1 Není nainstalován modul skladu
2 Není zadána identifikace dokladu
3 Chyba v čísle skladu - není zadán
4 Chyba v čísle skladu - není povolen insert pohybu do skladu
5 Chyba v prefixu číselné řady - není zadán
6 Chyba v prefixu číselné řady - není právo insertu dokladu v této číselné řadě
7 Chyba v prefixu číselné řady - není nalezen (synchronizace)
11 Chyba v druhu pohybu - nenalezen
12 Chyba v datumu pohybu (mimo rozsah, uzavřené období...)
100 Doklad nenalezen, nevyhovuje, má už pohyb
103 Chyba v čísle skladu - není zadán
104 Chyba v čísle skladu - není povolen insert pohybu do skladu
105 Chyba v prefixu číselné řady - není zadán
106 Chyba v prefixu číselné řady - není nalezen (synchronizace)
107 Chyba v načítání kurzu
110 Obecná chyba databáze
111 Chyba databáze, Firebird error
< 0 Chyby, ktere vrací naprogramované vyjímky vyvolané v rámci databáze

<mrpEnvelope>
  <body>
    <mrpResponse>
      <status>
        <request command="OP2SV0" requestId="20121203140300003"/>
        <error errorCode="106" errorClass="ESvcClientError">
          <errorMessage>Není zadaná číselná řada pro sklad 2!</errorMessage>
        </error>
      </status>
      <data/>
    </mrpResponse>
  </body>
</mrpEnvelope>


EXPUCDE Export účetního deníku ve formátu XML MRP-K/S v. 2.0

Požadavek

Příkaz umožňuje vyexportovat zápisy účetního deníku s použitím filtrovacích podmínek (nepovinných) uvedených v části <filter>. Podporované filtrovací atributy elementu <fltvalue>:

  • SourceDocument - Zdroj/Doklad za záhlaví skupiny zápisů
  • CostCentre - Středisko. Např. "10|20"
  • ContractNumber - Číslo zakázky
  • Activity - Číslo činnosti
  • Date - Datum zaúčtování. Např. "01.01.2022..31.12.2022"
  • PairingSymbol - Párovací symbol
  • DocumentNumber - Číslo dokladu
  • Text - Text účetního řádku
  • Archive - filtr ARCHivních zápisů. 1 - Všechny zápisy, 2 - Zápisy aktuálního období, 3 - Pouze archivní zápisy. Výchozí hodnota je 2. Pokud tato filtrovací podmínka není uvedena, program exportuje pouze zápisy aktuálního období.
  • AccountsFilter - Výběr účtů MD/DAL. Znak lomítka "/" určuje stranu MD/DAL, znak svislítka "|" je oddělovač hodnot. Příklad: "321" - zápisy s účtem 321 na straně MD nebo DAL. "321/" - zápisy s účtem 321 pouze na straně MD. "/321" - zápisy s účtem 321 pouze na straně DAL. "311/343" - zápisy s účtem 311 na MD a 343 na DAL. "395/|/321" - zápisy s účtem 395 na straně MD nebo zápisy s účtem 321 na straně DAL.

Příkaz podporuje stránkování.

 <mrpEnvelope>
  <body>
    <mrpRequest>
      <request command="EXPUCDE" requestId=""> 
      </request>
      <data>
        <paging>
          <!-- Stránkování - omezení počtu záznamů -->
          <RowFrom>1</RowFrom>
          <RowTo>200</RowTo>
        </paging>
        <filter>
          <!-- Zápisy v období   -->
          <fltvalue name="Date">01.01.2024..31.12.2024</fltvalue>
        </filter>
      </data>
    </mrpRequest>
  </body>
</mrpEnvelope>

Odpověď

V elementu <data> je vráceno XML formátu XML MRP-K/S verze 2.0.
Seznam a popis polí XML MRP-K/S verze 2.0 pro Účetní deník
Ukázkový soubor XML MRP-K/S verze 2.0 pro Účetní deník



IMPUCDE Import účetního deníku ve formátu XML MRP-K/S v. 2.0

Požadavek

Příkaz importuje zápisy účetního deníku ve formátu XML MRP-K/S verze 2.0.
Seznam a popis polí XML MRP-K/S verze 2.0 pro Účetní deník
Ukázkový soubor XML MRP-K/S verze 2.0 pro Účetní deník.

<mrpEnvelope>
  <body>
    <mrpRequest>
      <request command="IMPUCDE" requestId="20121203140300070"> 
      </request>
      <data>
        <MRPKSData version="2.0" countryCode="CZ" currencyCode="CZK">
          <AccountingItems>
            <AccountingItem>
              <SourceDocument>2021001</SourceDocument>
              <SourceDocumentPrefix>FV</SourceDocumentPrefix>
              <Description>Nábytek a.s.</Description>
              <DocumentDate>2021-11-25</DocumentDate>
              <ZeroTaxRateAmount>0.00</ZeroTaxRateAmount>
              <ReducedTaxRateAmount>0.00</ReducedTaxRateAmount>
              <BaseTaxRateAmount>5000.00</BaseTaxRateAmount>
              <RoundingAmount>0.00</RoundingAmount>
              <ReducedTaxRateTax>0.00</ReducedTaxRateTax>
              <BaseTaxRateTax>1050.00</BaseTaxRateTax>
              <Items>
                <Item>
                  <Archive>F</Archive>
                  <CostCentre>03</CostCentre>
                  <ContractNumber>0</ContractNumber>
                  <Activity>0</Activity>
                  <Text>Tržba</Text>
                  <PairingSymbol>2021001</PairingSymbol>
                  <Amount>5000.00</Amount>
                  <AmountCurr>0.00</AmountCurr>
                  <DocumentNumber>2021001</DocumentNumber>
                  <AccountingDate>2021-11-25</AccountingDate>
                  <CreditSynth>311</CreditSynth>
                  <DebitSynth>602</DebitSynth>
                  <CurrRateAmount>0.000000</CurrRateAmount>
                  <CurrRate>0.000000</CurrRate>
                </Item>
                ...
              </Items>
            </AccountingItem>
          </AccountingItems>
        </MRPKSData>
      </data>
    </mrpRequest>
  </body>
</mrpEnvelope>
* Berte prosím v potaz, že otázka a odpověď mohou být úzce svázané s verzí programu aktuální v době zveřejnění odpovědi.

Související otázky najdete ve skupinách: Přeskočit odkazy pro navigaci

© 2022 MRP-Informatics, spol. s r.o.                                         MRP na Slovensku