ec5ec800de72a3932cf44ff95c9649d17eb48741
All checks were successful
deploy / build-and-deploy (push) Successful in 20s
API
Wenn die env variable
API_SECRETgesetzt ist, muss jede API Request den HTTP HeaderAuthorization: Basic <"api:<API_SECRET>" as base64>haben.
POST /api/feedback (Erstellt Feedbackformulare)
Request Body
{
// Interner Event Name (oder ID)
"event": string,
// Event Titel, wird über dem Feedbackformular angezeigt
"title": string,
// UUIDs aller Spieler, die das Feedback ausfüllen sollen
"users": string[]
}
Response Codes
| http code | beschreibung |
|---|---|
| 200 | / |
| 400 | Der Request Body ist falsch |
| 401 | Es wurde ein falsches API Secret angegeben |
Response Body
{
"feedback": {
// UUID eines Spieler
"uuid": string
// URL zum Feedbackformular
"url": string
}[]
}
POST /api/reports (Erstellt einen Report)
Request Body
{
// UUID des Report Erstellers
"reporter": string,
// UUID des Reporteten Spielers
"reported": string | null,
// Report Grund
"reason": string
}
Response Codes
| http code | beschreibung |
|---|---|
| 200 | / |
| 400 | Der Request Body ist falsch |
| 401 | Es wurde ein falsches API Secret angegeben |
| 404 | Der Report Ersteller, oder der reportete Spieler, existiert nicht |
Response Body
{
// URL, wo der Ersteller den Report abschicken kann
"url": string
}
PUT /api/reports (Erstellt einen Abgeschlossenen Report)
Request Body
{
// UUID des Reporters. Wenn `null`, wird der Reporter als System interpretiert
"reporter": string | null,
// UUID des Reporteten Spielers
"reported": string,
// Report Grund
"reason": string,
// Inhalt des Reports
"body": string | null,
// Interne Notiz
"notice": string | null,
// Öffentliches Statement
"statement": string | null,
// ID des Strikegrundes
"strike_reason_id": number
}
Response Codes
| http code | beschreibung |
|---|---|
| 200 | / |
| 400 | Der Request Body ist falsch |
| 401 | Es wurde ein falsches API Secret angegeben |
| 404 | Der Report Ersteller, oder der reportete Spieler, existiert nicht |
Response Body
/
GET /api/users/{uuid} (Status eines Spielers)
Path Parameters
| parameter | beschreibung |
|---|---|
uuid |
UUID eines Spielers |
Response Codes
| http code | beschreibung |
|---|---|
| 200 | / |
| 400 | Der Request Body ist falsch |
| 401 | Es wurde ein falsches API Secret angegeben |
| 404 | Der Spieler existiert nicht |
Response Body
{
// Vorname des Spielers
firstname: string,
// Nachname des Spielers
lastname: string,
// Nutzername des Spielers
username: string,
// UUID des Spielers
uuid: string,
// Liste aller Strikes, die der Spieler hat
strikes: {
// UTC Timestamp wann der Strike erstellt wurde
"at": number,
// Strike Gewichtung
"weight": number,
}[]
}
GET /api/users/{uuid}/reports (Reports eines Spielers)
Path Parameters
| parameter | beschreibung |
|---|---|
uuid |
UUID eines Spielers |
Response Codes
| http code | beschreibung |
|---|---|
| 200 | / |
| 400 | Der Request Body ist falsch |
| 401 | Es wurde ein falsches API Secret angegeben |
| 404 | Der Spieler existiert nicht |
Response Body
{
// Alle Reports, die der Spieler selber erstellt hat
"from_self": {
// Die UUID des reporteten Spielers oder null falls ein unbekannter Spieler reportet wurde
"reported": string | null,
// Grund des Reports
"reason": string,
// Wann der Report abgeschickt wurde als UTC Millisekunden oder null falls der Report noch nicht abgeschickt wurde (=> kann noch bearbeitet werden)
"created": number | null,
// Status des Reports, "open" wenn er gerade bearbeitet wird, "closed" falls er bearbeitet wurde, null wenn nichts von beidem
"status": "open" | "closed" | null,
// Url zum Report auf der Website
"url": string
}[],
// Alle Reports, die gegen den Spieler erstellt wurden
"to_self": {
// Die UUID des Spielers, der den Report erstellt hat oder null falls der Report vom System kommt
"reporter": string | null,
// Grund des Reports
"reason": string,
// Wann der Report abgeschickt wurde als UTC Millisekunden oder null falls der Report noch nicht abgeschickt wurde (=> kann noch bearbeitet werden)
"created": number | null,
// Status des Reports, "open" wenn er gerade bearbeitet wird, "closed" falls er bearbeitet wurde, null wenn nichts von beidem
"status": "open" | "closed" | null,
// Url zum Report auf der Website
"url": string
}[]
}
Webhook
Die env variable
WEBHOOK_ENDPOINTmuss gesetzt und eine valide HTTP URL sein. Es können auch mehrere Endpoints gesetzt sein, dafür müssen die URLs mit einem komma getrennt sein.
Bei bestimmten Aktionen wird an den Webhook Endpoint ein Webhook gesendet.
Die Art des Webhooks wird dabei durch den x-webhook-action HTTP Header angegeben und hat einen festgelegten JSON Body.
Das Webhook wir so oft gesendet, bis der angegebene Webhook Endpoint eine Response mit Status 200 zurücksendet.
Alle Webhooks:
| Beschreibung | HTTP Header | Body |
|---|---|---|
| Ein neuer Nutzer hat sich registriert | x-webhook-action: signup |
{ |
| Ein neuer Report wurde erstellt | x-webhook-action: report |
{ |
| Ein neuer Strike wurde erstellt | x-webhook-action: strike |
{ |
Description
Languages
TypeScript
40.3%
Svelte
34.8%
Astro
23%
JavaScript
1.4%
CSS
0.5%