diff --git a/rest/src/main/resources/openapi/admin/v7.0/openapi.yaml b/rest/src/main/resources/openapi/admin/v7.0/openapi.yaml
new file mode 100644
index 000000000..d11791670
--- /dev/null
+++ b/rest/src/main/resources/openapi/admin/v7.0/openapi.yaml
@@ -0,0 +1,3829 @@
+openapi: 3.0.2
+info:
+ title: Administrační API v systému Kramerius
+ description: |
+ Popis je platný k verzi 7.0.35 a vyšší. Kramerius obsahuje REST API, které umožňuje všechny operace nad systémem. Standardně je dostupné na nainstalovaném serveru pod kontextem: `~/search/api/*`.
+ Primárně určeno pro administraci
+
+ version: "7.0"
+
+servers:
+ - url: /search/api/admin/v7.0
+
+tags:
+
+ - name: Administrace sbírek
+ description: >
+ Všechny operace nad sbírkou: editace metadat, přidávání do sbírky, odebírání ze sbírky, editace výstřižků, atd..
+
+ - name: Přístup do importních a exportních dat
+ description: >
+ Získání souborů a adresářů z importních a exportních složek. (Importy FOXML, NDK, Generované logy, atd..)
+
+ - name: Statistiky
+ description: >
+ Všechny operace týkající se statistik
+
+ - name: Titul
+ description: >
+ Operace nad titulem
+
+ - name: Licence
+ description: >
+ Vytváření, rušení licencí, priorita, atd..
+
+ - name: Role
+ description: >
+ Výpis, vytváření, rušení rolí, atd..
+
+ - name: Práva
+ description: >
+ Vytvoření, výpis, atd..
+
+ - name: Procesy
+ description: >
+ Výpis, plánování, stopování, atd..
+
+paths:
+
+ /collections:
+ get:
+ tags:
+ - Administrace sbírek
+ summary: Získání všech sbírek případně sbírek, které obsahují daný objekt
+ description: |
+ Získání všech sbírek případně sbírek, které obsahují daný objekt
+
+ operationId: getCollections
+ parameters:
+ - in: query
+ name: withItem
+ description: PID objektu, v případě vyplnění vrací jenom ty sbírky, které obsahují daný objekt
+ schema:
+ type: string
+ required: false
+ responses:
+ '200':
+ description: Úspěšně získaný resultset
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {
+ "collections": [
+ {
+ "thumbnail": "content",
+ "names": {
+ "cze": "Pokus",
+ "eng": "Example"
+ },
+ "created": "2024-08-03T08:54:45.385",
+ "standalone": false,
+ "modified": "2024-08-04T11:53:01.021",
+ "pid": "uuid:2fe4f178-a742-4b85-9af3-71d554a0c21d",
+ "descriptions": {
+ "cze": "Pokus",
+ "eng": "Example"
+ }
+ }
+ ],
+ "total_size": 1
+ }
+
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ post:
+ tags:
+ - Administrace sbírek
+
+ summary: Vytvoření nové sbírky
+ description: |
+ Vytvoření nové sbírky
+
+ operationId: createCollection
+
+ requestBody:
+ description: JSON reprezentace sbírky
+ required: true
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {
+ "names": {
+ "cze": "Cesky nazev",
+ "eng": "Name"
+ },
+ "descriptions": {
+ "cze": "Cesky popisek",
+ "eng": "Description"
+ },
+ "contents": {},
+ "standalone": true
+ }
+
+ responses:
+ '201':
+ description: Úspěšně vytvořená sbírka
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {
+ "thumbnail": "none",
+ "names": {
+ "cze": "Cesky nazev",
+ "eng": "Name"
+ },
+ "standalone": true,
+ "pid": "uuid:28b00683-977d-4743-ad4b-ff8135f5e263",
+ "descriptions": {
+ "cze": "Cesky popisek",
+ "eng": "Description"
+ }
+ }
+
+ '400':
+ description: Chybný dotaz
+
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ /collections/{pid}:
+ get:
+ tags:
+ - Administrace sbírek
+
+ summary: Získání plného popisu sbírky
+ description: |
+ Získání plného popisu sbírky
+
+ operationId: getCollection
+ parameters:
+ - in: path
+ name: pid
+ description: Identifikátor sbírky
+ schema:
+ type: string
+ required: true
+
+ responses:
+ '200':
+ description: Úspěšně získaná sbírka
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {
+ "thumbnail": "content",
+ "names": {
+ "cze": "RWar"
+ },
+ "keywords": {
+ "cze": [
+ "test",
+ "lest",
+ "pok"
+ ],
+ "eng": [
+ "ahoj",
+ "jest"
+ ]
+ },
+ "contents": {
+ "cze": "
Dlouhy popis sbirky<\\/p>"
+ },
+ "author": "Pavel Stastny",
+ "created": "2024-08-02T19:40:11.243",
+ "standalone": false,
+ "clippingitems": [
+ {
+ "thumb": "IMG_0514EF172485DC7BFD7E975B02B7FC21",
+ "name": "Zar",
+ "description": "Zar",
+ "url": "https://k7.inovatika.dev/uuid/uuid:48f84987-3921-11ef-a7a7-001b63bd97ba?bb=659,179,2467,1143"
+ },
+ {
+ "thumb": "IMG_DC6159E55D315F81A3D9FF89C9B8A6A6",
+ "name": "Pardubice",
+ "description": "Pardubice",
+ "url": "https://k7.inovatika.dev/uuid/uuid:48f8709e-3921-11ef-a7a7-001b63bd97ba?bb=509,172,3050,2283"
+ }
+ ],
+ "modified": "2024-09-12T08:33:37.606",
+ "pid": "uuid:bcc986fc-7ec8-47eb-b585-121e48f7bd02",
+ "descriptions": {
+ "cze": "Krakty popis sbirky"
+ },
+ "items": [
+ "uuid:31121290-d52e-4206-8723-56cd1fa200c7",
+ "uuid:b35833b3-7f7f-4cac-a434-484b6e096922"
+ ]
+ }
+ '400':
+ description: Chybný pid sbírky
+
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ '404':
+ description: Sbírka neexistuje
+
+ put:
+ tags:
+ - Administrace sbírek
+
+ summary: Update vlastností sbírky
+ description: |
+ Update vlastností sbírky
+
+ operationId: updateCollection
+
+ parameters:
+ - in: path
+ name: pid
+ description: Identifikátor sbírky
+ schema:
+ type: string
+ required: true
+
+ requestBody:
+ description: JSON reprezentace sbírky
+ required: true
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {
+ "names": {
+ "cze": "Cesky nazev",
+ "eng": "Name"
+ },
+ "descriptions": {
+ "cze": "Cesky popisek",
+ "eng": "Description"
+ },
+ "keywords": {
+ "cze": [
+ "test",
+ "lest",
+ "pok"
+ ],
+ "eng": [
+ "ahoj",
+ "jest"
+ ]
+ },
+
+ "contents": {
+ "cze": "
Dlouhy popis sbirky<\\/p>"
+ },
+ "standalone": true
+ }
+
+ responses:
+ '200':
+ description: Úspěšně updatovaná sbírka
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {
+ "thumbnail": "content",
+ "names": {
+ "cze": "RWar"
+ },
+ "keywords": {
+ "cze": [
+ "test",
+ "lest",
+ "pok"
+ ],
+ "eng": [
+ "ahoj",
+ "jest"
+ ]
+ },
+ "contents": {
+ "cze": "
Dlouhy popis sbirky<\\/p>"
+ },
+ "author": "Pavel Stastny",
+ "created": "2024-08-02T19:40:11.243",
+ "standalone": false,
+ "clippingitems": [
+ {
+ "thumb": "IMG_0514EF172485DC7BFD7E975B02B7FC21",
+ "name": "Zar",
+ "description": "Zar",
+ "url": "https://k7.inovatika.dev/uuid/uuid:48f84987-3921-11ef-a7a7-001b63bd97ba?bb=659,179,2467,1143"
+ },
+ {
+ "thumb": "IMG_DC6159E55D315F81A3D9FF89C9B8A6A6",
+ "name": "Pardubice",
+ "description": "Pardubice",
+ "url": "https://k7.inovatika.dev/uuid/uuid:48f8709e-3921-11ef-a7a7-001b63bd97ba?bb=509,172,3050,2283"
+ }
+ ],
+ "modified": "2024-09-12T08:33:37.606",
+ "pid": "uuid:bcc986fc-7ec8-47eb-b585-121e48f7bd02",
+ "descriptions": {
+ "cze": "Krakty popis sbirky"
+ },
+ "items": [
+ "uuid:31121290-d52e-4206-8723-56cd1fa200c7",
+ "uuid:b35833b3-7f7f-4cac-a434-484b6e096922"
+ ]
+ }
+ '400':
+ description: Chybný pid sbírky
+
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ '404':
+ description: Sbírka neexistuje
+
+ delete:
+ tags:
+ - Administrace sbírek
+ operationId: deleteCollection
+
+ summary: Smazání sbírky
+ description: |
+ Smazání sbírky
+
+ parameters:
+ - in: path
+ name: pid
+ description: Identifikátor sbírky
+ schema:
+ type: string
+ required: true
+
+ responses:
+ '200':
+ description: Úspěšně smazaná sbírka
+
+ '400':
+ description: Chybný pid sbírky
+
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+ '404':
+ description: Sbírka neexistuje
+
+ /collections/{pid}/items:
+ post:
+ tags:
+ - Administrace sbírek
+ operationId: addToContent
+
+ summary: Přidání objektů do sbírky
+ description: |
+ Update obsahu sbírky - přidání objektů do sbírky
+
+ parameters:
+ - in: path
+ name: pid
+ description: Identifikátor sbírky
+ schema:
+ type: string
+ required: true
+
+ - in: query
+ name: indexation
+ description: Spustit indexaci
+ schema:
+ type: string
+ enum: ["true","false"]
+ required: true
+
+ requestBody:
+ description: JSON reprezentace obsahu sbírky
+ required: true
+ content:
+ application/json:
+ schema:
+ type: string
+ example: ["uuid:b92c8b10-4a9a-11e3-ad8c-005056827e52","uuid:c11acb60-f28f-11e2-9923-005056827e52"]
+ responses:
+ '201':
+ description: Úspěšný update obsahu sbírky
+
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ /collections/prefix:
+ get:
+ tags:
+ - Administrace sbírek
+ operationId: prefixSearch
+
+ summary: Vyhledavání sbírek dle prefixu
+ description: |
+ Vyhledávání sbírek dle prefixu titulku
+
+ parameters:
+ - in: query
+ name: prefix
+ description: Vyhledavací dotaz, vyhledává se dle všech titlků a používá se prefix search
+ schema:
+ type: string
+ required: true
+ - in: query
+ name: rows
+ description: Počet vrácených řádků
+ schema:
+ type: number
+ required: false
+ - in: query
+ name: page
+ description: Číslo strany výsledků - počítáno od nuly
+ schema:
+ type: number
+ required: false
+ responses:
+ '200':
+ description: Úspěšně získaný resultset
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {
+ "collections": [
+ {
+ "thumbnail": "content",
+ "names": {
+ "cze": "Pokus",
+ "eng": "Example"
+ },
+ "created": "2024-08-03T08:54:45.385",
+ "standalone": false,
+ "modified": "2024-08-04T11:53:01.021",
+ "pid": "uuid:2fe4f178-a742-4b85-9af3-71d554a0c21d",
+ "descriptions": {
+ "cze": "Pokus",
+ "eng": "Example"
+ }
+ }
+ ],
+ "total_size": 1
+ }
+
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ /collections/{pid}/image/thumb:
+ post:
+ tags:
+ - Administrace sbírek
+
+
+ summary: Upload náhledu pro sbírku
+ description: |
+ Upload náhledu pro sbírku
+
+
+ operationId: uploadThumbnail
+ parameters:
+ - in: path
+ name: pid
+ description: PID identifikátor sbírky
+ schema:
+ type: string
+ required: true
+
+ requestBody:
+ required: true
+ content:
+ multipart/form-data:
+ schema:
+ type: object
+ properties:
+ file:
+ type: string
+ format: binary
+ description: Náhled pro sbírku
+ responses:
+ '200':
+ description: Náhled úspěšně nahraný
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {
+ "thumbnail": "content",
+ "names": {
+ "cze": "RWar"
+ },
+ "keywords": {
+ "cze": [
+ "test",
+ "lest",
+ "pok"
+ ],
+ "eng": [
+ "ahoj",
+ "jest"
+ ]
+ },
+ "contents": {
+ "cze": "
Dlouhy popis sbirky<\\/p>"
+ },
+ "author": "Pavel Stastny",
+ "created": "2024-08-02T19:40:11.243",
+ "standalone": false,
+ "clippingitems": [
+ {
+ "thumb": "IMG_0514EF172485DC7BFD7E975B02B7FC21",
+ "name": "Zar",
+ "description": "Zar",
+ "url": "https://k7.inovatika.dev/uuid/uuid:48f84987-3921-11ef-a7a7-001b63bd97ba?bb=659,179,2467,1143"
+ },
+ {
+ "thumb": "IMG_DC6159E55D315F81A3D9FF89C9B8A6A6",
+ "name": "Pardubice",
+ "description": "Pardubice",
+ "url": "https://k7.inovatika.dev/uuid/uuid:48f8709e-3921-11ef-a7a7-001b63bd97ba?bb=509,172,3050,2283"
+ }
+ ],
+ "modified": "2024-09-12T08:33:37.606",
+ "pid": "uuid:bcc986fc-7ec8-47eb-b585-121e48f7bd02",
+ "descriptions": {
+ "cze": "Krakty popis sbirky"
+ },
+ "items": [
+ "uuid:31121290-d52e-4206-8723-56cd1fa200c7",
+ "uuid:b35833b3-7f7f-4cac-a434-484b6e096922"
+ ]
+ }
+ '400':
+ description: Chybný pid sbírky
+
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ /collections/{colpid}/items/{itempid}:
+ delete:
+ tags:
+ - Administrace sbírek
+
+
+ summary: Smazání položky ze sbírky
+ description: |
+ Smazání položky ze sbírky
+
+ operationId: deleteItemPid
+ parameters:
+ - in: path
+ name: colpid
+ description: Identifikátor sbírky
+ schema:
+ type: string
+ required: true
+ - in: path
+ name: itempid
+ description: Identifikátor mazaného objektu
+ schema:
+ type: string
+ required: true
+
+ responses:
+ '200':
+ description: Úspěšné odstranění ze sbírky
+
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ /collections/{colpid}/items/delete_batch_items:
+ put:
+ tags:
+ - Administrace sbírek
+
+
+ summary: Smazání položky ze sbírky
+ description: |
+ Smazání položky ze sbírky
+
+ operationId: deleteBatchItems
+ parameters:
+ - in: path
+ name: colpid
+ description: Identifikátor sbírky
+ schema:
+ type: string
+ required: true
+
+ requestBody:
+ description: JSON reprezentace sbírky
+ required: true
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {
+ "pids": [
+ "uuid:31121290-d52e-4206-8723-56cd1fa200c7",
+ "uuid:b35833b3-7f7f-4cac-a434-484b6e096922"
+ ]
+ }
+
+ responses:
+ '200':
+ description: Úspěšné odstranění ze sbírky
+
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ /collections/{colpid}/add_clip_item:
+ post:
+ tags:
+ - Administrace sbírek
+
+ summary: Přidání výstřižků do sbírky
+ description: |
+ Přidání výstřižků do sbírky
+
+ operationId: addClipItem
+ parameters:
+ - in: path
+ name: colpid
+ description: Identifikátor sbírky
+ schema:
+ type: string
+ required: true
+
+ requestBody:
+ description: JSON reprezentace výstřižku
+ required: true
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {"name":"Popis","description":"Popis","url":"https://k7.inovatika.dev/uuid/uuid:488e8b24-3921-11ef-a7a7-001b63bd97ba?bb=2259,2567,903,861"}
+
+ responses:
+ '200':
+ description: Úspěšné přidání výstřižku
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {
+ "thumbnail": "content",
+ "names": {
+ "cze": "RWar"
+ },
+ "keywords": {
+ "cze": [
+ "test",
+ "lest",
+ "pok"
+ ],
+ "eng": [
+ "ahoj",
+ "jest"
+ ]
+ },
+ "contents": {
+ "cze": "
Dlouhy popis sbirky<\\/p>"
+ },
+ "author": "Pavel Stastny",
+ "created": "2024-08-02T19:40:11.243",
+ "standalone": false,
+ "clippingitems": [
+ {
+ "thumb": "IMG_0514EF172485DC7BFD7E975B02B7FC21",
+ "name": "Popis",
+ "description": "Popis",
+ "url": "https://k7.inovatika.dev/uuid/uuid:488e8b24-3921-11ef-a7a7-001b63bd97ba?bb=2259,2567,903,861"
+ }
+
+ ],
+ "modified": "2024-09-12T08:33:37.606",
+ "pid": "uuid:bcc986fc-7ec8-47eb-b585-121e48f7bd02",
+ "descriptions": {
+ "cze": "Krakty popis sbirky"
+ },
+ "items": [
+ "uuid:31121290-d52e-4206-8723-56cd1fa200c7",
+ "uuid:b35833b3-7f7f-4cac-a434-484b6e096922"
+ ]
+ }
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ /collections/{colpid}/delete_clip_item:
+ post:
+ tags:
+ - Administrace sbírek
+ summary: Odebrání výstřižků ze sbírky
+ description: |
+ Odebrání výstřižků ze sbírky
+
+ operationId: deleteClipItem
+ parameters:
+ - in: path
+ name: colpid
+ description: Identifikátor sbírky
+ schema:
+ type: string
+ required: true
+
+ requestBody:
+ description: JSON reprezentace výstřižku
+ required: true
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {"name":"Popis","description":"Popis","url":"https://k7.inovatika.dev/uuid/uuid:488e8b24-3921-11ef-a7a7-001b63bd97ba?bb=2259,2567,903,861"}
+
+ responses:
+ '200':
+ description: Úspěšné přidání výstřižku
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {
+ "thumbnail": "content",
+ "names": {
+ "cze": "RWar"
+ },
+ "keywords": {
+ "cze": [
+ "test",
+ "lest",
+ "pok"
+ ],
+ "eng": [
+ "ahoj",
+ "jest"
+ ]
+ },
+ "contents": {
+ "cze": "
Dlouhy popis sbirky<\\/p>"
+ },
+ "author": "Pavel Stastny",
+ "created": "2024-08-02T19:40:11.243",
+ "standalone": false,
+ "clippingitems": [
+
+ ],
+ "modified": "2024-09-12T08:33:37.606",
+ "pid": "uuid:bcc986fc-7ec8-47eb-b585-121e48f7bd02",
+ "descriptions": {
+ "cze": "Krakty popis sbirky"
+ },
+ "items": [
+ "uuid:31121290-d52e-4206-8723-56cd1fa200c7",
+ "uuid:b35833b3-7f7f-4cac-a434-484b6e096922"
+ ]
+ }
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ /collections/{colpid}/delete_batch_clipitems:
+ put:
+ tags:
+ - Administrace sbírek
+ summary: Dávkové odebrání výstřižků ze sbírky
+ description: |
+ Dávkové odebrání výstřižků ze sbírky
+
+
+ operationId: deleteClipBatchItems
+ parameters:
+ - in: path
+ name: colpid
+ description: Identifikátor sbírky
+ schema:
+ type: string
+ required: true
+
+ requestBody:
+ description: JSON reprezentace výstřižku
+ required: true
+ content:
+ application/json:
+ schema:
+ type: string
+ example: { "clippingitems": [
+ {
+ "thumb": "IMG_0514EF172485DC7BFD7E975B02B7FC21",
+ "name": "Popis",
+ "description": "Popis",
+ "url": "https://k7.inovatika.dev/uuid/uuid:488e8b24-3921-11ef-a7a7-001b63bd97ba?bb=2259,2567,903,861"
+ }
+ ]}
+ responses:
+ '200':
+ description: Úspěšné přidání výstřižku
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {
+ "thumbnail": "content",
+ "names": {
+ "cze": "RWar"
+ },
+ "keywords": {
+ "cze": [
+ "test",
+ "lest",
+ "pok"
+ ],
+ "eng": [
+ "ahoj",
+ "jest"
+ ]
+ },
+ "contents": {
+ "cze": "
Dlouhy popis sbirky<\\/p>"
+ },
+ "author": "Pavel Stastny",
+ "created": "2024-08-02T19:40:11.243",
+ "standalone": false,
+ "clippingitems": [
+
+ ],
+ "modified": "2024-09-12T08:33:37.606",
+ "pid": "uuid:bcc986fc-7ec8-47eb-b585-121e48f7bd02",
+ "descriptions": {
+ "cze": "Krakty popis sbirky"
+ },
+ "items": [
+ "uuid:31121290-d52e-4206-8723-56cd1fa200c7",
+ "uuid:b35833b3-7f7f-4cac-a434-484b6e096922"
+ ]
+ }
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ /files/output-data-dir-for_collectionsbackup/{path}:
+ get:
+ tags:
+ - Přístup do importních a exportních dat
+ summary: Přístup do složky pro zálohy sbírek
+ description: |
+ Přístup do složky pro zálohy sbírek
+
+ operationId: getCollectionsBackups
+
+ parameters:
+ - name: path
+ in: path
+ description: Cesta ke specifickému souboru nebo adresáři ve složce pro backup sbírek
+ required: true
+ schema:
+ type: string
+ - name: generatedownloads
+ in: query
+ description: Zda má rovněž generovat download link
+ required: false
+ schema:
+ type: boolean
+
+ responses:
+ '200':
+ description: Úspěšné získání seznamu
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {
+ "rootDir": "/root/.kramerius4/import/",
+ "files": [
+ {
+ "lastModifiedTime": 1719867550113,
+ "lastAccessTime": 1719926700235,
+ "name": "d28b2a1a-508e-419e-9d3b-12ed4560138e",
+ "isDir": true
+ },
+ {
+ "lastModifiedTime": 1719867551097,
+ "lastAccessTime": 1719867578945,
+ "name": "k4_1c8fc53b-9c82-4bc7-8e1f-038d92749b1f",
+ "isDir": true
+ },
+ {
+ "lastModifiedTime": 1719867549701,
+ "lastAccessTime": 1719867578945,
+ "name": "k4_77970356-2bf4-430a-92cf-6a9a58ae58b6",
+ "isDir": true
+ },
+ {
+ "lastModifiedTime": 1719867551093,
+ "lastAccessTime": 1719867578945,
+ "name": "k4_dd5c6f25-b415-40ee-97b6-71653a8618e6",
+ "isDir": true
+ },
+ {
+ "lastModifiedTime": 1721135638301,
+ "lastAccessTime": 1725355798501,
+ "name": "proarc-export",
+ "isDir": true
+ },
+ {
+ "lastModifiedTime": 1719867549801,
+ "lastAccessTime": 1719867578945,
+ "name": "testLs",
+ "isDir": true
+ }
+ ]
+ }
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ /files/output-data-dir-for_nkplogs/{path}:
+ get:
+ tags:
+ - Přístup do importních a exportních dat
+ summary: Přístup do složky pro export nkp logů
+ description: |
+ Přístup do složky pro export nkp logů
+
+ operationId: getNKPLogs
+
+ parameters:
+ - name: path
+ in: path
+ description: Cesta ke specifickému souboru nebo adresáři ve složce pro export nkp logů
+ required: true
+ schema:
+ type: string
+ - name: generatedownloads
+ in: query
+ description: Zda má rovněž generovat download link
+ required: false
+ schema:
+ type: boolean
+
+ responses:
+ '200':
+ description: Úspěšné získání seznamu
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {
+ "rootDir": "/root/.kramerius4/statistics/",
+ "files": [
+ {
+ "lastModifiedTime": 1728549184165,
+ "lastAccessTime": 1728549373130,
+ "name": "statistics-2024.09.10-2024.10.11.zip",
+ "isDir": false
+ }
+ ]
+ }
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ /files/input-data-dir-for_import-foxml/{path}:
+ get:
+ tags:
+ - Přístup do importních a exportních dat
+ summary: Přístup do složky pro import foxml souborů
+ description: |
+ Přístup do složky pro import foxml souborů
+
+ operationId: getImportFOXML
+
+ parameters:
+ - name: path
+ in: path
+ description: Cesta ke specifickému souboru nebo adresáři ve složce pro export nkp logů
+ required: true
+ schema:
+ type: string
+
+ responses:
+ '200':
+ description: Úspěšné získání seznamu
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {
+ "rootDir": "/root/.kramerius4/import/",
+ "files": [
+ {
+ "lastModifiedTime": 1719867550113,
+ "lastAccessTime": 1719926700235,
+ "name": "d28b2a1a-508e-419e-9d3b-12ed4560138e",
+ "isDir": true
+ },
+ {
+ "lastModifiedTime": 1719867551097,
+ "lastAccessTime": 1719867578945,
+ "name": "k4_1c8fc53b-9c82-4bc7-8e1f-038d92749b1f",
+ "isDir": true
+ },
+ {
+ "lastModifiedTime": 1719867549701,
+ "lastAccessTime": 1719867578945,
+ "name": "k4_77970356-2bf4-430a-92cf-6a9a58ae58b6",
+ "isDir": true
+ },
+ {
+ "lastModifiedTime": 1719867551093,
+ "lastAccessTime": 1719867578945,
+ "name": "k4_dd5c6f25-b415-40ee-97b6-71653a8618e6",
+ "isDir": true
+ },
+ {
+ "lastModifiedTime": 1721135638301,
+ "lastAccessTime": 1725355798501,
+ "name": "proarc-export",
+ "isDir": true
+ },
+ {
+ "lastModifiedTime": 1719867549801,
+ "lastAccessTime": 1719867578945,
+ "name": "testLs",
+ "isDir": true
+ }
+ ]
+ }
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ /files/input-data-dir-for_convert-and-import-ndk/{path}:
+ get:
+ tags:
+ - Přístup do importních a exportních dat
+ summary: Přístup do složky pro import NDK balíčků
+ description: |
+ Přístup do složky pro import NDK balíčků
+
+ operationId: getImportNDK
+
+ parameters:
+ - name: path
+ in: path
+ description: Cesta ke specifickému souboru nebo adresáři ve složce pro import
+ required: true
+ schema:
+ type: string
+
+ responses:
+ '200':
+ description: Úspěšné získání seznamu
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {
+ "rootDir": "/root/.kramerius4/import/",
+ "files": [
+ {
+ "lastModifiedTime": 1719867550113,
+ "lastAccessTime": 1719926700235,
+ "name": "d28b2a1a-508e-419e-9d3b-12ed4560138e",
+ "isDir": true
+ },
+ {
+ "lastModifiedTime": 1719867551097,
+ "lastAccessTime": 1719867578945,
+ "name": "k4_1c8fc53b-9c82-4bc7-8e1f-038d92749b1f",
+ "isDir": true
+ },
+ {
+ "lastModifiedTime": 1719867549701,
+ "lastAccessTime": 1719867578945,
+ "name": "k4_77970356-2bf4-430a-92cf-6a9a58ae58b6",
+ "isDir": true
+ },
+ {
+ "lastModifiedTime": 1719867551093,
+ "lastAccessTime": 1719867578945,
+ "name": "k4_dd5c6f25-b415-40ee-97b6-71653a8618e6",
+ "isDir": true
+ },
+ {
+ "lastModifiedTime": 1721135638301,
+ "lastAccessTime": 1725355798501,
+ "name": "proarc-export",
+ "isDir": true
+ },
+ {
+ "lastModifiedTime": 1719867549801,
+ "lastAccessTime": 1719867578945,
+ "name": "testLs",
+ "isDir": true
+ }
+ ]
+ }
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ /files/pidlist-dir/{path}:
+ get:
+ tags:
+ - Přístup do importních a exportních dat
+ summary: Přístup do spožky pro seznam pidů
+ description: |
+ Přístup do spožky pro seznam pidů
+
+ operationId: getPidList
+
+ parameters:
+ - name: path
+ in: path
+ description: Cesta ke specifickému souboru nebo adresáři ve složce pro import
+ required: true
+ schema:
+ type: string
+
+ responses:
+ '200':
+ description: Úspěšné získání seznamu
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ /files/download-path/{path}:
+ get:
+ tags:
+ - Přístup do importních a exportních dat
+
+ summary: Přístup pro download linky
+ description: |
+ Přístup pro downlink
+
+ operationId: getDownload
+
+ parameters:
+ - name: path
+ in: path
+ description: Cesta k souboru pro který byl vygenerovaný download link
+ required: true
+ schema:
+ type: string
+
+ responses:
+ '200':
+ description: Úspěšné získání souboru
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ /statistics:
+
+ delete:
+ tags:
+ - Statistiky
+ summary: Smazání statistických záznamů
+ description: |
+ Smazání statistických záznamů
+
+ operationId: deleteLogs
+
+ parameters:
+ - name: dateFrom
+ in: query
+ required: true
+ description: Počáteční datum pro čištění statistických dat
+ schema:
+ type: string
+ format: date
+ - name: dateTo
+ in: query
+ required: true
+ description: Konečné datum pro čištění statistických dat
+ schema:
+ type: string
+ format: date
+ responses:
+ '200':
+ description: Úspěšné smazání dat
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {
+ "deleted":103
+ }
+ '400':
+ description: Chybný požadavek
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ /statistics/facets/csv/{type}:
+ get:
+ tags:
+ - Statistiky
+ summary: Generovani csv pro facet langs / agregace dle jazyku
+ description: |
+ Generovani csv pro facet langs / agregace dle jazyku
+ parameters:
+ - name: type
+ in: path
+ description: Typ csv souboru
+ schema:
+ type: string
+ enum: [provided_by_license, authors, langs, all_models]
+ example: '*'
+ required: true
+
+ - name: q
+ in: query
+ description: Solr query parameter
+ schema:
+ type: string
+ example: '*'
+
+ - name: rows
+ in: query
+ description: Počet řádků v odpovědi solru
+ schema:
+ type: integer
+ example: 0
+
+ - name: facet
+ in: query
+ description: Povolení neb
+ schema:
+ type: boolean
+ example: true
+
+ - name: facet.mincount
+ in: query
+ description: Minimum count of facet values to be included
+ schema:
+ type: integer
+ example: 1
+
+ - name: facet.field
+ in: query
+ description: The facet fields to be included
+ schema:
+ type: string
+ enum: [provided_by_license, authors, langs, all_models]
+
+
+ - name: fq
+ in: query
+ description: Filtr query, ktere limituje vysledek
+ schema:
+ type: string
+ example: date:[2024-09-09T22:00:00.000Z TO 2024-10-10T22:00:00.000Z]
+
+ - name: fmt_headers
+ in: query
+ description: Hlavičky pro CSV soubor
+ schema:
+ type: array
+ items:
+ type: string
+ example: [Count, Lang]
+
+ - name: fmt_firstlinecomment
+ in: query
+ description: První řádek jako komentář do generovaného csv
+ schema:
+ type: string
+ example: Lang csv
+
+ - name: fmt_filename
+ in: query
+ description: Jméno generováného souboru
+ schema:
+ type: string
+ example: langs.csv
+
+ responses:
+ '200':
+ description: Soubor vygenerován
+ content:
+ text/csv:
+ schema:
+ type: string
+ format: binary
+ example: |
+ # Lang csv
+ # date:[2024-09-13T22:00:00.000Z,2024-10-14T22:00:00.000Z]
+ Count;Lang
+ 24;cze
+ 4;eng
+ headers:
+ Content-Disposition:
+ description: Jméno generováného souboru
+ schema:
+ type: string
+ example: attachment; filename="langs.csv"
+
+ '400':
+ description: Špatný dotaz
+
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ /statistics/search:
+ get:
+ tags:
+ - Statistiky
+ summary: Vyhledávní v logu přístupů. Používá admin prostředí pro rendrování statistik
+ description: Endpoint umožňuje vyhledávání dle zadaných kritérií a vrací výsledky buď ve formátu JSON nebo XML podle požadovaného parametru. _Parametry jsou uvedené jenom ty základní. Pro úplný přehled všech parametrů jděte sem_
+ parameters:
+
+ - in: query
+ name: q
+ description: Samotný dotaz do solru
+ schema:
+ type: string
+ required: true
+
+ - in: query
+ name: fl
+ description: Seznam polí ve výsledku
+ schema:
+ type: string
+ required: false
+
+ - in: query
+ name: fq
+ description: Filter query
+ schema:
+ type: array
+ items:
+ type: string
+ required: false
+
+ - in: query
+ name: sort
+ description: Pole pro třídění
+ schema:
+ type: string
+ required: false
+
+ - in: query
+ name: start
+ description: Počet dokumentů od kterých se má vracet výsledek
+ schema:
+ type: integer
+ required: false
+
+ - in: query
+ name: rows
+ description: Počet dokumentů v odpovědi
+ schema:
+ type: integer
+ required: false
+
+ - in: query
+ name: facet
+ description: Faseting
+ schema:
+ type: boolean
+ required: false
+
+ - in: query
+ name: facet.field
+ description: Pole pro fasetování
+ schema:
+ type: string
+ required: false
+
+ - in: query
+ name: facet.mincount
+ description: Minimální počet výsledků ve fasetu
+ schema:
+ type: integer
+ required: false
+
+
+ - in: query
+ name: wt
+ schema:
+ type: string
+ enum: ["xml","json"]
+ required: false
+ responses:
+ '200':
+ description: Vrací výsledek dotazu
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {
+ "responseHeader": {
+ "status": 0,
+ "QTime": 2,
+ "params": {
+ "q": "*",
+ "facet.field": [
+ "provided_by_license",
+ "authors",
+ "langs",
+ "all_models"
+ ],
+ "facet.mincount": "1",
+ "fq": "date:[2024-09-13T22:00:00.000Z TO 2024-10-14T22:00:00.000Z]",
+ "rows": "0",
+ "facet": "true",
+ "wt": "json"
+ }
+ },
+ "response": {
+ "numFound": 28,
+ "start": 0,
+ "numFoundExact": true,
+ "docs": []
+ },
+ "facet_counts": {
+ "facet_queries": {
+
+ },
+ "facet_fields": {
+ "provided_by_license": [
+ "public",
+ 17, "onsite",
+ 3],
+ "authors": [
+ "Krajský výbor (Pardubice, Česko)",
+ 24, "Okresní národní výbor",
+ 24, "Jurajda, Štěpán, 1970-",
+ 4, "Kovač, Dejan, 1984-",
+ 4, "Národohospodářský ústav (Akademie věd ČR)",
+ 4, "Univerzita Karlova Centrum pro ekonomický výzkum a doktorské studium",
+ 4, "Zápal, Jan",
+ 4, "jo2017953195",
+ 4, "kn20020321166",
+ 4, "mzk2009517323",
+ 4, "olak2002113688",
+ 4, "xx0003189",
+ 4],
+ "langs": [
+ "cze",
+ 24, "eng",
+ 4],
+ "all_models": [
+ "page",
+ 24, "periodical",
+ 24, "periodicalitem",
+ 24, "periodicalvolume",
+ 24, "monograph",
+ 4]
+ },
+ "facet_ranges": {
+
+ },
+ "facet_intervals": {
+
+ },
+ "facet_heatmaps": {
+
+ }
+ }
+ }
+
+ application/xml:
+ schema:
+ type: string
+ example: |
+ 0 4 * provided_by_license authors langs all_models 1 date:[2024-09-13T22:00:00.000Z TO 2024-10-14T22:00:00.000Z] 0 true xml xml 17 3 24 24 4 4 4 4 4 4 4 4 4 4 24 4 24 24 24 24 4
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ /statistics/logs:
+ get:
+ tags:
+ - Statistiky
+ summary: Přístup do logů jádra dle zadaného rozsahu. Určeno pro statistické moduly
+ description: Vrací logy dle zadaných kritérií. Maximální rozsah je 120 hodin
+ parameters:
+ - name: dateFrom
+ in: query
+ required: true
+ description: Počáteční datum "YYYY-MM-DD".
+ schema:
+ type: string
+ format: date-time
+ example: 2024-10-14T00:00:00Z
+ - name: dateTo
+ in: query
+ required: true
+ description: Koncové datum "YYYY-MM-DD".
+ schema:
+ type: string
+ format: date-time
+ example: 2024-10-14T00:00:00Z
+ - name: rows
+ in: query
+ required: false
+ description: Počet vrácených řádků
+ schema:
+ type: string
+ default: "10"
+ - name: start
+ in: query
+ required: false
+ description: Počáteční bod stránkování
+ schema:
+ type: string
+ default: "0"
+ responses:
+ '200':
+ description: Vrácené logy dle zadaných kritériíí
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {
+ "response": {
+ "docs": [
+ {
+ "date": "2024-10-13T17:53:31.080Z",
+ "pids_page": [
+ "uuid:4aa843db-3921-11ef-a7a7-001b63bd97ba"
+ ],
+ "pids_periodicalitem": [
+ "uuid:ad11c4fb-91d5-4d92-854e-e026df09ed8b"
+ ],
+ "provided_by_license": "public",
+ "date_range_start.year": 1952,
+ "pid": "uuid:4aa843db-3921-11ef-a7a7-001b63bd97ba",
+ "all_pids": [
+ "uuid:06011240-a943-4efe-9f89-6707453b5f3d",
+ "uuid:d0134941-11e8-43a1-ac7f-c2bfc74fa663",
+ "uuid:ad11c4fb-91d5-4d92-854e-e026df09ed8b",
+ "uuid:4aa843db-3921-11ef-a7a7-001b63bd97ba"
+ ],
+ "issue_dates": [
+ "02.05.1952",
+ "1952",
+ "[1945]-1992"
+ ],
+ "session_token": "3BDD4142C7AF7A1097B6682F7DE85B9B",
+ "pid_paths": [
+ "uuid:06011240-a943-4efe-9f89-6707453b5f3d/uuid:d0134941-11e8-43a1-ac7f-c2bfc74fa663/uuid:ad11c4fb-91d5-4d92-854e-e026df09ed8b/uuid:4aa843db-3921-11ef-a7a7-001b63bd97ba"
+ ],
+ "pids_periodicalvolume": [
+ "uuid:d0134941-11e8-43a1-ac7f-c2bfc74fa663"
+ ],
+ "publishers": [
+ "KV KSČ",
+ "ONV",
+ "Polabí"
+ ],
+ "langs": [
+ "cze"
+ ],
+ "id": "c3ecfcae-d3a8-45aa-b067-39f80381653f",
+ "licences": [
+ "public",
+ "onsite"
+ ],
+ "pids_periodical": [
+ "uuid:06011240-a943-4efe-9f89-6707453b5f3d"
+ ],
+ "reported_action": "READ",
+ "evaluated_map": "{\"providedByLabel\":\"public\",\"providedByLicense\":\"public\"}",
+ "all_models": [
+ "periodical",
+ "periodicalvolume",
+ "periodicalitem",
+ "page"
+ ],
+ "own_model_path": "periodical/periodicalvolume/periodicalitem/page",
+ "requested_url": "http://k7.inovatika.dev/search/iiif/uuid:4aa843db-3921-11ef-a7a7-001b63bd97ba/info.json",
+ "hrh_referer": "https://k7.inovatika.dev/view/uuid:ad11c4fb-91d5-4d92-854e-e026df09ed8b?page=uuid:4aa843db-3921-11ef-a7a7-001b63bd97ba",
+ "ip_address": "HMEU8cx48zMXS6jFG55oqA==",
+ "titles": [
+ "1",
+ "Zář"
+ ],
+ "db_version": "7.0.4",
+ "date_range_end.year": 1952,
+ "licenses": [
+ "public",
+ "onsite"
+ ],
+ "_version_": 1812822240612319200,
+ "date.str": "02.05.1952",
+ "root_title": "Zář: list KSČ pardubického kraje",
+ "user": "not_logged",
+ "own_pid_path": "uuid:06011240-a943-4efe-9f89-6707453b5f3d/uuid:d0134941-11e8-43a1-ac7f-c2bfc74fa663/uuid:ad11c4fb-91d5-4d92-854e-e026df09ed8b/uuid:4aa843db-3921-11ef-a7a7-001b63bd97ba",
+ "authors": [
+ "Krajský výbor (Pardubice, Česko)",
+ "Okresní národní výbor"
+ ]
+ }
+ ],
+ "numFound": 3,
+ "start": 0,
+ "numFoundExact": true
+ },
+ "responseHeader": {
+ "QTime": 21,
+ "params": {
+ "q": "*",
+ "start": "0",
+ "fq": "date:[2024-10-13T00:00:00Z TO 2024-10-14T00:00:00Z]",
+ "rows": "10",
+ "wt": "json"
+ },
+ "status": 0
+ }
+ }
+
+ '400':
+ description: Špatně formátovaný parameter dateFrom a/nebo dateTo.
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ /statistics/anual/csv:
+ get:
+ tags:
+ - Statistiky
+ summary: Generovani ročního výkazu
+ description: Vrací csv pro roční výkaz
+ parameters:
+ - name: year
+ in: query
+ required: true
+ description: Rok pro který se má výkaz generovat
+ schema:
+ type: string
+ - name: fmt_filename
+ in: query
+ required: false
+ schema:
+ type: string
+ responses:
+ '200':
+ description: Vrací vygenerovaný CSV soubor
+ content:
+ text/csv:
+ schema:
+ type: string
+ format: binary
+ example: |
+ # Sample CSV content
+ "100","monograph"
+ "50","periodicalvolume"
+ '400':
+ description: Nevalidní parametr
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ /items:
+ get:
+ tags:
+ - Titul
+ summary: Získání položek dle modelu.
+ description: Vrací seznam titulů z úložiště dle modelu, offsetu, kurzoru a limitu. Vyžaduje oprávnění pro čtení.
+ parameters:
+ - name: model
+ in: query
+ required: true
+ description: Model položky, pro kterou se mají vrátit položky.
+ schema:
+ type: string
+ - name: offset
+ in: query
+ required: false
+ description: Počet položek, které se mají přeskočit.
+ schema:
+ type: integer
+ default: 0
+ - name: cursor
+ in: query
+ required: false
+ description: Kurzor pro stránkování výsledků.
+ schema:
+ type: string
+ - name: limit
+ in: query
+ required: false
+ description: Maximální počet vrácených položek.
+ schema:
+ type: integer
+ default: 10
+ - name: order
+ in: query
+ required: false
+ description: Určuje pořadí výsledků, možné hodnoty jsou 'ASC' nebo 'DESC'.
+ schema:
+ type: string
+ enum: [ASC, DESC]
+ default: ASC
+ responses:
+ '200':
+ description: Úspěšně vrací seznam položek jako řetězec.
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {
+ "model": "monograph",
+ "items": [
+ {
+ "pid": "uuid:33244df3-e448-4a2c-b69f-3a0fb96fc8c7",
+ "title": "Marná sláva: profesorské romanetto"
+ },
+ {
+ "pid": "uuid:9cd864d5-981a-42bb-badc-2d8160488ac2",
+ "title": "What's in a name in a war"
+ }
+ ]
+ }
+
+ '400':
+ description: Chybný požadavek - chybí nebo je neplatný parametr.
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {
+ "message": "missing mandatory query param 'model'"
+ }
+
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ /items/models:
+ get:
+ tags:
+ - Titul
+ summary: Získání seznamu modelů z úložiště.
+ description: Vrací seznam všech modelů z Fedora úložiště. Pouze oprávnění uživatelé mohou volat tento endpoint.
+ responses:
+ '200':
+ description: Úspěšně vrací seznam modelů jako string.
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {
+ "model:periodical": 1,
+ "model:monograph": 2,
+ "model:collection": 3,
+ "model:periodicalitem": 90,
+ "model:page": 850,
+ "model:periodicalvolume": 2
+ }
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ /items/{pid}/foxml:
+ get:
+ tags:
+ - Titul
+ summary: Získání FOXML dokumentu.
+ description: Vrací FOXML dokument pro zadané PID. Uživatel musí mít oprávnění k přečtení nebo úpravě objektu.
+ parameters:
+ - name: pid
+ in: path
+ required: true
+ description: PID objektu, pro který se má získat FOXML dokument.
+ schema:
+ type: string
+ responses:
+ '200':
+ description: Úspěšně vrací FOXML dokument.
+ content:
+ application/xml:
+ schema:
+ type: string
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ '404':
+ description: Objekt s daným PID nebyl nalezen.
+
+ /items/{pid}/children_order:
+ put:
+ tags:
+ - Titul
+ summary: Nastavení pořadí dětí pro daný objekt.
+ description: Umožňuje nastavit nové pořadí dětí pro objekt podle PID. Uživatel musí mít oprávnění k přečtení objektu.
+ parameters:
+ - name: pid
+ in: path
+ required: true
+ description: PID objektu, pro který se nastavuje pořadí dětí.
+ schema:
+ type: string
+ requestBody:
+ required: true
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {"childrenPids":["uuid:b35833b3-7f7f-4cac-a434-484b6e096922","uuid:31121290-d52e-4206-8723-56cd1fa200c7"]}
+ responses:
+ '200':
+ description: Úspěšně nastaveno nové pořadí dětí.
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {"childrenPids":["uuid:b35833b3-7f7f-4cac-a434-484b6e096922","uuid:31121290-d52e-4206-8723-56cd1fa200c7"]}
+
+
+ '400':
+ description: Chyba při zpracování - některé PID dětí nejsou nalezeny v RELS-EXT nebo chybí v požadovaných datech.
+ content:
+ application/json:
+ schema:
+ type: string
+ example: { "message": "'badpid' is not in supported PID format for this operation"
+ }
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+ '404':
+ description: Objekt s daným PID nebyl nalezen.
+
+ /items/{pid}:
+ delete:
+ tags:
+ - Titul
+ summary: Odstranění objektu podle PID.
+ description: Umožňuje odstranit objekt určený jeho PID. Uživatel musí mít oprávnění k přečtení objektu.
+ parameters:
+ - name: pid
+ in: path
+ required: true
+ description: PID objektu, který má být odstraněn.
+ schema:
+ type: string
+ responses:
+ '200':
+ description: Objekt byl úspěšně odstraněn.
+ content:
+ application/json:
+ schema:
+ type: string
+ '400':
+ description: Chyba při zpracování - některé PID dětí nejsou nalezeny v RELS-EXT nebo chybí v požadovaných datech.
+ content:
+ application/json:
+ schema:
+ type: string
+ example: { "message": "'badpid' is not in supported PID format for this operation"
+ }
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+ '404':
+ description: Objekt s daným PID nebyl nalezen.
+
+ /licenses:
+ get:
+ tags:
+ - Licence
+ summary: Vrací všechny licence
+ operationId: getAllLicenses
+ description: Vrací všechny licence
+ responses:
+ '200':
+ description: JSON reprezentace licencí
+ content:
+ application/json:
+ schema:
+ type: string
+ example: [{
+ "name": "dnntt",
+ "description": "DNNT terminal license",
+ "id": 1,
+ "priority": 1,
+ "group": "embedded"
+ },
+ {
+ "name": "dnnto",
+ "description": "DNNT online license",
+ "id": 2,
+ "priority": 2,
+ "group": "embedded"
+ }]
+
+ /licenses/global:
+ get:
+ tags:
+ - Licence
+ summary: Vrací všechny globální licence
+ operationId: getGlobalLicenses
+ description: Vrací globální licence
+ responses:
+ '200':
+ description: JSON reprezentace licencí
+ content:
+ application/json:
+ schema:
+ type: string
+ example: [{
+ "name": "dnntt",
+ "description": "DNNT terminal license",
+ "id": 1,
+ "priority": 1,
+ "group": "embedded"
+ },
+ {
+ "name": "dnnto",
+ "description": "DNNT online license",
+ "id": 2,
+ "priority": 2,
+ "group": "embedded"
+ }]
+
+ /licenses/local:
+ get:
+ tags:
+ - Licence
+ summary: Vrací všechny lokální licence
+ operationId: getLocalLicenses
+ description: Vrací lokální licence
+ responses:
+ '200':
+ description: JSON reprezentace licencí
+ content:
+ application/json:
+ schema:
+ type: string
+ example: [{
+ "name": "inovatika_licence_zamek",
+ "description": "Zamek s licenci",
+ "exclusive": true,
+ "maxreaders": 1,
+ "id": 8,
+ "refreshinterval": 20,
+ "priority": 8,
+ "type": "RULE",
+ "maxinterval": 10000,
+ "group": "local"
+ }]
+
+ post:
+ tags:
+ - Licence
+ summary: Vytváří novou lokální licenci
+ operationId: createLocalLicense
+ description: Vytváří novou lokální licenci
+ requestBody:
+ required: true
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {
+ "name": "inovatika_test",
+ "description": "test",
+ "priority": 9,
+ "group": "local"
+ }
+ responses:
+ '200':
+ description: JSON reprezentace vytvořemé licence
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {
+ "name": "inovatika_test",
+ "description": "test",
+ "id": 9,
+ "priority": 9,
+ "group": "local"
+ }
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ /licenses/local/{id}:
+ get:
+ tags:
+ - Licence
+ summary: Vrací lokální licence dle podaného id
+ operationId: getLicenseById
+ description: Získá lokálni licenci dle id
+ parameters:
+ - name: id
+ in: path
+ required: true
+ description: Id licence
+ schema:
+ type: string
+ pattern: '^[0-9]+$'
+ responses:
+ '200':
+ description: JSON reprezentace licence
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {
+ "name": "inovatika_licence_zamek",
+ "description": "Zamek s licenci",
+ "exclusive": true,
+ "maxreaders": 1,
+ "id": 8,
+ "refreshinterval": 20,
+ "priority": 8,
+ "type": "RULE",
+ "maxinterval": 10000,
+ "group": "local"}
+
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+ '404':
+ description: Licence nenalezena.
+
+ put:
+ tags:
+ - Licence
+ summary: Modifikuje lokální licenci
+ operationId: updateLocalLicense
+ description: Modifikuje lokální licenci
+ parameters:
+ - name: id
+ in: path
+ required: true
+ description: Id licence
+ schema:
+ type: string
+ pattern: '^[0-9]+$'
+
+ requestBody:
+ required: true
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {
+ "name": "inovatika_test",
+ "description": "test",
+ "id": 9,
+ "priority": 9,
+ "group": "local"
+ }
+ responses:
+ '200':
+ description: JSON reprezentace licencí
+ content:
+ application/json:
+ schema:
+ type: string
+
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ '404':
+ description: Licence nenalezena.
+
+ delete:
+ tags:
+ - Licence
+ summary: Maže lokální licenci
+ operationId: deleteLocalLicense
+ description: Maže lokální licenci
+ parameters:
+ - name: id
+ in: path
+ required: true
+ description: Id licence
+ schema:
+ type: string
+ pattern: '^[0-9]+$'
+ responses:
+ '204':
+ description: Licence úspěšně smazána
+
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+
+ /licenses/changeOrdering:
+ put:
+ tags:
+ - Licence
+ summary: Modifikuje pořadí licencí
+ operationId: updateOrdering
+ description: Modifikuje pořadí licencí
+
+ requestBody:
+ required: true
+ content:
+ application/json:
+ schema:
+ type: string
+ example: [{
+ "name": "dnntt",
+ "description": "DNNT terminal license",
+ "id": 1,
+ "priority": 1,
+ "group": "embedded"
+ },
+ {
+ "name": "dnnto",
+ "description": "DNNT online license",
+ "id": 2,
+ "priority": 2,
+ "group": "embedded"
+ }]
+ responses:
+ '200':
+ description: JSON reprezentace licencí
+ content:
+ application/json:
+ schema:
+ type: string
+ example: [{
+ "name": "dnntt",
+ "description": "DNNT terminal license",
+ "id": 1,
+ "priority": 1,
+ "group": "embedded"
+ },
+ {
+ "name": "dnnto",
+ "description": "DNNT online license",
+ "id": 2,
+ "priority": 2,
+ "group": "embedded"
+ }]
+
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ /licenses/moveup/{id}:
+ put:
+ tags:
+ - Licence
+ summary: Zvětší prioritu licence
+ operationId: moveUpLicense
+ description: Zvětší prioritu licence
+ parameters:
+ - name: id
+ in: path
+ required: true
+ description: Id licence
+ schema:
+ type: string
+ pattern: '^[0-9]+$'
+
+ responses:
+ '200':
+ description: JSON reprezentace licencí
+ content:
+ application/json:
+ schema:
+ type: string
+ example: [{
+ "name": "dnntt",
+ "description": "DNNT terminal license",
+ "id": 1,
+ "priority": 1,
+ "group": "embedded"
+ },
+ {
+ "name": "dnnto",
+ "description": "DNNT online license",
+ "id": 2,
+ "priority": 2,
+ "group": "embedded"
+ }]
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ /licenses/movedown/{id}:
+ put:
+ tags:
+ - Licence
+ summary: Zmenší prioritu licence
+ operationId: moveDownLicense
+ description: Zmenší prioritu licence
+ parameters:
+ - name: id
+ in: path
+ required: true
+ description: Id licence
+ schema:
+ type: string
+ pattern: '^[0-9]+$'
+
+ responses:
+ '200':
+ description: JSON reprezentace licencí
+ content:
+ application/json:
+ schema:
+ type: string
+ example: [{
+ "name": "dnntt",
+ "description": "DNNT terminal license",
+ "id": 1,
+ "priority": 1,
+ "group": "embedded"
+ },
+ {
+ "name": "dnnto",
+ "description": "DNNT online license",
+ "id": 2,
+ "priority": 2,
+ "group": "embedded"
+ }]
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ /roles:
+ get:
+ tags:
+ - Role
+ summary: Získat filtrované role
+ operationId: getRoles
+ description: Načte seznam rolí na základě poskytnutých dotazovacích parametrů.
+ parameters:
+ - name: name
+ in: query
+ description: Filtrovat role podle názvu.
+ required: false
+ schema:
+ type: string
+ - name: offset
+ in: query
+ description: Posun pro stránkování (výchozí hodnota je 0).
+ required: false
+ schema:
+ type: string
+ example: '0'
+ - name: resultSize
+ in: query
+ description: Počet výsledků k vrácení (výchozí hodnota je 20).
+ required: false
+ schema:
+ type: string
+ example: '20'
+ - name: ordering
+ in: query
+ description: Pole, podle kterého se výsledky seřadí.
+ required: false
+ schema:
+ type: string
+ - name: typefordering
+ in: query
+ description: Typ řazení (ASC nebo DESC).
+ required: false
+ schema:
+ type: string
+ default: ASC
+ responses:
+ '200':
+ description: JSON pole s rolemi na základě filtračních kritérií.
+ content:
+ application/json:
+ schema:
+ type: string
+ example: [{"name": "common_users","id": 1},{"name": "kramerius_admin","id": 2},{"name": "offline_access","id": 3}]
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ post:
+ tags:
+ - Role
+ summary: Vytvoření nové role
+ operationId: createRole
+ description: Vytvoří novou roli na základě poskytnutých dat v JSON. Pokud role s daným názvem již existuje, akce bude odmítnuta.
+ requestBody:
+ description: JSON obsahující data nové role (mimo ID, které přidává server).
+ required: true
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {"name":"new_role"}
+ responses:
+ '201':
+ description: Role byla úspěšně vytvořena.
+ headers:
+ Location:
+ description: URI nové role
+ schema:
+ type: string
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {"name":"moje_role","id":11}
+ '400':
+ description: Chyba při vytváření role (např. role již existuje).
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ /roles/{id}:
+ put:
+ tags:
+ - Role
+ summary: Změna existující role
+ operationId: changeRole
+ description: Upraví existující roli na základě ID a poskytnutých dat v JSON.
+ parameters:
+ - name: id
+ in: path
+ required: true
+ description: ID role, kterou chcete změnit.
+ schema:
+ type: string
+ example: '1'
+ requestBody:
+ description: JSON obsahující nová data pro roli.
+ required: true
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {"name":"moje_role","id":11}
+ responses:
+ '200':
+ description: Role byla úspěšně změněna.
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {"name":"moje_role","id":11}
+ '400':
+ description: Chyba při změně role (např. role s daným ID nebyla nalezena nebo název role již existuje).
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ get:
+ tags:
+ - Role
+
+ summary: Získání detailů role podle ID
+ operationId: getRole
+ description: Vrací informace o roli na základě zadaného ID. Pokud role neexistuje, vrátí chybu.
+ parameters:
+ - name: id
+ in: path
+ required: true
+ description: ID role, kterou chcete získat.
+ schema:
+ type: string
+ example: '1'
+ responses:
+ '200':
+ description: Úspěšný dotaz, role byla nalezena.
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {"name": "kramerius_admin","id": 2}
+ '404':
+ description: Role nebyla nalezena.
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ delete:
+ tags:
+ - Role
+
+ summary: Smazání role podle ID
+ operationId: deleteRole
+ description: Smaže roli na základě jejího ID. Pokud role neexistuje, nebo nastane problém při mazání, vrátí chybu.
+ parameters:
+ - name: id
+ in: path
+ required: true
+ description: ID role, kterou chcete získat.
+ schema:
+ type: string
+ example: '1'
+ responses:
+ '204':
+ description: Role byla úspěšně smazána.
+ '404':
+ description: Role nebyla nalezena.
+ '400':
+ description: Chyba při mazání role (např. pokud ji nelze smazat kvůli asociacím nebo SQL chybě).
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ /rights:
+ get:
+ tags:
+ - Práva
+ summary: Získání práv na základě PID a akce
+ operationId: getRights
+ description: Vrací seznam práv na základě zadaných parametrů `pids` (IDs) a `action` (akce). Pokud uživatel nemá oprávnění, vrátí chybu.
+ parameters:
+ - name: pids
+ in: query
+ required: false
+ description: Čísla PID, oddělená čárkou.
+ schema:
+ type: string
+ - name: action
+ in: query
+ required: false
+ description: Akce, ke které se právo vztahuje
+ schema:
+ type: string
+ responses:
+ '200':
+ description: Seznam nalezených práv.
+ content:
+ application/json:
+ schema:
+ type: string
+ example: [{
+ "role": {
+ "name": "common_users",
+ "id": 1
+ },
+ "criterium": {
+ "license": "public",
+ "qname": "cz.incad.kramerius.security.impl.criteria.Licenses",
+ "label": "public",
+ "params": {
+ "objects": [],
+ "id": 0
+ }
+ },
+ "action": "a_read",
+ "pid": "uuid:1",
+ "id": 48
+ },
+ {
+ "role": {
+ "name": "kramerius_admin",
+ "id": 4
+ },
+ "criterium": {
+ "license": "inovatika_licence_zamek",
+ "qname": "cz.incad.kramerius.security.impl.criteria.Licenses",
+ "label": "inovatika_licence_zamek",
+ "params": {
+ "objects": [],
+ "id": 0
+ }
+ },
+ "action": "a_read",
+ "pid": "uuid:1",
+ "id": 50
+ },
+ {
+ "role": {
+ "name": "kramerius_admin",
+ "id": 4
+ },
+ "action": "a_pdf_read",
+ "pid": "uuid:1",
+ "id": 24
+ },
+ {
+ "role": {
+ "name": "kramerius_admin",
+ "id": 4
+ },
+ "action": "a_import",
+ "pid": "uuid:1",
+ "id": 25
+ },
+ {
+ "role": {
+ "name": "kramerius_admin",
+ "id": 4
+ },
+ "action": "a_delete",
+ "pid": "uuid:1",
+ "id": 26
+ }
+ ]
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+ post:
+ tags:
+ - Práva
+ summary: Vložení nového práva
+ description: Umožňuje vložit nové právo, pokud má uživatel odpovídající oprávnění.
+ requestBody:
+ required: true
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {"action":"a_read","role":{"name":"common_users","id":1},"pid":"uuid:1","criterium":{"qname":"cz.incad.kramerius.security.impl.criteria.LicensesIPFiltered","params":{"description":"Localhosts","objects":["127.*","localhost","0.*"],"id":1},"label":"orphan"}}
+ responses:
+ '201':
+ description: Právo bylo úspěšně vytvořeno
+ content:
+ application/json:
+ example: {
+ "role": {
+ "name": "common_users",
+ "id": -1
+ },
+ "criterium": {
+ "license": "orphan",
+ "qname": "cz.incad.kramerius.security.impl.criteria.LicensesIPFiltered",
+ "label": "orphan",
+ "params": {
+ "objects": [
+ "127.*",
+ "localhost",
+ "0.*"
+ ],
+ "description": "Localhosts",
+ "id": 1
+ }
+ },
+ "action": "a_read",
+ "pid": "uuid:1",
+ "id": 62
+ }
+
+ '400':
+ description: Neplatná data požadavku nebo právo nelze vložit
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ /rights/{id}:
+ get:
+ tags:
+ - Práva
+ summary: Získání práva dle ID
+ description: Vrací konkrétní právo na základě ID. Pokud uživatel nemá oprávnění, nebo pokud právo neexistuje, žádost selže.
+ parameters:
+ - name: id
+ in: path
+ required: true
+ description: ID práva, které chcete získat (musí být číslo).
+ schema:
+ type: integer
+ responses:
+ '200':
+ description: Právo bylo úspěšně získáno
+ content:
+ application/json:
+ schema:
+ type: string
+ description: JSON reprezentace prava
+ example:
+ right: {
+ "role": {
+ "name": "common_users",
+ "id": -1
+ },
+ "criterium": {
+ "license": "orphan",
+ "qname": "cz.incad.kramerius.security.impl.criteria.LicensesIPFiltered",
+ "label": "orphan",
+ "params": {
+ "objects": [
+ "127.*",
+ "localhost",
+ "0.*"
+ ],
+ "description": "Localhosts",
+ "id": 1
+ }
+ },
+ "action": "a_read",
+ "pid": "uuid:1",
+ "id": 62
+ }
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+ '404':
+ description: Právo s daným ID nebylo nalezeno
+
+ put:
+ tags:
+ - Práva
+ summary: Aktualizace existujícího práva podle ID
+ description: Aktualizuje právo na základě poskytnutého ID a JSON dat. Uživatel musí mít oprávnění pro tuto akci.
+ parameters:
+ - name: id
+ in: path
+ required: true
+ description: ID práva, které chcete aktualizovat (musí být číslo).
+ schema:
+ type: integer
+ requestBody:
+ required: true
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {
+ "role": {
+ "name": "moje_role",
+ "id": 11
+ },
+ "criterium": {
+ "license": "orphan",
+ "qname": "cz.incad.kramerius.security.impl.criteria.LicensesIPFiltered",
+ "label": "orphan",
+ "params": {
+ "objects": [
+ "127.*",
+ "localhost",
+ "0.*"
+ ],
+ "description": "Localhosts",
+ "id": 1
+ }
+ },
+ "action": "a_read",
+ "pid": "uuid:1",
+ "id": 62
+ }
+ responses:
+ '200':
+ description: Právo bylo úspěšně aktualizováno
+ content:
+ application/json:
+ example: {
+ "role": {
+ "name": "moje_role",
+ "id": 11
+ },
+ "criterium": {
+ "license": "orphan",
+ "qname": "cz.incad.kramerius.security.impl.criteria.LicensesIPFiltered",
+ "label": "orphan",
+ "params": {
+ "objects": [
+ "127.*",
+ "localhost",
+ "0.*"
+ ],
+ "description": "Localhosts",
+ "id": 1
+ }
+ },
+ "action": "a_read",
+ "pid": "uuid:1",
+ "id": 62
+ }
+ '400':
+ description: Neplatná data požadavku nebo právo nelze aktualizovat
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+ '404':
+ description: Právo s daným ID nebylo nalezeno
+
+ delete:
+ tags:
+ - Práva
+ summary: Smazání práva podle ID
+ description: Smaže existující právo podle jeho ID. Uživatel musí mít oprávnění pro tuto akci.
+ parameters:
+ - name: id
+ in: path
+ required: true
+ description: ID práva, které chcete smazat (musí být číslo).
+ schema:
+ type: integer
+ responses:
+ '200':
+ description: Právo bylo úspěšně smazáno
+ content:
+ application/json:
+ example: {
+ "id": 123,
+ "deleted": true
+ }
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+ '404':
+ description: Právo s daným ID nebylo nalezeno
+
+ /rights/resolve/{pid}:
+ get:
+ tags:
+ - Práva
+ summary: Vypíše seznam práv pro konkrétní pid a akci
+ description: Vypíše seznam práv pro konkrétní pid a akci
+ parameters:
+ - name: pid
+ in: path
+ required: true
+ description: PID, jehož cesty a práva chcete vyřešit.
+ schema:
+ type: string
+ - name: action
+ in: query
+ required: false
+ description: Akce, na základě které se mají získat práva.
+ schema:
+ type: string
+ enum: ["a_read", "a_pdf_read", "a_delete", "a_process_edit", "a_process_read", "a_owner_process_edit", "a_index", "a_rebuild_processing_index", "a_import", "a_set_accessibility", "a_export_cdk", "a_statistics", "a_statistics_edit", "a_export_statistics", "a_export_replications", "a_import_replications", "a_rights_edit", "a_criteria_read", "a_collections_read", "a_collections_edit", "a_able_tobe_part_of_collections", "a_generate_nkplogs", "a_roles_edit", "a_roles_read", "a_admin_read", "a_sdnnt_sync", "a_object_edit", "a_admin_api_specification_read"]
+
+ responses:
+ '200':
+ description: Úspěšně získaná práva pro zadané PID
+ content:
+ application/json:
+ example: {
+ "uuid:1/uuid:06011240-a943-4efe-9f89-6707453b5f3d/uuid:d0134941-11e8-43a1-ac7f-c2bfc74fa663/uuid:c40fe6af-5c63-4c27-9434-9832ebe1f9d6/uuid:488e650f-3921-11ef-a7a7-001b63bd97ba": [
+ {
+ "role": {
+ "name": "kramerius_admin",
+ "id": -1
+ },
+ "action": "a_read",
+ "pid": "uuid:1",
+ "id": 59
+ },
+ {
+ "role": {
+ "name": "kramerius_admin",
+ "id": -1
+ },
+ "action": "a_read",
+ "pid": "uuid:1",
+ "id": 54
+ },
+ {
+ "role": {
+ "name": "moje_role",
+ "id": -1
+ },
+ "criterium": {
+ "license": "orphan",
+ "qname": "cz.incad.kramerius.security.impl.criteria.LicensesIPFiltered",
+ "label": "orphan",
+ "params": {
+ "objects": [
+ "127.*",
+ "localhost",
+ "0.*"
+ ],
+ "description": "Localhosts",
+ "id": 1
+ }
+ },
+ "action": "a_read",
+ "pid": "uuid:1",
+ "id": 62
+ },
+ {
+ "role": {
+ "name": "common_users",
+ "id": -1
+ },
+ "criterium": {
+ "license": "public",
+ "qname": "cz.incad.kramerius.security.impl.criteria.Licenses",
+ "label": "public",
+ "params": {
+ "objects": [],
+ "id": 0
+ }
+ },
+ "action": "a_read",
+ "pid": "uuid:1",
+ "id": 48
+ },
+ {
+ "role": {
+ "name": "kramerius_admin",
+ "id": -1
+ },
+ "criterium": {
+ "license": "inovatika_licence_zamek",
+ "qname": "cz.incad.kramerius.security.impl.criteria.Licenses",
+ "label": "inovatika_licence_zamek",
+ "params": {
+ "objects": [],
+ "id": 0
+ }
+ },
+ "action": "a_read",
+ "pid": "uuid:1",
+ "id": 50
+ }
+ ]
+ }
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+ '400':
+ description: Chybějící nebo neplatný parametr akce
+
+ /rights/params:
+ get:
+ tags:
+ - Práva
+ summary: Výpis všech parametrů
+ description: Výpis všech parametrů
+ responses:
+ '200':
+ description: Seznam všech parametrů
+ content:
+ application/json:
+ example: [
+ {
+ "objects": [
+ "127.*",
+ "localhost",
+ "0.*"
+ ],
+ "description": "Localhosts",
+ "id": 1
+ },
+ {
+ "objects": [
+ "172.*"
+ ],
+ "description": "Bash_IP",
+ "id": 2
+ }
+ ]
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ /rights/params/{id}:
+ get:
+ tags:
+ - Práva
+ summary: Získání parametrů práva podle ID
+ description: Získává parametry práva na základě zadaného ID. Uživatel musí mít oprávnění pro tuto akci.
+ parameters:
+ - name: id
+ in: path
+ required: true
+ description: ID parametru, který chcete získat (musí být číslo).
+ schema:
+ type: integer
+ responses:
+ '200':
+ description: Úspěšně získané parametry práva
+ content:
+ application/json:
+ example: {
+ "objects": [
+ "127.*",
+ "localhost",
+ "0.*"
+ ],
+ "description": "Localhosts",
+ "id": 1
+ }
+
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+ '404':
+ description: Parametr s daným ID nebyl nalezen
+
+ put:
+ tags:
+ - Práva
+ summary: Aktualizace parametru dle id
+ description: Aktualizuje existující parametr dle id.
+ parameters:
+ - name: id
+ in: path
+ required: true
+ description: ID parametru, který chcete aktualizovat (musí být číslo).
+ schema:
+ type: integer
+ requestBody:
+ required: true
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {
+ "objects": [
+ "127.*",
+ "localhost",
+ "0.*"
+ ],
+ "description": "Localhosts",
+ "id": 1
+ }
+ responses:
+ '200':
+ description: Parametr byl úspěšně aktualizován
+ content:
+ application/json:
+ example: {
+ "objects": [
+ "127.*",
+ "localhost",
+ "0.*"
+ ],
+ "description": "Localhosts",
+ "id": 1
+ }
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+ '404':
+ description: Parametr s daným ID nebyl nalezen
+
+ delete:
+ tags:
+ - Práva
+ summary: Smazání parametru práva podle ID
+ description: Smaže existující parametr práva podle jeho ID. Uživatel musí mít oprávnění pro tuto akci a parametr nesmí být používán.
+ parameters:
+ - name: id
+ in: path
+ required: true
+ description: ID parametru, který chcete smazat (musí být číslo).
+ schema:
+ type: integer
+ responses:
+ '200':
+ description: Parametr byl úspěšně smazán
+ content:
+ application/json:
+ example: |
+ {
+ "id": 123,
+ "deleted": true
+ }
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+ '404':
+ description: Parametr s daným ID nebyl nalezen
+ '409':
+ description: Parametr nemůže být smazán, protože je používán
+
+ /rights/criteria:
+ get:
+ tags:
+ - Práva
+ summary: Získání kritérií práv
+ description: Získává seznam všech kritérií práv, pokud má uživatel oprávnění pro čtení nebo úpravu.
+ responses:
+ '200':
+ description: Úspěšně získaná kritéria práv
+ content:
+ application/json:
+ example: {
+ "cz.incad.kramerius.security.impl.criteria.LicensesIPFiltered": {
+ "paramsNecessary": true,
+ "isLabelAssignable": true,
+ "isLicenseAssignable": true,
+ "rootLevelCriterum": true,
+ "applicableActions": [
+ "a_read"
+ ]
+ },
+ "cz.incad.kramerius.security.impl.criteria.PolicyFlag": {
+ "paramsNecessary": false,
+ "isLabelAssignable": false,
+ "isLicenseAssignable": false,
+ "rootLevelCriterum": false,
+ "applicableActions": [
+ "a_read"
+ ]
+ },
+ "cz.incad.kramerius.security.impl.criteria.DefaultDomainFilter": {
+ "paramsNecessary": true,
+ "isLabelAssignable": false,
+ "isLicenseAssignable": false,
+ "rootLevelCriterum": false,
+ "applicableActions": [
+ "a_read",
+ "a_pdf_read",
+ "a_delete",
+ "a_process_edit",
+ "a_process_read",
+ "a_owner_process_edit",
+ "a_index",
+ "a_rebuild_processing_index",
+ "a_import",
+ "a_set_accessibility",
+ "a_export_cdk",
+ "a_statistics",
+ "a_statistics_edit",
+ "a_export_statistics",
+ "a_export_replications",
+ "a_import_replications",
+ "a_rights_edit",
+ "a_criteria_read",
+ "a_collections_read",
+ "a_collections_edit",
+ "a_able_tobe_part_of_collections",
+ "a_generate_nkplogs",
+ "a_roles_edit",
+ "a_roles_read",
+ "a_admin_read",
+ "a_sdnnt_sync",
+ "a_object_edit"
+ ]
+ },
+ "cz.incad.kramerius.security.impl.criteria.Window": {
+ "paramsNecessary": true,
+ "isLabelAssignable": false,
+ "isLicenseAssignable": false,
+ "rootLevelCriterum": false,
+ "applicableActions": [
+ "a_read"
+ ]
+ },
+ "cz.incad.kramerius.security.impl.criteria.DefaultIPAddressFilter": {
+ "paramsNecessary": true,
+ "isLabelAssignable": false,
+ "isLicenseAssignable": false,
+ "rootLevelCriterum": false,
+ "applicableActions": [
+ "a_read",
+ "a_pdf_read",
+ "a_delete",
+ "a_process_edit",
+ "a_process_read",
+ "a_owner_process_edit",
+ "a_index",
+ "a_rebuild_processing_index",
+ "a_import",
+ "a_set_accessibility",
+ "a_export_cdk",
+ "a_statistics",
+ "a_statistics_edit",
+ "a_export_statistics",
+ "a_export_replications",
+ "a_import_replications",
+ "a_rights_edit",
+ "a_criteria_read",
+ "a_collections_read",
+ "a_collections_edit",
+ "a_able_tobe_part_of_collections",
+ "a_generate_nkplogs",
+ "a_roles_edit",
+ "a_roles_read",
+ "a_admin_read",
+ "a_sdnnt_sync",
+ "a_object_edit"
+ ]
+ },
+ "cz.incad.kramerius.security.impl.criteria.PDFDNNTLabels": {
+ "paramsNecessary": false,
+ "isLabelAssignable": true,
+ "isLicenseAssignable": true,
+ "rootLevelCriterum": true,
+ "applicableActions": [
+ "a_pdf_read"
+ ]
+ },
+ "cz.incad.kramerius.security.impl.criteria.BenevolentMovingWall": {
+ "paramsNecessary": true,
+ "isLabelAssignable": false,
+ "isLicenseAssignable": false,
+ "rootLevelCriterum": false,
+ "applicableActions": [
+ "a_read"
+ ]
+ },
+ "cz.incad.kramerius.security.impl.criteria.Licenses": {
+ "paramsNecessary": false,
+ "isLabelAssignable": true,
+ "isLicenseAssignable": true,
+ "rootLevelCriterum": true,
+ "applicableActions": [
+ "a_read"
+ ]
+ },
+ "cz.incad.kramerius.security.impl.criteria.CoverAndContentFilter": {
+ "paramsNecessary": false,
+ "isLabelAssignable": false,
+ "isLicenseAssignable": false,
+ "rootLevelCriterum": false,
+ "applicableActions": [
+ "a_read"
+ ]
+ },
+ "cz.incad.kramerius.security.impl.criteria.ReadDNNTLabelsIPFiltered": {
+ "paramsNecessary": true,
+ "isLabelAssignable": true,
+ "isLicenseAssignable": true,
+ "rootLevelCriterum": true,
+ "applicableActions": [
+ "a_read"
+ ]
+ },
+ "cz.incad.kramerius.security.impl.criteria.NegativeBenevolentModelFilter": {
+ "paramsNecessary": true,
+ "isLabelAssignable": false,
+ "isLicenseAssignable": false,
+ "rootLevelCriterum": false,
+ "applicableActions": [
+ "a_read"
+ ]
+ },
+ "cz.incad.kramerius.security.impl.criteria.ReadDNNTLabels": {
+ "paramsNecessary": false,
+ "isLabelAssignable": true,
+ "isLicenseAssignable": true,
+ "rootLevelCriterum": true,
+ "applicableActions": [
+ "a_read"
+ ]
+ },
+ "cz.incad.kramerius.security.impl.criteria.StrictIPAddresFilter": {
+ "paramsNecessary": true,
+ "isLabelAssignable": false,
+ "isLicenseAssignable": false,
+ "rootLevelCriterum": false,
+ "applicableActions": [
+ "a_read",
+ "a_pdf_read",
+ "a_delete",
+ "a_process_edit",
+ "a_process_read",
+ "a_owner_process_edit",
+ "a_index",
+ "a_rebuild_processing_index",
+ "a_import",
+ "a_set_accessibility",
+ "a_export_cdk",
+ "a_statistics",
+ "a_statistics_edit",
+ "a_export_statistics",
+ "a_export_replications",
+ "a_import_replications",
+ "a_rights_edit",
+ "a_criteria_read",
+ "a_collections_read",
+ "a_collections_edit",
+ "a_able_tobe_part_of_collections",
+ "a_generate_nkplogs",
+ "a_roles_edit",
+ "a_roles_read",
+ "a_admin_read",
+ "a_sdnnt_sync",
+ "a_object_edit"
+ ]
+ },
+ "cz.incad.kramerius.security.impl.criteria.LicensesGEOIPFiltered": {
+ "paramsNecessary": true,
+ "isLabelAssignable": true,
+ "isLicenseAssignable": true,
+ "rootLevelCriterum": true,
+ "applicableActions": [
+ "a_read"
+ ]
+ },
+ "cz.incad.kramerius.security.impl.criteria.MovingWall": {
+ "paramsNecessary": true,
+ "isLabelAssignable": false,
+ "isLicenseAssignable": false,
+ "rootLevelCriterum": false,
+ "applicableActions": [
+ "a_read"
+ ]
+ },
+ "cz.incad.kramerius.security.impl.criteria.StrictDomainFilter": {
+ "paramsNecessary": true,
+ "isLabelAssignable": false,
+ "isLicenseAssignable": false,
+ "rootLevelCriterum": false,
+ "applicableActions": [
+ "a_read",
+ "a_pdf_read",
+ "a_delete",
+ "a_process_edit",
+ "a_process_read",
+ "a_owner_process_edit",
+ "a_index",
+ "a_rebuild_processing_index",
+ "a_import",
+ "a_set_accessibility",
+ "a_export_cdk",
+ "a_statistics",
+ "a_statistics_edit",
+ "a_export_statistics",
+ "a_export_replications",
+ "a_import_replications",
+ "a_rights_edit",
+ "a_criteria_read",
+ "a_collections_read",
+ "a_collections_edit",
+ "a_able_tobe_part_of_collections",
+ "a_generate_nkplogs",
+ "a_roles_edit",
+ "a_roles_read",
+ "a_admin_read",
+ "a_sdnnt_sync",
+ "a_object_edit"
+ ]
+ },
+ "cz.incad.kramerius.security.impl.criteria.PDFProtectedByLicense": {
+ "paramsNecessary": false,
+ "isLabelAssignable": true,
+ "isLicenseAssignable": true,
+ "rootLevelCriterum": true,
+ "applicableActions": [
+ "a_pdf_read"
+ ]
+ },
+ "cz.incad.kramerius.security.impl.criteria.BenevolentModelFilter": {
+ "paramsNecessary": true,
+ "isLabelAssignable": false,
+ "isLicenseAssignable": false,
+ "rootLevelCriterum": false,
+ "applicableActions": [
+ "a_read"
+ ]
+ }
+ }
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+
+ /rights/licenses:
+ get:
+ tags:
+ - Práva
+ summary: Získání seznamu licencí
+ description: Vrátí seznam všech licencí, pokud má uživatel oprávnění pro tuto akci.
+ responses:
+ '200':
+ description: Úspěšně získané licence
+ content:
+ application/json:
+ example: [{
+ "name": "dnntt",
+ "description": "DNNT terminal license",
+ "id": 1,
+ "priority": 1,
+ "group": "embedded"
+ },
+ {
+ "name": "dnnto",
+ "description": "DNNT online license",
+ "id": 2,
+ "priority": 2,
+ "group": "embedded"
+ },
+ {
+ "name": "onsite",
+ "description": "Accessible only in library",
+ "id": 3,
+ "priority": 3,
+ "group": "embedded"
+ },
+ {
+ "name": "orphan",
+ "description": "Orphan works",
+ "id": 4,
+ "priority": 4,
+ "group": "embedded"
+ },
+ {
+ "name": "public",
+ "description": "Public license",
+ "id": 5,
+ "priority": 5,
+ "group": "embedded"
+ },
+ {
+ "name": "onsite-sheetmusic",
+ "description": "On site sheet music",
+ "id": 7,
+ "priority": 7,
+ "group": "embedded"
+ }
+ ]
+
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ /processes:
+ post:
+ tags:
+ - Procesy
+ summary: Naplánování procesu
+ description: Naplánuje nový proces, který může být různých typů, jako například indexace, import, import NDK, atd.
+ requestBody:
+ required: true
+ content:
+ application/json:
+ schema:
+ type: string
+
+ examples:
+
+ importfoxml:
+ summary: Plánování procesu import/FOXML
+ description: |
+ Příklad naplánování procesu importu FOXML.
+ Popis parametrů:
+
+ - **inputDataDir**: Cesta k adresáři s daty pro import.
+ - **startIndexer**: Boolean hodnota určující, zda začít indexaci.
+ - **license**: Typ licence pro import.
+ - **collections**: UUID kolekcí, do kterých budou data importována.
+ value: {"defid":"import","params":{"inputDataDir":"/d28b2a1a-508e-419e-9d3b-12ed4560138e","startIndexer":true,"license":"dnnto","collections":"uuid:bcc986fc-7ec8-47eb-b585-121e48f7bd02"}}
+ importndk:
+ summary: Plánování procesu import/NDK-METS
+ description: |
+ Příklad naplánování procesu importu NDK-METS
+ Popis parametrů:
+
+ - **inputDataDir**: Cesta k adresáři s daty pro import.
+ - **startIndexer**: Boolean hodnota určující, zda začít indexaci.
+ - **useIIPServer**: Use IIP server.
+ - **license**: Typ licence pro import.
+ - **collections**: UUID kolekcí, do kterých budou data importována.
+
+ value: {"defid":"convert_and_import","params":{"policy":"PRIVATE","inputDataDir":"/1c8fc53b-9c82-4bc7-8e1f-038d92749b1f","startIndexer":true,"useIIPServer":true,"license":"dnnto","collections":"uuid:28b00683-977d-4743-ad4b-ff8135f5e263"}}
+ index_object:
+ summary: Plánování indexace objektu
+ description: |
+ Příklad naplánování procesu indexace objektu
+ Popis parametrů:
+
+ - **type**: Typ indexace. Možné hodnoty jsou TREE_AND_FOSTER_TREES nebo OBJECT
+ - **pid**: Pid identifkikátor objektu
+ - **pidlist**: V případě, že chceme více objektů, je možno využít pole pidů
+ - **ignoreInconsistentObjects**: Příznak určuje zda má indexer pokračovat i v případě nalezení nekonzistence .
+
+
+ value: {"defid":"new_indexer_index_object","params":{"type":"TREE_AND_FOSTER_TREES","pid":"uuid:b35833b3-7f7f-4cac-a434-484b6e096922","ignoreInconsistentObjects":false}}
+
+
+ add_license:
+ summary: Plánování procesu přidání licence
+ description: |
+ Příklad přidání licence
+ Popis parametrů:
+
+ - **license**: Přiřazovaná licence
+ - **pid**: Pid identifkikátor objektu
+ - **pidlist**: V případě, že chceme více objektů, je možno využít pole pidů
+
+ value: {"defid":"add_license","params":{"license":"orphan","pid":"uuid:b35833b3-7f7f-4cac-a434-484b6e096922"}}
+
+ remove_license:
+ summary: Plánování procesu odebírání licence
+ description: |
+
+ Příklad odebírání licence
+ Popis parametrů:
+
+ - **license**: Odebíraná licence
+ - **pid**: Pid identifkikátor objektu
+ - **pidlist**: V případě, že chceme více objektů, je možno využít pole pidů
+
+
+ value: {"defid":"remove_license","params":{"license":"dnnto","pid":"uuid:b35833b3-7f7f-4cac-a434-484b6e096922"}}
+
+
+ backup_collection:
+ summary: Vytvoření zálohy sbírky/sbírek
+ description: |
+ Vytvoří zálohu sbírky/sbírek
+ Popis parametrů:
+
+ - **pid**: Pid identifkikátor objektu
+ - **pidlist**: V případě, že chceme více objektů, je možno využít pole pidů
+ - **backupname**: Jméno zálohy
+
+
+ value: {"defid":"backup-collections","params":{"pidlist":["uuid:bcc986fc-7ec8-47eb-b585-121e48f7bd02"],"backupname":"Test"}}
+
+
+ restore_collection:
+ summary: Obnovení sbírek ze zálohy
+ description: |
+ Obnovení sbírek ze zálohy
+ Popis parametrů:
+
+ - **backupname**: Jméno zálohy
+
+
+ value: {"defid":"restore-collections","params":{"backupname":"Test.zip"}}
+
+
+ flag_to_license:
+ summary: Změna příznaku na licence (public a onsite)
+ description: Příklad změny poříznaku
+
+ value: {"defid":"flag_to_license","params":{}}
+
+
+ sdnnt_sync:
+ summary: Plánování procesu synchronizace se SDNNT
+ description: Příklad synchronizace se SDNNT
+
+
+ value: {"defid":"sdnnt-sync","params":{}}
+
+ delete:
+ summary: Plánování procesu mazání
+ description: |
+ Příklad smazání objektu
+ Popis parametrů:
+
+ - **pid**: Pid identifkikátor objektu
+ - **pidlist**: V případě, že chceme více objektů, je možno využít pole pidů
+
+ - **ignoreIncosistencies**: Ignorovat nekozistence
+
+ value: {"defid":"delete_tree","params":{"pid":"uuid:1c8fc53b-9c82-4bc7-8e1f-038d92749b1f","ignoreIncosistencies":true}}
+
+ responses:
+ '200':
+ description: Proces byl úspěšně naplánován
+ content:
+ application/json:
+ example: {
+ "name": "Import FOXML z /d28b2a1a-508e-419e-9d3b-12ed4560138e ",
+ "id": "import",
+ "state": "PLANNED",
+ "planned": "+56753-06-10T20:40:06",
+ "uuid": "103cb713-b778-4370-8d58-f13bf4b276ec"
+ }
+ '400':
+ description: Špatný požadavek - chybí definice procesu nebo `defid`
+ content:
+ application/json:
+ example:
+ error: "missing process definition"
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+ content:
+ application/json:
+ example:
+ error: "user 'username' is not allowed to manage processes"
+
+
+
+ /processes/batches:
+ get:
+ tags:
+ - Procesy
+ summary: Vrací všechny dávky procesů
+ description: Vrací všechny dávky procesů a umožňuje filtrování a paginaci
+ parameters:
+ - name: offset
+ in: query
+ required: false
+ description: Počáteční bod výpisu/paginace. Standardně 0.
+ schema:
+ type: integer
+ default: 0
+ - name: limit
+ in: query
+ required: false
+ description: Maximální počet vrácených položek. Standardně 50.
+ schema:
+ type: integer
+ default: 50
+ - name: owner
+ in: query
+ required: false
+ description: Filtrování dle vlastníka
+ schema:
+ type: string
+ - name: from
+ in: query
+ required: false
+ description: Filtrování dle počátečního data. (ISO 8601 formát).
+ schema:
+ type: string
+ format: date-time
+ - name: until
+ in: query
+ required: false
+ description: Filtrování dle koncového data. (ISO 8601 formát).
+ schema:
+ type: string
+ format: date-time
+ - name: state
+ in: query
+ required: false
+ description: Filtrování dle stavu.
+ schema:
+ type: string
+ responses:
+ '200':
+ description: Výpis všech dávek asociovaných s procesem
+ content:
+ application/json:
+ schema:
+ type: string
+ '400':
+ description: Nevalidní query parametr (offset, limit, from, until)
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+
+ /processes/owners:
+ get:
+ tags:
+ - Procesy
+ summary: Vrací seznam všech vlastníků procesů
+ description: Vrací seznam všech vlastníků procesů.
+ responses:
+ '200':
+ description: Úspěšně získané licence
+ content:
+ application/json:
+ example: {
+ "owners": [
+ {
+ "name": "krameriusadmin",
+ "id": "krameriusadmin"
+ }
+ ]
+ }
+
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ /processes/by_process_id/{process_id}:
+ get:
+ tags:
+ - Procesy
+ summary: Vrací detail procesu/dávky dle databázového id
+ description: Vrací detail procesu/dávky dle databázového id
+ parameters:
+ - name: process_id
+ in: path
+ required: true
+ description: Databázová id procesu
+ schema:
+ type: string
+ example: 576
+ responses:
+ '200':
+ description: JSON reprezentace procesu/dávky
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {
+ "process": {
+ "defid": "import",
+ "name": "Import FOXML z ./import/d28b2a1a-508e-419e-9d3b-12ed4560138e ",
+ "started": "2024-10-13T07:46:51.141",
+ "finished": "2024-10-13T07:46:54.077",
+ "id": "576",
+ "state": "FAILED",
+ "planned": "2024-10-13T07:46:50.406",
+ "uuid": "103cb713-b778-4370-8d58-f13bf4b276ec"
+ },
+ "batch": {
+ "owner_name": "krameriusadmin",
+ "owner_id": "krameriusadmin",
+ "started": "2024-10-13T07:46:51.141",
+ "finished": "2024-10-13T07:46:54.077",
+ "id": "576",
+ "state": "FAILED",
+ "planned": "2024-10-13T07:46:50.406",
+ "token": "13d099c7-e95c-4834-ad6e-d8f40017d0b9"
+ }
+ }
+ '400':
+ description: Nevalidní id procesu, process_id musí být číslo
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+ '404':
+ description: Proces se zadaným id neexistuje
+
+ /processes/by_process_uuid/{process_uuid}:
+ get:
+ tags:
+ - Procesy
+ summary: Vrací detail procesu dle zadaného uuid
+ description: Retrieve process and batch information for a given process UUID.
+ parameters:
+ - name: process_uuid
+ in: path
+ required: true
+ description: UUID of the process to fetch.
+ schema:
+ type: string
+ format: uuid
+ responses:
+ '200':
+ description: Process found, returns JSON object with process data.
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {
+ "process": {
+ "defid": "import",
+ "name": "Import FOXML z ./import/d28b2a1a-508e-419e-9d3b-12ed4560138e ",
+ "started": "2024-10-13T07:46:51.141",
+ "finished": "2024-10-13T07:46:54.077",
+ "id": "576",
+ "state": "FAILED",
+ "planned": "2024-10-13T07:46:50.406",
+ "uuid": "103cb713-b778-4370-8d58-f13bf4b276ec"
+ },
+ "batch": {
+ "owner_name": "krameriusadmin",
+ "owner_id": "krameriusadmin",
+ "started": "2024-10-13T07:46:51.141",
+ "finished": "2024-10-13T07:46:54.077",
+ "id": "576",
+ "state": "FAILED",
+ "planned": "2024-10-13T07:46:50.406",
+ "token": "13d099c7-e95c-4834-ad6e-d8f40017d0b9"
+ }
+ }
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+ '404':
+ description: No process found with the given process UUID.
+
+
+ /processes/by_process_uuid/{process_uuid}/logs/out:
+ get:
+ tags:
+ - Procesy
+ summary: Vrací standardní výstup z procesu
+ description: Vrací standardní výstup z procesu
+ parameters:
+ - name: process_uuid
+ in: path
+ required: true
+ description: UUID procesu
+ schema:
+ type: string
+ format: uuid
+ example: 103cb713-b778-4370-8d58-f13bf4b276ec
+ - name: fileName
+ in: query
+ required: false
+ description: Jméno souboru pro download. Standardně "out.txt".
+ schema:
+ type: string
+ default: "out.txt"
+ responses:
+ '200':
+ description: Proces nalezen a logy poskytnuty ve formě streamu
+ content:
+ application/octet-stream:
+ schema:
+ type: string
+ format: binary
+ '403':
+ description: User is not authorized to access these logs.
+ '404':
+ description: Process logs not found for the given UUID.
+
+
+ /processes/by_process_uuid/{process_uuid}/logs/err:
+ get:
+ tags:
+ - Procesy
+ summary: Vrací chybový výstup procesu
+ description: Vrací chybový výstup procesu
+ parameters:
+ - name: process_uuid
+ in: path
+ required: true
+ description: uuid procesu
+ schema:
+ type: string
+ format: uuid
+ example: 103cb713-b778-4370-8d58-f13bf4b276ec
+ - name: fileName
+ in: query
+ required: false
+ description: Jméno výstupního souboru. Standardně "err.txt".
+ schema:
+ type: string
+ default: "err.txt"
+ responses:
+ '200':
+ description: Error logs file found and returned as a binary stream.
+ content:
+ application/octet-stream:
+ schema:
+ type: string
+ format: binary
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ '404':
+ description: Error logs not found for the given UUID.
+
+
+
+
+ /processes/batches/by_first_process_id/{process_id}:
+ delete:
+ tags:
+ - Procesy
+ summary: Smaže konkrétní procesu
+ description: Smaže konkrétní proces
+ parameters:
+ - name: process_id
+ in: path
+ required: true
+ description: ID prvního procesu v dávce.
+ schema:
+ type: integer
+ example: 576
+ responses:
+ '200':
+ description: Proces úspěšně smazán
+ content:
+ application/json:
+ schema:
+ type: string
+ '400':
+ description: Neplatné ID procesu nebo dávka nelze smazat.
+
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+
+ /processes/batches/by_first_process_id/{process_id}/execution:
+ delete:
+ tags:
+ - Procesy
+ summary: Ukončí běžící proces
+ description: Ukončí běžící proces
+ parameters:
+ - name: process_id
+ in: path
+ required: true
+ description: ID procesu
+ schema:
+ type: integer
+ example: 576
+ responses:
+ '200':
+ description: Proces úspěšně ukončen.
+ '400':
+ description: Neplatné ID.
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+
+ /processes/by_process_uuid/{process_uuid}/logs/out/lines:
+ get:
+ tags:
+ - Procesy
+ summary: Získá standardní výstup ve formě řádklů
+ description: Získá standardní výstup ve formě řádků
+ parameters:
+ - name: process_uuid
+ in: path
+ required: true
+ description: UUID procesu, pro který se získávají logy.
+ schema:
+ type: string
+ - name: offset
+ in: query
+ description: Počáteční index, od kterého se začnou načítat řádky logu.
+ schema:
+ type: integer
+ example: 0
+ - name: limit
+ in: query
+ description: Maximální počet řádků logu, které se mají vrátit.
+ schema:
+ type: integer
+ example: 100
+ responses:
+ '200':
+ description: Úspěšně načtené logy procesu.
+ '400':
+ description: Neplatný požadavek, např. neplatný offset nebo limit.
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+ '404':
+ description: Proces s daným UUID nebyl nalezen.
+ operationId: getProcessLogsOutLinesByProcessUuid
+
+
+ /processes/by_process_uuid/{process_uuid}/logs/err/lines:
+ get:
+ summary: Získá chybový výstup ve formě řádků
+ description: Získá chybový výstup ve formě řádků
+ tags:
+ - Procesy
+ parameters:
+ - name: process_uuid
+ in: path
+ required: true
+ description: UUID procesu, pro který se získávají chybové logy.
+ schema:
+ type: string
+ - name: offset
+ in: query
+ description: Počáteční index, od kterého se začnou načítat řádky chybového logu.
+ schema:
+ type: integer
+ example: 0
+ - name: limit
+ in: query
+ description: Maximální počet řádků chybového logu, které se mají vrátit.
+ schema:
+ type: integer
+ example: 100
+ responses:
+ '200':
+ description: Úspěšně načtené chybové logy procesu.
+ '400':
+ description: Neplatný požadavek, např. neplatný offset nebo limit.
+
+ '403':
+ description: Uživatel nemá oprávnění k požadované akci
+
+ '404':
+ description: Proces s daným UUID nebyl nalezen.
+
diff --git a/rest/src/main/resources/openapi/openapi.yaml b/rest/src/main/resources/openapi/client/v7.0/openapi.yaml
similarity index 75%
rename from rest/src/main/resources/openapi/openapi.yaml
rename to rest/src/main/resources/openapi/client/v7.0/openapi.yaml
index 6ab6d7379..52a19b735 100644
--- a/rest/src/main/resources/openapi/openapi.yaml
+++ b/rest/src/main/resources/openapi/client/v7.0/openapi.yaml
@@ -37,8 +37,7 @@ paths:
summary: Vyhledávání titulů
description: |
- Vyhledávání je umožněno endpointem, který slouží jako proxy do vyhledávacího enginu SOLR. Přebírá všechny parametry, validuje je a následně posílá na vyhledávací server solr. Z odpovědi jsou filtrována data typu TEXT_OCR a je posílán zpět na klienta. Možné parametry jsou všechny, které akceptuje vyhledávací engine solr. Dokumentace je k nalezení [zde](https://solr.apache.org/guide/solr/latest/query-guide/query-syntax-and-parsers.html) Popis jednotlivých indexovaných polí je k nalezení [zde](https://github.com/ceskaexpedice/kramerius/blob/master/installation/solr-9.x/search/conf/managed-schema). V definici jsou uvedeny pouze ty nejdůležitější
-
+ Vyhledávání je umožněno prostřednictvím endpointu, který slouží jako proxy do vyhledávacího enginu Solr. Přebírá všechny parametry, validuje je a následně je posílá na vyhledávací server Solr. Z odpovědi jsou filtrována data typu TEXT_OCR a posílána zpět na klienta. Možné parametry jsou všechny, které akceptuje vyhledávací engine Solr. Dokumentace je k nalezení [zde](https://solr.apache.org/guide/solr/latest/query-guide/query-syntax-and-parsers.html). Popis jednotlivých indexovaných polí je k nalezení [zde](https://github.com/ceskaexpedice/kramerius/blob/master/installation/solr-9.x/search/conf/managed-schema). V definici jsou uvedeny pouze ty nejdůležitější.
operationId: searching
parameters:
@@ -117,7 +116,7 @@ paths:
responses:
'200':
- description: Standardní výstup ze solru. JSON nebo xml
+ description: Standardní výstup ze Solru. JSON nebo XML
content:
application/json:
schema:
@@ -255,7 +254,7 @@ paths:
tags:
- Informace o titulu
summary: Kontrolní endpoint pro titul
- description: Umožňuje získat info titulu
+ description: Umožňuje získat informace o titulu
operationId: exist
parameters:
- in: path
@@ -296,8 +295,7 @@ paths:
application/json:
schema:
type: string
- example: |
- {
+ example: {
"image": {
"type": "tiles"
},
@@ -336,8 +334,8 @@ paths:
get:
tags:
- Informace o titulu
- summary: Informace jak zobrazovat data - dlaždice, obrázek, audio, atd..
- description: Informace jak zobrazovat data
+ summary: Informace o způsobu zobrazení dat (dlaždice, obrázek, audio atd.)
+ description: Informace o způsobu zobrazení dat.
operationId: getImageInfo
parameters:
- in: path
@@ -353,8 +351,7 @@ paths:
application/json:
schema:
type: string
- example: |
- {"type":"tiles"}
+ example: {"type":"tiles"}
'400':
description: Chybný formát nebo hodnota PID identifikátoru
'403':
@@ -367,8 +364,8 @@ paths:
get:
tags:
- Informace o titulu
- summary: Informace o licenci dle které je dílo poskytnuto
- description: Informace o licenci které je dílo poskytnuto
+ summary: Informace o licenci, podle které je dílo poskytnuto
+ description: Informace o licenci, podle které je dílo poskytnuto.
operationId: getProvidedByLicenses
parameters:
- in: path
@@ -384,8 +381,7 @@ paths:
application/json:
schema:
type: string
- example: |
- {
+ example: {
"licenses":[
"onsite"
]
@@ -402,8 +398,8 @@ paths:
get:
tags:
- Informace o titulu
- summary: Informace o objektu pro zobrazení
- description: Informace o objektu pro zobrazení, typ zobrazení, licence, dle které se pid poskytnul
+ summary: Informace o struktuře objektu pro zobrazení
+ description: Informace o struktuře, děti, rodiče, atd..
operationId: structure
parameters:
- in: path
@@ -419,8 +415,7 @@ paths:
application/json:
schema:
type: string
- example: |
- {
+ example: {
"children": {
"own": [
{
@@ -467,8 +462,8 @@ paths:
get:
tags:
- Informace o titulu
- summary: Informace o dostupných datech/datastreamech
- description: Inforamce o dostupných datech/datastreamech
+ summary: Informace o dostupných datech/datastreams
+ description: Informace o dostupných datech/datastreams.
operationId: getDataAvailability
parameters:
- in: path
@@ -479,13 +474,12 @@ paths:
description: Identifikátor PID
responses:
'200':
- description: Úspěšné získání informací přístupných datech (obrázky, audiosoubory, metadata, atd.. ).
+ description: Úspěšné získání informací o dostupných datech (obrázky, audio soubory, metadata atd.).
content:
application/json:
schema:
type: string
- example: |
- {
+ example: {
"image": {
"preview": true,
"thumb": true,
@@ -512,13 +506,13 @@ paths:
# Informace o metadatech
- /items/{pid}/metadata/{metadata}:
+ /items/{pid}/metadata/dc:
head:
tags:
- Informace o titulu
summary: Dotaz na existenci metadat
description: Ziskani informace pro metadata
- operationId: metadata
+ operationId: dcMetadata
parameters:
- in: path
name: pid
@@ -526,15 +520,6 @@ paths:
type: string
required: true
description: Identifikátor PID
- - in: path
- name: metadata
- schema:
- type: string
- enum:
- - dc
- - mods
- required: true
- description: Identifikátor metadat (povoleny pouze 'dc' nebo 'mods')
responses:
'200':
description: Metadata jsou dostupná
@@ -547,7 +532,42 @@ paths:
- Informace o titulu
summary: Získání metadat
description: Informace o objektu pro zobrazení, typ zobrazení, licence, dle které se pid poskytnul
- operationId: getMetadata
+ operationId: getDcMetadata
+ parameters:
+ - in: path
+ name: pid
+ schema:
+ type: string
+ required: true
+ description: Identifikátor PID
+
+ responses:
+ '200':
+ description: Úspěšné získání dc metadat
+ content:
+ application/xml:
+ schema:
+ type: string
+ xml:
+ name: dc
+ namespace: "http://www.openarchives.org/OAI/2.0/oai_dc/"
+ prefix: oai_dc
+ example: ... obsah dc streamu ...
+
+
+ '400':
+ description: Chybný formát nebo hodnota PID identifikátoru.
+ '404':
+ description: PID identifikátor neexistuje nebo nebyl nalezen
+
+ # Informace o metadatech
+ /items/{pid}/metadata/mods:
+ head:
+ tags:
+ - Informace o titulu
+ summary: Dotaz na existenci metadat
+ description: Ziskani informace pro metadata
+ operationId: modsMetadata
parameters:
- in: path
name: pid
@@ -555,195 +575,53 @@ paths:
type: string
required: true
description: Identifikátor PID
+ responses:
+ '200':
+ description: Metadata jsou dostupná
+ '400':
+ description: Chybný formát nebo hodnota PID identifikátoru.
+ '404':
+ description: PID identifikátor neexistuje nebo nebyl nalezen.
+ get:
+ tags:
+ - Informace o titulu
+ summary: Získání metadat
+ description: Informace o objektu pro zobrazení, typ zobrazení, licence, dle které se pid poskytnul
+ operationId: getModsMetadata
+ parameters:
- in: path
- name: metadata
+ name: pid
schema:
type: string
- enum:
- - dc
- - mods
required: true
- description: Identifikátor metadat (povoleny pouze 'dc' nebo 'mods')
-
+ description: Identifikátor PID
+
responses:
'200':
- description: Úspěšné získání metadat
+ description: Úspěšné získání dc metadat
content:
application/xml:
schema:
- type: string
- examples:
- dc:
- summary: Dublin Core příklad
- value: |
-
- Nejistá věda: co věda o klimatu říká, co neříká, a proč na tom záleží
- Unsettled. Česky
- Koonin, Steven E., 1951-
- Kaňa, Štěpán, 1977-
- pna20241227247
- xx0070486
- Geologie. Meteorologie. Klimatologie
- klimatologie
- klimatické změny
- globální oteplování
- climatology
- climate changes
- global warming
- 551.58
- 551.583
- 551.588.7
- (0.062)
- 7
- 551
- Kniha se podrobně a apoliticky zabývá mylnými představami a ideologickým zkreslením mainstreamové prezentace vědy o klimatu, jež je mnohem méně černobílá, než si mnozí lidé uvědomují.
- Steven E. Koonin ; z anglického originálu Unsettled : what climate science tells us, what it doesn't, and why it matters ... přeložil Štěpán Kaňa.
- Obsahuje bibliografické odkazy a rejstřík
- Books & Pipes
- 2024
- model:monograph
- print
- bez média
- svazek
- 339 stran : ilustrace, grafy, mapy.
- uuid:48460ae7-6800-4e61-bd4a-85b42179451b
- ccnb:cnb003607882
- isbn:978-80-7485-292-3
- barcode:26002401684
- urnnbn:urn:nbn:cz:aba007-000lls
- ABA007
- F 150662
- cze
- eng
- Brno
- policy:private
-
- mods:
- summary: Biblio_MODS příklad
- value: |
-
-
- Kniha se podrobně a apoliticky zabývá mylnými představami a ideologickým zkreslením mainstreamové prezentace vědy o klimatu, jež je mnohem méně černobílá, než si mnozí lidé uvědomují.
- 551.58
- 551.583
- 551.588.7
- (0.062)
- 7
- 551
- volume
- text
- populárně-naučné publikace
- popular works
- 48460ae7-6800-4e61-bd4a-85b42179451b
- cnb003607882
- 978-80-7485-292-3
- 26002401684
- urn:nbn:cz:aba007-000lls
-
- cze
-
-
- eng
-
-
- ABA007
- F 150662
-
-
- Koonin
- Steven E.
- 1951-
-
- aut
-
- pna20241227247
-
-
- Kaňa
- Štěpán
- 1977-
-
- trl
-
- xx0070486
-
- Steven E. Koonin ; z anglického originálu Unsettled : what climate science tells us, what it doesn't, and why it matters ... přeložil Štěpán Kaňa.
- Obsahuje bibliografické odkazy a rejstřík
-
-
- xr
-
-
- Brno
-
- Books & Pipes
- 2024
- 1. vydání
- single unit
-
-
- print
- bez média
- svazek
- 339 stran : ilustrace, grafy, mapy.
-
-
- ABA007
- 20240819T073342
- 20240826T120948
- 002908972
-
- cze
-
- machine generated
- rda
- Converted from MARCXML to MODS version 3.6 using MARC21slim2MODS3.xsl (Revision 1.98 2018/02/09, ProArc patch 18.1352 2022/10/12)
-
-
- Geologie. Meteorologie. Klimatologie
-
-
- klimatologie
-
-
- klimatické změny
-
-
- globální oteplování
-
-
- climatology
-
-
- climate changes
-
-
- global warming
-
- adult
-
- Nejistá věda
- co věda o klimatu říká, co neříká, a proč na tom záleží
-
-
- Unsettled. Česky
-
- text
-
-
+ type: string
+ xml:
+ name: modsCollection
+ namespace: "http://www.loc.gov/mods/v3"
+ prefix: mods
+ example: ... obsah dc streamu ...
'400':
description: Chybný formát nebo hodnota PID identifikátoru.
'404':
description: PID identifikátor neexistuje nebo nebyl nalezen
-
+
+
# Dotazy na ocr data
- /items/{pid}/ocr/{type}:
+ /items/{pid}/ocr/text:
head:
tags:
- Informace o titulu
- summary: Dotaz na existenci ocr dat
- description: Dotaz na existenci ocr dat
- operationId: hasOcr
+ summary: Dotaz na existenci ocr dat v textové podobě
+ description: Dotaz na existenci ocr dat v textové podobě
+ operationId: hasTextOcr
parameters:
- in: path
name: pid
@@ -751,30 +629,53 @@ paths:
type: string
required: true
description: Identifikátor PID
+ responses:
+ '200':
+ description: OCR data jsou dostupná
+ '400':
+ description: Chybný formát nebo hodnota PID identifikátoru.
+ '403':
+ description: Uživatel nemá dostatečná oprávnění k přístupu k tomuto objektu.
+ '404':
+ description: PID identifikátor neexistuje nebo nebyl nalezen.
+ get:
+ tags:
+ - Informace o titulu
+ summary: Získání OCR dat v textové podobě
+ description: Získání OCR dat v textové podobě
+ operationId: getTextOcr
+ parameters:
- in: path
- name: type
+ name: pid
schema:
type: string
- enum:
- - text
- - alto
required: true
- description: Identifikátor ocr dat (povoleny pouze 'text' nebo 'alto')
+ description: Identifikátor PID
responses:
'200':
- description: OCR data jsou dostupná
+ description: Úspěšné získání textových ocr dat
+ content:
+ text/plain:
+ schema:
+ type: string
+ example: |
+ Toto je příklad textového OCR obsahu.
'400':
description: Chybný formát nebo hodnota PID identifikátoru.
'403':
description: Uživatel nemá dostatečná oprávnění k přístupu k tomuto objektu.
'404':
description: PID identifikátor neexistuje nebo nebyl nalezen.
- get:
+
+
+ # Dotazy na ocr data
+ /items/{pid}/ocr/alto:
+ head:
tags:
- Informace o titulu
- summary: Získání OCR dat
- description: Získání OCR dat k danému titulu
- operationId: getOcr
+ summary: Dotaz na existenci ocr dat v alto formátu
+ description: Dotaz na existenci ocr dat v alto formátu
+ operationId: hasAltotOcr
parameters:
- in: path
name: pid
@@ -782,42 +683,50 @@ paths:
type: string
required: true
description: Identifikátor PID
+ responses:
+ '200':
+ description: OCR data jsou dostupná
+ '400':
+ description: Chybný formát nebo hodnota PID identifikátoru.
+ '403':
+ description: Uživatel nemá dostatečná oprávnění k přístupu k tomuto objektu.
+ '404':
+ description: PID identifikátor neexistuje nebo nebyl nalezen.
+ get:
+ tags:
+ - Informace o titulu
+ summary: Získání OCR dat v alto formátu
+ description: Získání OCR dat v alto formátu
+ operationId: getAltotOcr
+ parameters:
- in: path
- name: type
+ name: pid
schema:
type: string
- enum:
- - text
- - alto
required: true
- description: Identifikátor ocr dat (povoleny pouze 'text' nebo 'alto')
+ description: Identifikátor PID
responses:
'200':
- description: Úspěšné získání ocr dat
+ description: Úspěšné získání textových ocr dat
content:
- text/plain:
- schema:
- type: string
- example: |
- Toto je příklad textového OCR obsahu.
application/xml:
schema:
type: string
- example: |
-
-
-
-
-
-
-
+ xml:
+ name: alto
+ namespace: "http://www.loc.gov/standards/alto/ns-v2#"
+ prefix: alto
+ example: ... příklad alto streamu ...
'400':
description: Chybný formát nebo hodnota PID identifikátoru.
'403':
description: Uživatel nemá dostatečná oprávnění k přístupu k tomuto objektu.
'404':
description: PID identifikátor neexistuje nebo nebyl nalezen.
-
+
+
+
+
# Dotazy na obrazová data
/items/{pid}/image:
head:
@@ -1534,3 +1443,5 @@ paths:
'404':
description: Neexistující zámek nebo volající není vlastníkem zámku
+
+
diff --git a/rest/src/main/resources/openapi/exts/v7.0/openapi.yaml b/rest/src/main/resources/openapi/exts/v7.0/openapi.yaml
new file mode 100644
index 000000000..5fc531bca
--- /dev/null
+++ b/rest/src/main/resources/openapi/exts/v7.0/openapi.yaml
@@ -0,0 +1,66 @@
+openapi: 3.0.2
+info:
+ title: API pro externí aplikace
+ description: |
+ Popis je platný k verzi 7.0.38 a vyšší. Kramerius obsahuje REST API, které je určeno pro externí aplikace a bude se dále rozšiřovat.
+ version: "7.0"
+
+servers:
+ - url: /search/api/exts/v7.0
+
+tags:
+
+ - name: Získání servisního tokenu
+ description: >
+ Pokud je potřeba aby aplikace pracovala s JWT tokenem, který má jinou expirační dobu (typicky dlouho trvajicí proces), může administrátor vyrvořit nový objekt v keycloaku typu client, k němu přiřadit servisní roli. Proces pomocí endpointu krameria, clientId a secret je schopen získat token. Administrátor může upravit vlastnosti klienta dle požadavků procesu
+
+paths:
+ /tokens/{clientid}:
+ get:
+ tags:
+ - Získání servisního tokenu
+ summary: Získání servisního tokenu
+ description: Získání servisního tokenu
+ parameters:
+
+ - name: clientid
+ in: path
+ required: true
+ description: Identifikátor objektu client
+ schema:
+ type: string
+
+ - name: secrets
+ in: query
+ required: true
+ description: Secrets svázaný s přístupem na token.
+ schema:
+ type: string
+
+
+ responses:
+ '200':
+ description: JSON odpověď z keycloaku
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {
+ "access_token": "xxxxfffffaaa",
+ "expires_in": 36000,
+ "refresh_expires_in": 0,
+ "token_type": "Bearer",
+ "not-before-policy": 0,
+ "scope": "profile email"
+ }
+
+ '401':
+ description: Neautorizovaný přístup
+ content:
+ application/json:
+ schema:
+ type: string
+ example: {
+ "error": "unauthorized_client",
+ "error_description": "Invalid client secret"
+ }
\ No newline at end of file
diff --git a/search/web/openapi/exts/v7.0/favicon-16x16.png b/search/web/openapi/exts/v7.0/favicon-16x16.png
new file mode 100644
index 000000000..8b194e617
Binary files /dev/null and b/search/web/openapi/exts/v7.0/favicon-16x16.png differ
diff --git a/search/web/openapi/exts/v7.0/favicon-32x32.png b/search/web/openapi/exts/v7.0/favicon-32x32.png
new file mode 100644
index 000000000..249737fe4
Binary files /dev/null and b/search/web/openapi/exts/v7.0/favicon-32x32.png differ
diff --git a/search/web/openapi/exts/v7.0/index.css b/search/web/openapi/exts/v7.0/index.css
new file mode 100644
index 000000000..f2376fdaa
--- /dev/null
+++ b/search/web/openapi/exts/v7.0/index.css
@@ -0,0 +1,16 @@
+html {
+ box-sizing: border-box;
+ overflow: -moz-scrollbars-vertical;
+ overflow-y: scroll;
+}
+
+*,
+*:before,
+*:after {
+ box-sizing: inherit;
+}
+
+body {
+ margin: 0;
+ background: #fafafa;
+}
diff --git a/search/web/openapi/exts/v7.0/index.html b/search/web/openapi/exts/v7.0/index.html
new file mode 100644
index 000000000..f91fc46d1
--- /dev/null
+++ b/search/web/openapi/exts/v7.0/index.html
@@ -0,0 +1,120 @@
+
+
+
+
+
+ Swagger UI
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/search/web/openapi/exts/v7.0/oauth2-redirect-kram.html b/search/web/openapi/exts/v7.0/oauth2-redirect-kram.html
new file mode 100644
index 000000000..8cc1c5f0b
--- /dev/null
+++ b/search/web/openapi/exts/v7.0/oauth2-redirect-kram.html
@@ -0,0 +1,25 @@
+
+
+
+
+ OAuth2 Redirect
+
+
+
+
+
diff --git a/search/web/openapi/exts/v7.0/oauth2-redirect.html b/search/web/openapi/exts/v7.0/oauth2-redirect.html
new file mode 100644
index 000000000..564091718
--- /dev/null
+++ b/search/web/openapi/exts/v7.0/oauth2-redirect.html
@@ -0,0 +1,79 @@
+
+
+
+ Swagger UI: OAuth2 Redirect
+
+
+
+
+
diff --git a/search/web/openapi/exts/v7.0/swagger-initializer.js b/search/web/openapi/exts/v7.0/swagger-initializer.js
new file mode 100644
index 000000000..8ea0ea3af
--- /dev/null
+++ b/search/web/openapi/exts/v7.0/swagger-initializer.js
@@ -0,0 +1,20 @@
+window.onload = function() {
+ //
+
+ // the following lines will be replaced by docker/configurator, when it runs in a docker-container
+ window.ui = SwaggerUIBundle({
+ url: "https://petstore.swagger.io/v2/swagger.json",
+ dom_id: '#swagger-ui',
+ deepLinking: true,
+ presets: [
+ SwaggerUIBundle.presets.apis,
+ SwaggerUIStandalonePreset
+ ],
+ plugins: [
+ SwaggerUIBundle.plugins.DownloadUrl
+ ],
+ layout: "StandaloneLayout"
+ });
+
+ //
+};
diff --git a/search/web/openapi/exts/v7.0/swagger-ui-bundle.js b/search/web/openapi/exts/v7.0/swagger-ui-bundle.js
new file mode 100644
index 000000000..551e172e3
--- /dev/null
+++ b/search/web/openapi/exts/v7.0/swagger-ui-bundle.js
@@ -0,0 +1,2 @@
+/*! For license information please see swagger-ui-bundle.js.LICENSE.txt */
+!function webpackUniversalModuleDefinition(o,s){"object"==typeof exports&&"object"==typeof module?module.exports=s():"function"==typeof define&&define.amd?define([],s):"object"==typeof exports?exports.SwaggerUIBundle=s():o.SwaggerUIBundle=s()}(this,(()=>(()=>{var o,s,i={69119:(o,s)=>{"use strict";Object.defineProperty(s,"__esModule",{value:!0}),s.BLANK_URL=s.relativeFirstCharacters=s.whitespaceEscapeCharsRegex=s.urlSchemeRegex=s.ctrlCharactersRegex=s.htmlCtrlEntityRegex=s.htmlEntitiesRegex=s.invalidProtocolRegex=void 0,s.invalidProtocolRegex=/^([^\w]*)(javascript|data|vbscript)/im,s.htmlEntitiesRegex=/(\w+)(^\w|;)?/g,s.htmlCtrlEntityRegex=/&(newline|tab);/gi,s.ctrlCharactersRegex=/[\u0000-\u001F\u007F-\u009F\u2000-\u200D\uFEFF]/gim,s.urlSchemeRegex=/^.+(:|:)/gim,s.whitespaceEscapeCharsRegex=/(\\|%5[cC])((%(6[eE]|72|74))|[nrt])/g,s.relativeFirstCharacters=[".","/"],s.BLANK_URL="about:blank"},16750:(o,s,i)=>{"use strict";s.J=void 0;var u=i(69119);function decodeURI(o){try{return decodeURIComponent(o)}catch(s){return o}}s.J=function sanitizeUrl(o){if(!o)return u.BLANK_URL;var s,i,_=decodeURI(o);do{s=(_=decodeURI(_=(i=_,i.replace(u.ctrlCharactersRegex,"").replace(u.htmlEntitiesRegex,(function(o,s){return String.fromCharCode(s)}))).replace(u.htmlCtrlEntityRegex,"").replace(u.ctrlCharactersRegex,"").replace(u.whitespaceEscapeCharsRegex,"").trim())).match(u.ctrlCharactersRegex)||_.match(u.htmlEntitiesRegex)||_.match(u.htmlCtrlEntityRegex)||_.match(u.whitespaceEscapeCharsRegex)}while(s&&s.length>0);var w=_;if(!w)return u.BLANK_URL;if(function isRelativeUrlWithoutProtocol(o){return u.relativeFirstCharacters.indexOf(o[0])>-1}(w))return w;var x=w.match(u.urlSchemeRegex);if(!x)return w;var C=x[0];return u.invalidProtocolRegex.test(C)?u.BLANK_URL:w}},67526:(o,s)=>{"use strict";s.byteLength=function byteLength(o){var s=getLens(o),i=s[0],u=s[1];return 3*(i+u)/4-u},s.toByteArray=function toByteArray(o){var s,i,w=getLens(o),x=w[0],C=w[1],j=new _(function _byteLength(o,s,i){return 3*(s+i)/4-i}(0,x,C)),L=0,B=C>0?x-4:x;for(i=0;i>16&255,j[L++]=s>>8&255,j[L++]=255&s;2===C&&(s=u[o.charCodeAt(i)]<<2|u[o.charCodeAt(i+1)]>>4,j[L++]=255&s);1===C&&(s=u[o.charCodeAt(i)]<<10|u[o.charCodeAt(i+1)]<<4|u[o.charCodeAt(i+2)]>>2,j[L++]=s>>8&255,j[L++]=255&s);return j},s.fromByteArray=function fromByteArray(o){for(var s,u=o.length,_=u%3,w=[],x=16383,C=0,j=u-_;Cj?j:C+x));1===_?(s=o[u-1],w.push(i[s>>2]+i[s<<4&63]+"==")):2===_&&(s=(o[u-2]<<8)+o[u-1],w.push(i[s>>10]+i[s>>4&63]+i[s<<2&63]+"="));return w.join("")};for(var i=[],u=[],_="undefined"!=typeof Uint8Array?Uint8Array:Array,w="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",x=0;x<64;++x)i[x]=w[x],u[w.charCodeAt(x)]=x;function getLens(o){var s=o.length;if(s%4>0)throw new Error("Invalid string. Length must be a multiple of 4");var i=o.indexOf("=");return-1===i&&(i=s),[i,i===s?0:4-i%4]}function encodeChunk(o,s,u){for(var _,w,x=[],C=s;C>18&63]+i[w>>12&63]+i[w>>6&63]+i[63&w]);return x.join("")}u["-".charCodeAt(0)]=62,u["_".charCodeAt(0)]=63},48287:(o,s,i)=>{"use strict";const u=i(67526),_=i(251),w="function"==typeof Symbol&&"function"==typeof Symbol.for?Symbol.for("nodejs.util.inspect.custom"):null;s.Buffer=Buffer,s.SlowBuffer=function SlowBuffer(o){+o!=o&&(o=0);return Buffer.alloc(+o)},s.INSPECT_MAX_BYTES=50;const x=2147483647;function createBuffer(o){if(o>x)throw new RangeError('The value "'+o+'" is invalid for option "size"');const s=new Uint8Array(o);return Object.setPrototypeOf(s,Buffer.prototype),s}function Buffer(o,s,i){if("number"==typeof o){if("string"==typeof s)throw new TypeError('The "string" argument must be of type string. Received type number');return allocUnsafe(o)}return from(o,s,i)}function from(o,s,i){if("string"==typeof o)return function fromString(o,s){"string"==typeof s&&""!==s||(s="utf8");if(!Buffer.isEncoding(s))throw new TypeError("Unknown encoding: "+s);const i=0|byteLength(o,s);let u=createBuffer(i);const _=u.write(o,s);_!==i&&(u=u.slice(0,_));return u}(o,s);if(ArrayBuffer.isView(o))return function fromArrayView(o){if(isInstance(o,Uint8Array)){const s=new Uint8Array(o);return fromArrayBuffer(s.buffer,s.byteOffset,s.byteLength)}return fromArrayLike(o)}(o);if(null==o)throw new TypeError("The first argument must be one of type string, Buffer, ArrayBuffer, Array, or Array-like Object. Received type "+typeof o);if(isInstance(o,ArrayBuffer)||o&&isInstance(o.buffer,ArrayBuffer))return fromArrayBuffer(o,s,i);if("undefined"!=typeof SharedArrayBuffer&&(isInstance(o,SharedArrayBuffer)||o&&isInstance(o.buffer,SharedArrayBuffer)))return fromArrayBuffer(o,s,i);if("number"==typeof o)throw new TypeError('The "value" argument must not be of type number. Received type number');const u=o.valueOf&&o.valueOf();if(null!=u&&u!==o)return Buffer.from(u,s,i);const _=function fromObject(o){if(Buffer.isBuffer(o)){const s=0|checked(o.length),i=createBuffer(s);return 0===i.length||o.copy(i,0,0,s),i}if(void 0!==o.length)return"number"!=typeof o.length||numberIsNaN(o.length)?createBuffer(0):fromArrayLike(o);if("Buffer"===o.type&&Array.isArray(o.data))return fromArrayLike(o.data)}(o);if(_)return _;if("undefined"!=typeof Symbol&&null!=Symbol.toPrimitive&&"function"==typeof o[Symbol.toPrimitive])return Buffer.from(o[Symbol.toPrimitive]("string"),s,i);throw new TypeError("The first argument must be one of type string, Buffer, ArrayBuffer, Array, or Array-like Object. Received type "+typeof o)}function assertSize(o){if("number"!=typeof o)throw new TypeError('"size" argument must be of type number');if(o<0)throw new RangeError('The value "'+o+'" is invalid for option "size"')}function allocUnsafe(o){return assertSize(o),createBuffer(o<0?0:0|checked(o))}function fromArrayLike(o){const s=o.length<0?0:0|checked(o.length),i=createBuffer(s);for(let u=0;u=x)throw new RangeError("Attempt to allocate Buffer larger than maximum size: 0x"+x.toString(16)+" bytes");return 0|o}function byteLength(o,s){if(Buffer.isBuffer(o))return o.length;if(ArrayBuffer.isView(o)||isInstance(o,ArrayBuffer))return o.byteLength;if("string"!=typeof o)throw new TypeError('The "string" argument must be one of type string, Buffer, or ArrayBuffer. Received type '+typeof o);const i=o.length,u=arguments.length>2&&!0===arguments[2];if(!u&&0===i)return 0;let _=!1;for(;;)switch(s){case"ascii":case"latin1":case"binary":return i;case"utf8":case"utf-8":return utf8ToBytes(o).length;case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return 2*i;case"hex":return i>>>1;case"base64":return base64ToBytes(o).length;default:if(_)return u?-1:utf8ToBytes(o).length;s=(""+s).toLowerCase(),_=!0}}function slowToString(o,s,i){let u=!1;if((void 0===s||s<0)&&(s=0),s>this.length)return"";if((void 0===i||i>this.length)&&(i=this.length),i<=0)return"";if((i>>>=0)<=(s>>>=0))return"";for(o||(o="utf8");;)switch(o){case"hex":return hexSlice(this,s,i);case"utf8":case"utf-8":return utf8Slice(this,s,i);case"ascii":return asciiSlice(this,s,i);case"latin1":case"binary":return latin1Slice(this,s,i);case"base64":return base64Slice(this,s,i);case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return utf16leSlice(this,s,i);default:if(u)throw new TypeError("Unknown encoding: "+o);o=(o+"").toLowerCase(),u=!0}}function swap(o,s,i){const u=o[s];o[s]=o[i],o[i]=u}function bidirectionalIndexOf(o,s,i,u,_){if(0===o.length)return-1;if("string"==typeof i?(u=i,i=0):i>2147483647?i=2147483647:i<-2147483648&&(i=-2147483648),numberIsNaN(i=+i)&&(i=_?0:o.length-1),i<0&&(i=o.length+i),i>=o.length){if(_)return-1;i=o.length-1}else if(i<0){if(!_)return-1;i=0}if("string"==typeof s&&(s=Buffer.from(s,u)),Buffer.isBuffer(s))return 0===s.length?-1:arrayIndexOf(o,s,i,u,_);if("number"==typeof s)return s&=255,"function"==typeof Uint8Array.prototype.indexOf?_?Uint8Array.prototype.indexOf.call(o,s,i):Uint8Array.prototype.lastIndexOf.call(o,s,i):arrayIndexOf(o,[s],i,u,_);throw new TypeError("val must be string, number or Buffer")}function arrayIndexOf(o,s,i,u,_){let w,x=1,C=o.length,j=s.length;if(void 0!==u&&("ucs2"===(u=String(u).toLowerCase())||"ucs-2"===u||"utf16le"===u||"utf-16le"===u)){if(o.length<2||s.length<2)return-1;x=2,C/=2,j/=2,i/=2}function read(o,s){return 1===x?o[s]:o.readUInt16BE(s*x)}if(_){let u=-1;for(w=i;wC&&(i=C-j),w=i;w>=0;w--){let i=!0;for(let u=0;u_&&(u=_):u=_;const w=s.length;let x;for(u>w/2&&(u=w/2),x=0;x>8,_=i%256,w.push(_),w.push(u);return w}(s,o.length-i),o,i,u)}function base64Slice(o,s,i){return 0===s&&i===o.length?u.fromByteArray(o):u.fromByteArray(o.slice(s,i))}function utf8Slice(o,s,i){i=Math.min(o.length,i);const u=[];let _=s;for(;_239?4:s>223?3:s>191?2:1;if(_+x<=i){let i,u,C,j;switch(x){case 1:s<128&&(w=s);break;case 2:i=o[_+1],128==(192&i)&&(j=(31&s)<<6|63&i,j>127&&(w=j));break;case 3:i=o[_+1],u=o[_+2],128==(192&i)&&128==(192&u)&&(j=(15&s)<<12|(63&i)<<6|63&u,j>2047&&(j<55296||j>57343)&&(w=j));break;case 4:i=o[_+1],u=o[_+2],C=o[_+3],128==(192&i)&&128==(192&u)&&128==(192&C)&&(j=(15&s)<<18|(63&i)<<12|(63&u)<<6|63&C,j>65535&&j<1114112&&(w=j))}}null===w?(w=65533,x=1):w>65535&&(w-=65536,u.push(w>>>10&1023|55296),w=56320|1023&w),u.push(w),_+=x}return function decodeCodePointsArray(o){const s=o.length;if(s<=C)return String.fromCharCode.apply(String,o);let i="",u=0;for(;uu.length?(Buffer.isBuffer(s)||(s=Buffer.from(s)),s.copy(u,_)):Uint8Array.prototype.set.call(u,s,_);else{if(!Buffer.isBuffer(s))throw new TypeError('"list" argument must be an Array of Buffers');s.copy(u,_)}_+=s.length}return u},Buffer.byteLength=byteLength,Buffer.prototype._isBuffer=!0,Buffer.prototype.swap16=function swap16(){const o=this.length;if(o%2!=0)throw new RangeError("Buffer size must be a multiple of 16-bits");for(let s=0;si&&(o+=" ... "),""},w&&(Buffer.prototype[w]=Buffer.prototype.inspect),Buffer.prototype.compare=function compare(o,s,i,u,_){if(isInstance(o,Uint8Array)&&(o=Buffer.from(o,o.offset,o.byteLength)),!Buffer.isBuffer(o))throw new TypeError('The "target" argument must be one of type Buffer or Uint8Array. Received type '+typeof o);if(void 0===s&&(s=0),void 0===i&&(i=o?o.length:0),void 0===u&&(u=0),void 0===_&&(_=this.length),s<0||i>o.length||u<0||_>this.length)throw new RangeError("out of range index");if(u>=_&&s>=i)return 0;if(u>=_)return-1;if(s>=i)return 1;if(this===o)return 0;let w=(_>>>=0)-(u>>>=0),x=(i>>>=0)-(s>>>=0);const C=Math.min(w,x),j=this.slice(u,_),L=o.slice(s,i);for(let o=0;o>>=0,isFinite(i)?(i>>>=0,void 0===u&&(u="utf8")):(u=i,i=void 0)}const _=this.length-s;if((void 0===i||i>_)&&(i=_),o.length>0&&(i<0||s<0)||s>this.length)throw new RangeError("Attempt to write outside buffer bounds");u||(u="utf8");let w=!1;for(;;)switch(u){case"hex":return hexWrite(this,o,s,i);case"utf8":case"utf-8":return utf8Write(this,o,s,i);case"ascii":case"latin1":case"binary":return asciiWrite(this,o,s,i);case"base64":return base64Write(this,o,s,i);case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return ucs2Write(this,o,s,i);default:if(w)throw new TypeError("Unknown encoding: "+u);u=(""+u).toLowerCase(),w=!0}},Buffer.prototype.toJSON=function toJSON(){return{type:"Buffer",data:Array.prototype.slice.call(this._arr||this,0)}};const C=4096;function asciiSlice(o,s,i){let u="";i=Math.min(o.length,i);for(let _=s;_u)&&(i=u);let _="";for(let u=s;ui)throw new RangeError("Trying to access beyond buffer length")}function checkInt(o,s,i,u,_,w){if(!Buffer.isBuffer(o))throw new TypeError('"buffer" argument must be a Buffer instance');if(s>_||so.length)throw new RangeError("Index out of range")}function wrtBigUInt64LE(o,s,i,u,_){checkIntBI(s,u,_,o,i,7);let w=Number(s&BigInt(4294967295));o[i++]=w,w>>=8,o[i++]=w,w>>=8,o[i++]=w,w>>=8,o[i++]=w;let x=Number(s>>BigInt(32)&BigInt(4294967295));return o[i++]=x,x>>=8,o[i++]=x,x>>=8,o[i++]=x,x>>=8,o[i++]=x,i}function wrtBigUInt64BE(o,s,i,u,_){checkIntBI(s,u,_,o,i,7);let w=Number(s&BigInt(4294967295));o[i+7]=w,w>>=8,o[i+6]=w,w>>=8,o[i+5]=w,w>>=8,o[i+4]=w;let x=Number(s>>BigInt(32)&BigInt(4294967295));return o[i+3]=x,x>>=8,o[i+2]=x,x>>=8,o[i+1]=x,x>>=8,o[i]=x,i+8}function checkIEEE754(o,s,i,u,_,w){if(i+u>o.length)throw new RangeError("Index out of range");if(i<0)throw new RangeError("Index out of range")}function writeFloat(o,s,i,u,w){return s=+s,i>>>=0,w||checkIEEE754(o,0,i,4),_.write(o,s,i,u,23,4),i+4}function writeDouble(o,s,i,u,w){return s=+s,i>>>=0,w||checkIEEE754(o,0,i,8),_.write(o,s,i,u,52,8),i+8}Buffer.prototype.slice=function slice(o,s){const i=this.length;(o=~~o)<0?(o+=i)<0&&(o=0):o>i&&(o=i),(s=void 0===s?i:~~s)<0?(s+=i)<0&&(s=0):s>i&&(s=i),s>>=0,s>>>=0,i||checkOffset(o,s,this.length);let u=this[o],_=1,w=0;for(;++w>>=0,s>>>=0,i||checkOffset(o,s,this.length);let u=this[o+--s],_=1;for(;s>0&&(_*=256);)u+=this[o+--s]*_;return u},Buffer.prototype.readUint8=Buffer.prototype.readUInt8=function readUInt8(o,s){return o>>>=0,s||checkOffset(o,1,this.length),this[o]},Buffer.prototype.readUint16LE=Buffer.prototype.readUInt16LE=function readUInt16LE(o,s){return o>>>=0,s||checkOffset(o,2,this.length),this[o]|this[o+1]<<8},Buffer.prototype.readUint16BE=Buffer.prototype.readUInt16BE=function readUInt16BE(o,s){return o>>>=0,s||checkOffset(o,2,this.length),this[o]<<8|this[o+1]},Buffer.prototype.readUint32LE=Buffer.prototype.readUInt32LE=function readUInt32LE(o,s){return o>>>=0,s||checkOffset(o,4,this.length),(this[o]|this[o+1]<<8|this[o+2]<<16)+16777216*this[o+3]},Buffer.prototype.readUint32BE=Buffer.prototype.readUInt32BE=function readUInt32BE(o,s){return o>>>=0,s||checkOffset(o,4,this.length),16777216*this[o]+(this[o+1]<<16|this[o+2]<<8|this[o+3])},Buffer.prototype.readBigUInt64LE=defineBigIntMethod((function readBigUInt64LE(o){validateNumber(o>>>=0,"offset");const s=this[o],i=this[o+7];void 0!==s&&void 0!==i||boundsError(o,this.length-8);const u=s+256*this[++o]+65536*this[++o]+this[++o]*2**24,_=this[++o]+256*this[++o]+65536*this[++o]+i*2**24;return BigInt(u)+(BigInt(_)<>>=0,"offset");const s=this[o],i=this[o+7];void 0!==s&&void 0!==i||boundsError(o,this.length-8);const u=s*2**24+65536*this[++o]+256*this[++o]+this[++o],_=this[++o]*2**24+65536*this[++o]+256*this[++o]+i;return(BigInt(u)<>>=0,s>>>=0,i||checkOffset(o,s,this.length);let u=this[o],_=1,w=0;for(;++w=_&&(u-=Math.pow(2,8*s)),u},Buffer.prototype.readIntBE=function readIntBE(o,s,i){o>>>=0,s>>>=0,i||checkOffset(o,s,this.length);let u=s,_=1,w=this[o+--u];for(;u>0&&(_*=256);)w+=this[o+--u]*_;return _*=128,w>=_&&(w-=Math.pow(2,8*s)),w},Buffer.prototype.readInt8=function readInt8(o,s){return o>>>=0,s||checkOffset(o,1,this.length),128&this[o]?-1*(255-this[o]+1):this[o]},Buffer.prototype.readInt16LE=function readInt16LE(o,s){o>>>=0,s||checkOffset(o,2,this.length);const i=this[o]|this[o+1]<<8;return 32768&i?4294901760|i:i},Buffer.prototype.readInt16BE=function readInt16BE(o,s){o>>>=0,s||checkOffset(o,2,this.length);const i=this[o+1]|this[o]<<8;return 32768&i?4294901760|i:i},Buffer.prototype.readInt32LE=function readInt32LE(o,s){return o>>>=0,s||checkOffset(o,4,this.length),this[o]|this[o+1]<<8|this[o+2]<<16|this[o+3]<<24},Buffer.prototype.readInt32BE=function readInt32BE(o,s){return o>>>=0,s||checkOffset(o,4,this.length),this[o]<<24|this[o+1]<<16|this[o+2]<<8|this[o+3]},Buffer.prototype.readBigInt64LE=defineBigIntMethod((function readBigInt64LE(o){validateNumber(o>>>=0,"offset");const s=this[o],i=this[o+7];void 0!==s&&void 0!==i||boundsError(o,this.length-8);const u=this[o+4]+256*this[o+5]+65536*this[o+6]+(i<<24);return(BigInt(u)<>>=0,"offset");const s=this[o],i=this[o+7];void 0!==s&&void 0!==i||boundsError(o,this.length-8);const u=(s<<24)+65536*this[++o]+256*this[++o]+this[++o];return(BigInt(u)<>>=0,s||checkOffset(o,4,this.length),_.read(this,o,!0,23,4)},Buffer.prototype.readFloatBE=function readFloatBE(o,s){return o>>>=0,s||checkOffset(o,4,this.length),_.read(this,o,!1,23,4)},Buffer.prototype.readDoubleLE=function readDoubleLE(o,s){return o>>>=0,s||checkOffset(o,8,this.length),_.read(this,o,!0,52,8)},Buffer.prototype.readDoubleBE=function readDoubleBE(o,s){return o>>>=0,s||checkOffset(o,8,this.length),_.read(this,o,!1,52,8)},Buffer.prototype.writeUintLE=Buffer.prototype.writeUIntLE=function writeUIntLE(o,s,i,u){if(o=+o,s>>>=0,i>>>=0,!u){checkInt(this,o,s,i,Math.pow(2,8*i)-1,0)}let _=1,w=0;for(this[s]=255&o;++w>>=0,i>>>=0,!u){checkInt(this,o,s,i,Math.pow(2,8*i)-1,0)}let _=i-1,w=1;for(this[s+_]=255&o;--_>=0&&(w*=256);)this[s+_]=o/w&255;return s+i},Buffer.prototype.writeUint8=Buffer.prototype.writeUInt8=function writeUInt8(o,s,i){return o=+o,s>>>=0,i||checkInt(this,o,s,1,255,0),this[s]=255&o,s+1},Buffer.prototype.writeUint16LE=Buffer.prototype.writeUInt16LE=function writeUInt16LE(o,s,i){return o=+o,s>>>=0,i||checkInt(this,o,s,2,65535,0),this[s]=255&o,this[s+1]=o>>>8,s+2},Buffer.prototype.writeUint16BE=Buffer.prototype.writeUInt16BE=function writeUInt16BE(o,s,i){return o=+o,s>>>=0,i||checkInt(this,o,s,2,65535,0),this[s]=o>>>8,this[s+1]=255&o,s+2},Buffer.prototype.writeUint32LE=Buffer.prototype.writeUInt32LE=function writeUInt32LE(o,s,i){return o=+o,s>>>=0,i||checkInt(this,o,s,4,4294967295,0),this[s+3]=o>>>24,this[s+2]=o>>>16,this[s+1]=o>>>8,this[s]=255&o,s+4},Buffer.prototype.writeUint32BE=Buffer.prototype.writeUInt32BE=function writeUInt32BE(o,s,i){return o=+o,s>>>=0,i||checkInt(this,o,s,4,4294967295,0),this[s]=o>>>24,this[s+1]=o>>>16,this[s+2]=o>>>8,this[s+3]=255&o,s+4},Buffer.prototype.writeBigUInt64LE=defineBigIntMethod((function writeBigUInt64LE(o,s=0){return wrtBigUInt64LE(this,o,s,BigInt(0),BigInt("0xffffffffffffffff"))})),Buffer.prototype.writeBigUInt64BE=defineBigIntMethod((function writeBigUInt64BE(o,s=0){return wrtBigUInt64BE(this,o,s,BigInt(0),BigInt("0xffffffffffffffff"))})),Buffer.prototype.writeIntLE=function writeIntLE(o,s,i,u){if(o=+o,s>>>=0,!u){const u=Math.pow(2,8*i-1);checkInt(this,o,s,i,u-1,-u)}let _=0,w=1,x=0;for(this[s]=255&o;++_>>=0,!u){const u=Math.pow(2,8*i-1);checkInt(this,o,s,i,u-1,-u)}let _=i-1,w=1,x=0;for(this[s+_]=255&o;--_>=0&&(w*=256);)o<0&&0===x&&0!==this[s+_+1]&&(x=1),this[s+_]=(o/w|0)-x&255;return s+i},Buffer.prototype.writeInt8=function writeInt8(o,s,i){return o=+o,s>>>=0,i||checkInt(this,o,s,1,127,-128),o<0&&(o=255+o+1),this[s]=255&o,s+1},Buffer.prototype.writeInt16LE=function writeInt16LE(o,s,i){return o=+o,s>>>=0,i||checkInt(this,o,s,2,32767,-32768),this[s]=255&o,this[s+1]=o>>>8,s+2},Buffer.prototype.writeInt16BE=function writeInt16BE(o,s,i){return o=+o,s>>>=0,i||checkInt(this,o,s,2,32767,-32768),this[s]=o>>>8,this[s+1]=255&o,s+2},Buffer.prototype.writeInt32LE=function writeInt32LE(o,s,i){return o=+o,s>>>=0,i||checkInt(this,o,s,4,2147483647,-2147483648),this[s]=255&o,this[s+1]=o>>>8,this[s+2]=o>>>16,this[s+3]=o>>>24,s+4},Buffer.prototype.writeInt32BE=function writeInt32BE(o,s,i){return o=+o,s>>>=0,i||checkInt(this,o,s,4,2147483647,-2147483648),o<0&&(o=4294967295+o+1),this[s]=o>>>24,this[s+1]=o>>>16,this[s+2]=o>>>8,this[s+3]=255&o,s+4},Buffer.prototype.writeBigInt64LE=defineBigIntMethod((function writeBigInt64LE(o,s=0){return wrtBigUInt64LE(this,o,s,-BigInt("0x8000000000000000"),BigInt("0x7fffffffffffffff"))})),Buffer.prototype.writeBigInt64BE=defineBigIntMethod((function writeBigInt64BE(o,s=0){return wrtBigUInt64BE(this,o,s,-BigInt("0x8000000000000000"),BigInt("0x7fffffffffffffff"))})),Buffer.prototype.writeFloatLE=function writeFloatLE(o,s,i){return writeFloat(this,o,s,!0,i)},Buffer.prototype.writeFloatBE=function writeFloatBE(o,s,i){return writeFloat(this,o,s,!1,i)},Buffer.prototype.writeDoubleLE=function writeDoubleLE(o,s,i){return writeDouble(this,o,s,!0,i)},Buffer.prototype.writeDoubleBE=function writeDoubleBE(o,s,i){return writeDouble(this,o,s,!1,i)},Buffer.prototype.copy=function copy(o,s,i,u){if(!Buffer.isBuffer(o))throw new TypeError("argument should be a Buffer");if(i||(i=0),u||0===u||(u=this.length),s>=o.length&&(s=o.length),s||(s=0),u>0&&u=this.length)throw new RangeError("Index out of range");if(u<0)throw new RangeError("sourceEnd out of bounds");u>this.length&&(u=this.length),o.length-s>>=0,i=void 0===i?this.length:i>>>0,o||(o=0),"number"==typeof o)for(_=s;_=u+4;i-=3)s=`_${o.slice(i-3,i)}${s}`;return`${o.slice(0,i)}${s}`}function checkIntBI(o,s,i,u,_,w){if(o>i||o3?0===s||s===BigInt(0)?`>= 0${u} and < 2${u} ** ${8*(w+1)}${u}`:`>= -(2${u} ** ${8*(w+1)-1}${u}) and < 2 ** ${8*(w+1)-1}${u}`:`>= ${s}${u} and <= ${i}${u}`,new j.ERR_OUT_OF_RANGE("value",_,o)}!function checkBounds(o,s,i){validateNumber(s,"offset"),void 0!==o[s]&&void 0!==o[s+i]||boundsError(s,o.length-(i+1))}(u,_,w)}function validateNumber(o,s){if("number"!=typeof o)throw new j.ERR_INVALID_ARG_TYPE(s,"number",o)}function boundsError(o,s,i){if(Math.floor(o)!==o)throw validateNumber(o,i),new j.ERR_OUT_OF_RANGE(i||"offset","an integer",o);if(s<0)throw new j.ERR_BUFFER_OUT_OF_BOUNDS;throw new j.ERR_OUT_OF_RANGE(i||"offset",`>= ${i?1:0} and <= ${s}`,o)}E("ERR_BUFFER_OUT_OF_BOUNDS",(function(o){return o?`${o} is outside of buffer bounds`:"Attempt to access memory outside buffer bounds"}),RangeError),E("ERR_INVALID_ARG_TYPE",(function(o,s){return`The "${o}" argument must be of type number. Received type ${typeof s}`}),TypeError),E("ERR_OUT_OF_RANGE",(function(o,s,i){let u=`The value of "${o}" is out of range.`,_=i;return Number.isInteger(i)&&Math.abs(i)>2**32?_=addNumericalSeparator(String(i)):"bigint"==typeof i&&(_=String(i),(i>BigInt(2)**BigInt(32)||i<-(BigInt(2)**BigInt(32)))&&(_=addNumericalSeparator(_)),_+="n"),u+=` It must be ${s}. Received ${_}`,u}),RangeError);const L=/[^+/0-9A-Za-z-_]/g;function utf8ToBytes(o,s){let i;s=s||1/0;const u=o.length;let _=null;const w=[];for(let x=0;x55295&&i<57344){if(!_){if(i>56319){(s-=3)>-1&&w.push(239,191,189);continue}if(x+1===u){(s-=3)>-1&&w.push(239,191,189);continue}_=i;continue}if(i<56320){(s-=3)>-1&&w.push(239,191,189),_=i;continue}i=65536+(_-55296<<10|i-56320)}else _&&(s-=3)>-1&&w.push(239,191,189);if(_=null,i<128){if((s-=1)<0)break;w.push(i)}else if(i<2048){if((s-=2)<0)break;w.push(i>>6|192,63&i|128)}else if(i<65536){if((s-=3)<0)break;w.push(i>>12|224,i>>6&63|128,63&i|128)}else{if(!(i<1114112))throw new Error("Invalid code point");if((s-=4)<0)break;w.push(i>>18|240,i>>12&63|128,i>>6&63|128,63&i|128)}}return w}function base64ToBytes(o){return u.toByteArray(function base64clean(o){if((o=(o=o.split("=")[0]).trim().replace(L,"")).length<2)return"";for(;o.length%4!=0;)o+="=";return o}(o))}function blitBuffer(o,s,i,u){let _;for(_=0;_=s.length||_>=o.length);++_)s[_+i]=o[_];return _}function isInstance(o,s){return o instanceof s||null!=o&&null!=o.constructor&&null!=o.constructor.name&&o.constructor.name===s.name}function numberIsNaN(o){return o!=o}const B=function(){const o="0123456789abcdef",s=new Array(256);for(let i=0;i<16;++i){const u=16*i;for(let _=0;_<16;++_)s[u+_]=o[i]+o[_]}return s}();function defineBigIntMethod(o){return"undefined"==typeof BigInt?BufferBigIntNotDefined:o}function BufferBigIntNotDefined(){throw new Error("BigInt not supported")}},38075:(o,s,i)=>{"use strict";var u=i(70453),_=i(10487),w=_(u("String.prototype.indexOf"));o.exports=function callBoundIntrinsic(o,s){var i=u(o,!!s);return"function"==typeof i&&w(o,".prototype.")>-1?_(i):i}},10487:(o,s,i)=>{"use strict";var u=i(66743),_=i(70453),w=i(96897),x=i(69675),C=_("%Function.prototype.apply%"),j=_("%Function.prototype.call%"),L=_("%Reflect.apply%",!0)||u.call(j,C),B=i(30655),$=_("%Math.max%");o.exports=function callBind(o){if("function"!=typeof o)throw new x("a function is required");var s=L(u,j,arguments);return w(s,1+$(0,o.length-(arguments.length-1)),!0)};var V=function applyBind(){return L(u,C,arguments)};B?B(o.exports,"apply",{value:V}):o.exports.apply=V},57427:(o,s)=>{"use strict";s.parse=function parse(o,s){if("string"!=typeof o)throw new TypeError("argument str must be a string");var i={},u=(s||{}).decode||decode,_=0;for(;_{"use strict";var u=i(16426),_={"text/plain":"Text","text/html":"Url",default:"Text"};o.exports=function copy(o,s){var i,w,x,C,j,L,B=!1;s||(s={}),i=s.debug||!1;try{if(x=u(),C=document.createRange(),j=document.getSelection(),(L=document.createElement("span")).textContent=o,L.ariaHidden="true",L.style.all="unset",L.style.position="fixed",L.style.top=0,L.style.clip="rect(0, 0, 0, 0)",L.style.whiteSpace="pre",L.style.webkitUserSelect="text",L.style.MozUserSelect="text",L.style.msUserSelect="text",L.style.userSelect="text",L.addEventListener("copy",(function(u){if(u.stopPropagation(),s.format)if(u.preventDefault(),void 0===u.clipboardData){i&&console.warn("unable to use e.clipboardData"),i&&console.warn("trying IE specific stuff"),window.clipboardData.clearData();var w=_[s.format]||_.default;window.clipboardData.setData(w,o)}else u.clipboardData.clearData(),u.clipboardData.setData(s.format,o);s.onCopy&&(u.preventDefault(),s.onCopy(u.clipboardData))})),document.body.appendChild(L),C.selectNodeContents(L),j.addRange(C),!document.execCommand("copy"))throw new Error("copy command was unsuccessful");B=!0}catch(u){i&&console.error("unable to copy using execCommand: ",u),i&&console.warn("trying IE specific stuff");try{window.clipboardData.setData(s.format||"text",o),s.onCopy&&s.onCopy(window.clipboardData),B=!0}catch(u){i&&console.error("unable to copy using clipboardData: ",u),i&&console.error("falling back to prompt"),w=function format(o){var s=(/mac os x/i.test(navigator.userAgent)?"⌘":"Ctrl")+"+C";return o.replace(/#{\s*key\s*}/g,s)}("message"in s?s.message:"Copy to clipboard: #{key}, Enter"),window.prompt(w,o)}}finally{j&&("function"==typeof j.removeRange?j.removeRange(C):j.removeAllRanges()),L&&document.body.removeChild(L),x()}return B}},2205:function(o,s,i){var u;u=void 0!==i.g?i.g:this,o.exports=function(o){if(o.CSS&&o.CSS.escape)return o.CSS.escape;var cssEscape=function(o){if(0==arguments.length)throw new TypeError("`CSS.escape` requires an argument.");for(var s,i=String(o),u=i.length,_=-1,w="",x=i.charCodeAt(0);++_=1&&s<=31||127==s||0==_&&s>=48&&s<=57||1==_&&s>=48&&s<=57&&45==x?"\\"+s.toString(16)+" ":0==_&&1==u&&45==s||!(s>=128||45==s||95==s||s>=48&&s<=57||s>=65&&s<=90||s>=97&&s<=122)?"\\"+i.charAt(_):i.charAt(_):w+="�";return w};return o.CSS||(o.CSS={}),o.CSS.escape=cssEscape,cssEscape}(u)},81919:(o,s,i)=>{"use strict";var u=i(48287).Buffer;function isSpecificValue(o){return o instanceof u||o instanceof Date||o instanceof RegExp}function cloneSpecificValue(o){if(o instanceof u){var s=u.alloc?u.alloc(o.length):new u(o.length);return o.copy(s),s}if(o instanceof Date)return new Date(o.getTime());if(o instanceof RegExp)return new RegExp(o);throw new Error("Unexpected situation")}function deepCloneArray(o){var s=[];return o.forEach((function(o,i){"object"==typeof o&&null!==o?Array.isArray(o)?s[i]=deepCloneArray(o):isSpecificValue(o)?s[i]=cloneSpecificValue(o):s[i]=_({},o):s[i]=o})),s}function safeGetProperty(o,s){return"__proto__"===s?void 0:o[s]}var _=o.exports=function(){if(arguments.length<1||"object"!=typeof arguments[0])return!1;if(arguments.length<2)return arguments[0];var o,s,i=arguments[0];return Array.prototype.slice.call(arguments,1).forEach((function(u){"object"!=typeof u||null===u||Array.isArray(u)||Object.keys(u).forEach((function(w){return s=safeGetProperty(i,w),(o=safeGetProperty(u,w))===i?void 0:"object"!=typeof o||null===o?void(i[w]=o):Array.isArray(o)?void(i[w]=deepCloneArray(o)):isSpecificValue(o)?void(i[w]=cloneSpecificValue(o)):"object"!=typeof s||null===s||Array.isArray(s)?void(i[w]=_({},o)):void(i[w]=_(s,o))}))})),i}},14744:o=>{"use strict";var s=function isMergeableObject(o){return function isNonNullObject(o){return!!o&&"object"==typeof o}(o)&&!function isSpecial(o){var s=Object.prototype.toString.call(o);return"[object RegExp]"===s||"[object Date]"===s||function isReactElement(o){return o.$$typeof===i}(o)}(o)};var i="function"==typeof Symbol&&Symbol.for?Symbol.for("react.element"):60103;function cloneUnlessOtherwiseSpecified(o,s){return!1!==s.clone&&s.isMergeableObject(o)?deepmerge(function emptyTarget(o){return Array.isArray(o)?[]:{}}(o),o,s):o}function defaultArrayMerge(o,s,i){return o.concat(s).map((function(o){return cloneUnlessOtherwiseSpecified(o,i)}))}function getKeys(o){return Object.keys(o).concat(function getEnumerableOwnPropertySymbols(o){return Object.getOwnPropertySymbols?Object.getOwnPropertySymbols(o).filter((function(s){return Object.propertyIsEnumerable.call(o,s)})):[]}(o))}function propertyIsOnObject(o,s){try{return s in o}catch(o){return!1}}function mergeObject(o,s,i){var u={};return i.isMergeableObject(o)&&getKeys(o).forEach((function(s){u[s]=cloneUnlessOtherwiseSpecified(o[s],i)})),getKeys(s).forEach((function(_){(function propertyIsUnsafe(o,s){return propertyIsOnObject(o,s)&&!(Object.hasOwnProperty.call(o,s)&&Object.propertyIsEnumerable.call(o,s))})(o,_)||(propertyIsOnObject(o,_)&&i.isMergeableObject(s[_])?u[_]=function getMergeFunction(o,s){if(!s.customMerge)return deepmerge;var i=s.customMerge(o);return"function"==typeof i?i:deepmerge}(_,i)(o[_],s[_],i):u[_]=cloneUnlessOtherwiseSpecified(s[_],i))})),u}function deepmerge(o,i,u){(u=u||{}).arrayMerge=u.arrayMerge||defaultArrayMerge,u.isMergeableObject=u.isMergeableObject||s,u.cloneUnlessOtherwiseSpecified=cloneUnlessOtherwiseSpecified;var _=Array.isArray(i);return _===Array.isArray(o)?_?u.arrayMerge(o,i,u):mergeObject(o,i,u):cloneUnlessOtherwiseSpecified(i,u)}deepmerge.all=function deepmergeAll(o,s){if(!Array.isArray(o))throw new Error("first argument should be an array");return o.reduce((function(o,i){return deepmerge(o,i,s)}),{})};var u=deepmerge;o.exports=u},30041:(o,s,i)=>{"use strict";var u=i(30655),_=i(58068),w=i(69675),x=i(75795);o.exports=function defineDataProperty(o,s,i){if(!o||"object"!=typeof o&&"function"!=typeof o)throw new w("`obj` must be an object or a function`");if("string"!=typeof s&&"symbol"!=typeof s)throw new w("`property` must be a string or a symbol`");if(arguments.length>3&&"boolean"!=typeof arguments[3]&&null!==arguments[3])throw new w("`nonEnumerable`, if provided, must be a boolean or null");if(arguments.length>4&&"boolean"!=typeof arguments[4]&&null!==arguments[4])throw new w("`nonWritable`, if provided, must be a boolean or null");if(arguments.length>5&&"boolean"!=typeof arguments[5]&&null!==arguments[5])throw new w("`nonConfigurable`, if provided, must be a boolean or null");if(arguments.length>6&&"boolean"!=typeof arguments[6])throw new w("`loose`, if provided, must be a boolean");var C=arguments.length>3?arguments[3]:null,j=arguments.length>4?arguments[4]:null,L=arguments.length>5?arguments[5]:null,B=arguments.length>6&&arguments[6],$=!!x&&x(o,s);if(u)u(o,s,{configurable:null===L&&$?$.configurable:!L,enumerable:null===C&&$?$.enumerable:!C,value:i,writable:null===j&&$?$.writable:!j});else{if(!B&&(C||j||L))throw new _("This environment does not support defining a property as non-configurable, non-writable, or non-enumerable.");o[s]=i}}},42838:function(o){o.exports=function(){"use strict";const{entries:o,setPrototypeOf:s,isFrozen:i,getPrototypeOf:u,getOwnPropertyDescriptor:_}=Object;let{freeze:w,seal:x,create:C}=Object,{apply:j,construct:L}="undefined"!=typeof Reflect&&Reflect;w||(w=function freeze(o){return o}),x||(x=function seal(o){return o}),j||(j=function apply(o,s,i){return o.apply(s,i)}),L||(L=function construct(o,s){return new o(...s)});const B=unapply(Array.prototype.forEach),$=unapply(Array.prototype.pop),V=unapply(Array.prototype.push),U=unapply(String.prototype.toLowerCase),z=unapply(String.prototype.toString),Y=unapply(String.prototype.match),Z=unapply(String.prototype.replace),ee=unapply(String.prototype.indexOf),ie=unapply(String.prototype.trim),ae=unapply(Object.prototype.hasOwnProperty),ce=unapply(RegExp.prototype.test),le=unconstruct(TypeError);function numberIsNaN(o){return"number"==typeof o&&isNaN(o)}function unapply(o){return function(s){for(var i=arguments.length,u=new Array(i>1?i-1:0),_=1;_2&&void 0!==arguments[2]?arguments[2]:U;s&&s(o,null);let w=u.length;for(;w--;){let s=u[w];if("string"==typeof s){const o=_(s);o!==s&&(i(u)||(u[w]=o),s=o)}o[s]=!0}return o}function cleanArray(o){for(let s=0;s/gm),$e=x(/\${[\w\W]*}/gm),ze=x(/^data-[\-\w.\u00B7-\uFFFF]/),We=x(/^aria-[\-\w]+$/),He=x(/^(?:(?:(?:f|ht)tps?|mailto|tel|callto|sms|cid|xmpp):|[^a-z]|[a-z+.\-]+(?:[^a-z+.\-:]|$))/i),Ye=x(/^(?:\w+script|data):/i),Xe=x(/[\u0000-\u0020\u00A0\u1680\u180E\u2000-\u2029\u205F\u3000]/g),Qe=x(/^html$/i),et=x(/^[a-z][.\w]*(-[.\w]+)+$/i);var tt=Object.freeze({__proto__:null,MUSTACHE_EXPR:Re,ERB_EXPR:qe,TMPLIT_EXPR:$e,DATA_ATTR:ze,ARIA_ATTR:We,IS_ALLOWED_URI:He,IS_SCRIPT_OR_DATA:Ye,ATTR_WHITESPACE:Xe,DOCTYPE_NAME:Qe,CUSTOM_ELEMENT:et});const rt={element:1,attribute:2,text:3,cdataSection:4,entityReference:5,entityNode:6,progressingInstruction:7,comment:8,document:9,documentType:10,documentFragment:11,notation:12},nt=function getGlobal(){return"undefined"==typeof window?null:window},ot=function _createTrustedTypesPolicy(o,s){if("object"!=typeof o||"function"!=typeof o.createPolicy)return null;let i=null;const u="data-tt-policy-suffix";s&&s.hasAttribute(u)&&(i=s.getAttribute(u));const _="dompurify"+(i?"#"+i:"");try{return o.createPolicy(_,{createHTML:o=>o,createScriptURL:o=>o})}catch(o){return console.warn("TrustedTypes policy "+_+" could not be created."),null}};function createDOMPurify(){let s=arguments.length>0&&void 0!==arguments[0]?arguments[0]:nt();const DOMPurify=o=>createDOMPurify(o);if(DOMPurify.version="3.1.4",DOMPurify.removed=[],!s||!s.document||s.document.nodeType!==rt.document)return DOMPurify.isSupported=!1,DOMPurify;let{document:i}=s;const u=i,_=u.currentScript,{DocumentFragment:x,HTMLTemplateElement:j,Node:L,Element:Re,NodeFilter:qe,NamedNodeMap:$e=s.NamedNodeMap||s.MozNamedAttrMap,HTMLFormElement:ze,DOMParser:We,trustedTypes:Ye}=s,Xe=Re.prototype,et=lookupGetter(Xe,"cloneNode"),st=lookupGetter(Xe,"nextSibling"),it=lookupGetter(Xe,"childNodes"),at=lookupGetter(Xe,"parentNode");if("function"==typeof j){const o=i.createElement("template");o.content&&o.content.ownerDocument&&(i=o.content.ownerDocument)}let ct,lt="";const{implementation:ut,createNodeIterator:pt,createDocumentFragment:ht,getElementsByTagName:dt}=i,{importNode:mt}=u;let gt={};DOMPurify.isSupported="function"==typeof o&&"function"==typeof at&&ut&&void 0!==ut.createHTMLDocument;const{MUSTACHE_EXPR:yt,ERB_EXPR:vt,TMPLIT_EXPR:bt,DATA_ATTR:_t,ARIA_ATTR:Et,IS_SCRIPT_OR_DATA:wt,ATTR_WHITESPACE:St,CUSTOM_ELEMENT:xt}=tt;let{IS_ALLOWED_URI:kt}=tt,Ot=null;const Ct=addToSet({},[...pe,...de,...fe,...be,...we]);let At=null;const jt=addToSet({},[...Se,...xe,...Pe,...Te]);let Pt=Object.seal(C(null,{tagNameCheck:{writable:!0,configurable:!1,enumerable:!0,value:null},attributeNameCheck:{writable:!0,configurable:!1,enumerable:!0,value:null},allowCustomizedBuiltInElements:{writable:!0,configurable:!1,enumerable:!0,value:!1}})),It=null,Mt=null,Nt=!0,Tt=!0,Rt=!1,Dt=!0,Lt=!1,Bt=!0,Ft=!1,qt=!1,$t=!1,Vt=!1,Ut=!1,zt=!1,Wt=!0,Kt=!1;const Ht="user-content-";let Jt=!0,Gt=!1,Yt={},Xt=null;const Qt=addToSet({},["annotation-xml","audio","colgroup","desc","foreignobject","head","iframe","math","mi","mn","mo","ms","mtext","noembed","noframes","noscript","plaintext","script","style","svg","template","thead","title","video","xmp"]);let Zt=null;const er=addToSet({},["audio","video","img","source","image","track"]);let tr=null;const rr=addToSet({},["alt","class","for","id","label","name","pattern","placeholder","role","summary","title","value","style","xmlns"]),nr="http://www.w3.org/1998/Math/MathML",sr="http://www.w3.org/2000/svg",ir="http://www.w3.org/1999/xhtml";let ar=ir,cr=!1,lr=null;const ur=addToSet({},[nr,sr,ir],z);let pr=null;const dr=["application/xhtml+xml","text/html"],fr="text/html";let mr=null,gr=null;const yr=255,vr=i.createElement("form"),br=function isRegexOrFunction(o){return o instanceof RegExp||o instanceof Function},_r=function _parseConfig(){let o=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};if(!gr||gr!==o){if(o&&"object"==typeof o||(o={}),o=clone(o),pr=-1===dr.indexOf(o.PARSER_MEDIA_TYPE)?fr:o.PARSER_MEDIA_TYPE,mr="application/xhtml+xml"===pr?z:U,Ot=ae(o,"ALLOWED_TAGS")?addToSet({},o.ALLOWED_TAGS,mr):Ct,At=ae(o,"ALLOWED_ATTR")?addToSet({},o.ALLOWED_ATTR,mr):jt,lr=ae(o,"ALLOWED_NAMESPACES")?addToSet({},o.ALLOWED_NAMESPACES,z):ur,tr=ae(o,"ADD_URI_SAFE_ATTR")?addToSet(clone(rr),o.ADD_URI_SAFE_ATTR,mr):rr,Zt=ae(o,"ADD_DATA_URI_TAGS")?addToSet(clone(er),o.ADD_DATA_URI_TAGS,mr):er,Xt=ae(o,"FORBID_CONTENTS")?addToSet({},o.FORBID_CONTENTS,mr):Qt,It=ae(o,"FORBID_TAGS")?addToSet({},o.FORBID_TAGS,mr):{},Mt=ae(o,"FORBID_ATTR")?addToSet({},o.FORBID_ATTR,mr):{},Yt=!!ae(o,"USE_PROFILES")&&o.USE_PROFILES,Nt=!1!==o.ALLOW_ARIA_ATTR,Tt=!1!==o.ALLOW_DATA_ATTR,Rt=o.ALLOW_UNKNOWN_PROTOCOLS||!1,Dt=!1!==o.ALLOW_SELF_CLOSE_IN_ATTR,Lt=o.SAFE_FOR_TEMPLATES||!1,Bt=!1!==o.SAFE_FOR_XML,Ft=o.WHOLE_DOCUMENT||!1,Vt=o.RETURN_DOM||!1,Ut=o.RETURN_DOM_FRAGMENT||!1,zt=o.RETURN_TRUSTED_TYPE||!1,$t=o.FORCE_BODY||!1,Wt=!1!==o.SANITIZE_DOM,Kt=o.SANITIZE_NAMED_PROPS||!1,Jt=!1!==o.KEEP_CONTENT,Gt=o.IN_PLACE||!1,kt=o.ALLOWED_URI_REGEXP||He,ar=o.NAMESPACE||ir,Pt=o.CUSTOM_ELEMENT_HANDLING||{},o.CUSTOM_ELEMENT_HANDLING&&br(o.CUSTOM_ELEMENT_HANDLING.tagNameCheck)&&(Pt.tagNameCheck=o.CUSTOM_ELEMENT_HANDLING.tagNameCheck),o.CUSTOM_ELEMENT_HANDLING&&br(o.CUSTOM_ELEMENT_HANDLING.attributeNameCheck)&&(Pt.attributeNameCheck=o.CUSTOM_ELEMENT_HANDLING.attributeNameCheck),o.CUSTOM_ELEMENT_HANDLING&&"boolean"==typeof o.CUSTOM_ELEMENT_HANDLING.allowCustomizedBuiltInElements&&(Pt.allowCustomizedBuiltInElements=o.CUSTOM_ELEMENT_HANDLING.allowCustomizedBuiltInElements),Lt&&(Tt=!1),Ut&&(Vt=!0),Yt&&(Ot=addToSet({},we),At=[],!0===Yt.html&&(addToSet(Ot,pe),addToSet(At,Se)),!0===Yt.svg&&(addToSet(Ot,de),addToSet(At,xe),addToSet(At,Te)),!0===Yt.svgFilters&&(addToSet(Ot,fe),addToSet(At,xe),addToSet(At,Te)),!0===Yt.mathMl&&(addToSet(Ot,be),addToSet(At,Pe),addToSet(At,Te))),o.ADD_TAGS&&(Ot===Ct&&(Ot=clone(Ot)),addToSet(Ot,o.ADD_TAGS,mr)),o.ADD_ATTR&&(At===jt&&(At=clone(At)),addToSet(At,o.ADD_ATTR,mr)),o.ADD_URI_SAFE_ATTR&&addToSet(tr,o.ADD_URI_SAFE_ATTR,mr),o.FORBID_CONTENTS&&(Xt===Qt&&(Xt=clone(Xt)),addToSet(Xt,o.FORBID_CONTENTS,mr)),Jt&&(Ot["#text"]=!0),Ft&&addToSet(Ot,["html","head","body"]),Ot.table&&(addToSet(Ot,["tbody"]),delete It.tbody),o.TRUSTED_TYPES_POLICY){if("function"!=typeof o.TRUSTED_TYPES_POLICY.createHTML)throw le('TRUSTED_TYPES_POLICY configuration option must provide a "createHTML" hook.');if("function"!=typeof o.TRUSTED_TYPES_POLICY.createScriptURL)throw le('TRUSTED_TYPES_POLICY configuration option must provide a "createScriptURL" hook.');ct=o.TRUSTED_TYPES_POLICY,lt=ct.createHTML("")}else void 0===ct&&(ct=ot(Ye,_)),null!==ct&&"string"==typeof lt&&(lt=ct.createHTML(""));w&&w(o),gr=o}},Er=addToSet({},["mi","mo","mn","ms","mtext"]),wr=addToSet({},["foreignobject","annotation-xml"]),Sr=addToSet({},["title","style","font","a","script"]),xr=addToSet({},[...de,...fe,...ye]),kr=addToSet({},[...be,..._e]),Or=function _checkValidNamespace(o){let s=at(o);s&&s.tagName||(s={namespaceURI:ar,tagName:"template"});const i=U(o.tagName),u=U(s.tagName);return!!lr[o.namespaceURI]&&(o.namespaceURI===sr?s.namespaceURI===ir?"svg"===i:s.namespaceURI===nr?"svg"===i&&("annotation-xml"===u||Er[u]):Boolean(xr[i]):o.namespaceURI===nr?s.namespaceURI===ir?"math"===i:s.namespaceURI===sr?"math"===i&&wr[u]:Boolean(kr[i]):o.namespaceURI===ir?!(s.namespaceURI===sr&&!wr[u])&&!(s.namespaceURI===nr&&!Er[u])&&!kr[i]&&(Sr[i]||!xr[i]):!("application/xhtml+xml"!==pr||!lr[o.namespaceURI]))},Cr=function _forceRemove(o){V(DOMPurify.removed,{element:o});try{o.parentNode.removeChild(o)}catch(s){o.remove()}},Ar=function _removeAttribute(o,s){try{V(DOMPurify.removed,{attribute:s.getAttributeNode(o),from:s})}catch(o){V(DOMPurify.removed,{attribute:null,from:s})}if(s.removeAttribute(o),"is"===o&&!At[o])if(Vt||Ut)try{Cr(s)}catch(o){}else try{s.setAttribute(o,"")}catch(o){}},jr=function _initDocument(o){let s=null,u=null;if($t)o=""+o;else{const s=Y(o,/^[\r\n\t ]+/);u=s&&s[0]}"application/xhtml+xml"===pr&&ar===ir&&(o=''+o+"");const _=ct?ct.createHTML(o):o;if(ar===ir)try{s=(new We).parseFromString(_,pr)}catch(o){}if(!s||!s.documentElement){s=ut.createDocument(ar,"template",null);try{s.documentElement.innerHTML=cr?lt:_}catch(o){}}const w=s.body||s.documentElement;return o&&u&&w.insertBefore(i.createTextNode(u),w.childNodes[0]||null),ar===ir?dt.call(s,Ft?"html":"body")[0]:Ft?s.documentElement:w},Pr=function _createNodeIterator(o){return pt.call(o.ownerDocument||o,o,qe.SHOW_ELEMENT|qe.SHOW_COMMENT|qe.SHOW_TEXT|qe.SHOW_PROCESSING_INSTRUCTION|qe.SHOW_CDATA_SECTION,null)},Ir=function _isClobbered(o){return o instanceof ze&&(void 0!==o.__depth&&"number"!=typeof o.__depth||void 0!==o.__removalCount&&"number"!=typeof o.__removalCount||"string"!=typeof o.nodeName||"string"!=typeof o.textContent||"function"!=typeof o.removeChild||!(o.attributes instanceof $e)||"function"!=typeof o.removeAttribute||"function"!=typeof o.setAttribute||"string"!=typeof o.namespaceURI||"function"!=typeof o.insertBefore||"function"!=typeof o.hasChildNodes)},Mr=function _isNode(o){return"function"==typeof L&&o instanceof L},Nr=function _executeHook(o,s,i){gt[o]&&B(gt[o],(o=>{o.call(DOMPurify,s,i,gr)}))},Tr=function _sanitizeElements(o){let s=null;if(Nr("beforeSanitizeElements",o,null),Ir(o))return Cr(o),!0;const i=mr(o.nodeName);if(Nr("uponSanitizeElement",o,{tagName:i,allowedTags:Ot}),o.hasChildNodes()&&!Mr(o.firstElementChild)&&ce(/<[/\w]/g,o.innerHTML)&&ce(/<[/\w]/g,o.textContent))return Cr(o),!0;if(o.nodeType===rt.progressingInstruction)return Cr(o),!0;if(Bt&&o.nodeType===rt.comment&&ce(/<[/\w]/g,o.data))return Cr(o),!0;if(!Ot[i]||It[i]){if(!It[i]&&Dr(i)){if(Pt.tagNameCheck instanceof RegExp&&ce(Pt.tagNameCheck,i))return!1;if(Pt.tagNameCheck instanceof Function&&Pt.tagNameCheck(i))return!1}if(Jt&&!Xt[i]){const s=at(o)||o.parentNode,i=it(o)||o.childNodes;if(i&&s)for(let u=i.length-1;u>=0;--u){const _=et(i[u],!0);_.__removalCount=(o.__removalCount||0)+1,s.insertBefore(_,st(o))}}return Cr(o),!0}return o instanceof Re&&!Or(o)?(Cr(o),!0):"noscript"!==i&&"noembed"!==i&&"noframes"!==i||!ce(/<\/no(script|embed|frames)/i,o.innerHTML)?(Lt&&o.nodeType===rt.text&&(s=o.textContent,B([yt,vt,bt],(o=>{s=Z(s,o," ")})),o.textContent!==s&&(V(DOMPurify.removed,{element:o.cloneNode()}),o.textContent=s)),Nr("afterSanitizeElements",o,null),!1):(Cr(o),!0)},Rr=function _isValidAttribute(o,s,u){if(Wt&&("id"===s||"name"===s)&&(u in i||u in vr||"__depth"===u||"__removalCount"===u))return!1;if(Tt&&!Mt[s]&&ce(_t,s));else if(Nt&&ce(Et,s));else if(!At[s]||Mt[s]){if(!(Dr(o)&&(Pt.tagNameCheck instanceof RegExp&&ce(Pt.tagNameCheck,o)||Pt.tagNameCheck instanceof Function&&Pt.tagNameCheck(o))&&(Pt.attributeNameCheck instanceof RegExp&&ce(Pt.attributeNameCheck,s)||Pt.attributeNameCheck instanceof Function&&Pt.attributeNameCheck(s))||"is"===s&&Pt.allowCustomizedBuiltInElements&&(Pt.tagNameCheck instanceof RegExp&&ce(Pt.tagNameCheck,u)||Pt.tagNameCheck instanceof Function&&Pt.tagNameCheck(u))))return!1}else if(tr[s]);else if(ce(kt,Z(u,St,"")));else if("src"!==s&&"xlink:href"!==s&&"href"!==s||"script"===o||0!==ee(u,"data:")||!Zt[o])if(Rt&&!ce(wt,Z(u,St,"")));else if(u)return!1;return!0},Dr=function _isBasicCustomElement(o){return"annotation-xml"!==o&&Y(o,xt)},Lr=function _sanitizeAttributes(o){Nr("beforeSanitizeAttributes",o,null);const{attributes:s}=o;if(!s)return;const i={attrName:"",attrValue:"",keepAttr:!0,allowedAttributes:At};let u=s.length;for(;u--;){const _=s[u],{name:w,namespaceURI:x,value:C}=_,j=mr(w);let L="value"===w?C:ie(C);if(i.attrName=j,i.attrValue=L,i.keepAttr=!0,i.forceKeepAttr=void 0,Nr("uponSanitizeAttribute",o,i),L=i.attrValue,i.forceKeepAttr)continue;if(Ar(w,o),!i.keepAttr)continue;if(!Dt&&ce(/\/>/i,L)){Ar(w,o);continue}if(Bt&&ce(/((--!?|])>)|<\/(style|title)/i,L)){Ar(w,o);continue}Lt&&B([yt,vt,bt],(o=>{L=Z(L,o," ")}));const V=mr(o.nodeName);if(Rr(V,j,L)){if(!Kt||"id"!==j&&"name"!==j||(Ar(w,o),L=Ht+L),ct&&"object"==typeof Ye&&"function"==typeof Ye.getAttributeType)if(x);else switch(Ye.getAttributeType(V,j)){case"TrustedHTML":L=ct.createHTML(L);break;case"TrustedScriptURL":L=ct.createScriptURL(L)}try{x?o.setAttributeNS(x,w,L):o.setAttribute(w,L),Ir(o)?Cr(o):$(DOMPurify.removed)}catch(o){}}}Nr("afterSanitizeAttributes",o,null)},Br=function _sanitizeShadowDOM(o){let s=null;const i=Pr(o);for(Nr("beforeSanitizeShadowDOM",o,null);s=i.nextNode();){if(Nr("uponSanitizeShadowNode",s,null),Tr(s))continue;const o=at(s);s.nodeType===rt.element&&(o&&o.__depth?s.__depth=(s.__removalCount||0)+o.__depth+1:s.__depth=1),(s.__depth>=yr||s.__depth<0||numberIsNaN(s.__depth))&&Cr(s),s.content instanceof x&&(s.content.__depth=s.__depth,_sanitizeShadowDOM(s.content)),Lr(s)}Nr("afterSanitizeShadowDOM",o,null)};return DOMPurify.sanitize=function(o){let s=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},i=null,_=null,w=null,C=null;if(cr=!o,cr&&(o="\x3c!--\x3e"),"string"!=typeof o&&!Mr(o)){if("function"!=typeof o.toString)throw le("toString is not a function");if("string"!=typeof(o=o.toString()))throw le("dirty is not a string, aborting")}if(!DOMPurify.isSupported)return o;if(qt||_r(s),DOMPurify.removed=[],"string"==typeof o&&(Gt=!1),Gt){if(o.nodeName){const s=mr(o.nodeName);if(!Ot[s]||It[s])throw le("root node is forbidden and cannot be sanitized in-place")}}else if(o instanceof L)i=jr("\x3c!----\x3e"),_=i.ownerDocument.importNode(o,!0),_.nodeType===rt.element&&"BODY"===_.nodeName||"HTML"===_.nodeName?i=_:i.appendChild(_);else{if(!Vt&&!Lt&&!Ft&&-1===o.indexOf("<"))return ct&&zt?ct.createHTML(o):o;if(i=jr(o),!i)return Vt?null:zt?lt:""}i&&$t&&Cr(i.firstChild);const j=Pr(Gt?o:i);for(;w=j.nextNode();){if(Tr(w))continue;const o=at(w);w.nodeType===rt.element&&(o&&o.__depth?w.__depth=(w.__removalCount||0)+o.__depth+1:w.__depth=1),(w.__depth>=yr||w.__depth<0||numberIsNaN(w.__depth))&&Cr(w),w.content instanceof x&&(w.content.__depth=w.__depth,Br(w.content)),Lr(w)}if(Gt)return o;if(Vt){if(Ut)for(C=ht.call(i.ownerDocument);i.firstChild;)C.appendChild(i.firstChild);else C=i;return(At.shadowroot||At.shadowrootmode)&&(C=mt.call(u,C,!0)),C}let $=Ft?i.outerHTML:i.innerHTML;return Ft&&Ot["!doctype"]&&i.ownerDocument&&i.ownerDocument.doctype&&i.ownerDocument.doctype.name&&ce(Qe,i.ownerDocument.doctype.name)&&($="\n"+$),Lt&&B([yt,vt,bt],(o=>{$=Z($,o," ")})),ct&&zt?ct.createHTML($):$},DOMPurify.setConfig=function(){_r(arguments.length>0&&void 0!==arguments[0]?arguments[0]:{}),qt=!0},DOMPurify.clearConfig=function(){gr=null,qt=!1},DOMPurify.isValidAttribute=function(o,s,i){gr||_r({});const u=mr(o),_=mr(s);return Rr(u,_,i)},DOMPurify.addHook=function(o,s){"function"==typeof s&&(gt[o]=gt[o]||[],V(gt[o],s))},DOMPurify.removeHook=function(o){if(gt[o])return $(gt[o])},DOMPurify.removeHooks=function(o){gt[o]&&(gt[o]=[])},DOMPurify.removeAllHooks=function(){gt={}},DOMPurify}return createDOMPurify()}()},78004:o=>{"use strict";class SubRange{constructor(o,s){this.low=o,this.high=s,this.length=1+s-o}overlaps(o){return!(this.higho.high)}touches(o){return!(this.high+1o.high)}add(o){return new SubRange(Math.min(this.low,o.low),Math.max(this.high,o.high))}subtract(o){return o.low<=this.low&&o.high>=this.high?[]:o.low>this.low&&o.higho+s.length),0)}add(o,s){var _add=o=>{for(var s=0;s{for(var s=0;s{for(var s=0;s{for(var i=s.low;i<=s.high;)o.push(i),i++;return o}),[])}subranges(){return this.ranges.map((o=>({low:o.low,high:o.high,length:1+o.high-o.low})))}}o.exports=DRange},30655:(o,s,i)=>{"use strict";var u=i(70453)("%Object.defineProperty%",!0)||!1;if(u)try{u({},"a",{value:1})}catch(o){u=!1}o.exports=u},41237:o=>{"use strict";o.exports=EvalError},69383:o=>{"use strict";o.exports=Error},79290:o=>{"use strict";o.exports=RangeError},79538:o=>{"use strict";o.exports=ReferenceError},58068:o=>{"use strict";o.exports=SyntaxError},69675:o=>{"use strict";o.exports=TypeError},35345:o=>{"use strict";o.exports=URIError},37007:o=>{"use strict";var s,i="object"==typeof Reflect?Reflect:null,u=i&&"function"==typeof i.apply?i.apply:function ReflectApply(o,s,i){return Function.prototype.apply.call(o,s,i)};s=i&&"function"==typeof i.ownKeys?i.ownKeys:Object.getOwnPropertySymbols?function ReflectOwnKeys(o){return Object.getOwnPropertyNames(o).concat(Object.getOwnPropertySymbols(o))}:function ReflectOwnKeys(o){return Object.getOwnPropertyNames(o)};var _=Number.isNaN||function NumberIsNaN(o){return o!=o};function EventEmitter(){EventEmitter.init.call(this)}o.exports=EventEmitter,o.exports.once=function once(o,s){return new Promise((function(i,u){function errorListener(i){o.removeListener(s,resolver),u(i)}function resolver(){"function"==typeof o.removeListener&&o.removeListener("error",errorListener),i([].slice.call(arguments))}eventTargetAgnosticAddListener(o,s,resolver,{once:!0}),"error"!==s&&function addErrorHandlerIfEventEmitter(o,s,i){"function"==typeof o.on&&eventTargetAgnosticAddListener(o,"error",s,i)}(o,errorListener,{once:!0})}))},EventEmitter.EventEmitter=EventEmitter,EventEmitter.prototype._events=void 0,EventEmitter.prototype._eventsCount=0,EventEmitter.prototype._maxListeners=void 0;var w=10;function checkListener(o){if("function"!=typeof o)throw new TypeError('The "listener" argument must be of type Function. Received type '+typeof o)}function _getMaxListeners(o){return void 0===o._maxListeners?EventEmitter.defaultMaxListeners:o._maxListeners}function _addListener(o,s,i,u){var _,w,x;if(checkListener(i),void 0===(w=o._events)?(w=o._events=Object.create(null),o._eventsCount=0):(void 0!==w.newListener&&(o.emit("newListener",s,i.listener?i.listener:i),w=o._events),x=w[s]),void 0===x)x=w[s]=i,++o._eventsCount;else if("function"==typeof x?x=w[s]=u?[i,x]:[x,i]:u?x.unshift(i):x.push(i),(_=_getMaxListeners(o))>0&&x.length>_&&!x.warned){x.warned=!0;var C=new Error("Possible EventEmitter memory leak detected. "+x.length+" "+String(s)+" listeners added. Use emitter.setMaxListeners() to increase limit");C.name="MaxListenersExceededWarning",C.emitter=o,C.type=s,C.count=x.length,function ProcessEmitWarning(o){console&&console.warn&&console.warn(o)}(C)}return o}function onceWrapper(){if(!this.fired)return this.target.removeListener(this.type,this.wrapFn),this.fired=!0,0===arguments.length?this.listener.call(this.target):this.listener.apply(this.target,arguments)}function _onceWrap(o,s,i){var u={fired:!1,wrapFn:void 0,target:o,type:s,listener:i},_=onceWrapper.bind(u);return _.listener=i,u.wrapFn=_,_}function _listeners(o,s,i){var u=o._events;if(void 0===u)return[];var _=u[s];return void 0===_?[]:"function"==typeof _?i?[_.listener||_]:[_]:i?function unwrapListeners(o){for(var s=new Array(o.length),i=0;i0&&(x=s[0]),x instanceof Error)throw x;var C=new Error("Unhandled error."+(x?" ("+x.message+")":""));throw C.context=x,C}var j=w[o];if(void 0===j)return!1;if("function"==typeof j)u(j,this,s);else{var L=j.length,B=arrayClone(j,L);for(i=0;i=0;w--)if(i[w]===s||i[w].listener===s){x=i[w].listener,_=w;break}if(_<0)return this;0===_?i.shift():function spliceOne(o,s){for(;s+1=0;u--)this.removeListener(o,s[u]);return this},EventEmitter.prototype.listeners=function listeners(o){return _listeners(this,o,!0)},EventEmitter.prototype.rawListeners=function rawListeners(o){return _listeners(this,o,!1)},EventEmitter.listenerCount=function(o,s){return"function"==typeof o.listenerCount?o.listenerCount(s):listenerCount.call(o,s)},EventEmitter.prototype.listenerCount=listenerCount,EventEmitter.prototype.eventNames=function eventNames(){return this._eventsCount>0?s(this._events):[]}},85587:(o,s,i)=>{"use strict";var u=i(26311),_=create(Error);function create(o){return FormattedError.displayName=o.displayName||o.name,FormattedError;function FormattedError(s){return s&&(s=u.apply(null,arguments)),new o(s)}}o.exports=_,_.eval=create(EvalError),_.range=create(RangeError),_.reference=create(ReferenceError),_.syntax=create(SyntaxError),_.type=create(TypeError),_.uri=create(URIError),_.create=create},26311:o=>{!function(){var s;function format(o){for(var s,i,u,_,w=1,x=[].slice.call(arguments),C=0,j=o.length,L="",B=!1,$=!1,nextArg=function(){return x[w++]},slurpNumber=function(){for(var i="";/\d/.test(o[C]);)i+=o[C++],s=o[C];return i.length>0?parseInt(i):null};C{"use strict";var s=Object.prototype.toString,i=Math.max,u=function concatty(o,s){for(var i=[],u=0;u{"use strict";var u=i(89353);o.exports=Function.prototype.bind||u},70453:(o,s,i)=>{"use strict";var u,_=i(69383),w=i(41237),x=i(79290),C=i(79538),j=i(58068),L=i(69675),B=i(35345),$=Function,getEvalledConstructor=function(o){try{return $('"use strict"; return ('+o+").constructor;")()}catch(o){}},V=Object.getOwnPropertyDescriptor;if(V)try{V({},"")}catch(o){V=null}var throwTypeError=function(){throw new L},U=V?function(){try{return throwTypeError}catch(o){try{return V(arguments,"callee").get}catch(o){return throwTypeError}}}():throwTypeError,z=i(64039)(),Y=i(80024)(),Z=Object.getPrototypeOf||(Y?function(o){return o.__proto__}:null),ee={},ie="undefined"!=typeof Uint8Array&&Z?Z(Uint8Array):u,ae={__proto__:null,"%AggregateError%":"undefined"==typeof AggregateError?u:AggregateError,"%Array%":Array,"%ArrayBuffer%":"undefined"==typeof ArrayBuffer?u:ArrayBuffer,"%ArrayIteratorPrototype%":z&&Z?Z([][Symbol.iterator]()):u,"%AsyncFromSyncIteratorPrototype%":u,"%AsyncFunction%":ee,"%AsyncGenerator%":ee,"%AsyncGeneratorFunction%":ee,"%AsyncIteratorPrototype%":ee,"%Atomics%":"undefined"==typeof Atomics?u:Atomics,"%BigInt%":"undefined"==typeof BigInt?u:BigInt,"%BigInt64Array%":"undefined"==typeof BigInt64Array?u:BigInt64Array,"%BigUint64Array%":"undefined"==typeof BigUint64Array?u:BigUint64Array,"%Boolean%":Boolean,"%DataView%":"undefined"==typeof DataView?u:DataView,"%Date%":Date,"%decodeURI%":decodeURI,"%decodeURIComponent%":decodeURIComponent,"%encodeURI%":encodeURI,"%encodeURIComponent%":encodeURIComponent,"%Error%":_,"%eval%":eval,"%EvalError%":w,"%Float32Array%":"undefined"==typeof Float32Array?u:Float32Array,"%Float64Array%":"undefined"==typeof Float64Array?u:Float64Array,"%FinalizationRegistry%":"undefined"==typeof FinalizationRegistry?u:FinalizationRegistry,"%Function%":$,"%GeneratorFunction%":ee,"%Int8Array%":"undefined"==typeof Int8Array?u:Int8Array,"%Int16Array%":"undefined"==typeof Int16Array?u:Int16Array,"%Int32Array%":"undefined"==typeof Int32Array?u:Int32Array,"%isFinite%":isFinite,"%isNaN%":isNaN,"%IteratorPrototype%":z&&Z?Z(Z([][Symbol.iterator]())):u,"%JSON%":"object"==typeof JSON?JSON:u,"%Map%":"undefined"==typeof Map?u:Map,"%MapIteratorPrototype%":"undefined"!=typeof Map&&z&&Z?Z((new Map)[Symbol.iterator]()):u,"%Math%":Math,"%Number%":Number,"%Object%":Object,"%parseFloat%":parseFloat,"%parseInt%":parseInt,"%Promise%":"undefined"==typeof Promise?u:Promise,"%Proxy%":"undefined"==typeof Proxy?u:Proxy,"%RangeError%":x,"%ReferenceError%":C,"%Reflect%":"undefined"==typeof Reflect?u:Reflect,"%RegExp%":RegExp,"%Set%":"undefined"==typeof Set?u:Set,"%SetIteratorPrototype%":"undefined"!=typeof Set&&z&&Z?Z((new Set)[Symbol.iterator]()):u,"%SharedArrayBuffer%":"undefined"==typeof SharedArrayBuffer?u:SharedArrayBuffer,"%String%":String,"%StringIteratorPrototype%":z&&Z?Z(""[Symbol.iterator]()):u,"%Symbol%":z?Symbol:u,"%SyntaxError%":j,"%ThrowTypeError%":U,"%TypedArray%":ie,"%TypeError%":L,"%Uint8Array%":"undefined"==typeof Uint8Array?u:Uint8Array,"%Uint8ClampedArray%":"undefined"==typeof Uint8ClampedArray?u:Uint8ClampedArray,"%Uint16Array%":"undefined"==typeof Uint16Array?u:Uint16Array,"%Uint32Array%":"undefined"==typeof Uint32Array?u:Uint32Array,"%URIError%":B,"%WeakMap%":"undefined"==typeof WeakMap?u:WeakMap,"%WeakRef%":"undefined"==typeof WeakRef?u:WeakRef,"%WeakSet%":"undefined"==typeof WeakSet?u:WeakSet};if(Z)try{null.error}catch(o){var ce=Z(Z(o));ae["%Error.prototype%"]=ce}var le=function doEval(o){var s;if("%AsyncFunction%"===o)s=getEvalledConstructor("async function () {}");else if("%GeneratorFunction%"===o)s=getEvalledConstructor("function* () {}");else if("%AsyncGeneratorFunction%"===o)s=getEvalledConstructor("async function* () {}");else if("%AsyncGenerator%"===o){var i=doEval("%AsyncGeneratorFunction%");i&&(s=i.prototype)}else if("%AsyncIteratorPrototype%"===o){var u=doEval("%AsyncGenerator%");u&&Z&&(s=Z(u.prototype))}return ae[o]=s,s},pe={__proto__:null,"%ArrayBufferPrototype%":["ArrayBuffer","prototype"],"%ArrayPrototype%":["Array","prototype"],"%ArrayProto_entries%":["Array","prototype","entries"],"%ArrayProto_forEach%":["Array","prototype","forEach"],"%ArrayProto_keys%":["Array","prototype","keys"],"%ArrayProto_values%":["Array","prototype","values"],"%AsyncFunctionPrototype%":["AsyncFunction","prototype"],"%AsyncGenerator%":["AsyncGeneratorFunction","prototype"],"%AsyncGeneratorPrototype%":["AsyncGeneratorFunction","prototype","prototype"],"%BooleanPrototype%":["Boolean","prototype"],"%DataViewPrototype%":["DataView","prototype"],"%DatePrototype%":["Date","prototype"],"%ErrorPrototype%":["Error","prototype"],"%EvalErrorPrototype%":["EvalError","prototype"],"%Float32ArrayPrototype%":["Float32Array","prototype"],"%Float64ArrayPrototype%":["Float64Array","prototype"],"%FunctionPrototype%":["Function","prototype"],"%Generator%":["GeneratorFunction","prototype"],"%GeneratorPrototype%":["GeneratorFunction","prototype","prototype"],"%Int8ArrayPrototype%":["Int8Array","prototype"],"%Int16ArrayPrototype%":["Int16Array","prototype"],"%Int32ArrayPrototype%":["Int32Array","prototype"],"%JSONParse%":["JSON","parse"],"%JSONStringify%":["JSON","stringify"],"%MapPrototype%":["Map","prototype"],"%NumberPrototype%":["Number","prototype"],"%ObjectPrototype%":["Object","prototype"],"%ObjProto_toString%":["Object","prototype","toString"],"%ObjProto_valueOf%":["Object","prototype","valueOf"],"%PromisePrototype%":["Promise","prototype"],"%PromiseProto_then%":["Promise","prototype","then"],"%Promise_all%":["Promise","all"],"%Promise_reject%":["Promise","reject"],"%Promise_resolve%":["Promise","resolve"],"%RangeErrorPrototype%":["RangeError","prototype"],"%ReferenceErrorPrototype%":["ReferenceError","prototype"],"%RegExpPrototype%":["RegExp","prototype"],"%SetPrototype%":["Set","prototype"],"%SharedArrayBufferPrototype%":["SharedArrayBuffer","prototype"],"%StringPrototype%":["String","prototype"],"%SymbolPrototype%":["Symbol","prototype"],"%SyntaxErrorPrototype%":["SyntaxError","prototype"],"%TypedArrayPrototype%":["TypedArray","prototype"],"%TypeErrorPrototype%":["TypeError","prototype"],"%Uint8ArrayPrototype%":["Uint8Array","prototype"],"%Uint8ClampedArrayPrototype%":["Uint8ClampedArray","prototype"],"%Uint16ArrayPrototype%":["Uint16Array","prototype"],"%Uint32ArrayPrototype%":["Uint32Array","prototype"],"%URIErrorPrototype%":["URIError","prototype"],"%WeakMapPrototype%":["WeakMap","prototype"],"%WeakSetPrototype%":["WeakSet","prototype"]},de=i(66743),fe=i(9957),ye=de.call(Function.call,Array.prototype.concat),be=de.call(Function.apply,Array.prototype.splice),_e=de.call(Function.call,String.prototype.replace),we=de.call(Function.call,String.prototype.slice),Se=de.call(Function.call,RegExp.prototype.exec),xe=/[^%.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|%$))/g,Pe=/\\(\\)?/g,Te=function getBaseIntrinsic(o,s){var i,u=o;if(fe(pe,u)&&(u="%"+(i=pe[u])[0]+"%"),fe(ae,u)){var _=ae[u];if(_===ee&&(_=le(u)),void 0===_&&!s)throw new L("intrinsic "+o+" exists, but is not available. Please file an issue!");return{alias:i,name:u,value:_}}throw new j("intrinsic "+o+" does not exist!")};o.exports=function GetIntrinsic(o,s){if("string"!=typeof o||0===o.length)throw new L("intrinsic name must be a non-empty string");if(arguments.length>1&&"boolean"!=typeof s)throw new L('"allowMissing" argument must be a boolean');if(null===Se(/^%?[^%]*%?$/,o))throw new j("`%` may not be present anywhere but at the beginning and end of the intrinsic name");var i=function stringToPath(o){var s=we(o,0,1),i=we(o,-1);if("%"===s&&"%"!==i)throw new j("invalid intrinsic syntax, expected closing `%`");if("%"===i&&"%"!==s)throw new j("invalid intrinsic syntax, expected opening `%`");var u=[];return _e(o,xe,(function(o,s,i,_){u[u.length]=i?_e(_,Pe,"$1"):s||o})),u}(o),u=i.length>0?i[0]:"",_=Te("%"+u+"%",s),w=_.name,x=_.value,C=!1,B=_.alias;B&&(u=B[0],be(i,ye([0,1],B)));for(var $=1,U=!0;$=i.length){var ee=V(x,z);x=(U=!!ee)&&"get"in ee&&!("originalValue"in ee.get)?ee.get:x[z]}else U=fe(x,z),x=x[z];U&&!C&&(ae[w]=x)}}return x}},75795:(o,s,i)=>{"use strict";var u=i(70453)("%Object.getOwnPropertyDescriptor%",!0);if(u)try{u([],"length")}catch(o){u=null}o.exports=u},30592:(o,s,i)=>{"use strict";var u=i(30655),_=function hasPropertyDescriptors(){return!!u};_.hasArrayLengthDefineBug=function hasArrayLengthDefineBug(){if(!u)return null;try{return 1!==u([],"length",{value:1}).length}catch(o){return!0}},o.exports=_},80024:o=>{"use strict";var s={__proto__:null,foo:{}},i=Object;o.exports=function hasProto(){return{__proto__:s}.foo===s.foo&&!(s instanceof i)}},64039:(o,s,i)=>{"use strict";var u="undefined"!=typeof Symbol&&Symbol,_=i(41333);o.exports=function hasNativeSymbols(){return"function"==typeof u&&("function"==typeof Symbol&&("symbol"==typeof u("foo")&&("symbol"==typeof Symbol("bar")&&_())))}},41333:o=>{"use strict";o.exports=function hasSymbols(){if("function"!=typeof Symbol||"function"!=typeof Object.getOwnPropertySymbols)return!1;if("symbol"==typeof Symbol.iterator)return!0;var o={},s=Symbol("test"),i=Object(s);if("string"==typeof s)return!1;if("[object Symbol]"!==Object.prototype.toString.call(s))return!1;if("[object Symbol]"!==Object.prototype.toString.call(i))return!1;for(s in o[s]=42,o)return!1;if("function"==typeof Object.keys&&0!==Object.keys(o).length)return!1;if("function"==typeof Object.getOwnPropertyNames&&0!==Object.getOwnPropertyNames(o).length)return!1;var u=Object.getOwnPropertySymbols(o);if(1!==u.length||u[0]!==s)return!1;if(!Object.prototype.propertyIsEnumerable.call(o,s))return!1;if("function"==typeof Object.getOwnPropertyDescriptor){var _=Object.getOwnPropertyDescriptor(o,s);if(42!==_.value||!0!==_.enumerable)return!1}return!0}},9957:(o,s,i)=>{"use strict";var u=Function.prototype.call,_=Object.prototype.hasOwnProperty,w=i(66743);o.exports=w.call(u,_)},45981:o=>{function deepFreeze(o){return o instanceof Map?o.clear=o.delete=o.set=function(){throw new Error("map is read-only")}:o instanceof Set&&(o.add=o.clear=o.delete=function(){throw new Error("set is read-only")}),Object.freeze(o),Object.getOwnPropertyNames(o).forEach((function(s){var i=o[s];"object"!=typeof i||Object.isFrozen(i)||deepFreeze(i)})),o}var s=deepFreeze,i=deepFreeze;s.default=i;class Response{constructor(o){void 0===o.data&&(o.data={}),this.data=o.data,this.isMatchIgnored=!1}ignoreMatch(){this.isMatchIgnored=!0}}function escapeHTML(o){return o.replace(/&/g,"&").replace(//g,">").replace(/"/g,""").replace(/'/g,"'")}function inherit(o,...s){const i=Object.create(null);for(const s in o)i[s]=o[s];return s.forEach((function(o){for(const s in o)i[s]=o[s]})),i}const emitsWrappingTags=o=>!!o.kind;class HTMLRenderer{constructor(o,s){this.buffer="",this.classPrefix=s.classPrefix,o.walk(this)}addText(o){this.buffer+=escapeHTML(o)}openNode(o){if(!emitsWrappingTags(o))return;let s=o.kind;o.sublanguage||(s=`${this.classPrefix}${s}`),this.span(s)}closeNode(o){emitsWrappingTags(o)&&(this.buffer+="")}value(){return this.buffer}span(o){this.buffer+=``}}class TokenTree{constructor(){this.rootNode={children:[]},this.stack=[this.rootNode]}get top(){return this.stack[this.stack.length-1]}get root(){return this.rootNode}add(o){this.top.children.push(o)}openNode(o){const s={kind:o,children:[]};this.add(s),this.stack.push(s)}closeNode(){if(this.stack.length>1)return this.stack.pop()}closeAllNodes(){for(;this.closeNode(););}toJSON(){return JSON.stringify(this.rootNode,null,4)}walk(o){return this.constructor._walk(o,this.rootNode)}static _walk(o,s){return"string"==typeof s?o.addText(s):s.children&&(o.openNode(s),s.children.forEach((s=>this._walk(o,s))),o.closeNode(s)),o}static _collapse(o){"string"!=typeof o&&o.children&&(o.children.every((o=>"string"==typeof o))?o.children=[o.children.join("")]:o.children.forEach((o=>{TokenTree._collapse(o)})))}}class TokenTreeEmitter extends TokenTree{constructor(o){super(),this.options=o}addKeyword(o,s){""!==o&&(this.openNode(s),this.addText(o),this.closeNode())}addText(o){""!==o&&this.add(o)}addSublanguage(o,s){const i=o.root;i.kind=s,i.sublanguage=!0,this.add(i)}toHTML(){return new HTMLRenderer(this,this.options).value()}finalize(){return!0}}function source(o){return o?"string"==typeof o?o:o.source:null}const u=/\[(?:[^\\\]]|\\.)*\]|\(\??|\\([1-9][0-9]*)|\\./;const _="[a-zA-Z]\\w*",w="[a-zA-Z_]\\w*",x="\\b\\d+(\\.\\d+)?",C="(-?)(\\b0[xX][a-fA-F0-9]+|(\\b\\d+(\\.\\d*)?|\\.\\d+)([eE][-+]?\\d+)?)",j="\\b(0b[01]+)",L={begin:"\\\\[\\s\\S]",relevance:0},B={className:"string",begin:"'",end:"'",illegal:"\\n",contains:[L]},$={className:"string",begin:'"',end:'"',illegal:"\\n",contains:[L]},V={begin:/\b(a|an|the|are|I'm|isn't|don't|doesn't|won't|but|just|should|pretty|simply|enough|gonna|going|wtf|so|such|will|you|your|they|like|more)\b/},COMMENT=function(o,s,i={}){const u=inherit({className:"comment",begin:o,end:s,contains:[]},i);return u.contains.push(V),u.contains.push({className:"doctag",begin:"(?:TODO|FIXME|NOTE|BUG|OPTIMIZE|HACK|XXX):",relevance:0}),u},U=COMMENT("//","$"),z=COMMENT("/\\*","\\*/"),Y=COMMENT("#","$"),Z={className:"number",begin:x,relevance:0},ee={className:"number",begin:C,relevance:0},ie={className:"number",begin:j,relevance:0},ae={className:"number",begin:x+"(%|em|ex|ch|rem|vw|vh|vmin|vmax|cm|mm|in|pt|pc|px|deg|grad|rad|turn|s|ms|Hz|kHz|dpi|dpcm|dppx)?",relevance:0},ce={begin:/(?=\/[^/\n]*\/)/,contains:[{className:"regexp",begin:/\//,end:/\/[gimuy]*/,illegal:/\n/,contains:[L,{begin:/\[/,end:/\]/,relevance:0,contains:[L]}]}]},le={className:"title",begin:_,relevance:0},pe={className:"title",begin:w,relevance:0},de={begin:"\\.\\s*"+w,relevance:0};var fe=Object.freeze({__proto__:null,MATCH_NOTHING_RE:/\b\B/,IDENT_RE:_,UNDERSCORE_IDENT_RE:w,NUMBER_RE:x,C_NUMBER_RE:C,BINARY_NUMBER_RE:j,RE_STARTERS_RE:"!|!=|!==|%|%=|&|&&|&=|\\*|\\*=|\\+|\\+=|,|-|-=|/=|/|:|;|<<|<<=|<=|<|===|==|=|>>>=|>>=|>=|>>>|>>|>|\\?|\\[|\\{|\\(|\\^|\\^=|\\||\\|=|\\|\\||~",SHEBANG:(o={})=>{const s=/^#![ ]*\//;return o.binary&&(o.begin=function concat(...o){return o.map((o=>source(o))).join("")}(s,/.*\b/,o.binary,/\b.*/)),inherit({className:"meta",begin:s,end:/$/,relevance:0,"on:begin":(o,s)=>{0!==o.index&&s.ignoreMatch()}},o)},BACKSLASH_ESCAPE:L,APOS_STRING_MODE:B,QUOTE_STRING_MODE:$,PHRASAL_WORDS_MODE:V,COMMENT,C_LINE_COMMENT_MODE:U,C_BLOCK_COMMENT_MODE:z,HASH_COMMENT_MODE:Y,NUMBER_MODE:Z,C_NUMBER_MODE:ee,BINARY_NUMBER_MODE:ie,CSS_NUMBER_MODE:ae,REGEXP_MODE:ce,TITLE_MODE:le,UNDERSCORE_TITLE_MODE:pe,METHOD_GUARD:de,END_SAME_AS_BEGIN:function(o){return Object.assign(o,{"on:begin":(o,s)=>{s.data._beginMatch=o[1]},"on:end":(o,s)=>{s.data._beginMatch!==o[1]&&s.ignoreMatch()}})}});function skipIfhasPrecedingDot(o,s){"."===o.input[o.index-1]&&s.ignoreMatch()}function beginKeywords(o,s){s&&o.beginKeywords&&(o.begin="\\b("+o.beginKeywords.split(" ").join("|")+")(?!\\.)(?=\\b|\\s)",o.__beforeBegin=skipIfhasPrecedingDot,o.keywords=o.keywords||o.beginKeywords,delete o.beginKeywords,void 0===o.relevance&&(o.relevance=0))}function compileIllegal(o,s){Array.isArray(o.illegal)&&(o.illegal=function either(...o){return"("+o.map((o=>source(o))).join("|")+")"}(...o.illegal))}function compileMatch(o,s){if(o.match){if(o.begin||o.end)throw new Error("begin & end are not supported with match");o.begin=o.match,delete o.match}}function compileRelevance(o,s){void 0===o.relevance&&(o.relevance=1)}const ye=["of","and","for","in","not","or","if","then","parent","list","value"],be="keyword";function compileKeywords(o,s,i=be){const u={};return"string"==typeof o?compileList(i,o.split(" ")):Array.isArray(o)?compileList(i,o):Object.keys(o).forEach((function(i){Object.assign(u,compileKeywords(o[i],s,i))})),u;function compileList(o,i){s&&(i=i.map((o=>o.toLowerCase()))),i.forEach((function(s){const i=s.split("|");u[i[0]]=[o,scoreForKeyword(i[0],i[1])]}))}}function scoreForKeyword(o,s){return s?Number(s):function commonKeyword(o){return ye.includes(o.toLowerCase())}(o)?0:1}function compileLanguage(o,{plugins:s}){function langRe(s,i){return new RegExp(source(s),"m"+(o.case_insensitive?"i":"")+(i?"g":""))}class MultiRegex{constructor(){this.matchIndexes={},this.regexes=[],this.matchAt=1,this.position=0}addRule(o,s){s.position=this.position++,this.matchIndexes[this.matchAt]=s,this.regexes.push([s,o]),this.matchAt+=function countMatchGroups(o){return new RegExp(o.toString()+"|").exec("").length-1}(o)+1}compile(){0===this.regexes.length&&(this.exec=()=>null);const o=this.regexes.map((o=>o[1]));this.matcherRe=langRe(function join(o,s="|"){let i=0;return o.map((o=>{i+=1;const s=i;let _=source(o),w="";for(;_.length>0;){const o=u.exec(_);if(!o){w+=_;break}w+=_.substring(0,o.index),_=_.substring(o.index+o[0].length),"\\"===o[0][0]&&o[1]?w+="\\"+String(Number(o[1])+s):(w+=o[0],"("===o[0]&&i++)}return w})).map((o=>`(${o})`)).join(s)}(o),!0),this.lastIndex=0}exec(o){this.matcherRe.lastIndex=this.lastIndex;const s=this.matcherRe.exec(o);if(!s)return null;const i=s.findIndex(((o,s)=>s>0&&void 0!==o)),u=this.matchIndexes[i];return s.splice(0,i),Object.assign(s,u)}}class ResumableMultiRegex{constructor(){this.rules=[],this.multiRegexes=[],this.count=0,this.lastIndex=0,this.regexIndex=0}getMatcher(o){if(this.multiRegexes[o])return this.multiRegexes[o];const s=new MultiRegex;return this.rules.slice(o).forEach((([o,i])=>s.addRule(o,i))),s.compile(),this.multiRegexes[o]=s,s}resumingScanAtSamePosition(){return 0!==this.regexIndex}considerAll(){this.regexIndex=0}addRule(o,s){this.rules.push([o,s]),"begin"===s.type&&this.count++}exec(o){const s=this.getMatcher(this.regexIndex);s.lastIndex=this.lastIndex;let i=s.exec(o);if(this.resumingScanAtSamePosition())if(i&&i.index===this.lastIndex);else{const s=this.getMatcher(0);s.lastIndex=this.lastIndex+1,i=s.exec(o)}return i&&(this.regexIndex+=i.position+1,this.regexIndex===this.count&&this.considerAll()),i}}if(o.compilerExtensions||(o.compilerExtensions=[]),o.contains&&o.contains.includes("self"))throw new Error("ERR: contains `self` is not supported at the top-level of a language. See documentation.");return o.classNameAliases=inherit(o.classNameAliases||{}),function compileMode(s,i){const u=s;if(s.isCompiled)return u;[compileMatch].forEach((o=>o(s,i))),o.compilerExtensions.forEach((o=>o(s,i))),s.__beforeBegin=null,[beginKeywords,compileIllegal,compileRelevance].forEach((o=>o(s,i))),s.isCompiled=!0;let _=null;if("object"==typeof s.keywords&&(_=s.keywords.$pattern,delete s.keywords.$pattern),s.keywords&&(s.keywords=compileKeywords(s.keywords,o.case_insensitive)),s.lexemes&&_)throw new Error("ERR: Prefer `keywords.$pattern` to `mode.lexemes`, BOTH are not allowed. (see mode reference) ");return _=_||s.lexemes||/\w+/,u.keywordPatternRe=langRe(_,!0),i&&(s.begin||(s.begin=/\B|\b/),u.beginRe=langRe(s.begin),s.endSameAsBegin&&(s.end=s.begin),s.end||s.endsWithParent||(s.end=/\B|\b/),s.end&&(u.endRe=langRe(s.end)),u.terminatorEnd=source(s.end)||"",s.endsWithParent&&i.terminatorEnd&&(u.terminatorEnd+=(s.end?"|":"")+i.terminatorEnd)),s.illegal&&(u.illegalRe=langRe(s.illegal)),s.contains||(s.contains=[]),s.contains=[].concat(...s.contains.map((function(o){return function expandOrCloneMode(o){o.variants&&!o.cachedVariants&&(o.cachedVariants=o.variants.map((function(s){return inherit(o,{variants:null},s)})));if(o.cachedVariants)return o.cachedVariants;if(dependencyOnParent(o))return inherit(o,{starts:o.starts?inherit(o.starts):null});if(Object.isFrozen(o))return inherit(o);return o}("self"===o?s:o)}))),s.contains.forEach((function(o){compileMode(o,u)})),s.starts&&compileMode(s.starts,i),u.matcher=function buildModeRegex(o){const s=new ResumableMultiRegex;return o.contains.forEach((o=>s.addRule(o.begin,{rule:o,type:"begin"}))),o.terminatorEnd&&s.addRule(o.terminatorEnd,{type:"end"}),o.illegal&&s.addRule(o.illegal,{type:"illegal"}),s}(u),u}(o)}function dependencyOnParent(o){return!!o&&(o.endsWithParent||dependencyOnParent(o.starts))}function BuildVuePlugin(o){const s={props:["language","code","autodetect"],data:function(){return{detectedLanguage:"",unknownLanguage:!1}},computed:{className(){return this.unknownLanguage?"":"hljs "+this.detectedLanguage},highlighted(){if(!this.autoDetect&&!o.getLanguage(this.language))return console.warn(`The language "${this.language}" you specified could not be found.`),this.unknownLanguage=!0,escapeHTML(this.code);let s={};return this.autoDetect?(s=o.highlightAuto(this.code),this.detectedLanguage=s.language):(s=o.highlight(this.language,this.code,this.ignoreIllegals),this.detectedLanguage=this.language),s.value},autoDetect(){return!this.language||function hasValueOrEmptyAttribute(o){return Boolean(o||""===o)}(this.autodetect)},ignoreIllegals:()=>!0},render(o){return o("pre",{},[o("code",{class:this.className,domProps:{innerHTML:this.highlighted}})])}};return{Component:s,VuePlugin:{install(o){o.component("highlightjs",s)}}}}const _e={"after:highlightElement":({el:o,result:s,text:i})=>{const u=nodeStream(o);if(!u.length)return;const _=document.createElement("div");_.innerHTML=s.value,s.value=function mergeStreams(o,s,i){let u=0,_="";const w=[];function selectStream(){return o.length&&s.length?o[0].offset!==s[0].offset?o[0].offset"}function close(o){_+=""+tag(o)+">"}function render(o){("start"===o.event?open:close)(o.node)}for(;o.length||s.length;){let s=selectStream();if(_+=escapeHTML(i.substring(u,s[0].offset)),u=s[0].offset,s===o){w.reverse().forEach(close);do{render(s.splice(0,1)[0]),s=selectStream()}while(s===o&&s.length&&s[0].offset===u);w.reverse().forEach(open)}else"start"===s[0].event?w.push(s[0].node):w.pop(),render(s.splice(0,1)[0])}return _+escapeHTML(i.substr(u))}(u,nodeStream(_),i)}};function tag(o){return o.nodeName.toLowerCase()}function nodeStream(o){const s=[];return function _nodeStream(o,i){for(let u=o.firstChild;u;u=u.nextSibling)3===u.nodeType?i+=u.nodeValue.length:1===u.nodeType&&(s.push({event:"start",offset:i,node:u}),i=_nodeStream(u,i),tag(u).match(/br|hr|img|input/)||s.push({event:"stop",offset:i,node:u}));return i}(o,0),s}const we={},error=o=>{console.error(o)},warn=(o,...s)=>{console.log(`WARN: ${o}`,...s)},deprecated=(o,s)=>{we[`${o}/${s}`]||(console.log(`Deprecated as of ${o}. ${s}`),we[`${o}/${s}`]=!0)},Se=escapeHTML,xe=inherit,Pe=Symbol("nomatch");var Te=function(o){const i=Object.create(null),u=Object.create(null),_=[];let w=!0;const x=/(^(<[^>]+>|\t|)+|\n)/gm,C="Could not find the language '{}', did you forget to load/include a language module?",j={disableAutodetect:!0,name:"Plain text",contains:[]};let L={noHighlightRe:/^(no-?highlight)$/i,languageDetectRe:/\blang(?:uage)?-([\w-]+)\b/i,classPrefix:"hljs-",tabReplace:null,useBR:!1,languages:null,__emitter:TokenTreeEmitter};function shouldNotHighlight(o){return L.noHighlightRe.test(o)}function highlight(o,s,i,u){let _="",w="";"object"==typeof s?(_=o,i=s.ignoreIllegals,w=s.language,u=void 0):(deprecated("10.7.0","highlight(lang, code, ...args) has been deprecated."),deprecated("10.7.0","Please use highlight(code, options) instead.\nhttps://github.com/highlightjs/highlight.js/issues/2277"),w=o,_=s);const x={code:_,language:w};fire("before:highlight",x);const C=x.result?x.result:_highlight(x.language,x.code,i,u);return C.code=x.code,fire("after:highlight",C),C}function _highlight(o,s,u,x){function keywordData(o,s){const i=B.case_insensitive?s[0].toLowerCase():s[0];return Object.prototype.hasOwnProperty.call(o.keywords,i)&&o.keywords[i]}function processBuffer(){null!=U.subLanguage?function processSubLanguage(){if(""===Z)return;let o=null;if("string"==typeof U.subLanguage){if(!i[U.subLanguage])return void Y.addText(Z);o=_highlight(U.subLanguage,Z,!0,z[U.subLanguage]),z[U.subLanguage]=o.top}else o=highlightAuto(Z,U.subLanguage.length?U.subLanguage:null);U.relevance>0&&(ee+=o.relevance),Y.addSublanguage(o.emitter,o.language)}():function processKeywords(){if(!U.keywords)return void Y.addText(Z);let o=0;U.keywordPatternRe.lastIndex=0;let s=U.keywordPatternRe.exec(Z),i="";for(;s;){i+=Z.substring(o,s.index);const u=keywordData(U,s);if(u){const[o,_]=u;if(Y.addText(i),i="",ee+=_,o.startsWith("_"))i+=s[0];else{const i=B.classNameAliases[o]||o;Y.addKeyword(s[0],i)}}else i+=s[0];o=U.keywordPatternRe.lastIndex,s=U.keywordPatternRe.exec(Z)}i+=Z.substr(o),Y.addText(i)}(),Z=""}function startNewMode(o){return o.className&&Y.openNode(B.classNameAliases[o.className]||o.className),U=Object.create(o,{parent:{value:U}}),U}function endOfMode(o,s,i){let u=function startsWith(o,s){const i=o&&o.exec(s);return i&&0===i.index}(o.endRe,i);if(u){if(o["on:end"]){const i=new Response(o);o["on:end"](s,i),i.isMatchIgnored&&(u=!1)}if(u){for(;o.endsParent&&o.parent;)o=o.parent;return o}}if(o.endsWithParent)return endOfMode(o.parent,s,i)}function doIgnore(o){return 0===U.matcher.regexIndex?(Z+=o[0],1):(ce=!0,0)}function doBeginMatch(o){const s=o[0],i=o.rule,u=new Response(i),_=[i.__beforeBegin,i["on:begin"]];for(const i of _)if(i&&(i(o,u),u.isMatchIgnored))return doIgnore(s);return i&&i.endSameAsBegin&&(i.endRe=function escape(o){return new RegExp(o.replace(/[-/\\^$*+?.()|[\]{}]/g,"\\$&"),"m")}(s)),i.skip?Z+=s:(i.excludeBegin&&(Z+=s),processBuffer(),i.returnBegin||i.excludeBegin||(Z=s)),startNewMode(i),i.returnBegin?0:s.length}function doEndMatch(o){const i=o[0],u=s.substr(o.index),_=endOfMode(U,o,u);if(!_)return Pe;const w=U;w.skip?Z+=i:(w.returnEnd||w.excludeEnd||(Z+=i),processBuffer(),w.excludeEnd&&(Z=i));do{U.className&&Y.closeNode(),U.skip||U.subLanguage||(ee+=U.relevance),U=U.parent}while(U!==_.parent);return _.starts&&(_.endSameAsBegin&&(_.starts.endRe=_.endRe),startNewMode(_.starts)),w.returnEnd?0:i.length}let j={};function processLexeme(i,_){const x=_&&_[0];if(Z+=i,null==x)return processBuffer(),0;if("begin"===j.type&&"end"===_.type&&j.index===_.index&&""===x){if(Z+=s.slice(_.index,_.index+1),!w){const s=new Error("0 width match regex");throw s.languageName=o,s.badRule=j.rule,s}return 1}if(j=_,"begin"===_.type)return doBeginMatch(_);if("illegal"===_.type&&!u){const o=new Error('Illegal lexeme "'+x+'" for mode "'+(U.className||"")+'"');throw o.mode=U,o}if("end"===_.type){const o=doEndMatch(_);if(o!==Pe)return o}if("illegal"===_.type&&""===x)return 1;if(ae>1e5&&ae>3*_.index){throw new Error("potential infinite loop, way more iterations than matches")}return Z+=x,x.length}const B=getLanguage(o);if(!B)throw error(C.replace("{}",o)),new Error('Unknown language: "'+o+'"');const $=compileLanguage(B,{plugins:_});let V="",U=x||$;const z={},Y=new L.__emitter(L);!function processContinuations(){const o=[];for(let s=U;s!==B;s=s.parent)s.className&&o.unshift(s.className);o.forEach((o=>Y.openNode(o)))}();let Z="",ee=0,ie=0,ae=0,ce=!1;try{for(U.matcher.considerAll();;){ae++,ce?ce=!1:U.matcher.considerAll(),U.matcher.lastIndex=ie;const o=U.matcher.exec(s);if(!o)break;const i=processLexeme(s.substring(ie,o.index),o);ie=o.index+i}return processLexeme(s.substr(ie)),Y.closeAllNodes(),Y.finalize(),V=Y.toHTML(),{relevance:Math.floor(ee),value:V,language:o,illegal:!1,emitter:Y,top:U}}catch(i){if(i.message&&i.message.includes("Illegal"))return{illegal:!0,illegalBy:{msg:i.message,context:s.slice(ie-100,ie+100),mode:i.mode},sofar:V,relevance:0,value:Se(s),emitter:Y};if(w)return{illegal:!1,relevance:0,value:Se(s),emitter:Y,language:o,top:U,errorRaised:i};throw i}}function highlightAuto(o,s){s=s||L.languages||Object.keys(i);const u=function justTextHighlightResult(o){const s={relevance:0,emitter:new L.__emitter(L),value:Se(o),illegal:!1,top:j};return s.emitter.addText(o),s}(o),_=s.filter(getLanguage).filter(autoDetection).map((s=>_highlight(s,o,!1)));_.unshift(u);const w=_.sort(((o,s)=>{if(o.relevance!==s.relevance)return s.relevance-o.relevance;if(o.language&&s.language){if(getLanguage(o.language).supersetOf===s.language)return 1;if(getLanguage(s.language).supersetOf===o.language)return-1}return 0})),[x,C]=w,B=x;return B.second_best=C,B}const B={"before:highlightElement":({el:o})=>{L.useBR&&(o.innerHTML=o.innerHTML.replace(/\n/g,"").replace(/
/g,"\n"))},"after:highlightElement":({result:o})=>{L.useBR&&(o.value=o.value.replace(/\n/g,"
"))}},$=/^(<[^>]+>|\t)+/gm,V={"after:highlightElement":({result:o})=>{L.tabReplace&&(o.value=o.value.replace($,(o=>o.replace(/\t/g,L.tabReplace))))}};function highlightElement(o){let s=null;const i=function blockLanguage(o){let s=o.className+" ";s+=o.parentNode?o.parentNode.className:"";const i=L.languageDetectRe.exec(s);if(i){const s=getLanguage(i[1]);return s||(warn(C.replace("{}",i[1])),warn("Falling back to no-highlight mode for this block.",o)),s?i[1]:"no-highlight"}return s.split(/\s+/).find((o=>shouldNotHighlight(o)||getLanguage(o)))}(o);if(shouldNotHighlight(i))return;fire("before:highlightElement",{el:o,language:i}),s=o;const _=s.textContent,w=i?highlight(_,{language:i,ignoreIllegals:!0}):highlightAuto(_);fire("after:highlightElement",{el:o,result:w,text:_}),o.innerHTML=w.value,function updateClassName(o,s,i){const _=s?u[s]:i;o.classList.add("hljs"),_&&o.classList.add(_)}(o,i,w.language),o.result={language:w.language,re:w.relevance,relavance:w.relevance},w.second_best&&(o.second_best={language:w.second_best.language,re:w.second_best.relevance,relavance:w.second_best.relevance})}const initHighlighting=()=>{if(initHighlighting.called)return;initHighlighting.called=!0,deprecated("10.6.0","initHighlighting() is deprecated. Use highlightAll() instead.");document.querySelectorAll("pre code").forEach(highlightElement)};let U=!1;function highlightAll(){if("loading"===document.readyState)return void(U=!0);document.querySelectorAll("pre code").forEach(highlightElement)}function getLanguage(o){return o=(o||"").toLowerCase(),i[o]||i[u[o]]}function registerAliases(o,{languageName:s}){"string"==typeof o&&(o=[o]),o.forEach((o=>{u[o.toLowerCase()]=s}))}function autoDetection(o){const s=getLanguage(o);return s&&!s.disableAutodetect}function fire(o,s){const i=o;_.forEach((function(o){o[i]&&o[i](s)}))}"undefined"!=typeof window&&window.addEventListener&&window.addEventListener("DOMContentLoaded",(function boot(){U&&highlightAll()}),!1),Object.assign(o,{highlight,highlightAuto,highlightAll,fixMarkup:function deprecateFixMarkup(o){return deprecated("10.2.0","fixMarkup will be removed entirely in v11.0"),deprecated("10.2.0","Please see https://github.com/highlightjs/highlight.js/issues/2534"),function fixMarkup(o){return L.tabReplace||L.useBR?o.replace(x,(o=>"\n"===o?L.useBR?"
":o:L.tabReplace?o.replace(/\t/g,L.tabReplace):o)):o}(o)},highlightElement,highlightBlock:function deprecateHighlightBlock(o){return deprecated("10.7.0","highlightBlock will be removed entirely in v12.0"),deprecated("10.7.0","Please use highlightElement now."),highlightElement(o)},configure:function configure(o){o.useBR&&(deprecated("10.3.0","'useBR' will be removed entirely in v11.0"),deprecated("10.3.0","Please see https://github.com/highlightjs/highlight.js/issues/2559")),L=xe(L,o)},initHighlighting,initHighlightingOnLoad:function initHighlightingOnLoad(){deprecated("10.6.0","initHighlightingOnLoad() is deprecated. Use highlightAll() instead."),U=!0},registerLanguage:function registerLanguage(s,u){let _=null;try{_=u(o)}catch(o){if(error("Language definition for '{}' could not be registered.".replace("{}",s)),!w)throw o;error(o),_=j}_.name||(_.name=s),i[s]=_,_.rawDefinition=u.bind(null,o),_.aliases&®isterAliases(_.aliases,{languageName:s})},unregisterLanguage:function unregisterLanguage(o){delete i[o];for(const s of Object.keys(u))u[s]===o&&delete u[s]},listLanguages:function listLanguages(){return Object.keys(i)},getLanguage,registerAliases,requireLanguage:function requireLanguage(o){deprecated("10.4.0","requireLanguage will be removed entirely in v11."),deprecated("10.4.0","Please see https://github.com/highlightjs/highlight.js/pull/2844");const s=getLanguage(o);if(s)return s;throw new Error("The '{}' language is required, but not loaded.".replace("{}",o))},autoDetection,inherit:xe,addPlugin:function addPlugin(o){!function upgradePluginAPI(o){o["before:highlightBlock"]&&!o["before:highlightElement"]&&(o["before:highlightElement"]=s=>{o["before:highlightBlock"](Object.assign({block:s.el},s))}),o["after:highlightBlock"]&&!o["after:highlightElement"]&&(o["after:highlightElement"]=s=>{o["after:highlightBlock"](Object.assign({block:s.el},s))})}(o),_.push(o)},vuePlugin:BuildVuePlugin(o).VuePlugin}),o.debugMode=function(){w=!1},o.safeMode=function(){w=!0},o.versionString="10.7.3";for(const o in fe)"object"==typeof fe[o]&&s(fe[o]);return Object.assign(o,fe),o.addPlugin(B),o.addPlugin(_e),o.addPlugin(V),o}({});o.exports=Te},35344:o=>{function concat(...o){return o.map((o=>function source(o){return o?"string"==typeof o?o:o.source:null}(o))).join("")}o.exports=function bash(o){const s={},i={begin:/\$\{/,end:/\}/,contains:["self",{begin:/:-/,contains:[s]}]};Object.assign(s,{className:"variable",variants:[{begin:concat(/\$[\w\d#@][\w\d_]*/,"(?![\\w\\d])(?![$])")},i]});const u={className:"subst",begin:/\$\(/,end:/\)/,contains:[o.BACKSLASH_ESCAPE]},_={begin:/<<-?\s*(?=\w+)/,starts:{contains:[o.END_SAME_AS_BEGIN({begin:/(\w+)/,end:/(\w+)/,className:"string"})]}},w={className:"string",begin:/"/,end:/"/,contains:[o.BACKSLASH_ESCAPE,s,u]};u.contains.push(w);const x={begin:/\$\(\(/,end:/\)\)/,contains:[{begin:/\d+#[0-9a-f]+/,className:"number"},o.NUMBER_MODE,s]},C=o.SHEBANG({binary:`(${["fish","bash","zsh","sh","csh","ksh","tcsh","dash","scsh"].join("|")})`,relevance:10}),j={className:"function",begin:/\w[\w\d_]*\s*\(\s*\)\s*\{/,returnBegin:!0,contains:[o.inherit(o.TITLE_MODE,{begin:/\w[\w\d_]*/})],relevance:0};return{name:"Bash",aliases:["sh","zsh"],keywords:{$pattern:/\b[a-z._-]+\b/,keyword:"if then else elif fi for while in do done case esac function",literal:"true false",built_in:"break cd continue eval exec exit export getopts hash pwd readonly return shift test times trap umask unset alias bind builtin caller command declare echo enable help let local logout mapfile printf read readarray source type typeset ulimit unalias set shopt autoload bg bindkey bye cap chdir clone comparguments compcall compctl compdescribe compfiles compgroups compquote comptags comptry compvalues dirs disable disown echotc echoti emulate fc fg float functions getcap getln history integer jobs kill limit log noglob popd print pushd pushln rehash sched setcap setopt stat suspend ttyctl unfunction unhash unlimit unsetopt vared wait whence where which zcompile zformat zftp zle zmodload zparseopts zprof zpty zregexparse zsocket zstyle ztcp"},contains:[C,o.SHEBANG(),j,x,o.HASH_COMMENT_MODE,_,w,{className:"",begin:/\\"/},{className:"string",begin:/'/,end:/'/},s]}}},73402:o=>{function concat(...o){return o.map((o=>function source(o){return o?"string"==typeof o?o:o.source:null}(o))).join("")}o.exports=function http(o){const s="HTTP/(2|1\\.[01])",i={className:"attribute",begin:concat("^",/[A-Za-z][A-Za-z0-9-]*/,"(?=\\:\\s)"),starts:{contains:[{className:"punctuation",begin:/: /,relevance:0,starts:{end:"$",relevance:0}}]}},u=[i,{begin:"\\n\\n",starts:{subLanguage:[],endsWithParent:!0}}];return{name:"HTTP",aliases:["https"],illegal:/\S/,contains:[{begin:"^(?="+s+" \\d{3})",end:/$/,contains:[{className:"meta",begin:s},{className:"number",begin:"\\b\\d{3}\\b"}],starts:{end:/\b\B/,illegal:/\S/,contains:u}},{begin:"(?=^[A-Z]+ (.*?) "+s+"$)",end:/$/,contains:[{className:"string",begin:" ",end:" ",excludeBegin:!0,excludeEnd:!0},{className:"meta",begin:s},{className:"keyword",begin:"[A-Z]+"}],starts:{end:/\b\B/,illegal:/\S/,contains:u}},o.inherit(i,{relevance:0})]}}},95089:o=>{const s="[A-Za-z$_][0-9A-Za-z$_]*",i=["as","in","of","if","for","while","finally","var","new","function","do","return","void","else","break","catch","instanceof","with","throw","case","default","try","switch","continue","typeof","delete","let","yield","const","class","debugger","async","await","static","import","from","export","extends"],u=["true","false","null","undefined","NaN","Infinity"],_=[].concat(["setInterval","setTimeout","clearInterval","clearTimeout","require","exports","eval","isFinite","isNaN","parseFloat","parseInt","decodeURI","decodeURIComponent","encodeURI","encodeURIComponent","escape","unescape"],["arguments","this","super","console","window","document","localStorage","module","global"],["Intl","DataView","Number","Math","Date","String","RegExp","Object","Function","Boolean","Error","Symbol","Set","Map","WeakSet","WeakMap","Proxy","Reflect","JSON","Promise","Float64Array","Int16Array","Int32Array","Int8Array","Uint16Array","Uint32Array","Float32Array","Array","Uint8Array","Uint8ClampedArray","ArrayBuffer","BigInt64Array","BigUint64Array","BigInt"],["EvalError","InternalError","RangeError","ReferenceError","SyntaxError","TypeError","URIError"]);function lookahead(o){return concat("(?=",o,")")}function concat(...o){return o.map((o=>function source(o){return o?"string"==typeof o?o:o.source:null}(o))).join("")}o.exports=function javascript(o){const w=s,x="<>",C=">",j={begin:/<[A-Za-z0-9\\._:-]+/,end:/\/[A-Za-z0-9\\._:-]+>|\/>/,isTrulyOpeningTag:(o,s)=>{const i=o[0].length+o.index,u=o.input[i];"<"!==u?">"===u&&(((o,{after:s})=>{const i=""+o[0].slice(1);return-1!==o.input.indexOf(i,s)})(o,{after:i})||s.ignoreMatch()):s.ignoreMatch()}},L={$pattern:s,keyword:i,literal:u,built_in:_},B="[0-9](_?[0-9])*",$=`\\.(${B})`,V="0|[1-9](_?[0-9])*|0[0-7]*[89][0-9]*",U={className:"number",variants:[{begin:`(\\b(${V})((${$})|\\.)?|(${$}))[eE][+-]?(${B})\\b`},{begin:`\\b(${V})\\b((${$})\\b|\\.)?|(${$})\\b`},{begin:"\\b(0|[1-9](_?[0-9])*)n\\b"},{begin:"\\b0[xX][0-9a-fA-F](_?[0-9a-fA-F])*n?\\b"},{begin:"\\b0[bB][0-1](_?[0-1])*n?\\b"},{begin:"\\b0[oO][0-7](_?[0-7])*n?\\b"},{begin:"\\b0[0-7]+n?\\b"}],relevance:0},z={className:"subst",begin:"\\$\\{",end:"\\}",keywords:L,contains:[]},Y={begin:"html`",end:"",starts:{end:"`",returnEnd:!1,contains:[o.BACKSLASH_ESCAPE,z],subLanguage:"xml"}},Z={begin:"css`",end:"",starts:{end:"`",returnEnd:!1,contains:[o.BACKSLASH_ESCAPE,z],subLanguage:"css"}},ee={className:"string",begin:"`",end:"`",contains:[o.BACKSLASH_ESCAPE,z]},ie={className:"comment",variants:[o.COMMENT(/\/\*\*(?!\/)/,"\\*/",{relevance:0,contains:[{className:"doctag",begin:"@[A-Za-z]+",contains:[{className:"type",begin:"\\{",end:"\\}",relevance:0},{className:"variable",begin:w+"(?=\\s*(-)|$)",endsParent:!0,relevance:0},{begin:/(?=[^\n])\s/,relevance:0}]}]}),o.C_BLOCK_COMMENT_MODE,o.C_LINE_COMMENT_MODE]},ae=[o.APOS_STRING_MODE,o.QUOTE_STRING_MODE,Y,Z,ee,U,o.REGEXP_MODE];z.contains=ae.concat({begin:/\{/,end:/\}/,keywords:L,contains:["self"].concat(ae)});const ce=[].concat(ie,z.contains),le=ce.concat([{begin:/\(/,end:/\)/,keywords:L,contains:["self"].concat(ce)}]),pe={className:"params",begin:/\(/,end:/\)/,excludeBegin:!0,excludeEnd:!0,keywords:L,contains:le};return{name:"Javascript",aliases:["js","jsx","mjs","cjs"],keywords:L,exports:{PARAMS_CONTAINS:le},illegal:/#(?![$_A-z])/,contains:[o.SHEBANG({label:"shebang",binary:"node",relevance:5}),{label:"use_strict",className:"meta",relevance:10,begin:/^\s*['"]use (strict|asm)['"]/},o.APOS_STRING_MODE,o.QUOTE_STRING_MODE,Y,Z,ee,ie,U,{begin:concat(/[{,\n]\s*/,lookahead(concat(/(((\/\/.*$)|(\/\*(\*[^/]|[^*])*\*\/))\s*)*/,w+"\\s*:"))),relevance:0,contains:[{className:"attr",begin:w+lookahead("\\s*:"),relevance:0}]},{begin:"("+o.RE_STARTERS_RE+"|\\b(case|return|throw)\\b)\\s*",keywords:"return throw case",contains:[ie,o.REGEXP_MODE,{className:"function",begin:"(\\([^()]*(\\([^()]*(\\([^()]*\\)[^()]*)*\\)[^()]*)*\\)|"+o.UNDERSCORE_IDENT_RE+")\\s*=>",returnBegin:!0,end:"\\s*=>",contains:[{className:"params",variants:[{begin:o.UNDERSCORE_IDENT_RE,relevance:0},{className:null,begin:/\(\s*\)/,skip:!0},{begin:/\(/,end:/\)/,excludeBegin:!0,excludeEnd:!0,keywords:L,contains:le}]}]},{begin:/,/,relevance:0},{className:"",begin:/\s/,end:/\s*/,skip:!0},{variants:[{begin:x,end:C},{begin:j.begin,"on:begin":j.isTrulyOpeningTag,end:j.end}],subLanguage:"xml",contains:[{begin:j.begin,end:j.end,skip:!0,contains:["self"]}]}],relevance:0},{className:"function",beginKeywords:"function",end:/[{;]/,excludeEnd:!0,keywords:L,contains:["self",o.inherit(o.TITLE_MODE,{begin:w}),pe],illegal:/%/},{beginKeywords:"while if switch catch for"},{className:"function",begin:o.UNDERSCORE_IDENT_RE+"\\([^()]*(\\([^()]*(\\([^()]*\\)[^()]*)*\\)[^()]*)*\\)\\s*\\{",returnBegin:!0,contains:[pe,o.inherit(o.TITLE_MODE,{begin:w})]},{variants:[{begin:"\\."+w},{begin:"\\$"+w}],relevance:0},{className:"class",beginKeywords:"class",end:/[{;=]/,excludeEnd:!0,illegal:/[:"[\]]/,contains:[{beginKeywords:"extends"},o.UNDERSCORE_TITLE_MODE]},{begin:/\b(?=constructor)/,end:/[{;]/,excludeEnd:!0,contains:[o.inherit(o.TITLE_MODE,{begin:w}),"self",pe]},{begin:"(get|set)\\s+(?="+w+"\\()",end:/\{/,keywords:"get set",contains:[o.inherit(o.TITLE_MODE,{begin:w}),{begin:/\(\)/},pe]},{begin:/\$[(.]/}]}}},65772:o=>{o.exports=function json(o){const s={literal:"true false null"},i=[o.C_LINE_COMMENT_MODE,o.C_BLOCK_COMMENT_MODE],u=[o.QUOTE_STRING_MODE,o.C_NUMBER_MODE],_={end:",",endsWithParent:!0,excludeEnd:!0,contains:u,keywords:s},w={begin:/\{/,end:/\}/,contains:[{className:"attr",begin:/"/,end:/"/,contains:[o.BACKSLASH_ESCAPE],illegal:"\\n"},o.inherit(_,{begin:/:/})].concat(i),illegal:"\\S"},x={begin:"\\[",end:"\\]",contains:[o.inherit(_)],illegal:"\\S"};return u.push(w,x),i.forEach((function(o){u.push(o)})),{name:"JSON",contains:u,keywords:s,illegal:"\\S"}}},26571:o=>{o.exports=function powershell(o){const s={$pattern:/-?[A-z\.\-]+\b/,keyword:"if else foreach return do while until elseif begin for trap data dynamicparam end break throw param continue finally in switch exit filter try process catch hidden static parameter",built_in:"ac asnp cat cd CFS chdir clc clear clhy cli clp cls clv cnsn compare copy cp cpi cpp curl cvpa dbp del diff dir dnsn ebp echo|0 epal epcsv epsn erase etsn exsn fc fhx fl ft fw gal gbp gc gcb gci gcm gcs gdr gerr ghy gi gin gjb gl gm gmo gp gps gpv group gsn gsnp gsv gtz gu gv gwmi h history icm iex ihy ii ipal ipcsv ipmo ipsn irm ise iwmi iwr kill lp ls man md measure mi mount move mp mv nal ndr ni nmo npssc nsn nv ogv oh popd ps pushd pwd r rbp rcjb rcsn rd rdr ren ri rjb rm rmdir rmo rni rnp rp rsn rsnp rujb rv rvpa rwmi sajb sal saps sasv sbp sc scb select set shcm si sl sleep sls sort sp spjb spps spsv start stz sujb sv swmi tee trcm type wget where wjb write"},i={begin:"`[\\s\\S]",relevance:0},u={className:"variable",variants:[{begin:/\$\B/},{className:"keyword",begin:/\$this/},{begin:/\$[\w\d][\w\d_:]*/}]},_={className:"string",variants:[{begin:/"/,end:/"/},{begin:/@"/,end:/^"@/}],contains:[i,u,{className:"variable",begin:/\$[A-z]/,end:/[^A-z]/}]},w={className:"string",variants:[{begin:/'/,end:/'/},{begin:/@'/,end:/^'@/}]},x=o.inherit(o.COMMENT(null,null),{variants:[{begin:/#/,end:/$/},{begin:/<#/,end:/#>/}],contains:[{className:"doctag",variants:[{begin:/\.(synopsis|description|example|inputs|outputs|notes|link|component|role|functionality)/},{begin:/\.(parameter|forwardhelptargetname|forwardhelpcategory|remotehelprunspace|externalhelp)\s+\S+/}]}]}),C={className:"built_in",variants:[{begin:"(".concat("Add|Clear|Close|Copy|Enter|Exit|Find|Format|Get|Hide|Join|Lock|Move|New|Open|Optimize|Pop|Push|Redo|Remove|Rename|Reset|Resize|Search|Select|Set|Show|Skip|Split|Step|Switch|Undo|Unlock|Watch|Backup|Checkpoint|Compare|Compress|Convert|ConvertFrom|ConvertTo|Dismount|Edit|Expand|Export|Group|Import|Initialize|Limit|Merge|Mount|Out|Publish|Restore|Save|Sync|Unpublish|Update|Approve|Assert|Build|Complete|Confirm|Deny|Deploy|Disable|Enable|Install|Invoke|Register|Request|Restart|Resume|Start|Stop|Submit|Suspend|Uninstall|Unregister|Wait|Debug|Measure|Ping|Repair|Resolve|Test|Trace|Connect|Disconnect|Read|Receive|Send|Write|Block|Grant|Protect|Revoke|Unblock|Unprotect|Use|ForEach|Sort|Tee|Where",")+(-)[\\w\\d]+")}]},j={className:"class",beginKeywords:"class enum",end:/\s*[{]/,excludeEnd:!0,relevance:0,contains:[o.TITLE_MODE]},L={className:"function",begin:/function\s+/,end:/\s*\{|$/,excludeEnd:!0,returnBegin:!0,relevance:0,contains:[{begin:"function",relevance:0,className:"keyword"},{className:"title",begin:/\w[\w\d]*((-)[\w\d]+)*/,relevance:0},{begin:/\(/,end:/\)/,className:"params",relevance:0,contains:[u]}]},B={begin:/using\s/,end:/$/,returnBegin:!0,contains:[_,w,{className:"keyword",begin:/(using|assembly|command|module|namespace|type)/}]},$={variants:[{className:"operator",begin:"(".concat("-and|-as|-band|-bnot|-bor|-bxor|-casesensitive|-ccontains|-ceq|-cge|-cgt|-cle|-clike|-clt|-cmatch|-cne|-cnotcontains|-cnotlike|-cnotmatch|-contains|-creplace|-csplit|-eq|-exact|-f|-file|-ge|-gt|-icontains|-ieq|-ige|-igt|-ile|-ilike|-ilt|-imatch|-in|-ine|-inotcontains|-inotlike|-inotmatch|-ireplace|-is|-isnot|-isplit|-join|-le|-like|-lt|-match|-ne|-not|-notcontains|-notin|-notlike|-notmatch|-or|-regex|-replace|-shl|-shr|-split|-wildcard|-xor",")\\b")},{className:"literal",begin:/(-)[\w\d]+/,relevance:0}]},V={className:"function",begin:/\[.*\]\s*[\w]+[ ]??\(/,end:/$/,returnBegin:!0,relevance:0,contains:[{className:"keyword",begin:"(".concat(s.keyword.toString().replace(/\s/g,"|"),")\\b"),endsParent:!0,relevance:0},o.inherit(o.TITLE_MODE,{endsParent:!0})]},U=[V,x,i,o.NUMBER_MODE,_,w,C,u,{className:"literal",begin:/\$(null|true|false)\b/},{className:"selector-tag",begin:/@\B/,relevance:0}],z={begin:/\[/,end:/\]/,excludeBegin:!0,excludeEnd:!0,relevance:0,contains:[].concat("self",U,{begin:"("+["string","char","byte","int","long","bool","decimal","single","double","DateTime","xml","array","hashtable","void"].join("|")+")",className:"built_in",relevance:0},{className:"type",begin:/[\.\w\d]+/,relevance:0})};return V.contains.unshift(z),{name:"PowerShell",aliases:["ps","ps1"],case_insensitive:!0,keywords:s,contains:U.concat(j,L,B,$,z)}}},17285:o=>{function source(o){return o?"string"==typeof o?o:o.source:null}function lookahead(o){return concat("(?=",o,")")}function concat(...o){return o.map((o=>source(o))).join("")}function either(...o){return"("+o.map((o=>source(o))).join("|")+")"}o.exports=function xml(o){const s=concat(/[A-Z_]/,function optional(o){return concat("(",o,")?")}(/[A-Z0-9_.-]*:/),/[A-Z0-9_.-]*/),i={className:"symbol",begin:/&[a-z]+;|[0-9]+;|[a-f0-9]+;/},u={begin:/\s/,contains:[{className:"meta-keyword",begin:/#?[a-z_][a-z1-9_-]+/,illegal:/\n/}]},_=o.inherit(u,{begin:/\(/,end:/\)/}),w=o.inherit(o.APOS_STRING_MODE,{className:"meta-string"}),x=o.inherit(o.QUOTE_STRING_MODE,{className:"meta-string"}),C={endsWithParent:!0,illegal:/,relevance:0,contains:[{className:"attr",begin:/[A-Za-z0-9._:-]+/,relevance:0},{begin:/=\s*/,relevance:0,contains:[{className:"string",endsParent:!0,variants:[{begin:/"/,end:/"/,contains:[i]},{begin:/'/,end:/'/,contains:[i]},{begin:/[^\s"'=<>`]+/}]}]}]};return{name:"HTML, XML",aliases:["html","xhtml","rss","atom","xjb","xsd","xsl","plist","wsf","svg"],case_insensitive:!0,contains:[{className:"meta",begin://,relevance:10,contains:[u,x,w,_,{begin:/\[/,end:/\]/,contains:[{className:"meta",begin://,contains:[u,_,x,w]}]}]},o.COMMENT(//,{relevance:10}),{begin://,relevance:10},i,{className:"meta",begin:/<\?xml/,end:/\?>/,relevance:10},{className:"tag",begin:/