[add] api:action:invite_read [mod] api:action:invite_create
This commit is contained in:
parent
519da08557
commit
9c6de46702
7 changed files with 349 additions and 81 deletions
|
@ -24,6 +24,7 @@ namespace _espe.api
|
||||||
{
|
{
|
||||||
lib_plankton.rest_http.register<
|
lib_plankton.rest_http.register<
|
||||||
{
|
{
|
||||||
|
data : {
|
||||||
membership_number_changeable : boolean;
|
membership_number_changeable : boolean;
|
||||||
membership_number_value : (null | string);
|
membership_number_value : (null | string);
|
||||||
name_changeable : boolean;
|
name_changeable : boolean;
|
||||||
|
@ -32,8 +33,10 @@ namespace _espe.api
|
||||||
email_address_value : (null | string);
|
email_address_value : (null | string);
|
||||||
groups_changeable : boolean;
|
groups_changeable : boolean;
|
||||||
groups_value : Array<string>;
|
groups_value : Array<string>;
|
||||||
expiry ?: (null | int);
|
expiry : (null | int);
|
||||||
// notification_target_url_template ?: (null | string);
|
};
|
||||||
|
notification_target_url_template ?: (null | string);
|
||||||
|
send_immediatly : boolean;
|
||||||
},
|
},
|
||||||
(
|
(
|
||||||
string
|
string
|
||||||
|
@ -57,6 +60,16 @@ namespace _espe.api
|
||||||
"nullable": false,
|
"nullable": false,
|
||||||
"additionalProperties": false,
|
"additionalProperties": false,
|
||||||
"properties": {
|
"properties": {
|
||||||
|
"data": {
|
||||||
|
"nullable": false,
|
||||||
|
"type": "object",
|
||||||
|
"additionalProperties": false,
|
||||||
|
"properties": {
|
||||||
|
"expiry": {
|
||||||
|
"nullable": true,
|
||||||
|
"type": "intiger",
|
||||||
|
"description": "Ablaufzeitpunkt"
|
||||||
|
},
|
||||||
"membership_number_changeable": {
|
"membership_number_changeable": {
|
||||||
"type": "boolean",
|
"type": "boolean",
|
||||||
"nullable": false,
|
"nullable": false,
|
||||||
|
@ -101,18 +114,6 @@ namespace _espe.api
|
||||||
},
|
},
|
||||||
"description": "Gruppen | Wert"
|
"description": "Gruppen | Wert"
|
||||||
},
|
},
|
||||||
"expiry": {
|
|
||||||
"nullable": true,
|
|
||||||
"type": "intiger",
|
|
||||||
"description": "Ablaufzeitpunkt"
|
|
||||||
},
|
|
||||||
/*
|
|
||||||
"notification_target_url_template": {
|
|
||||||
"type": "string",
|
|
||||||
"nullable": true,
|
|
||||||
"description": "Platz-Halter: id"
|
|
||||||
},
|
|
||||||
*/
|
|
||||||
},
|
},
|
||||||
"required": [
|
"required": [
|
||||||
"membership_number_changeable",
|
"membership_number_changeable",
|
||||||
|
@ -125,6 +126,22 @@ namespace _espe.api
|
||||||
"groups_value",
|
"groups_value",
|
||||||
"expiry",
|
"expiry",
|
||||||
]
|
]
|
||||||
|
},
|
||||||
|
"notification_target_url_template": {
|
||||||
|
"type": "string",
|
||||||
|
"nullable": true,
|
||||||
|
"description": "Platz-Halter: key"
|
||||||
|
},
|
||||||
|
"send_immediatly": {
|
||||||
|
"nullable": false,
|
||||||
|
"type": "boolean",
|
||||||
|
"description": "Einladungs-Link direkt an angegebene E-Mail-Adresse versenden"
|
||||||
|
},
|
||||||
|
},
|
||||||
|
"required": [
|
||||||
|
"data",
|
||||||
|
"send_immediatly",
|
||||||
|
]
|
||||||
}),
|
}),
|
||||||
"output_schema": () => ({
|
"output_schema": () => ({
|
||||||
"type": "object",
|
"type": "object",
|
||||||
|
@ -155,9 +172,9 @@ namespace _espe.api
|
||||||
(! _espe.conf.get().settings.misc.facultative_membership_number)
|
(! _espe.conf.get().settings.misc.facultative_membership_number)
|
||||||
&&
|
&&
|
||||||
(
|
(
|
||||||
(input.membership_number_value === null)
|
(input.data.membership_number_value === null)
|
||||||
||
|
||
|
||||||
(input.membership_number_value === "")
|
(input.data.membership_number_value === "")
|
||||||
)
|
)
|
||||||
) {
|
) {
|
||||||
return Promise.resolve({
|
return Promise.resolve({
|
||||||
|
@ -168,17 +185,19 @@ namespace _espe.api
|
||||||
else {
|
else {
|
||||||
const invite_info : {id : _espe.type.invite_id; key : _espe.type.invite_key;} = await _espe.service.invite.create(
|
const invite_info : {id : _espe.type.invite_id; key : _espe.type.invite_key;} = await _espe.service.invite.create(
|
||||||
{
|
{
|
||||||
"membership_number_changeable": input.membership_number_changeable,
|
"membership_number_changeable": input.data.membership_number_changeable,
|
||||||
"membership_number_value": input.membership_number_value,
|
"membership_number_value": input.data.membership_number_value,
|
||||||
"name_changeable": input.name_changeable,
|
"name_changeable": input.data.name_changeable,
|
||||||
"name_value": input.name_value,
|
"name_value": input.data.name_value,
|
||||||
"email_address_changeable": input.email_address_changeable,
|
"email_address_changeable": input.data.email_address_changeable,
|
||||||
"email_address_value": input.email_address_value,
|
"email_address_value": input.data.email_address_value,
|
||||||
"groups_changeable": input.groups_changeable,
|
"groups_changeable": input.data.groups_changeable,
|
||||||
"groups_value": input.groups_value,
|
"groups_value": input.data.groups_value,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"expiry": input.expiry,
|
"expiry": input.data.expiry,
|
||||||
|
"notification_target_url_template": input.notification_target_url_template,
|
||||||
|
"send_immediatly": input.send_immediatly,
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
return Promise.resolve({
|
return Promise.resolve({
|
||||||
|
|
160
source/api/actions/invite_read.ts
Normal file
160
source/api/actions/invite_read.ts
Normal file
|
@ -0,0 +1,160 @@
|
||||||
|
/*
|
||||||
|
Espe | Ein schlichtes Werkzeug zur Mitglieder-Verwaltung | Backend
|
||||||
|
Copyright (C) 2024 Christian Fraß
|
||||||
|
|
||||||
|
This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public
|
||||||
|
License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later
|
||||||
|
version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied
|
||||||
|
warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License along with this program. If not, see
|
||||||
|
<https://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace _espe.api
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
*/
|
||||||
|
export function register_invite_read(
|
||||||
|
rest_subject : lib_plankton.rest_http.type_rest
|
||||||
|
) : void
|
||||||
|
{
|
||||||
|
lib_plankton.rest_http.register<
|
||||||
|
int,
|
||||||
|
(
|
||||||
|
string
|
||||||
|
|
|
||||||
|
{
|
||||||
|
key : string;
|
||||||
|
expiry : (null | int);
|
||||||
|
membership_number_changeable : boolean;
|
||||||
|
membership_number_value : (null | string);
|
||||||
|
name_changeable : boolean;
|
||||||
|
name_value : string;
|
||||||
|
email_address_changeable : boolean;
|
||||||
|
email_address_value : (null | string);
|
||||||
|
groups_changeable : boolean;
|
||||||
|
groups_value : Array<string>;
|
||||||
|
}
|
||||||
|
)
|
||||||
|
>(
|
||||||
|
rest_subject,
|
||||||
|
lib_plankton.http.enum_method.get,
|
||||||
|
_espe.api.full_path("/invite/read"),
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @todo translation
|
||||||
|
*/
|
||||||
|
"description": () => "gibt die Daten einer Einladung anhand ihrer ID aus",
|
||||||
|
"query_parameters": () => [
|
||||||
|
{
|
||||||
|
"name": "id",
|
||||||
|
"required": true,
|
||||||
|
"description": "id",
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"output_schema": () => ({
|
||||||
|
"type": "object",
|
||||||
|
"nullable": false,
|
||||||
|
"additionalProperties": false,
|
||||||
|
"properties": {
|
||||||
|
"expiry": {
|
||||||
|
"nullable": true,
|
||||||
|
"type": "integer",
|
||||||
|
"description": "Ablaufzeitpunkt"
|
||||||
|
},
|
||||||
|
"membership_number_changeable": {
|
||||||
|
"type": "boolean",
|
||||||
|
"nullable": false,
|
||||||
|
"description": "Mitgliedsnummer | änderbar"
|
||||||
|
},
|
||||||
|
"membership_number_value": {
|
||||||
|
"type": "string",
|
||||||
|
"nullable": true,
|
||||||
|
"description": "Mitgliedsnummer | Wert"
|
||||||
|
},
|
||||||
|
"name_changeable": {
|
||||||
|
"type": "boolean",
|
||||||
|
"nullable": false,
|
||||||
|
"description": "Name | änderbar"
|
||||||
|
},
|
||||||
|
"name_value": {
|
||||||
|
"type": "string",
|
||||||
|
"nullable": true,
|
||||||
|
"description": "Name | Wert"
|
||||||
|
},
|
||||||
|
"email_address_changeable": {
|
||||||
|
"type": "boolean",
|
||||||
|
"nullable": false,
|
||||||
|
"description": "E-Mail-Adresse | änderbar"
|
||||||
|
},
|
||||||
|
"email_address_value": {
|
||||||
|
"type": "string",
|
||||||
|
"nullable": true,
|
||||||
|
"description": "E-Mail-Adresse | Wert"
|
||||||
|
},
|
||||||
|
"groups_changeable": {
|
||||||
|
"type": "boolean",
|
||||||
|
"nullable": false,
|
||||||
|
"description": "Gruppen | änderbar"
|
||||||
|
},
|
||||||
|
"groups_value": {
|
||||||
|
"nullable": false,
|
||||||
|
"type": "array",
|
||||||
|
"items": {
|
||||||
|
"type": "string",
|
||||||
|
"nullable": false,
|
||||||
|
},
|
||||||
|
"description": "Gruppen | Wert"
|
||||||
|
},
|
||||||
|
},
|
||||||
|
"required": [
|
||||||
|
"expiry",
|
||||||
|
"membership_number_mode",
|
||||||
|
"membership_number_value",
|
||||||
|
"name_mode",
|
||||||
|
"name_value",
|
||||||
|
"email_address_mode",
|
||||||
|
"email_address_value",
|
||||||
|
"groups_mode",
|
||||||
|
"groups_value",
|
||||||
|
]
|
||||||
|
}),
|
||||||
|
"restriction": () => restriction_logged_in,
|
||||||
|
"execution": () => ({"query_parameters": query_parameters, "input": input}) => {
|
||||||
|
const invite_id : _espe.type.invite_id = parseInt(query_parameters["id"]);
|
||||||
|
return (
|
||||||
|
_espe.service.invite.get_by_id(invite_id)
|
||||||
|
.then(
|
||||||
|
(invite_object) => Promise.resolve({
|
||||||
|
"status_code": 200,
|
||||||
|
"data": {
|
||||||
|
"key": invite_object.key,
|
||||||
|
"expiry": invite_object.expiry,
|
||||||
|
"membership_number_changeable": invite_object.membership_number_changeable,
|
||||||
|
"membership_number_value": invite_object.membership_number_value,
|
||||||
|
"name_changeable": invite_object.name_changeable,
|
||||||
|
"name_value": invite_object.name_value,
|
||||||
|
"email_address_changeable": invite_object.email_address_changeable,
|
||||||
|
"email_address_value": invite_object.email_address_value,
|
||||||
|
"groups_changeable": invite_object.groups_changeable,
|
||||||
|
"groups_value": invite_object.groups_value,
|
||||||
|
}
|
||||||
|
})
|
||||||
|
)
|
||||||
|
.catch(
|
||||||
|
(error) => Promise.resolve({
|
||||||
|
"status_code": 404,
|
||||||
|
"data": "not found"
|
||||||
|
})
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -62,6 +62,7 @@ namespace _espe.api
|
||||||
// invite
|
// invite
|
||||||
{
|
{
|
||||||
_espe.api.register_invite_list(rest_subject);
|
_espe.api.register_invite_list(rest_subject);
|
||||||
|
_espe.api.register_invite_read(rest_subject);
|
||||||
_espe.api.register_invite_create(rest_subject);
|
_espe.api.register_invite_create(rest_subject);
|
||||||
_espe.api.register_invite_examine(rest_subject);
|
_espe.api.register_invite_examine(rest_subject);
|
||||||
_espe.api.register_invite_accept(rest_subject);
|
_espe.api.register_invite_accept(rest_subject);
|
||||||
|
|
|
@ -14,6 +14,8 @@
|
||||||
"email.password_change.initialization.body": "Hi, {{name}}\n\nDie Funktion zum Ändern deines Passwortes wurde aufgerufen. Wenn du dein Passwort ändern willst, rufe folgenden Link auf:\n\n{{url}}\n",
|
"email.password_change.initialization.body": "Hi, {{name}}\n\nDie Funktion zum Ändern deines Passwortes wurde aufgerufen. Wenn du dein Passwort ändern willst, rufe folgenden Link auf:\n\n{{url}}\n",
|
||||||
"email.password_change.execution.subject": "Passwort-Änderung abgeschlossen",
|
"email.password_change.execution.subject": "Passwort-Änderung abgeschlossen",
|
||||||
"email.password_change.execution.body": "Hi, {{name}}\n\nDein Passwort wurde soeben geändert.\n",
|
"email.password_change.execution.body": "Hi, {{name}}\n\nDein Passwort wurde soeben geändert.\n",
|
||||||
|
"email.invitation.subject": "Einladung",
|
||||||
|
"email.invitation.body": "{{url}}",
|
||||||
"help.args.action.description": "auszuführende Aktion; Auswahl",
|
"help.args.action.description": "auszuführende Aktion; Auswahl",
|
||||||
"help.args.action.options.serve": "Server starten",
|
"help.args.action.options.serve": "Server starten",
|
||||||
"help.args.action.options.api_doc": "API-Dokumentation gemäß OpenAPI-Spezifikation auf Standard-Ausgabe schreiben",
|
"help.args.action.options.api_doc": "API-Dokumentation gemäß OpenAPI-Spezifikation auf Standard-Ausgabe schreiben",
|
||||||
|
|
|
@ -14,6 +14,8 @@
|
||||||
"email.password_change.initialization.body": "Hi, {{name}}\n\nThe function for changing your password has been triggered. If you want to change your password, open the folloling link:\n\n{{url}}",
|
"email.password_change.initialization.body": "Hi, {{name}}\n\nThe function for changing your password has been triggered. If you want to change your password, open the folloling link:\n\n{{url}}",
|
||||||
"email.password_change.execution.subject": "Password change concluded",
|
"email.password_change.execution.subject": "Password change concluded",
|
||||||
"email.password_change.execution.body": "Hi, {{name}}\n\nYour password has just been changed.\n",
|
"email.password_change.execution.body": "Hi, {{name}}\n\nYour password has just been changed.\n",
|
||||||
|
"email.invitation.subject": "invitation",
|
||||||
|
"email.invitation.body": "{{url}}",
|
||||||
"help.args.action.description": "action to executo; options",
|
"help.args.action.description": "action to executo; options",
|
||||||
"help.args.action.options.serve": "start server",
|
"help.args.action.options.serve": "start server",
|
||||||
"help.args.action.options.api_doc": "write API documentation according to OpenAPI specification to stdout",
|
"help.args.action.options.api_doc": "write API documentation according to OpenAPI specification to stdout",
|
||||||
|
|
|
@ -72,8 +72,12 @@ namespace _espe.service.invite
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"expiry": expiry = -1,
|
"expiry": expiry = -1,
|
||||||
|
"notification_target_url_template": notification_target_url_template = null,
|
||||||
|
"send_immediatly": send_immediatly = true,
|
||||||
} : {
|
} : {
|
||||||
expiry ?: (null | int);
|
expiry ?: (null | int);
|
||||||
|
notification_target_url_template ?: (null | string);
|
||||||
|
send_immediatly ?: boolean;
|
||||||
} = {
|
} = {
|
||||||
}
|
}
|
||||||
) : Promise<{id : _espe.type.invite_id; key : _espe.type.invite_key}>
|
) : Promise<{id : _espe.type.invite_id; key : _espe.type.invite_key}>
|
||||||
|
@ -114,6 +118,75 @@ namespace _espe.service.invite
|
||||||
"groups_value": groups_value,
|
"groups_value": groups_value,
|
||||||
};
|
};
|
||||||
const invite_id : _espe.type.invite_id = await _espe.repository.invite.create(invite_object);
|
const invite_id : _espe.type.invite_id = await _espe.repository.invite.create(invite_object);
|
||||||
|
// send link
|
||||||
|
{
|
||||||
|
if (! send_immediatly)
|
||||||
|
{
|
||||||
|
// do nothing
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (
|
||||||
|
! (
|
||||||
|
(
|
||||||
|
(email_address_value !== null)
|
||||||
|
&&
|
||||||
|
(email_address_value !== "")
|
||||||
|
)
|
||||||
|
&&
|
||||||
|
(notification_target_url_template !== null)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
{
|
||||||
|
lib_plankton.log._warning(
|
||||||
|
"espe.service.invite.create.email.condition_unmet",
|
||||||
|
{
|
||||||
|
"details": {
|
||||||
|
"provided_address": email_address_value,
|
||||||
|
"notification_target_url_template": notification_target_url_template,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
const url : (null | string) = _espe.helpers.frontend_url_get(
|
||||||
|
notification_target_url_template,
|
||||||
|
{
|
||||||
|
"key": invite_key,
|
||||||
|
}
|
||||||
|
);
|
||||||
|
try {
|
||||||
|
await _espe.helpers.email_send(
|
||||||
|
[email_address_value],
|
||||||
|
lib_plankton.translate.get(
|
||||||
|
"email.invitation.subject",
|
||||||
|
{
|
||||||
|
}
|
||||||
|
),
|
||||||
|
lib_plankton.translate.get(
|
||||||
|
"email.invitation.body",
|
||||||
|
{
|
||||||
|
"url": (url ?? "?"),
|
||||||
|
}
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
catch (error)
|
||||||
|
{
|
||||||
|
lib_plankton.log._error(
|
||||||
|
"espe.service.invite.create.email.could_not_be_sent",
|
||||||
|
{
|
||||||
|
"details": {
|
||||||
|
"provided_address": email_address_value,
|
||||||
|
"error": String(error),
|
||||||
|
},
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
return {
|
return {
|
||||||
"id": invite_id,
|
"id": invite_id,
|
||||||
"key": invite_key,
|
"key": invite_key,
|
||||||
|
@ -123,7 +196,17 @@ namespace _espe.service.invite
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*/
|
*/
|
||||||
function get(
|
export function get_by_id(
|
||||||
|
id : _espe.type.invite_id
|
||||||
|
) : Promise<_espe.type.invite_object>
|
||||||
|
{
|
||||||
|
return _espe.repository.invite.read(id)
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
*/
|
||||||
|
function get_by_key(
|
||||||
key : _espe.type.invite_key
|
key : _espe.type.invite_key
|
||||||
) : Promise<_espe.type.invite_object>
|
) : Promise<_espe.type.invite_object>
|
||||||
{
|
{
|
||||||
|
@ -144,7 +227,7 @@ namespace _espe.service.invite
|
||||||
{
|
{
|
||||||
let invite_object : (null | _espe.type.invite_object);
|
let invite_object : (null | _espe.type.invite_object);
|
||||||
try {
|
try {
|
||||||
invite_object = await get(key);
|
invite_object = await get_by_key(key);
|
||||||
}
|
}
|
||||||
catch (error) {
|
catch (error) {
|
||||||
invite_object = null;
|
invite_object = null;
|
||||||
|
|
|
@ -72,6 +72,7 @@ ${dir_temp}/espe-core.js ${dir_temp}/espe-core.d.ts: \
|
||||||
${dir_source}/api/actions/member_password_change_initialize.ts \
|
${dir_source}/api/actions/member_password_change_initialize.ts \
|
||||||
${dir_source}/api/actions/member_password_change_execute.ts \
|
${dir_source}/api/actions/member_password_change_execute.ts \
|
||||||
${dir_source}/api/actions/invite_list.ts \
|
${dir_source}/api/actions/invite_list.ts \
|
||||||
|
${dir_source}/api/actions/invite_read.ts \
|
||||||
${dir_source}/api/actions/invite_create.ts \
|
${dir_source}/api/actions/invite_create.ts \
|
||||||
${dir_source}/api/actions/invite_examine.ts \
|
${dir_source}/api/actions/invite_examine.ts \
|
||||||
${dir_source}/api/actions/invite_accept.ts \
|
${dir_source}/api/actions/invite_accept.ts \
|
||||||
|
|
Loading…
Add table
Reference in a new issue