# Ordnerstruktur Als Konvention für neue Projekte hat sich folgende Ordnerstruktur etabliert: ![Ordnerstruktur](api-ordner.png) Die Aufteilung der YAML-Konfiguration ist durch den YAML-Tag "!include" möglich. Genaueres dazu wird auf den nachfolgenden Seiten beschrieben. ## /api Der Einstigesordner in die Konfiguration ist frei wählbar. "/api" innerhalb des Projektrepositories hat sich jedoch bewährt. Die Enstiegsdatei in die Gesamt-Konfiguration liegt hier und heißt `config.yml`. In dieser können Umgebungsvariablen erstetzt werden, welche in `config.yml.env` definiert sind. Ebenso sind alle nachfolgenden Unterordner beliebig zu benennen. Da aber ein JSON-Schema und VSCode-Konfiguration zur Validierung der YAML Dateien existiert, ist folgende Struktur hilfreich. ### JSON-Schema Das JSON-Schema ist in die package.json einzubinden via: ```json ... "devDependencies": { ..., "tibi-types": "https://gitbase.de/cms/tibi-types.git" }, ... ``` Die im Projekt liegende VSCode-Konfig sollte dementsprechend ergänzt werden: ```json ... "yaml.schemas": { "node_modules/tibi-types/schemas/api-config/config.json": "api/config.y*ml", "node_modules/tibi-types/schemas/api-config/collection.json": "api/collections/*.y*ml", "node_modules/tibi-types/schemas/api-config/field.json": "api/collections/fields/*.y*ml", "node_modules/tibi-types/schemas/api-config/fieldArray.json": "api/collections/fieldLists/*.y*ml" }, "yaml.customTags": ["!include scalar"], ... ``` Sollte Yarn2 verwendet werden ist die Verlinkung von "node_modules" nötig. Dazu ist folgendes in der `.yarnrc.yml` einzutragen: ```yaml ... nodeLinker: node-modules ``` ## /api/collections Bei Aufteilung der Kollektionskonfigurationen in einzelne Dateien, sollten diese in diesem Ordner gespeichert werden. Für jede Kollektion sollte eine eigene Datei verwendet werden, hier im Beispiel `democol.yml`. ### /api/collections/fields Sollten Feldkonfigurationen wieder verwendet werden, können diese im "fields" Unterordner gepeichert werden. Diese sind pro Feldkonfiguration als einzelne Datei aufzuführen. ### /api/hooks Jede Javascript-Datei, die einen Hook bedient sollte im Unterordner benannt nach der Kollektion im Ordner "hooks" sein. Der Name der Datei sollte sich nach den Hook richten. Z.B. `get_return.js` ist zustängig für den GET-Hook nach dem Lesen der Daten, bevor diese zurück gegeben werden. Mehr dazu unter [Hooks](hooks.md). ### /api/templates Ist es nötig im Projekt Templates zu rendern (z.B. für den Email-Versand), sind diese im Ordner "templates" gut aufgehoben.