Naar hoofdinhoud gaan

Messaging Endpoints

De Messaging module beheert real-time gesprekken, chatberichten, push-meldingen, SMS/e-mail-bezorging, WebSocket-verbindingen, privéberichten, apparaatregistratie en tekstproviders. Het biedt de communicatielaag die in alle ChurchApps-applicaties wordt gebruikt voor zowel live streaming-chat als asynchrone meldingen.

Base path: /messaging

Gesprekken

Base path: /messaging/conversations

MethodPathAuthPermissionDescription
GET/timeline/ids?ids=JWTGesprekken laden op kommagescheiden ID's met eerste/laatste berichten
GET/messages/:contentType/:contentIdJWTGesprekken voor inhoud laden met gepagineerde berichten (?page=&limit=)
GET/postsJWTPost-type-gesprekken voor groepen van huidige gebruiker ophalen
GET/posts/group/:groupIdJWTPost-type-gesprekken voor een specifieke groep ophalen
GET/current/:churchId/:contentType/:contentIdPublicHuidig gesprek voor inhoud ophalen of aanmaken (ontsleutelt automatisch contentId)
GET/:churchId/:contentType/:contentIdPublicGesprekken op inhoudtype en ID laden
GET/:churchId/:idPublicEen enkel gesprek op ID laden
POST/JWTGesprekken maken of bijwerken (batch)
POST/startJWTEen nieuw gesprek met een initieel opmerking-bericht starten
DELETE/:churchId/:idJWTEen gesprek verwijderen

Voorbeeld: Een Gesprek Starten

POST /messaging/conversations/start
Authorization: Bearer <token>

{
"groupId": "group-123",
"contentType": "group",
"contentId": "group-123",
"title": "Weekly Discussion",
"comment": "Welcome to this week's discussion thread!"
}
{
"id": "conv-456",
"churchId": "church-789",
"contentType": "group",
"contentId": "group-123",
"title": "Weekly Discussion",
"dateCreated": "2026-02-17T10:00:00.000Z",
"visibility": "public",
"allowAnonymousPosts": false,
"groupId": "group-123"
}

Berichten

Base path: /messaging/messages

MethodPathAuthPermissionDescription
GET/conversation/:conversationIdJWTAlle berichten voor een gesprek laden
GET/catchup/:churchId/:conversationIdPublicAlle berichten voor een gesprek laden (openbare inhaalronde voor live chat)
GET/:churchId/:idPublicEen enkel bericht op ID laden
POST/JWTBerichten opslaan (batch). Verzendt real-time updates en triggert meldingen
POST/sendPublicBerichten verzenden (batch, openbaar). Verzendt real-time updates via WebSocket en triggert meldingen
POST/setCalloutJWTEen oproepbericht naar een gesprek uitzenden in real-time
DELETE/:churchId/:idJWTEen bericht verwijderen en de verwijdering in real-time uitzenden

Voorbeeld: Een Bericht Verzenden

POST /messaging/messages/send

[
{
"churchId": "church-789",
"conversationId": "conv-456",
"personId": "person-123",
"displayName": "John Smith",
"content": "Hello everyone!",
"messageType": "comment"
}
]
[
{
"id": "msg-001",
"churchId": "church-789",
"conversationId": "conv-456",
"personId": "person-123",
"displayName": "John Smith",
"timeSent": "2026-02-17T10:05:00.000Z",
"content": "Hello everyone!",
"messageType": "comment"
}
]

Privéberichten

Base path: /messaging/privatemessages

MethodPathAuthPermissionDescription
GET/JWTAlle privéberichten voor huidige gebruiker laden (inclusief laatste bericht per gesprek, markeert alle als gelezen)
GET/existing/:personIdJWTEen bestaand privé-gesprek met een specifieke persoon zoeken
GET/:idJWTEen privébericht op ID laden (wist melding als gericht aan huidige gebruiker)
POST/JWTPrivéberichten verzenden (batch). Triggert push-melding naar ontvanger

Meldingen

Base path: /messaging/notifications

