---
tags: DOG
---
# **DOG Signer API** `v1.11.0`
> API slouží pro vytvoření odkazů na dokument pro získání elektronického podpisu zákazníkem a jejich následné uložení do DMS. Pracuje s dokumenty ve formátu PDF. Využívá služby podpisového serveru SignoSoft.
---
## **Změny ve verzích**
### **v1.11.0**
#### **Přidáno**
* Přidaný endpoint `dog://sign/signature/image` pro stažení PNG obrázku podpisu z dokumentu.
### **v1.10.0**
#### **Přidáno**
* Při vytváření dokumentu k podpisu pomocí `dog://sign/document` je přidaný parametr `signer[].inperson` pro možnost podpisu na místě bez emailové adresy.
### **v1.9.0**
#### **Přidáno**
* Upraveno chování `dog://sign/document` u typu podpisu `signer[].type = "token"`. Popsáno níže.
### **v1.8.2**
#### **Přidáno**
* `DOG.dog.debug` aktivuje deep log, který detailně zaznamená kompletní komunikaci do a z DOG. Dále zaznamená i veškerou komunikaci DOGa s externími nástroji. Data jsou párována s klíčem z `intID`. **Upozornění: generuje velké množství diskových dat.**
### **v1.8.1**
#### **Přidáno**
* `dog://sign/document/status` přidání detailu stavu podpisů na dokumentu
* Přidány diagramy do dokumentace
### **v1.8.0**
#### **Přidáno**
* `dog://sign/document` přidání více typů dokumentů `signer[].type` ("bio", "system", "token")
#### **Odebráno**
* `dog://sign/document` odebrání `signer[].system`, nahrazeno `signer[].type = "system"`
---
### **Postup podpisu dokumentu pomocí dotazování**
1. Nahrání dokumentu s metadaty (definice podpisu, PDF soubor) (sign/document)
1. Opakované volání na stav dokumentu (sign/document/status)
1. Stažení dokumentu (sign/document/download)
### **Postup podpisu dokumentu pomocí callback**
1. Nahrání dokumentu s metadaty (definice podpisu, PDF soubor, endpoint pro callback)
1. Pokud dojde k podpisu dokumentu, je na callback endpoint zasláno potvrzení s odkazem na soubor
### **Umístění API**
#### **TEST** prostředí
* Lokální síť: https://dog.test.ux.bee.corp/api/v1
* Externí zóna: https://apitest.bohemiaenergy.cz/dog
#### **PROD** prostředí
* Lokální síť: https://dog.bee.corp/api/v1
* Externí zóna: https://api.bohemiaenergy.cz/dog
### **Ověření přístupu k API**
Ověření je řešeno pomocí `API-KEY` vloženého do hlavičky
* `Authorization: Bearer <API-KEY>`
V případě použití přístupu z externí zóny, je nutné ještě navíc přístupový `PROXY-KEY` pro `Proxy` umístěný do hlavičky
* `X-APP-KEY: <PROXY-KEY>`
### **Vysvětlivky**
* ==*== - povinné položky
* [color=#ff4500] - další informace na konci dokumentu v Příloze
---
## **Scénáře průběhu komunikace**
### **s uložením do DMS a použitím callback**
```sequence
App->DOG Signer: dog://sign/document
DOG Signer->DMS: Uložení dokumentu
DMS->DOG Signer: Vrácení ID
DOG Signer->SignServer: Registrace dokumentu k podpisu
SignServer->DOG Signer: Vrácení odkazů na podpis
DOG Signer->App: Vrácení Tokenu, odkazů a DMS ID
SignServer->DOG Signer: Callback při podpisu všech podpisů
DOG Signer->SignServer: Kontrola podpisů a žádost o podpis systémových
SignServer->DOG Signer: Potvrzení a předání podepsaného dokumentu
DOG Signer->DMS: Uložení dokumentu
DMS->DOG Signer: Vrácení Verze
DOG Signer->App: dog://sign/callback
```
V `dog://sign/callback` je pak vráceno ID dokumentu v DMS
### **bez uložení do DMS a s použitím callback**
```sequence
App->DOG Signer: dog://sign/document
DOG Signer->SignServer: Registrace dokumentu k podpisu
SignServer->DOG Signer: Vrácení odkazů na podpis
DOG Signer->App: Vrácení Tokenu a odkazů
SignServer->DOG Signer: Callback při podpisu všech podpisů
DOG Signer->SignServer: Kontrola podpisů a žádost o podpis systémových
SignServer->DOG Signer: Potvrzení a předání podepsaného dokumentu
DOG Signer->App: dog://sign/callback
```
V `dog://sign/callback` je vrácen soubor v `BASE64`
### **s uložením do DMS a bez použití callback**
```sequence
App->DOG Signer: dog://sign/document
DOG Signer->DMS: Uložení dokumentu
DMS->DOG Signer: Vrácení ID
DOG Signer->SignServer: Registrace dokumentu k podpisu
SignServer->DOG Signer: Vrácení odkazů na podpis
DOG Signer->App: Vrácení Tokenu, odkazů a DMS ID
SignServer->DOG Signer: Callback při podpisu všech podpisů
DOG Signer->SignServer: Kontrola podpisů a žádost o podpis systémových
SignServer->DOG Signer: Potvrzení a předání podepsaného dokumentu
DOG Signer->DMS: Uložení dokumentu
DMS->DOG Signer: Vrácení Verze
App->DOG Signer: dog://sign/document/status
DOG Signer->SignServer: Ověření stavu dokumentu
SignServer->DOG Signer: Potvrzení stavu dokumentu
DOG Signer->App: Potvrzení stavu dokumentu
```
Protože volání callback ze SignServeru může být zpožděno a protože proces podpisu systémových podpisů může trvat několik vteřin je nutné aby před stažení dokumentu z DMS proběhlo ověření, že je dokument již podepsán a správně uložen.
Pokud je stav `SIGNED`, tak je nová verze dokumentu pod ID v DMS. V případě `NOT_SIGNED` je nutné počkat a kontrolovat stav v pravidelných intervalech.
### **bez uložení do DMS a bez použití callback**
```sequence
App->DOG Signer: dog://sign/document
DOG Signer->SignServer: Registrace dokumentu k podpisu
SignServer->DOG Signer: Vrácení odkazů na podpis
DOG Signer->App: Vrácení Tokenu a odkazů
SignServer->DOG Signer: Callback při podpisu všech podpisů
DOG Signer->SignServer: Kontrola podpisů a žádost o podpis systémových
SignServer->DOG Signer: Potvrzení provedení podpisu
App->DOG Signer: dog://sign/document/status
DOG Signer->SignServer: Ověření stavu dokumentu
SignServer->DOG Signer: Potvrzení stavu dokumentu
DOG Signer->App: Potvrzení stavu dokumentu
App->DOG Signer: dog://sign/document/download
DOG Signer->SignServer: Žádost o dokument
SignServer->DOG Signer: Vrácení dokumentu
DOG Signer->App: Vrácení dokumentu
```
Protože volání callback ze SignServeru může být zpožděno a protože proces podpisu systémových podpisů může trvat několik vteřin je nutné aby před stažení dokumentu proběhlo ověření, že je dokument již podepsán a je tedy možné jej stáhnout.
---
## **Způsob zpracování chyb**
#### **V případě jakékoliv chyby je vráceno například:**
```json=
{
"intID": "b59fb26d-89df-4fea-9560-0dc3379eda82",
"response": {
"error": {
"code": "MISSING_MANDATORY_DATA",
"message": "Missing mandatory nodes: entity",
"data": {}
}
}
}
```
#### **Popis:**
* **intID** `string` - interní ID DOG, pod kterým je provedeno zalogování požadavku
* **response** `object` - objekt s tělem odpovědi
* **error** `object` - objekt s tělem chyby
* **code** `string` - označení chyby, strojově zpracovatelný kód
* **message** `string` - doplňující popis chyby, většinou předávaná hodnota z dalších systémů nebo lidsky čitelná podoba chyby
* **data** `object` - další strojově zpracovatelné detaily chyby
### **Seznam kódů**
| Code | Message | Data | Popis |
| --------------------------- | -------------------------------------- |:----:| ----- |
| `INVALID_INPUT_JSON` | Chyba z parseru | - | Vstupní data nejsou validní JSON formát |
| `MISSING_MANDATORY_DATA` | List chybějících polí vstupních dat | - | Kontrola vstupních dat, kontrola povinných položek a jejich struktury, případně validita stupních dat |
| `INVALID_INPUT_FILE_FORMAT` | | - | Chyba MIME TYPE vstupních souborů |
| `SIGNOSOFT_INTERNAL_ERROR` | Přeposlaná chyba z podpisového serveru | - | Vnitřní chyba na straně podpisového serveru |
| `DMS_INTERNAL_ERROR` | Přeposlaná chyba z DMS | - | Vnitřní chyba na strane DMS |
| `DB_INTERNAL_ERROR` | | - | Vnitřní chyba databáze, chyba není eskalovaná, je logovaná pouze interně |
| `DOG_SIGNER_INTERNAL_ERROR` | | - | Vnitřní chyba DOG Signer |
**Způsob reportování chyb je u všech endpointů stejný. Dále nebude popisovaný.**
---
## **dog://sign/document**
> Vytvoření a nahrání dokumentu do podpisového server. Založení podpisových polí a vygenerování odkazů pro provedení podpisu.
**Metoda:** `POST` \
**URL:** `/sign/document` \
**Tělo dotazu:** `application/json` \
**Tělo odpovědi:** `application/json`
#### **Příklad:**
```json=
{
"signer": [
{
"firstname": "Jan",
"secondname": "Novák",
"mail": "jannovak1980@seznam.cz",
"expirein": 86400,
"position": {
"page": 1,
"positionX": 137,
"positionY": 239,
"width": 60,
"height": 15
},
{
"type": "token",
"token": "Zsm5XScO",
"firstname": "Anna",
"secondname": "Nováková",
"mail": "annanovakova1980@seznam.cz",
"expirein": 86400,
"position": {
"positionX": 137,
"positionY": 200,
"width": 60,
"height": 15
},
{
"firstname": "František",
"secondname": "Novák",
"expirein": 86400,
"inperson": true,
"position": {
"page": 1,
"positionX": 137,
"positionY": 239,
"width": 60,
"height": 15
},
{
"type": "system",
"mail": "rsima@bohemiaenergy.cz",
"position": {
"positionX": 50,
"positionY": 239,
"width": 60,
"height": 15
}
}
],
"document": {
"name": "Souhlas s osobními údaji",
"entity": "BE",
"web": "https://www.bohemiaenergy.cz/podekovani-za-podpis"
},
"callback": "https://app.bee.corp/callback",
"file": {
"dms": {
"name": "",
"xml": ""
},
"data": "data:application/pdf;base64,JVBERi0xLjcKJeLjz9MKMjIgMCBvYmo..."
}
}
```
#### **Popis:**
* **signer** ==*== `array of objects`- pole objektů jednotlivých podpisů
* **type** `string` ["bio"] - určuje typ podpisu. `bio` - biometrický podpis. `system` - systémově doplněný podpis, musí být v `signer[].mail` účet, který má vyplněný digitální podpis v podpisovém serveru. `token` - podpis dokumentu pomocí tokenu zaslaného jinou cestou.
* **token** `string` - heslo, které bude nastaveno a požadováno při podpisu. Pokud nebude předáno bude vygenerováno automaticky a vráceno v odpovědi. Délka hesla bude dle nastavení `DOG.signosoft.settings.token.length` a skládat se bude ze znaků definovaných v `DOG.signosoft.settings.token.chars`. Pokud je předané heslo kratší než `DOG.signosoft.settings.token.length`, tak je vrácena chyba vstupních dat.
* **firstname** `string` - jméno signatáře (==*== při `signer[].type=="bio" || signer[].type=="token")
* **secondname** `string` - příjmení signatáře (==*== při `signer[].type=="bio" || signer[].type=="token")
* **mail** `string` - emailová adresa signatáře, ID signatáře, je na něj odkazováno v odpovědi a je považován za unikátní v rámci podpisového serveru. Musí to být jedna validní emailová adresa. (==*== při `(signer[].type=="bio" || signer[].type=="token") && signer[].inperson = false`)
* **inperson** `bool` [*false*] - podpis na místě bez nutnosti mít emailovou adresu
* **expirein** `int` [*259200*] - expirace odkazu v sekundách (now + expirein)
* **expireat** `timestamp` - expirace odkazu v definovaném čase (unixtimestamp [seconds])
* **position** ==*== `object` - objekt popisující pozici podpisu
* **page** `int` [*1*] - číslo stránky umístění podpisu
* **positionx** `float` - pozice podpisu v [mm] od levého okraje (==*== při `lookup==""`)
* **positiony** `float` - pozice podpisu v [mm] od horního okraje (==*== při `lookup==""`)
* **width** ==*== `float` - šířka pole podpisu v [mm]
* **height** ==*== `float` - výška pole podpisu v [mm]
* **lookup** `string` - text od kterého bude určena pozice podpisového pole od levého dolního rohu hledaného textu
* **offsetx** `float` - posunutí podpisového pole od textu v lookup (==*== při `lookup!=""`)
* **offsety** `float` - posunutí podpisového pole od textu v lookup (==*== při `lookup!=""`)
* **document** ==*== `object` - definice objektu popisující dokument
* **name** ==*== `string` - název dokumentu, je zobrazeno v záhlaví stránky při podpisu
* **entity** ==*== `string` - účetní okruh, povolené hodnoty na základě konfiguračního číselníku `DOG.dog.entity[]` [color=#ff4500]
* **web** `string` - odkaz na webovou stránku v případě dokončeného podpisu, je předaný parametr docToken s ID dokumentu
* **callback** `string` - URL endpoint, kam bude zaslaná notifikace o provedeném podpisu (detailně popsáno v sekci dog://sign/callback). Callback adresa musí být **https** s **validním ověřitelným certifikátem**.
* **file** ==*== `object` - definice objektu se souborem určeným k podpisu
* **dms** `object` - objekt popisující soubor pro uložení do DMS
* **name** `string` - název souboru jak bude uložen do DMS
* **xml** `string` - XML metadata, obsah elementu \<v3:xmlFileAtts> při SOAP volání DMS
* **data** `string` - data mimetype s base64 souborem, akceptace pouze `application/pdf`
#### **Poznámky:**
**POZOR** `signer[].mail` musá být email s validní (existující) doménou, jinak podpisový server nedovolí podepsat.
Pokud není vyplněno `signer[].expirein` ani `signer[].expireat`, je čas validity odkazu nastaven na aktuální čas plus konfigurační hodnota `DOG.signosoft.settings.expirein`.
Pokud není vyplněno `document.web`, je automaticky doplněno na konfigurační hodnotu `DOG.signosoft.entity.<document.entity>.web`.
V případě, že `file.dms.name` a `file.dms.xml` není vyplněno, nedojde k uložení do DMS. Pro úspěšné uložení do DMS je nutné zajistit XML data od správce DMS a zajistit práva na daný typ souboru pro DOG.
`signer[].inperson` má omezení v případě použití více podpisů. Každý odkaz na podpis je sice unikátní, ale podpis lze provést na všechny místa podpisu z kteréhokoliv odkazu.
#### **Odpověď:**
```json=
{
"intID": "9e584f06-1b80-4752-bb55-ab6f0df95ea5",
"response": {
"document": {
"token": "dd04d303-fddb-4e6d-b6dc-7e5f52b52e37_1592341833031"
},
"links": [
{
"bioId": "f91a27a41a7b76dc2caa1aed1f71bb0ccbc4f87716bb4680177...",
"signer": "jon.doe@seznam.cz",
"url": "https://podpis.bohemiaenergy.cz?bioid=f91a27a41a7b76d...",
"validTo": 1592428233,
"token": "Zsm5XScO"
}
],
"file": {
"dms": {
"id": 3367441,
"version": 1
}
}
}
}
```
#### **Popis:**
* **intID** `string` - interní ID DOG, pod kterým je provedeno zalogování požadavku
* **response** `object` - objekt s tělem odpovědi
* **document** `object` - objekt s vlastnostmi dokumentu
* **token** `string` - unikátní identifikátor dokumentu v rámci podpisového serveru
* **links** `array of objects` - pole s vytvořenými odkazy k podpisu pro jednotlivé signatáře
* **bioId** `string` - identifikátor podpisu, použito pro `dog://sign/link/*`
* **signer** `string` - email signatáře, shodný s signer[].mail ze vstupních dat
* **url** `string` - odkaz k podpisu dokumentu
* **validTo** `timestamp` - platnost odkazu do (unixtimestamp [seconds])
* **token** `string` - pokud byl podpis definován `signer[].type=="token"`, tak bude vráceno zadané heslo pomocí `signer[].token` nebo automaticky vygenerované
* **file** `object` - objekt souboru
* **dms** `object` - objekt souboru v DMS
* **id** `int` - ID DMS souboru
* **version** `int` - Verze souboru v DMS
---
## **dog://sign/document/delete**
> Vymazání dokumentu a na něj navázané odkazy pro podpis. Lze smazat pouze dokument, který nebyl podepsaný nebo byl částečně podepsaný.
**Metoda:** `POST` \
**URL:** `/sign/document/delete` \
**Tělo dotazu:** `application/json` \
**Tělo odpovědi:** `application/json`
#### **Příklad:**
```json=
{
"document": {
"token": "4c6cb873-c9ab-4c24-ba65-a60ae31db33b_1591898899817"
}
}
```
#### **Popis:**
* **document** `object` - objekt s vlastnostmi dokumentu
* **token** `string` - token z volání `dog://sign/document` z `response.document.token`
#### **Odpověď:**
```json=
{
"intID": "f63924ae-1a4f-4502-ac70-3fe6d9458e7f",
"response": {
"status": "DELETED"
}
}
```
#### **Popis:**
* **intID** `string` - interní ID DOG, pod kterým je provedeno zalogování požadavku
* **response** `object` - objekt s tělem odpovědi
* **document** `object` - objekt s vlastnostmi dokumentu
* **status** `string` - stav provedení smazání dokumentu a na něj navázaných vlastností
#### **Poznámky:**
Dochází pouze ke smazanání dokumentu na straně podpisového serveru. Nedojde ke smazání z DMS.
---
## **dog://sign/document/status**
> Zjištění stavu dokumentu. V případě, že došlo k selhání při předání informace pomocí callback je možné pomocí tohoto endpointu zjistit stav dokumentu. Vhodné volat v nejnutnějších případech pro snížení zbytečné zátěže podpisového serveru.
**Metoda:** `POST` \
**URL:** `/sign/document/status` \
**Tělo dotazu:** `application/json` \
**Tělo odpovědi:** `application/json`
#### **Příklad:**
```json=
{
"document": {
"token": "4c6cb873-c9ab-4c24-ba65-a60ae31db33b_1591898899817"
}
}
```
#### **Popis:**
* **document** `object` - objekt s vlastnostmi dokumentu
* **token** `string` - token z volání `dog://sign/document` z `response.document.token`
#### **Odpověď:**
```json=
{
"intID": "56b686cd-3133-47b7-b368-e53446604618",
"response": {
"status": "NOT_SIGNED",
"missing": [
{
"mail": "jannovak@seznam.cz",
"type": "bio"
},
{
"mail": "rsima@bohemiaenergy.cz",
"type": "system"
}
]
}
}
```
#### **Popis:**
* **intID** `string` - interní ID DOG, pod kterým je provedeno zalogování požadavku
* **response** `object` - objekt s tělem odpovědi
* **document** `object` - objekt s vlastnostmi dokumentu
* **status** `string` - stav dokumentu, vrácené hodnoty mohou být **SIGNED** nebo **NOT_SIGNED**
* **missing** `array of objects` - pole se seznamem chybějících podpisů
* **mail** `string` - Email signatáře
* **type** `string` - Typ podpisu, odpovídá typům z `dog://sign/document` z `signer[].type` ("bio", "system", "token")
---
## **dog://sign/document/download**
> Stažení dokumentu po provedeném podpisu. Není nutné používat v případě, že je použit callback a je použito DMS pro práci se soubory.
**Metoda:** `POST` \
**URL:** `/sign/document/download` \
**Tělo dotazu:** `application/json` \
**Tělo odpovědi:** `application/json`
#### **Příklad:**
```json=
{
"document": {
"token": "4c6cb873-c9ab-4c24-ba65-a60ae31db33b_1591898899817"
}
}
```
#### **Popis:**
* **document** `object` - objekt s vlastnostmi dokumentu
* **token** `string` - token z volání `dog://sign/document` z `response.document.token`
#### **Odpověď:**
```json=
{
"intID": "845414a7-f1f9-4709-8e09-bfe44500cb5a",
"response": {
"file": {
"data": "data:application/pdf;base64,JVBERi0xLjcKJfbk/N8KMSAwIG9ia..."
}
}
}
```
#### **Popis:**
* **intID** `string` - interní ID DOG, pod kterým je provedeno zalogování požadavku
* **response** `object` - objekt s tělem odpovědi
* **document** `object` - objekt s vlastnostmi dokumentu
* **file** `object` - objekt se souborem
* **data** `string` - data mimetype base64 soubor
---
## **dog://sign/link/update**
> Aktualizace času expirace odkazu na podpis u dokumentu.
**Metoda:** `POST` \
**URL:** `/sign/link/update` \
**Tělo dotazu:** `application/json` \
**Tělo odpovědi:** `application/json`
#### **Příklad:**
```json=
{
"link": {
"bioId": "f91a27a41a7b76dc2caa1aed1f71bb0ccbc4f87716bb4680177b4450b0f...",
"expireIn": 86400
}
}
```
#### **Popis:**
* **link** ==*== `object` - objekt s definicí podpisu
* **bioId** ==*== `string` - token z `response.links[].bioId` z volání `dog://sign/document`
* **expireIn** ==*== `int` [*259200*] - expirace odkazu v sekundách (now + expirein)
* **expireAt** ==*== `timestamp` - expirace odkazu v definovaném čase (unixtimestamp [seconds])
#### **Poznámky:**
Je nutné vyplnit expireIn nebo expireAt. V případě obou má prioritu expireIn.
#### **Odpověď:**
```json=
{
"intID": "a8039fdf-a4e0-4757-befd-09a30b77bf3f",
"response": {
"link": {
"bioId": "f91a27a41a7b76dc2caa1aed1f71bb0ccbc4f87716bb4680177b445...",
"signer": "jannovak@seznam.cz",
"validTo": 1592428279
}
}
}
```
#### **Popis:**
* **intID** `string` - interní ID DOG, pod kterým je provedeno zalogování požadavku
* **response** `object` - objekt s tělem odpovědi
* **link** `object` - objekt s vlastnostmi podpisu
* **bioId** `string` - bioId token podpisu pro potvrzení
* **signer** `string` - email login signatáře pro potvrzení
* **validTo** `timestamp` - časové razítko do kdy platí podpis (unixtimestamp [seconds])
---
---
## **dog://sign/signature/image**
> Stažení obrázků podpisů z dokumentu. Stahuje obrázky pouze pokud na dokumentu existuje finalizovaný podpis. Jinak vrací prázdný objekt.
**Metoda:** `POST` \
**URL:** `/sign/signature/image` \
**Tělo dotazu:** `application/json` \
**Tělo odpovědi:** `application/json`
#### **Příklad:**
```json=
{
"document": {
"token": "4c6cb873-c9ab-4c24-ba65-a60ae31db33b_1591898899817"
}
}
```
#### **Popis:**
* **document** `object` - objekt s vlastnostmi dokumentu
* **token** `string` - token z volání `dog://sign/document` z `response.document.token`
#### **Odpověď:**
```json=
{
"intID": "56b686cd-3133-47b7-b368-e53446604618",
"response": {
"images": [
{
"mail": "jannovak1980@seznam.cz",
"image": "..."
}
]
}
}
```
#### **Popis:**
* **intID** `string` - interní ID DOG, pod kterým je provedeno zalogování požadavku
* **response** `object` - objekt s tělem odpovědi
* **images** `array of objects` - pole se seznamem obrázků u finalizovaných podpisů
* **mail** `string` - Email signatáře
* **image** `string` - PNG obrázek podpisu
<!--
---
## **dog://sign/link/delete**
> Smazání odkazu
**Metoda:** `POST` \
**URL:** `/sign/link/delete` \
**Tělo dotazu:** `application/json` \
**Tělo odpovědi:** `application/json`
#### **Příklad:**
```json=
{
"link": {
"bioId": "f91a27a41a7b76dc2caa1aed1f71bb0ccbc4f87716bb4680177b4450b0f8..."
}
}
```
#### **Popis:**
* **link** ==*== `object` - objekt s definicí podpisu
* **bioId** ==*== `string` - token z `response.links[].bioId` z volání `dog://sign/document`
#### **Odpověď:**
```json=
{
"intID": "521b043e-55d1-4464-a1ee-4cd9bfae050c",
"response": {
"status": "LINK_NOT_EXIST"
}
}
```
#### **Popis:**
* **intID** `string` - interní ID DOG, pod kterým je provedeno zalogování požadavku
* **response** `object` - objekt s tělem odpovědi
* **status** `string` - popis výsledku smazání podpisu
-->
---
## **dog://sign/callback**
> V případě, že byl v `dog://sign/document` vyplněn callback a dokument je podepsán, tak bude tento odkaz zavolán a bude předán výsledek z podpisového serveru. Callback adresa musí být **https** s **validním ověřitelným certifikátem**.
**Metoda:** `POST` \
**Tělo odpovědi:** `application/json`
#### **Předaná data bez použití DMS:**
```json=
{
"intID": "845414a7-f1f9-4709-8e09-bfe44500cb5a",
"document": {
"token": "c1227e93-3292-4fd4-be5e-09983e5a836d_1591889611773"
},
"file": {
"data": "data:application/pdf;base64,JVBERi0xLjcKJfbk/N8KMSAwIG9iago8P..."
}
}
```
#### **Popis:**
* **intID** `string` - interní ID DOG, pod kterým je provedeno zalogování požadavku
* **document** `object` - objekt s definicí dokumentu
* **token** `string` - token z volání `dog://sign/document` z `response.document.token`
* **file** `object` - objekt se souborem
* **data** `string` - data mimetype base64 soubor
#### **Předaná data při použití DMS:**
```json=
{
"intID": "845414a7-f1f9-4709-8e09-bfe44500cb5a",
"document": {
"token": "c1227e93-3292-4fd4-be5e-09983e5a836d_1591889611773"
},
"file": {
"dms": {
"id": 3367441,
"version": 2
}
}
}
```
#### **Popis:**
* **intID** `string` - interní ID DOG, pod kterým je provedeno zalogování požadavku
* **document** `object` - objekt s definicí dokumentu
* **token** `string` - token z volání `dog://sign/document` z `response.document.token`
* **file** `object` - objekt se souborem
* **dms** `object` - objekt souboru v DMS
* **id** `int` - ID souboru v DMS
* **version** `int` - verze souboru v DMS, v případě, že došlo k úspěšnému podpisu dokumentu, tak by verze měla být vždy 2. Verze 1 je soubor před podpisem.
#### **Poznámky:**
V případě, že je v body na callback odpověď, tak je pouze zalogována. Není na ni jakkoliv reagováno.
---
## Přílohy
### Číselník DOG.dog.entity[]
```json=
}
"entity": {
"BE": ["BE", "71", "B", "BEE", "bohemiaenergy.cz"],
"CE": ["CE", "82", "C", "comfortenergy.cz"],
"XE": ["XE", "81", "X", "X Energie", "xenergie.cz"],
"3E": ["3E", "100", "E", "3-e.cz"],
"BD": ["BD", "63", "Z", "BEZ", "bezdodavatele.cz"],
"SE": ["SE", "72", "S", "SK", "SKE", "slovakiaenergy.sk"],
"AM": ["AM", "75", "A", "ampermarket.cz"],
"BPL": ["BPL", "beplan.cz"],
"ECS": ["ECS", "77", "P", "energie-cs.cz"]
}
}
```