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-29 20:48:20 +02:00
|
|
|
namespace _espe.repository.member
|
|
|
|
{
|
|
|
|
|
|
|
|
/**
|
|
|
|
*/
|
|
|
|
var _store : (
|
|
|
|
null
|
|
|
|
|
|
|
|
|
lib_plankton.storage.type_store<
|
2024-04-29 22:40:52 +02:00
|
|
|
_espe.type.member_id,
|
2024-04-29 20:48:20 +02:00
|
|
|
Record<string, any>,
|
|
|
|
{},
|
|
|
|
lib_plankton.storage.type_sql_table_autokey_search_term,
|
|
|
|
Record<string, any>
|
|
|
|
>
|
|
|
|
) = null;
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
*/
|
|
|
|
function get_store(
|
|
|
|
) : lib_plankton.storage.type_store<
|
2024-04-29 22:40:52 +02:00
|
|
|
_espe.type.member_id,
|
2024-04-29 20:48:20 +02:00
|
|
|
Record<string, any>,
|
|
|
|
{},
|
|
|
|
lib_plankton.storage.type_sql_table_autokey_search_term,
|
|
|
|
Record<string, any>
|
|
|
|
>
|
|
|
|
{
|
|
|
|
if (_store === null) {
|
|
|
|
_store = lib_plankton.storage.sql_table_autokey_store(
|
|
|
|
{
|
|
|
|
"database_implementation": _espe.helpers.database_implementation(),
|
|
|
|
"table_name": "members",
|
|
|
|
"key_name": "id",
|
|
|
|
}
|
|
|
|
);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
// do nothing
|
|
|
|
}
|
|
|
|
return _store;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
*/
|
|
|
|
function encode(
|
2024-04-29 22:40:52 +02:00
|
|
|
object : _espe.type.member_object
|
2024-04-29 20:48:20 +02:00
|
|
|
) : Record<string, any>
|
|
|
|
{
|
|
|
|
return {
|
|
|
|
"membership_number": object.membership_number,
|
|
|
|
"name_real_value": object.name_real_value,
|
|
|
|
"name_real_index": object.name_real_index,
|
|
|
|
"email_address_private": object.email_address_private,
|
|
|
|
"registered": (object.registered ? 1 : 0),
|
|
|
|
"enabled": (object.enabled ? 1 : 0),
|
|
|
|
"email_use_veiled_address": (object.email_use_veiled_address ? 1 : 0),
|
|
|
|
"email_use_nominal_address": (object.email_use_nominal_address ? 1 : 0),
|
|
|
|
"email_redirect_to_private_address": (object.email_redirect_to_private_address ? 1 : 0),
|
|
|
|
"email_allow_sending": (object.email_allow_sending ? 1 : 0),
|
|
|
|
"password_image": object.password_image,
|
2024-05-20 12:20:59 +02:00
|
|
|
"password_change_last_attempt": object.password_change_last_attempt,
|
|
|
|
"password_change_token": object.password_change_token,
|
2024-04-29 20:48:20 +02:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
*/
|
|
|
|
function decode(
|
|
|
|
row : Record<string, any>
|
2024-04-29 22:40:52 +02:00
|
|
|
) : _espe.type.member_object
|
2024-04-29 20:48:20 +02:00
|
|
|
{
|
|
|
|
return {
|
|
|
|
"membership_number": row["membership_number"],
|
|
|
|
"name_real_value": row["name_real_value"],
|
|
|
|
"name_real_index": row["name_real_index"],
|
|
|
|
"email_address_private": row["email_address_private"],
|
|
|
|
"registered": (row["registered"] > 0),
|
|
|
|
"enabled": (row["enabled"] > 0),
|
|
|
|
"email_use_veiled_address": (row["email_use_veiled_address"] > 0),
|
|
|
|
"email_use_nominal_address": (row["email_use_nominal_address"] > 0),
|
|
|
|
"email_redirect_to_private_address": (row["email_redirect_to_private_address"] > 0),
|
|
|
|
"email_allow_sending": (row["email_allow_sending"] > 0),
|
|
|
|
"password_image": row["password_image"],
|
2024-05-20 12:20:59 +02:00
|
|
|
"password_change_last_attempt": row["password_change_last_attempt"],
|
|
|
|
"password_change_token": row["password_change_token"],
|
2024-04-29 20:48:20 +02:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
*/
|
|
|
|
export async function dump(
|
|
|
|
) : Promise<
|
|
|
|
Array<
|
|
|
|
{
|
2024-04-29 22:40:52 +02:00
|
|
|
id : _espe.type.member_id;
|
|
|
|
object : _espe.type.member_object;
|
2024-04-29 20:48:20 +02:00
|
|
|
}
|
|
|
|
>
|
|
|
|
>
|
|
|
|
{
|
|
|
|
return (
|
|
|
|
(await get_store().search(null))
|
|
|
|
.map(
|
|
|
|
({"key": key, "preview": preview}) => ({
|
|
|
|
"id": key,
|
2024-04-29 22:40:52 +02:00
|
|
|
"object": (preview as _espe.type.member_object),
|
2024-04-29 20:48:20 +02:00
|
|
|
})
|
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
2024-04-30 01:32:24 +02:00
|
|
|
* @todo optimize
|
2024-04-29 20:48:20 +02:00
|
|
|
*/
|
|
|
|
export async function list(
|
2024-04-30 01:32:24 +02:00
|
|
|
search_term : (null | string)
|
2024-04-29 20:48:20 +02:00
|
|
|
) : Promise<
|
|
|
|
Array<
|
|
|
|
{
|
2024-04-29 22:40:52 +02:00
|
|
|
id : _espe.type.member_id;
|
2024-04-29 20:48:20 +02:00
|
|
|
preview : {
|
2024-04-30 01:32:24 +02:00
|
|
|
membership_number : string;
|
|
|
|
name_real_value : string;
|
|
|
|
name_real_index : int;
|
2024-04-29 20:48:20 +02:00
|
|
|
};
|
|
|
|
}
|
|
|
|
>
|
|
|
|
>
|
|
|
|
{
|
|
|
|
return (
|
|
|
|
(await get_store().search(null))
|
2024-04-30 01:32:24 +02:00
|
|
|
.filter(
|
|
|
|
({"key": key, "preview": preview}) => (
|
|
|
|
(
|
|
|
|
(search_term === null)
|
|
|
|
||
|
|
|
|
(search_term.length <= 1)
|
|
|
|
)
|
|
|
|
? true
|
|
|
|
: (
|
|
|
|
preview["membership_number"].toLowerCase().includes(search_term.toLowerCase())
|
|
|
|
||
|
|
|
|
preview["name_real_value"].toLowerCase().includes(search_term.toLowerCase())
|
|
|
|
)
|
|
|
|
)
|
|
|
|
)
|
2024-04-29 20:48:20 +02:00
|
|
|
.map(
|
|
|
|
({"key": key, "preview": preview}) => ({
|
|
|
|
"id": key,
|
|
|
|
"preview": {
|
|
|
|
"membership_number": preview["membership_number"],
|
2024-04-30 01:32:24 +02:00
|
|
|
"name_real_value": preview["name_real_value"],
|
|
|
|
"name_real_index": preview["name_real_index"],
|
2024-04-29 20:48:20 +02:00
|
|
|
}
|
|
|
|
})
|
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
*/
|
|
|
|
export async function read(
|
2024-04-29 22:40:52 +02:00
|
|
|
id : _espe.type.member_id
|
|
|
|
) : Promise<_espe.type.member_object>
|
2024-04-29 20:48:20 +02:00
|
|
|
{
|
|
|
|
const row : Record<string, any> = await get_store().read(id);
|
|
|
|
|
|
|
|
return decode(row);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
*/
|
|
|
|
export async function create(
|
2024-04-29 22:40:52 +02:00
|
|
|
value : _espe.type.member_object
|
|
|
|
) : Promise<_espe.type.member_id>
|
2024-04-29 20:48:20 +02:00
|
|
|
{
|
|
|
|
const row : Record<string, any> = encode(value);
|
2024-04-29 22:40:52 +02:00
|
|
|
const id : _espe.type.member_id = await get_store().create(row);
|
2024-04-29 20:48:20 +02:00
|
|
|
|
|
|
|
return id;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
*/
|
|
|
|
export async function update(
|
2024-04-29 22:40:52 +02:00
|
|
|
id : _espe.type.member_id,
|
|
|
|
value : _espe.type.member_object
|
2024-04-29 20:48:20 +02:00
|
|
|
) : Promise<void>
|
|
|
|
{
|
|
|
|
const row : Record<string, any> = encode(value);
|
|
|
|
|
|
|
|
await get_store().update(id, row);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
*/
|
2024-04-29 22:40:52 +02:00
|
|
|
export async function delete_(
|
|
|
|
id : _espe.type.member_id
|
2024-04-29 20:48:20 +02:00
|
|
|
) : Promise<void>
|
|
|
|
{
|
|
|
|
await get_store().delete(id);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|