backend/source/api/actions/member_read.ts

94 lines
2.5 KiB
TypeScript
Raw Normal View History

2024-05-20 21:56:48 +02:00
/*
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/>.
*/
2024-04-22 10:22:18 +02:00
namespace _espe.api
2024-04-22 10:02:34 +02:00
{
/**
*/
export function register_member_read(
2025-04-03 06:19:19 +00:00
rest_subject : lib_plankton.rest_http.type_rest
2024-04-22 10:02:34 +02:00
) : void
{
2025-04-03 06:19:19 +00:00
lib_plankton.rest_http.register<
2024-04-30 01:32:24 +02:00
null,
{
2025-07-07 12:10:52 +02:00
name : string;
email_address : (null | string);
groups : Array<int>;
2024-04-30 01:32:24 +02:00
enabled : boolean;
password_set : boolean;
}
2024-04-29 20:48:20 +02:00
>(
2024-04-22 10:02:34 +02:00
rest_subject,
lib_plankton.http.enum_method.get,
2025-04-03 06:19:19 +00:00
_espe.api.full_path("/member/read/:id"),
2024-04-22 10:02:34 +02:00
{
2025-04-03 06:19:19 +00:00
"description": () => "gibt ein Mitglied anhand seiner ID aus",
2024-04-22 10:02:34 +02:00
"output_schema": () => ({
"nullable": false,
2024-04-29 20:48:20 +02:00
"type": "object",
"properties": {
2025-07-07 12:10:52 +02:00
"name": {
"nullable": false,
"type": "string"
},
2025-07-07 12:10:52 +02:00
"email_address": {
"nullable": true,
"type": "string"
},
2025-01-17 09:49:13 +01:00
"groups": {
"nullable": false,
"type": "array",
"items": {
"nullable": false,
2025-07-07 12:10:52 +02:00
"type": "int"
2025-01-17 09:49:13 +01:00
}
},
"enabled": {
"nullable": false,
"type": "boolean"
},
2024-04-29 20:48:20 +02:00
},
"additionalProperties": false,
"required": [
2025-07-07 12:10:52 +02:00
"name",
"email_address",
2025-01-17 09:49:13 +01:00
"groups",
"enabled",
"password_set",
2024-04-29 20:48:20 +02:00
]
2024-04-22 10:02:34 +02:00
}),
2025-04-03 06:19:19 +00:00
"restriction": () => restriction_logged_in,
"execution": () => async ({"path_parameters": path_parameters, "input": input}) => {
2024-04-30 01:32:24 +02:00
const member_id : _espe.type.member_id = parseInt(path_parameters["id"]);
const member_object : _espe.type.member_object = await _espe.service.member.get(member_id);
2024-04-22 10:02:34 +02:00
return Promise.resolve({
"status_code": 200,
2024-04-30 01:32:24 +02:00
"data": {
2025-07-07 12:10:52 +02:00
"name": member_object.name,
"email_address": member_object.email_address,
2025-01-17 09:49:13 +01:00
"groups": member_object.groups,
2024-04-30 01:32:24 +02:00
"enabled": member_object.enabled,
"password_set": (member_object.password_image !== null),
},
2024-04-22 10:02:34 +02:00
});
}
}
);
}
}