Add 'aktivierungsstatus' field to CAIKnowledge and CAdvowareAkten entities; update API documentation and configuration timestamps

This commit is contained in:
2026-03-11 21:49:02 +01:00
parent c678660ad6
commit ae359048af
9 changed files with 165 additions and 7 deletions

View File

@@ -9,6 +9,7 @@
"datenbankId": "Datenbank-ID", "datenbankId": "Datenbank-ID",
"syncStatus": "Sync-Status", "syncStatus": "Sync-Status",
"lastSync": "Letzte Synchronisation", "lastSync": "Letzte Synchronisation",
"aktivierungsstatus": "Aktivierungsstatus",
"dokumenteAiDocumentId": "AI Document ID", "dokumenteAiDocumentId": "AI Document ID",
"dokumenteSyncstatus": "Sync-Status", "dokumenteSyncstatus": "Sync-Status",
"dokumenteLastSync": "Letzter Sync" "dokumenteLastSync": "Letzter Sync"
@@ -23,6 +24,12 @@
"synced": "Synchronisiert", "synced": "Synchronisiert",
"unclean": "Nicht synchronisiert" "unclean": "Nicht synchronisiert"
}, },
"aktivierungsstatus": {
"new": "Neu",
"active": "Aktiv",
"paused": "Pausiert",
"deactivated": "Deaktiviert"
},
"dokumenteSyncstatus": { "dokumenteSyncstatus": {
"new": "Neu", "new": "Neu",
"unclean": "Nicht synchronisiert", "unclean": "Nicht synchronisiert",
@@ -34,6 +41,7 @@
"tooltips": { "tooltips": {
"syncStatus": "Globaler Synchronisationsstatus: synced = Alle Dokumente synchronisiert, unclean = Mindestens ein Dokument ist neu oder hat Änderungen. Wird automatisch basierend auf den Dokumenten-Status aktualisiert.", "syncStatus": "Globaler Synchronisationsstatus: synced = Alle Dokumente synchronisiert, unclean = Mindestens ein Dokument ist neu oder hat Änderungen. Wird automatisch basierend auf den Dokumenten-Status aktualisiert.",
"lastSync": "Zeitpunkt der letzten erfolgreichen Synchronisation aller Dokumente", "lastSync": "Zeitpunkt der letzten erfolgreichen Synchronisation aller Dokumente",
"aktivierungsstatus": "Aktivierungsstatus des AI Knowledge Entries: new = Neu angelegt, active = Aktiv synchronisiert, paused = Synchronisation pausiert, deactivated = Synchronisation deaktiviert",
"datenbankId": "Eindeutige ID in der AI-Datenbank" "datenbankId": "Eindeutige ID in der AI-Datenbank"
} }
} }

View File

@@ -17,6 +17,7 @@
"aktenpfad": "Aktenpfad (Windows)", "aktenpfad": "Aktenpfad (Windows)",
"syncStatus": "Sync-Status", "syncStatus": "Sync-Status",
"lastSync": "Letzte Synchronisation", "lastSync": "Letzte Synchronisation",
"aktivierungsstatus": "Aktivierungsstatus",
"dokumentes": "Dokumente", "dokumentes": "Dokumente",
"dokumenteHnr": "HNR", "dokumenteHnr": "HNR",
"dokumenteSyncstatus": "Sync-Status", "dokumenteSyncstatus": "Sync-Status",
@@ -26,11 +27,18 @@
"syncStatus": { "syncStatus": {
"synced": "Synchronisiert", "synced": "Synchronisiert",
"unclean": "Nicht synchronisiert" "unclean": "Nicht synchronisiert"
},
"aktivierungsstatus": {
"new": "Neu",
"active": "Aktiv",
"paused": "Pausiert",
"deactivated": "Deaktiviert"
} }
}, },
"tooltips": { "tooltips": {
"syncStatus": "Globaler Synchronisationsstatus: synced = Alle Dokumente synchronisiert, unclean = Mindestens ein Dokument ist neu oder hat Änderungen. Wird automatisch basierend auf den Dokumenten-Status aktualisiert.", "syncStatus": "Globaler Synchronisationsstatus: synced = Alle Dokumente synchronisiert, unclean = Mindestens ein Dokument ist neu oder hat Änderungen. Wird automatisch basierend auf den Dokumenten-Status aktualisiert.",
"lastSync": "Zeitpunkt der letzten erfolgreichen Synchronisation aller Dokumente", "lastSync": "Zeitpunkt der letzten erfolgreichen Synchronisation aller Dokumente",
"aktivierungsstatus": "Aktivierungsstatus der Akte: new = Neu angelegt, active = Aktiv synchronisiert, paused = Synchronisation pausiert, deactivated = Synchronisation deaktiviert",
"aktenpfad": "Windows-Dateipfad zur Akte in Advoware" "aktenpfad": "Windows-Dateipfad zur Akte in Advoware"
} }
} }

