Wiki-Quellcode von Search-API-Metaform
Zuletzt geändert von MACH formsolutions am 12.01.2021
Zeige letzte Bearbeiter
| author | version | line-number | content |
|---|---|---|---|
| 1 | > # ACHTUNG: Die Search-API-Metaform ist abgelöst durch die Search-API. | ||
| 2 | |||
| 3 | ## Allgemeines | ||
| 4 | |||
| 5 | Mittel zweier Restschnittstellen lassen sich flexible Anfragen zur Suche von Assistenten erstellen. | ||
| 6 | URL: | ||
| 7 | |||
| 8 | `<server-url>/metaform-search/assistant` | ||
| 9 | |||
| 10 | bzw. | ||
| 11 | |||
| 12 | `<server-url>/metaform-search/metaform` | ||
| 13 | |||
| 14 | Anfragen werden nur per POST mit dem Content-Type *application/json* entgegengenommen. | ||
| 15 | |||
| 16 | Nicht benötigte Anfrage-Parameter können entfallen. Lediglich ein oder mehrere Mandanten müssen angegeben werden. Das Anfrage-Objekt muss dabei folgende Struktur besitzen: | ||
| 17 | |||
| 18 | ```xml | ||
| 19 | { | ||
| 20 | "containsOne" : <Ergebnis muss eines der hier angegebenen | ||
| 21 | Stichworte enthalten>, | ||
| 22 | "containsExactly" : <Ergebnis muss die hier angegebene Phrase komplett beinhalten>, | ||
| 23 | "containsAll" : <Ergebnis muss alle hier angegebnen Stichworte enthalten>, | ||
| 24 | "without" : <Ergebnis darf keines der hier angegebenen | ||
| 25 | Stichworte enthalten>, | ||
| 26 | "organizationFilters" : [ | ||
| 27 | { | ||
| 28 | "id" : <Mandant, dessen Formulare gesucht werden sollen, z.B. "22222222-2222">, | ||
| 29 | "versionStatus" : [ | ||
| 30 | <Freigabestatus, auf den/die das Ergebnis für diesen Mandant beschränkt werden soll: | ||
| 31 | "DRAFT" - Entwurf | ||
| 32 | "READY_FOR_APPROVAL" - Zur Freigabe bereit | ||
| 33 | "APPROVAL" - Freigabe erfolgt | ||
| 34 | > | ||
| 35 | ], | ||
| 36 | "federalStates" : [ | ||
| 37 | <Bundesländer, auf die das Ergebnis für diesen Mandant beschränkt werden soll: | ||
| 38 | "BB", "BE", "BW", "BY", "HB", "HE", | ||
| 39 | "HH", "MV", "NI", "NW", "RP", "SH", | ||
| 40 | "SL", "SN", "ST", "TH" | ||
| 41 | > | ||
| 42 | ] | ||
| 43 | } | ||
| 44 | ], | ||
| 45 | "fields" : [ | ||
| 46 | <Liste der Felder, die nach den o.g. Begriffen durchsucht werden sollen. Z.B.: | ||
| 47 | "identifier" - Formularnummer | ||
| 48 | "i18n.i18nItems.de" - Formularname | ||
| 49 | "description" - Beschreibung | ||
| 50 | Es sind prinzipiell alle Felder durchsuchbar, | ||
| 51 | die auch im Ergebnis enthalten sind. | ||
| 52 | > | ||
| 53 | ], | ||
| 54 | "category" : <Zu durchsuchende Kategorie | ||
| 55 | - dabei nur den numerischen Wert (als Text angeben). | ||
| 56 | Z.B.: | ||
| 57 | "010" - Allgemeines, | ||
| 58 | "940" - Steuern - Gebühren >, | ||
| 59 | "changedAfter" : <Nur Ergebnisse liefern, die seit dem übergebenen Datum geändert wurden. | ||
| 60 | Als Format sind die Millisekunden seit 01.01.1970 0:00 GMT anzugeben.>, | ||
| 61 | "createdAfter" : <Nur Ergebnisse liefern, die seit dem übergebenen Datum erzeugt wurden. | ||
| 62 | Als Format sind die Millisekunden seit 01.01.1970 0:00 GMT anzugeben.> | ||
| 63 | } | ||
| 64 | ``` | ||
| 65 | |||
| 66 | |||
| 67 | Das Ergebnis wird als JSON-Array zurückgeliefert. Jedes enthaltene Objekt entspricht den Metadaten eines Assistenten. | ||
| 68 | |||
| 69 | Beispiele für eine umfassende Abfrage aller freigegebenen Verlags-Formulare: | ||
| 70 | |||
| 71 | ```xml | ||
| 72 | { | ||
| 73 | "organizationFilters" : [ | ||
| 74 | { | ||
| 75 | "id" : "22222222-2222", | ||
| 76 | "versionStatus" : ["APPROVAL"] | ||
| 77 | } | ||
| 78 | ] | ||
| 79 | } | ||
| 80 | ``` | ||
| 81 | |||
| 82 | ___ | ||
| 83 | |||
| 84 | ## Detailabfrage | ||
| 85 | |||
| 86 | Ist die ID eines Objekts bekannt, kann ein einzelner Datensatz über folgende URLs abgerufen werden: | ||
| 87 | |||
| 88 | `<server-url>/metaform-search/assistant/<ID>` | ||
| 89 | |||
| 90 | bzw. | ||
| 91 | |||
| 92 | `<server-url>/metaform-search/metaform/<ID>` | ||
| 93 | |||
| 94 | Ein einfaches *GET* liefert hierbei ein einzelnes JSON-Objekt zurück. | ||
| 95 | |||
| 96 | ___ | ||
| 97 | |||
| 98 | ## Versionsabfrage | ||
| 99 | |||
| 100 | Ist nicht nur die letzte (freigegebene) Version von Interesse, sondern alle Versionen eines Assistenten, können folgende URLs genutzt werden: | ||
| 101 | |||
| 102 | ```xml | ||
| 103 | <server-url>/metaform-search/assistant/versions/ | ||
| 104 | <Mandant des Suchenden - zur Bundeslandbegrenzung>/ | ||
| 105 | <Mandant des Assistenten>/ | ||
| 106 | <Formularnummer (identifier)> | ||
| 107 | ``` |