MethodPathAuthPermissionDescription
GET/unreadCountJWTAantal ongelezen meldingen voor huidige gebruiker ophalen
GET/myJWTAlle meldingen voor huidige gebruiker laden (markeert alle als gelezen)
GET/tmpEmailPublicDagelijkse e-mailmeldingssamenvattingstreggeren (debug-/cron-eindpunt)
GET/:churchId/person/:personIdJWTMeldingen voor een specifieke persoon laden
GET/:churchId/:idJWTEen melding op ID laden
POST/JWTMeldingen maken of bijwerken (batch)
POST/createJWTMeldingen voor meerdere personen aanmaken. Body: { peopleIds, contentType, contentId, message, link }
POST/markRead/:churchId/:personIdJWTAlle meldingen voor een persoon als gelezen markeren
POST/sendTestJWTEen test-push-melding verzenden. Body: { personId, title }
POST/pingPublicEen melding van een externe trigger aanmaken. Body: { personId, churchId, contentType, contentId, message, triggeredByPersonId }
DELETE/:churchId/:idJWTEen melding verwijderen

Voorbeeld: Meldingen Aanmaken

POST /messaging/notifications/create
Authorization: Bearer <token>

{
"peopleIds": ["person-123", "person-456"],
"contentType": "group",
"contentId": "group-789",
"message": "New event posted in your group",
"link": "/groups/group-789"
}

Meldingsvoorkeuren

Base path: /messaging/notificationpreferences

Breidt standaard CRUD uit. De basisklasse biedt POST / (maken of bijwerken, geen machtiging vereist).

MethodPathAuthPermissionDescription
POST/JWTMeldingsvoorkeuren maken of bijwerken (van CRUD-basisklasse)
GET/myJWTMeldingsvoorkeuren voor huidige gebruiker laden (maakt automatisch standaarden aan als deze niet bestaan)

Verbindingen

Base path: /messaging/connections

Beheert WebSocket-/real-time-verbindingen voor live streaming-chat.

MethodPathAuthPermissionDescription
GET/:churchId/:conversationIdPublicAlle verbindingen voor een gesprek laden
POST/PublicVerbindingen registreren (batch). Nummert anonieme gebruikers automatisch en verzendt aanwezigheids-/geblokkeerde IP-updates
POST/setNamePublicWeergavenaam voor een verbinding op socket-ID bijwerken. Body: { socketId, name }
POST/tmpSendAlertPublicEen meldingswaarschuwing naar verbindingen van een persoon verzenden. Body: { churchId, personId }

Apparaten

Base path: /messaging/devices

Beheert apparaatregistratie voor push-meldingen en inhoudscoppelaing (bijv. Lessons-app op TV-displays).

MethodPathAuthPermissionDescription
POST/enrollJWTEen apparaat inschrijven of bijwerken (mobiele push-registratie). Komt overeen met FCM-token of apparaat-ID
POST/enrollAnonPublicEen anoniem apparaat inschrijven en een 4-tekenige koppelingscode genereren
POST/PublicApparaten opslaan (batch)
GET/pair/:pairingCodeJWTEen apparaat koppelen met behulp van de koppelingscode. Optioneel ?contentType=&contentId= voor inhoudsopdrachtgering
GET/status/:deviceIdPublicKoppelingstatus van een apparaat controleren
GET/:churchIdJWTAlle apparaten voor een kerk laden
GET/:churchId/person/:personIdJWTAlle apparaten voor een persoon laden
GET/:churchId/:idJWTEen apparaat op ID laden
DELETE/:churchId/:idJWTEen apparaat verwijderen

Voorbeeld: Een Apparaat Inschrijven

POST /messaging/devices/enroll
Authorization: Bearer <token>

{
"fcmToken": "firebase-token-abc123",
"appName": "B1Mobile",
"label": "John's iPhone",
"deviceInfo": "iOS 17, iPhone 15"
}
{
"id": "device-001",
"churchId": "church-789",
"fcmToken": "firebase-token-abc123",
"appName": "B1Mobile",
"label": "John's iPhone",
"registrationDate": "2026-02-17T10:00:00.000Z",
"lastActiveDate": "2026-02-17T10:00:00.000Z"
}

Apparaatinhoud

Base path: /messaging/devicecontents

Beheert inhoudsopdrachtgeringen voor gekoppelde apparaten (bijv. welke les op een TV wordt weergegeven).