View File

@@ -6,6 +6,7 @@
"datenbankId": "Database ID", "datenbankId": "Database ID",
"syncStatus": "Sync Status", "syncStatus": "Sync Status",
"lastSync": "Last Synchronization", "lastSync": "Last Synchronization",
"aktivierungsstatus": "Activation Status",
"dokumenteAiDocumentId": "AI Document ID", "dokumenteAiDocumentId": "AI Document ID",
"dokumenteSyncstatus": "Sync Status", "dokumenteSyncstatus": "Sync Status",
"dokumenteLastSync": "Last Sync" "dokumenteLastSync": "Last Sync"
@@ -23,6 +24,12 @@
"synced": "Synchronized", "synced": "Synchronized",
"unclean": "Not Synchronized" "unclean": "Not Synchronized"
}, },
"aktivierungsstatus": {
"new": "New",
"active": "Active",
"paused": "Paused",
"deactivated": "Deactivated"
},
"dokumenteSyncstatus": { "dokumenteSyncstatus": {
"new": "New", "new": "New",
"unclean": "Not Synchronized", "unclean": "Not Synchronized",
@@ -34,6 +41,7 @@
"tooltips": { "tooltips": {
"syncStatus": "Global synchronization status: synced = All documents synchronized, unclean = At least one document is new or has changes. Updated automatically based on document status.", "syncStatus": "Global synchronization status: synced = All documents synchronized, unclean = At least one document is new or has changes. Updated automatically based on document status.",
"lastSync": "Timestamp of the last successful synchronization of all documents", "lastSync": "Timestamp of the last successful synchronization of all documents",
"aktivierungsstatus": "Activation status of the AI Knowledge entry: new = Newly created, active = Actively synchronized, paused = Synchronization paused, deactivated = Synchronization deactivated",
"datenbankId": "Unique ID in the AI database" "datenbankId": "Unique ID in the AI database"
} }
} }

View File

@@ -7,6 +7,7 @@
"aktenpfad": "File Path (Windows)", "aktenpfad": "File Path (Windows)",
"syncStatus": "Sync Status", "syncStatus": "Sync Status",
"lastSync": "Last Synchronization", "lastSync": "Last Synchronization",
"aktivierungsstatus": "Activation Status",
"dokumentes": "Dokumente", "dokumentes": "Dokumente",
"dokumenteHnr": "HNR", "dokumenteHnr": "HNR",
"dokumenteSyncstatus": "Sync Status", "dokumenteSyncstatus": "Sync Status",
@@ -27,11 +28,18 @@
"syncStatus": { "syncStatus": {
"synced": "Synchronized", "synced": "Synchronized",
"unclean": "Not Synchronized" "unclean": "Not Synchronized"
},
"aktivierungsstatus": {
"new": "New",
"active": "Active",
"paused": "Paused",
"deactivated": "Deactivated"
} }
}, },
"tooltips": { "tooltips": {
"syncStatus": "Global synchronization status: synced = All documents synchronized, unclean = At least one document is new or has changes. Updated automatically based on document status.", "syncStatus": "Global synchronization status: synced = All documents synchronized, unclean = At least one document is new or has changes. Updated automatically based on document status.",
"lastSync": "Timestamp of the last successful synchronization of all documents", "lastSync": "Timestamp of the last successful synchronization of all documents",
"aktivierungsstatus": "Activation status of the file: new = Newly created, active = Actively synchronized, paused = Synchronization paused, deactivated = Synchronization deactivated",
"aktenpfad": "Windows file path to the file in Advoware" "aktenpfad": "Windows file path to the file in Advoware"
} }
} }

View File

