backend/source/api/actions/member_list.ts

106 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_list(
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,
Array<
{
id : int;
preview : {
membership_number : string;
name_real_value : string;
name_real_index : int;
};
}
>
>(
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/list"),
2024-04-22 10:02:34 +02:00
{
2025-04-03 06:19:19 +00:00
"description": () => "listet alle Mitglieder auf",
"query_parameters": () => [
2024-04-30 01:32:24 +02:00
{
"name": "search_term",
"required": false,
"description": "search term",
}
],
2024-04-22 10:02:34 +02:00
"output_schema": () => ({
"type": "array",
"items": {
"type": "object",
"nullable": false,
"additionalProperties": false,
"properties": {
"id": {
2024-04-30 01:32:24 +02:00
"type": "number",
2024-04-22 10:02:34 +02:00
"nullable": false,
},
"preview": {
"type": "object",
"additionalProperties": false,
"properties": {
2024-04-30 01:32:24 +02:00
"membership_number": {
"type": "string",
"nullable": false,
},
"name_real_value": {
2024-04-22 10:02:34 +02:00
"type": "string",
"nullable": false,
},
2024-04-30 01:32:24 +02:00
"name_real_index": {
"type": "number",
"nullable": false,
},
2024-04-22 10:02:34 +02:00
},
"required": [
2024-04-30 01:32:24 +02:00
"membership_number",
"name_real_value",
"name_real_index",
2024-04-22 10:02:34 +02:00
]
}
},
"required": [
"id",
"preview",
],
}
}),
2025-04-03 06:19:19 +00:00
"restriction": () => restriction_logged_in,
"execution": () => ({"query_parameters": query_parameters}) => (
2024-04-30 01:32:24 +02:00
_espe.service.member.list(query_parameters["search_term"] ?? null)
.then(
data => Promise.resolve({
"status_code": 200,
"data": data,
})
)
)
2024-04-22 10:02:34 +02:00
}
);
}
}