MethodPathAuthPermissionDescription
GET/deviceId/:deviceIdJWTInhoudsopdrachtgeringen voor een apparaat laden
POST/JWTApparaatinhoudopdrachtgeringen opslaan (batch)
DELETE/:idJWTEen apparaatinhoudopdracht verwijderen

Texten

Base path: /messaging/texting

Beheert SMS-tekstingproviders, groepstekstbericht en bezorgingstracking.

MethodPathAuthPermissionDescription
GET/providersJWTTekstingsproviders voor de kerk laden (gegevens zijn gemaskeerd)
GET/preview/:groupIdJWTOntvangers voor een groepstekst voorvertonen (in aanmerking komend, opt-out, geen telefoontellen)
GET/sentJWTAlle verzonden tekstberichtrecords voor de kerk laden
GET/sent/:id/detailsJWTEen verzonden tekst met per-ontvanger-bezorgingslogs laden
POST/providersJWTTekstingsproviders opslaan (batch). Versleutelt API-gegevens
POST/sendJWTEen SMS naar alle in aanmerking komende leden van een groep verzenden. Body: { groupId, message }
POST/sendPersonJWTEen SMS naar een enkele persoon verzenden. Body: { personId, phoneNumber, message }
DELETE/providers/:idJWTEen tekstingsprovider verwijderen

Voorbeeld: Groepstekst Verzenden

POST /messaging/texting/send
Authorization: Bearer <token>

{
"groupId": "group-123",
"message": "Reminder: Service starts at 10 AM this Sunday!"
}
{
"totalMembers": 50,
"recipientCount": 42,
"successCount": 40,
"failCount": 2,
"optedOutCount": 5,
"noPhoneCount": 3
}

E-mailsjablonen

Base path: /messaging/emailTemplates

Beheert herbruikbare e-mailsjablonen en het verzenden van sjablone-mails naar groepen.

MethodPathAuthPermissionDescription
GET/JWTAlle e-mailsjablonen voor de kerk laden
GET/:idJWTEen enkel e-mailsjabloon op ID laden
GET/preview/:groupIdJWTE-mailbezorging voor een groep voorvertonen (in aanmerking komend ontvangersaantal, leden zonder e-mail)
POST/JWTE-mailsjablonen maken of bijwerken (batch)
POST/sendJWTEen sjablone-mail naar alle leden van een groep verzenden. Body: { groupId, subject, htmlContent }
DELETE/:idJWTEen e-mailsjabloon verwijderen

Voorbeeld: E-mail naar Groep Verzenden

POST /messaging/emailTemplates/send
Authorization: Bearer <token>

{
"groupId": "group-123",
"subject": "This Week's Update - {{churchName}}",
"htmlContent": "<p>Hello {{firstName}},</p><p>Here's what's happening this week...</p>"
}
{
"totalMembers": 50,
"recipientCount": 45,
"successCount": 44,
"failCount": 1,
"noEmailCount": 5
}

Ondersteunde mergevelden: {{firstName}}, {{lastName}}, {{displayName}}, {{email}}, {{churchName}}

Geblokkeerde IP's

Base path: /messaging/blockedips

Beheert IP-blokkering voor live streaming-chatgesprekken.

MethodPathAuthPermissionDescription
POST/JWTGeblokkeerde IP's opslaan (batch). Zendt bijgewerkte bloklijst naar het gesprek
POST/clearJWTAlle geblokkeerde IP's voor bepaalde services wissen. Body: [{ serviceId, churchId }]

Bezorgingslogs

Base path: /messaging/deliverylogs

Volgt bezorgingsstatus voor verzonden berichten (SMS, push-meldingen, e-mail) bij.

MethodPathAuthPermissionDescription
GET/content/:contentType/:contentIdJWTBezorgingslogs op inhoudtype en ID laden
GET/person/:personIdJWTBezorgingslogs voor een persoon laden. Optioneel ?startDate=&endDate= filters
GET/recentJWTRecente bezorgingslogs voor de kerk laden. Optioneel ?limit= (standaard 100)
GET/:idJWTEen bezorgingslog op ID laden

Gerelateerde Pagina's