@@ -69,6 +69,25 @@
"tooltip": true, "tooltip": true,
"isCustom": true "isCustom": true
}, },
"aktivierungsstatus": {
"type": "enum",
"required": false,
"options": [
"new",
"active",
"paused",
"deactivated"
],
"style": {
"new": "primary",
"active": "success",
"paused": "warning",
"deactivated": "danger"
},
"default": "new",
"tooltip": true,
"isCustom": true
},
"dokumenteAiDocumentId": { "dokumenteAiDocumentId": {
"type": "varchar", "type": "varchar",
"notStorable": true, "notStorable": true,

View File

@@ -84,6 +84,25 @@
"tooltip": true, "tooltip": true,
"isCustom": true "isCustom": true
}, },
"aktivierungsstatus": {
"type": "enum",
"required": false,
"options": [
"new",
"active",
"paused",
"deactivated"
],
"style": {
"new": "primary",
"active": "success",
"paused": "warning",
"deactivated": "danger"
},
"default": "new",
"tooltip": true,
"isCustom": true
},
"dokumenteHnr": { "dokumenteHnr": {
"type": "int", "type": "int",
"notStorable": true, "notStorable": true,

View File

@@ -1,9 +1,13 @@
# REST API Endpunkte - EspoCRM Custom Entities # REST API Endpunkte - EspoCRM Custom Entities
**Version:** 1.0 **Version:** 1.1
**Datum:** 11. März 2026 **Datum:** 11. März 2026
**Base URL:** `https://your-crm.com/api/v1` **Base URL:** `https://your-crm.com/api/v1`
**Changelog:**
- v1.1 (11. März 2026): Aktivierungsstatus-Feld hinzugefügt (new, active, paused, deactivated)
- v1.0 (11. März 2026): Initiale Version
--- ---
## 🔐 Authentifizierung ## 🔐 Authentifizierung
@@ -63,6 +67,7 @@ GET /api/v1/CAdvowareAkten
"aktenzeichen": "123/2026", "aktenzeichen": "123/2026",
"aktennummer": 123, "aktennummer": 123,
"aktenpfad": "/advoware/2026/001", "aktenpfad": "/advoware/2026/001",
"aktivierungsstatus": "new",
"syncStatus": "unclean", "syncStatus": "unclean",
"lastSync": null, "lastSync": null,
"createdAt": "2026-03-11 10:00:00", "createdAt": "2026-03-11 10:00:00",
@@ -85,6 +90,7 @@ GET /api/v1/CAdvowareAkten/{id}
"aktenzeichen": "123/2026", "aktenzeichen": "123/2026",
"aktennummer": 123, "aktennummer": 123,
"aktenpfad": "/advoware/2026/001", "aktenpfad": "/advoware/2026/001",
"aktivierungsstatus": "new",
"syncStatus": "unclean", "syncStatus": "unclean",
"lastSync": null, "lastSync": null,
"vmhRumungsklageId": "64e3f8a1234ab", "vmhRumungsklageId": "64e3f8a1234ab",
@@ -104,6 +110,7 @@ Content-Type: application/json
"aktenzeichen": "124/2026", "aktenzeichen": "124/2026",
"aktennummer": 124, "aktennummer": 124,
"aktenpfad": "/advoware/2026/002", "aktenpfad": "/advoware/2026/002",
"aktivierungsstatus": "new",
"syncStatus": "unclean" "syncStatus": "unclean"
} }
``` ```
@@ -121,6 +128,7 @@ PUT /api/v1/CAdvowareAkten/{id}
Content-Type: application/json Content-Type: application/json
{ {
"aktivierungsstatus": "active",
"syncStatus": "synced", "syncStatus": "synced",
"lastSync": "2026-03-11T20:00:00+00:00" "lastSync": "2026-03-11T20:00:00+00:00"
} }
@@ -211,6 +219,17 @@ GET /api/v1/CAdvowareAkten/{id}/mietinkasso
### Filterung & Suche ### Filterung & Suche
#### Nach aktivierungsstatus filtern
```http
GET /api/v1/CAdvowareAkten?where[0][type]=equals&where[0][attribute]=aktivierungsstatus&where[0][value]=new
```
**Verfügbare Werte:**
- `new` - Neu angelegt (Standard, blaue Badge)
- `active` - Aktiv synchronisiert (grüne Badge)
- `paused` - Synchronisation pausiert (gelbe Badge)
- `deactivated` - Synchronisation deaktiviert (rote Badge)
#### Nach syncStatus filtern #### Nach syncStatus filtern
```http ```http
GET /api/v1/CAdvowareAkten?where[0][type]=equals&where[0][attribute]=syncStatus&where[0][value]=unclean GET /api/v1/CAdvowareAkten?where[0][type]=equals&where[0][attribute]=syncStatus&where[0][value]=unclean
@@ -228,7 +247,7 @@ GET /api/v1/CAdvowareAkten?where[0][type]=equals&where[0][attribute]=syncStatus&
#### Nur bestimmte Felder #### Nur bestimmte Felder
```http ```http
GET /api/v1/CAdvowareAkten?select=name,aktenzeichen,syncStatus,lastSync GET /api/v1/CAdvowareAkten?select=id,name,aktivierungsstatus,syncStatus,lastSync
``` ```
#### Mit Sortierung #### Mit Sortierung
@@ -258,6 +277,7 @@ GET /api/v1/CAIKnowledge
"id": "kb-123", "id": "kb-123",
"name": "Knowledge Base 2026-001", "name": "Knowledge Base 2026-001",
"datenbankId": "kb-external-123", "datenbankId": "kb-external-123",
"aktivierungsstatus": "active",
"syncStatus": "synced", "syncStatus": "synced",
"lastSync": "2026-03-11 19:00:00", "lastSync": "2026-03-11 19:00:00",
"createdAt": "2026-03-10 10:00:00" "createdAt": "2026-03-10 10:00:00"
@@ -279,6 +299,7 @@ Content-Type: application/json
{ {
"name": "Knowledge Base 2026-002", "name": "Knowledge Base 2026-002",
"datenbankId": "kb-external-456", "datenbankId": "kb-external-456",
"aktivierungsstatus": "new",
"syncStatus": "unclean" "syncStatus": "unclean"
} }
``` ```
@@ -289,6 +310,7 @@ PUT /api/v1/CAIKnowledge/{id}
Content-Type: application/json Content-Type: application/json
{ {
"aktivierungsstatus": "active",
"syncStatus": "synced", "syncStatus": "synced",
"lastSync": "2026-03-11T20:00:00+00:00" "lastSync": "2026-03-11T20:00:00+00:00"
} }
@@ -330,6 +352,17 @@ DELETE /api/v1/CAIKnowledge/{id}/dokumentes/{dokumentId}
### Filterung & Suche ### Filterung & Suche
#### Nach aktivierungsstatus filtern
```http
GET /api/v1/CAIKnowledge?where[0][type]=equals&where[0][attribute]=aktivierungsstatus&where[0][value]=active
```
**Verfügbare Werte:**
- `new` - Neu angelegt (Standard, blaue Badge)
- `active` - Aktiv synchronisiert (grüne Badge)
- `paused` - Synchronisation pausiert (gelbe Badge)
- `deactivated` - Synchronisation deaktiviert (rote Badge)
#### Nach datenbankId suchen #### Nach datenbankId suchen
```http ```http
GET /api/v1/CAIKnowledge?where[0][type]=equals&where[0][attribute]=datenbankId&where[0][value]=kb-123 GET /api/v1/CAIKnowledge?where[0][type]=equals&where[0][attribute]=datenbankId&where[0][value]=kb-123
@@ -648,7 +681,7 @@ GET /api/v1/CAdvowareAkten?select=id,name,syncStatus,lastSync
### Beispiel 1: Alle unsynchronisierten Akten mit Details ### Beispiel 1: Alle unsynchronisierten Akten mit Details
```bash ```bash
curl -X GET "https://crm.example.com/api/v1/CAdvowareAkten?where[0][type]=equals&where[0][attribute]=syncStatus&where[0][value]=unclean&select=id,name,aktenzeichen,syncStatus&orderBy=createdAt&order=desc" \ curl -X GET "https://crm.example.com/api/v1/CAdvowareAkten?where[0][type]=equals&where[0][attribute]=syncStatus&where[0][value]=unclean&select=id,name,aktenzeichen,aktivierungsstatus,syncStatus&orderBy=createdAt&order=desc" \
-H "X-Api-Key: your-api-key" -H "X-Api-Key: your-api-key"
``` ```
@@ -699,6 +732,7 @@ curl -X PUT "https://crm.example.com/api/v1/CAdvowareAkten/akte-123" \
-H "X-Api-Key: your-api-key" \ -H "X-Api-Key: your-api-key" \
-H "Content-Type: application/json" \ -H "Content-Type: application/json" \
-d '{ -d '{
"aktivierungsstatus": "active",
"syncStatus": "synced", "syncStatus": "synced",
"lastSync": "2026-03-11T20:00:00+00:00" "lastSync": "2026-03-11T20:00:00+00:00"
}' }'
@@ -722,10 +756,64 @@ curl -X GET "https://crm.example.com/api/v1/CAdvowareAktenCDokumente?where[0][ty
-H "X-Api-Key: your-api-key" -H "X-Api-Key: your-api-key"
``` ```
### Beispiel 7: Alle aktiven Akten abrufen
```bash
# Finde alle Akten die aktiv synchronisiert werden
curl -X GET "https://crm.example.com/api/v1/CAdvowareAkten?where[0][type]=equals&where[0][attribute]=aktivierungsstatus&where[0][value]=active&select=id,name,aktenzeichen,aktivierungsstatus,syncStatus" \
-H "X-Api-Key: your-api-key"
```
### Beispiel 8: Akte von "new" auf "active" setzen
```bash
# Aktiviere eine neu angelegte Akte
curl -X PUT "https://crm.example.com/api/v1/CAdvowareAkten/akte-123" \
-H "X-Api-Key: your-api-key" \
-H "Content-Type: application/json" \
-d '{
"aktivierungsstatus": "active"
}'
```
--- ---
## 🎯 Wichtige Hinweise ## 🎯 Wichtige Hinweise
### Aktivierungsstatus
**Zweck:** Steuerung der Synchronisations-Aktivität für Akten und AI Knowledge Entries
**Verfügbare Status:**
- `new` (Standard) - Neu angelegte Einträge, noch nicht für Sync aktiviert
- `active` - Aktiv synchronisiert, alle Sync-Prozesse laufen
- `paused` - Synchronisation temporär pausiert, kann wieder aktiviert werden
- `deactivated` - Synchronisation dauerhaft deaktiviert
**Anwendungsfälle:**
```bash
# Neue Akte anlegen (automatisch status="new")
POST /api/v1/CAdvowareAkten { "name": "...", "aktivierungsstatus": "new" }
# Akte für Sync aktivieren
PUT /api/v1/CAdvowareAkten/{id} { "aktivierungsstatus": "active" }
# Sync temporär pausieren (z.B. während Wartung)
PUT /api/v1/CAdvowareAkten/{id} { "aktivierungsstatus": "paused" }
# Sync permanent deaktivieren
PUT /api/v1/CAdvowareAkten/{id} { "aktivierungsstatus": "deactivated" }
```
**Filterung:**
```bash
# Nur aktive Einträge für Sync-Job
GET /api/v1/CAdvowareAkten?where[0][type]=equals&where[0][attribute]=aktivierungsstatus&where[0][value]=active
# Alle pausierte oder deaktivierte
GET /api/v1/CAdvowareAkten?where[0][type]=in&where[0][attribute]=aktivierungsstatus&where[0][value][0]=paused&where[0][value][1]=deactivated
```
### Junction-Spalten via REST API ### Junction-Spalten via REST API
**✅ RICHTIG:** Nutze Junction-Entity-APIs **✅ RICHTIG:** Nutze Junction-Entity-APIs
@@ -780,6 +868,6 @@ WHERE name = 'Your Role Name';
--- ---
**Letzte Aktualisierung:** 11. März 2026 **Letzte Aktualisierung:** 11. März 2026
**Version:** 1.0 **Version:** 1.1
Für weitere Fragen: Siehe `custom/docs/ESPOCRM_BEST_PRACTICES.md` Für weitere Fragen: Siehe `custom/docs/ESPOCRM_BEST_PRACTICES.md`

View File

@@ -360,7 +360,7 @@ return [
0 => 'youtube.com', 0 => 'youtube.com',
1 => 'google.com' 1 => 'google.com'
], ],
'microtime' => 1773259888.998412, 'microtime' => 1773260767.92155,
'siteUrl' => 'https://crm.bitbylaw.com', 'siteUrl' => 'https://crm.bitbylaw.com',
'fullTextSearchMinLength' => 4, 'fullTextSearchMinLength' => 4,
'webSocketUrl' => 'ws://api.bitbylaw.com:5000/espocrm/ws', 'webSocketUrl' => 'ws://api.bitbylaw.com:5000/espocrm/ws',

View File

@@ -1,7 +1,7 @@
<?php <?php
return [ return [
'cacheTimestamp' => 1773259889, 'cacheTimestamp' => 1773260768,
'microtimeState' => 1773259889.126431, 'microtimeState' => 1773260768.04608,
'currencyRates' => [ 'currencyRates' => [
'EUR' => 1.0 'EUR' => 1.0
], ],