65 lines
2.7 KiB
Markdown
65 lines
2.7 KiB
Markdown
|
# 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 Einstiegsordner in die Konfiguration ist frei wählbar. "/api" innerhalb des Projektrepositories hat sich jedoch bewährt.
|
||
|
|
||
|
Die Einstiegsdatei in die Gesamt-Konfiguration liegt hier und heißt [config.yml](./config.yml.md). In dieser können Umgebungsvariablen erstetzt werden, welche in [config.yml.env](./config.yml.md) 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 [api/collections/democol.yml](./collections.md).
|
||
|
|
||
|
### /api/collections/fields
|
||
|
|
||
|
Sollten Feldkonfigurationen wieder verwendet werden, können diese im [api/collections/fields/](./collections/fields.md) 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 [api/hooks/](./collections/hooks.md) 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](./collections/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.
|