renamed + organistaion page + autonoms and structors

This commit is contained in:
2025-08-12 14:06:08 +07:00
parent 01e3984020
commit 0092f86a72
52 changed files with 2992 additions and 1200 deletions

View File

@@ -1,7 +1,7 @@
{ {
"name": "svoboda/svoboder", "name": "svoboda/antivertical",
"description": "Svoboda Telegram chat-robot", "description": "Svoboda Telegram chat-robot",
"homepage": "https://git.svoboda.works/svoboda/svoboder", "homepage": "https://git.svoboda.works/svoboda/antivertical",
"type": "chat-robot", "type": "chat-robot",
"keywords": [ "keywords": [
"svoboda", "svoboda",
@@ -21,13 +21,13 @@
} }
], ],
"support": { "support": {
"wiki": "https://git.svoboda.works/svoboda/svoboder/wiki", "wiki": "https://git.svoboda.works/svoboda/antivertical/wiki",
"issues": "https://git.svoboda.works/svoboda/svoboder/issues" "issues": "https://git.svoboda.works/svoboda/antivertical/issues"
}, },
"require": { "require": {
"php": "^8.4", "php": "^8.4",
"mirzaev/minimal": "^3.4.0", "mirzaev/minimal": "^3.6.2",
"mirzaev/baza": "^3.1.0", "mirzaev/baza": "^3.4",
"svoboda/time": "^1.0", "svoboda/time": "^1.0",
"badfarm/zanzara": "^0.9.1", "badfarm/zanzara": "^0.9.1",
"react/filesystem": "^0.1.2", "react/filesystem": "^0.1.2",
@@ -35,12 +35,12 @@
}, },
"autoload": { "autoload": {
"psr-4": { "psr-4": {
"svoboda\\svoboder\\": "svoboda/svoboder/system" "svoboda\\antivertical\\": "svoboda/antivertical/system"
} }
}, },
"autoload-dev": { "autoload-dev": {
"psr-4": { "psr-4": {
"svoboda\\svoboder\\tests\\": "svoboda/svoboder/tests" "svoboda\\antivertical\\tests\\": "svoboda/antivertical/tests"
} }
}, },
"scripts": { "scripts": {

View File

@@ -2,10 +2,10 @@
declare(strict_types=1); declare(strict_types=1);
namespace svoboda\svoboder\controllers; namespace svoboda\antivertical\controllers;
// Files of the project // Files of the project
use svoboda\svoboder\models\core as models; use svoboda\antivertical\models\core as models;
// Framework for PHP // Framework for PHP
use mirzaev\minimal\core as minimal, use mirzaev\minimal\core as minimal,
@@ -16,7 +16,7 @@ use mirzaev\minimal\core as minimal,
/** /**
* Controllers core * Controllers core
* *
* @package svoboda\svoboder\controllers * @package svoboda\antivertical\controllers
* *
* @param language $language Language * @param language $language Language
* @param response $response Response * @param response $response Response
@@ -25,7 +25,7 @@ use mirzaev\minimal\core as minimal,
* @method void __construct(minimal $minimal, bool $initialize) Constructor * @method void __construct(minimal $minimal, bool $initialize) Constructor
* *
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License * @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author svoboda <mail@domain.zone> * @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
*/ */
class core extends controller class core extends controller
{ {

View File

@@ -1,3 +1,3 @@
!.gitignore !.gitignore
*.baza *.baza
*.php # *.php

View File

@@ -0,0 +1,59 @@
<?php
declare(strict_types=1);
namespace svoboda\antivertical;
// Files of the project
use svoboda\antivertical\models\account;
// Svoboda time
use svoboda\time\statement as svoboda;
// Baza database
use mirzaev\baza\record;
// Enabling debugging
/* ini_set('error_reporting', E_ALL);
ini_set('display_errors', 1);
ini_set('display_startup_errors', 1); */
// Initializing path to the public directory
define('INDEX', __DIR__);
// Initializing path to the root directory
define('ROOT', INDEX . DIRECTORY_SEPARATOR . '..' . DIRECTORY_SEPARATOR . '..' . DIRECTORY_SEPARATOR . '..' . DIRECTORY_SEPARATOR . '..' . DIRECTORY_SEPARATOR);
// Initializing path to the settings directory
define('SETTINGS', INDEX . DIRECTORY_SEPARATOR . '..' . DIRECTORY_SEPARATOR . 'settings');
// Initializing path to the storage directory
define('STORAGE', INDEX . DIRECTORY_SEPARATOR . '..' . DIRECTORY_SEPARATOR . 'storage');
// Initializing path to the databases directory
define('DATABASES', INDEX . DIRECTORY_SEPARATOR . '..' . DIRECTORY_SEPARATOR . 'databases');
// Initializing path to the localizations directory
define('LOCALIZATIONS', INDEX . DIRECTORY_SEPARATOR . '..' . DIRECTORY_SEPARATOR . 'localizations');
// Initiailizing telegram key
define('TELEGRAM_KEY', require(SETTINGS . DIRECTORY_SEPARATOR . 'telegram.php'));
// Initializing dependencies
require ROOT . 'vendor' . DIRECTORY_SEPARATOR . 'autoload.php';
// Initializing the account model
$model = new account();
var_dump(
$model->database->read(
update: function (record &$record) {
$record->authorized_system_accounts = 1;
$record->authorized_system_distributions = 1;
$record->authorized_system_settings = 1;
$record->updated = svoboda::timestamp();
},
amount: 1,
offset: 0
)
);

View File

@@ -4,73 +4,97 @@
return [ return [
// System // System
'svoboda' => 'Svoboda', 'svoboda' => 'Svoboda',
'antivertical' => 'Antivertical',
'empty' => 'Empty', 'empty' => 'Empty',
'yes' => 'Yes', 'yes' => 'Yes',
'no' => 'No', 'no' => 'No',
// Main menu // Main menu
'menu_title' => 'Main menu', 'menu_title' => 'Antivertical',
'menu_accounts' => 'Accounts', 'menu_accounts' => 'Accounts',
'menu_members' => 'Members',
'menu_distributions' => 'Distributions', 'menu_distributions' => 'Distributions',
'menu_not_syncronized' => 'The database does not synchronize with the blockchain network', 'menu_structors' => 'Structors',
'menu_autonoms' => 'Autonoms',
'menu_volunteers' => 'Volunteers',
'menu_investors' => 'Investors',
'menu_recruiters' => 'Recruiters',
/* 'menu_' => '', */
'menu_not_syncronized' => 'The database are not synchronized with the blockchain network',
'menu_warning_database' => 'The database are publish into the repository everyday',
'menu_button_channel' => 'Channel',
'menu_button_site' => 'Site', 'menu_button_site' => 'Site',
'menu_button_map' => 'Map', 'menu_button_map' => 'Map',
'menu_button_blog' => 'Blog', 'menu_button_blog' => 'Blog',
'menu_button_projects' => 'Projects', 'menu_button_chats' => 'Chats',
'menu_button_members' => 'Members', 'menu_button_channels' => 'Channels',
'menu_button_memberships' => 'Memberships',
'menu_button_distributions' => 'Distributions', 'menu_button_distributions' => 'Distributions',
'menu_button_projects' => 'Projects',
'menu_button_events' => 'Events',
'menu_button_organisation' => 'Organisation',
// Members // Thinking stuff
'members_title' => 'Registry of members', 'thing_about_it_1' => 'Great names are created in the East',
'members_description' => 'Member is a person who has any form of affiliation with *Svoboda*', 'thing_about_it_1_author' => 'Lermontov M. Y.',
'members_button_search' => 'Search', 'thing_about_it_2' => '',
'thing_about_it_3' => '',
'thing_about_it_4' => '',
'thing_about_it_5' => '',
/* 'thing_about_it_' => '',
'thing_about_it__author' => '', */
// Members search
'member_search_started' => 'Process of the member search started', // Structor
'member_search_not_started' => 'Process of the member search has not started', 'memberships_title' => 'Registry of structors',
'member_search_ended' => 'Process of the member search ended', 'memberships_structor' => 'Structor \- an anarchist representing the distribution',
'member_search_not_localized' => 'Failed to initialize the member account localization', 'memberships_autonom' => 'Autonom - an anarchist representing only himself personally',
'member_search_not_named' => 'No name', 'memberships_button_search' => 'Search',
'member_search_status' => 'Status',
'member_search_status_2' => 'Member', // Memberships search
'member_search_status_1' => 'Planned', 'membership_search_started' => 'Process of the membership search started',
'member_search_status_0' => 'Unknown', 'membership_search_not_started' => 'Process of the membership search has not started',
'member_search_continiued' => 'Process of the member search found and continiued', 'membership_search_ended' => 'Process of the membership search ended',
'member_search_empty' => 'No members found', 'membership_search_not_localized' => 'Failed to initialize the membership account localization',
'member_search_title' => 'Member search', 'membership_search_not_named' => 'No name',
'member_search_distribution' => 'Distribution', 'membership_search_status' => 'Status',
'member_search_page_next_exists' => 'There are more members in the registry', 'membership_search_status_2' => 'Membership',
'member_search_page_next_not_exists' => 'There are no more members in the registry', 'membership_search_status_1' => 'Planned',
'member_search_button_name' => 'Name', 'membership_search_status_0' => 'Unknown',
'member_search_name_request_title' => 'Enter name', 'membership_search_continiued' => 'Process of the membership search found and continiued',
'member_search_name_request_description' => 'Search will be conducted by members names using the Levenshtein function', 'membership_search_empty' => 'No memberships found',
'member_search_name_request_not_acceptable' => 'Failed to process the name', 'membership_search_title' => 'Membership search',
'member_search_name_request_too_short' => 'Name length must be \>\= 2 and \<\= 128', 'membership_search_distribution' => 'Distribution',
'member_search_name_request_too_long' => 'Name length must be \>\= 2 and \<\= 128', 'membership_search_page_next_exists' => 'There are more memberships in the registry',
'member_search_name_request_restricted_characters_title' => "Restricted any characters except letters, dashes and spaces", 'membership_search_page_next_not_exists' => 'There are no more memberships in the registry',
'member_search_name_request_restricted_characters_description' => "Remove these characters:", 'membership_search_button_name' => 'Name',
'member_search_name_update_success' => 'Name replaced:', 'membership_search_name_request_title' => 'Enter name',
'member_search_name_update_fail' => 'Failed to replace name', 'membership_search_name_request_description' => 'Search will be conducted by memberships names using the Levenshtein function',
'member_search_distribution_selection_description' => 'The selected distribution will be used to search for members', 'membership_search_name_request_not_acceptable' => 'Failed to process the name',
'member_search_distribution_update_success' => 'Distribution replaced:', 'membership_search_name_request_too_short' => 'Name length must be \>\= 2 and \<\= 128',
'member_search_distribution_update_fail' => 'Failed to replace distribution', 'membership_search_name_request_too_long' => 'Name length must be \>\= 2 and \<\= 128',
'member_search_status_select_title' => 'Select the member status', 'membership_search_name_request_restricted_characters_title' => "Restricted any characters except letters, dashes and spaces",
'member_search_status_update_success' => 'Status replaced:', 'membership_search_name_request_restricted_characters_description' => "Remove these characters:",
'member_search_status_update_fail' => 'Failed to replace status', 'membership_search_name_update_success' => 'Name replaced:',
'member_search_button_start' => 'Start the search', 'membership_search_name_update_fail' => 'Failed to replace name',
'member_search_button_end' => 'End the search', 'membership_search_distribution_selection_description' => 'The selected distribution will be used to search for memberships',
'member_search_button_page_next' => 'Next page', 'membership_search_distribution_update_success' => 'Distribution replaced:',
'member_search_button_message' => 'Message', 'membership_search_distribution_update_fail' => 'Failed to replace distribution',
'member_search_button_distribution' => 'Distribution', 'membership_search_status_select_title' => 'Select the membership status',
'member_search_button_status' => 'Status', 'membership_search_status_update_success' => 'Status replaced:',
'member_search_button_status_2' => 'Member', 'membership_search_status_update_fail' => 'Failed to replace status',
'member_search_button_status_1' => 'Planned', 'membership_search_button_start' => 'Start the search',
'member_search_button_status_0' => 'Unknown', 'membership_search_button_end' => 'End the search',
'membership_search_button_page_next' => 'Next page',
'membership_search_button_message' => 'Message',
'membership_search_button_distribution' => 'Distribution',
'membership_search_button_status' => 'Status',
'membership_search_button_status_2' => 'Membership',
'membership_search_button_status_1' => 'Planned',
'membership_search_button_status_0' => 'Unknown',
// Distributions // Distributions
'distributions_title' => 'Registry of distributions', 'distributions_title' => 'Registry of distributions',
'distributions_description' => '*Distribution* is an autonomous cell of Svoboda, representing any type of formation \(for example: commune\), but necessarily inherits the *Vhod* protocol and tied to a location', 'distributions_description' => '*Distribution* is an autonomous cell of Svoboda, representing any type of formation, but necessarily inherits the codex',
'distributions_declared' => 'Declared', 'distributions_declared' => 'Declared',
'distributions_recognized' => 'Recognized', 'distributions_recognized' => 'Recognized',
'distributions_button_search' => 'Search', 'distributions_button_search' => 'Search',
@@ -139,7 +163,7 @@ return [
'distribution_search_continiued' => 'Process of the distribution search found and continiued', 'distribution_search_continiued' => 'Process of the distribution search found and continiued',
'distribution_search_empty' => 'No distributions found', 'distribution_search_empty' => 'No distributions found',
'distribution_search_title' => 'Distribution search', 'distribution_search_title' => 'Distribution search',
'distribution_search_members' => 'Members', 'distribution_search_memberships' => 'Memberships',
'distribution_search_recognized' => 'Recognized', 'distribution_search_recognized' => 'Recognized',
'distribution_search_planners' => 'Planners', 'distribution_search_planners' => 'Planners',
'distribution_search_volunteers' => 'Volunteers', 'distribution_search_volunteers' => 'Volunteers',
@@ -182,7 +206,7 @@ return [
'distribution_search_button_end' => 'End the search', 'distribution_search_button_end' => 'End the search',
'distribution_search_button_page_next' => 'Next page', 'distribution_search_button_page_next' => 'Next page',
'distribution_search_button_map' => 'Map', 'distribution_search_button_map' => 'Map',
'distribution_search_button_members' => 'Members', 'distribution_search_button_memberships' => 'Memberships',
'distribution_search_button_volunteers' => 'Volunteers', 'distribution_search_button_volunteers' => 'Volunteers',
'distribution_search_button_plan' => 'Plan', 'distribution_search_button_plan' => 'Plan',
'distribution_search_button_unplan' => 'Cancel the planning', 'distribution_search_button_unplan' => 'Cancel the planning',
@@ -193,18 +217,18 @@ return [
'distribution_search_button_join' => 'Join', 'distribution_search_button_join' => 'Join',
'distribution_search_button_leave' => 'Leave', 'distribution_search_button_leave' => 'Leave',
'distribution_search_joined_title' => 'You joined the distribution', 'distribution_search_joined_title' => 'You joined the distribution',
'distribution_search_joined_description' => 'You have claimed to be a member of the distribution, now you need to get recognition from its members', 'distribution_search_joined_description' => 'You stated yourself as the distribution structor',
'distribution_search_already_joined' => 'You are already joined to the distribution', 'distribution_search_already_joined' => 'You are already stated as the distribution structor',
'distribution_search_leaved' => 'You leaved the distribution', 'distribution_search_leaved' => 'You leaved the distribution',
'distribution_search_already_leaved' => 'You are already leaved the distribution', 'distribution_search_already_leaved' => 'You are already leaved the distribution',
'distribution_search_button_message' => 'Message', 'distribution_search_button_message' => 'Message',
'distribution_search_km' => 'km', 'distribution_search_km' => 'km',
'distribution_search_mi' => 'ml', 'distribution_search_mi' => 'ml',
'distribution_search_member_not_updated' => 'Failed to update the member record in the database', 'distribution_search_membership_not_updated' => 'Failed to update the membership record in the database',
'distribution_search_member_not_created' => 'Failed to create the member record in the database', 'distribution_search_membership_not_created' => 'Failed to create the membership record in the database',
'distribution_search_distribution_not_initialized' => 'Failed to initalize the distribution', 'distribution_search_distribution_not_initialized' => 'Failed to initalize the distribution',
'distribution_search_message_not_initialized' => 'Failed to initialized the message', 'distribution_search_message_not_initialized' => 'Failed to initialized the message',
'distribution_search_another_joined' => 'You are already a member of another distribution', 'distribution_search_another_joined' => 'You are already a membership of another distribution',
'distribution_search_another_planned' => 'You are already planning to join another distribution', 'distribution_search_another_planned' => 'You are already planning to join another distribution',
// Distribution select // Distribution select
@@ -256,20 +280,38 @@ return [
'distribution_select_km' => 'km', 'distribution_select_km' => 'km',
'distribution_select_mi' => 'ml', 'distribution_select_mi' => 'ml',
// Organisation
'organisation_title' => 'Organisation',
'organisation_description' => 'International association of all who want to live honestly and freely',
'organisation_structor' => 'Structor \- an anarchist representing the distribution',
'organisation_autonom' => 'Autonom - an anarchist representing only himself personally',
'organisation_warning_legal' => 'Do not do anything that breaks the law of the country you are in, do not trust anyone and think with your own head',
'organisation_warning_administration' => 'At this stage of the Antivertical project development, the administration reserves the right to make a sole decision on the removal of materials that are potentially dangerous for the organization and its participants',
'organisation_button_help' => 'Help',
'organisation_button_investor' => 'Investor',
'organisation_button_volunteer' => 'Volunteer',
'organisation_button_structor' => 'Structor',
'organisation_button_structor_distribution' => 'Distribution',
'organisation_button_autonom' => 'Autonom',
// Account // Account
'account_title' => 'Account', 'account_title' => 'Account',
'account_export' => 'This account can be exported to the Svoboda main blockchain network in the future', 'account_identifier' => 'Identifier',
'account_data' => "⚠️ Your data may be given to the special services of Russia\nBe careful and think with your head.", 'account_export' => 'Export to the main blockchain network is available',
/* 'account_data' => "⚠️ Your data may be given to the special services of Russia\nBe careful and think with your head",
'account_security_repository' => 'Information security', 'account_security_repository' => 'Information security',
'account_security_repository_mirror_github' => 'mirror', 'account_security_repository_mirror_github' => 'mirror', */
'account_authorized_system' => 'Access to the system', 'account_authorized_system' => 'Access to the system',
'account_authorized_messages' => 'Access to messages', 'account_authorized_messages' => 'Access to messages',
'account_authorized_joins' => 'Access to joins', 'account_authorized_autonom' => 'Be an autonom',
'account_authorized_structor' => 'Be a structor',
'account_authorized_volunteer' => 'Be a volunteer',
'account_authorized_investor' => 'Be an investor',
'account_authorized_recruiter' => 'Be a recruiter',
'account_authorized_settings' => 'Access to settings', 'account_authorized_settings' => 'Access to settings',
'account_authorized_system_accounts' => 'System access to accounts management', 'account_authorized_system_accounts' => 'Access to the accounts system',
'account_authorized_system_distributions' => 'System access to distributions management', 'account_authorized_system_distributions' => 'Access to the distributions system',
'account_authorized_system_members' => 'System access to members management', 'account_authorized_system_settings' => 'Access to the system settings',
'account_authorized_system_settings' => 'System access to system settings',
'account_button_localizations' => 'Localizations', 'account_button_localizations' => 'Localizations',
'account_localization_create_failted_to_initialize_language' => 'Failed to initialize language', 'account_localization_create_failted_to_initialize_language' => 'Failed to initialize language',

View File

@@ -4,73 +4,96 @@
return [ return [
// Система // Система
'svoboda' => 'Свобода', 'svoboda' => 'Свобода',
'antivertical' => 'Антивертикаль',
'empty' => 'Пусто', 'empty' => 'Пусто',
'yes' => 'Да', 'yes' => 'Да',
'no' => 'Нет', 'no' => 'Нет',
// Главное меню // Главное меню
'menu_title' => 'Главное меню', 'menu_title' => 'Антивертикаль',
'menu_accounts' => 'Аккаунты', 'menu_accounts' => 'Аккаунты',
'menu_members' => 'Участники',
'menu_distributions' => 'Дистрибутивы', 'menu_distributions' => 'Дистрибутивы',
'menu_not_syncronized' => 'База данных не синхронизируется с блокчейн сетью', 'menu_structors' => 'Структоры',
'menu_autonoms' => 'Автономы',
'menu_volunteers' => 'Волонтёры',
'menu_investors' => 'Инвесторы',
'menu_recruiters' => 'Вербовщики',
/* 'menu_' => '', */
'menu_not_syncronized' => 'База данных не синхронизирована с блокчейн сетью',
'menu_warning_database' => 'База данных публикуется в репозиторий ежедневно',
'menu_button_channel' => 'Канал',
'menu_button_site' => 'Сайт', 'menu_button_site' => 'Сайт',
'menu_button_map' => 'Карта', 'menu_button_map' => 'Карта',
'menu_button_blog' => 'Блог', 'menu_button_blog' => 'Блог',
'menu_button_projects' => 'Проекты', 'menu_button_chats' => 'Чаты',
'menu_button_members' => 'Участники', 'menu_button_channels' => 'Каналы',
'menu_button_memberships' => 'Участники',
'menu_button_distributions' => 'Дистрибутивы', 'menu_button_distributions' => 'Дистрибутивы',
'menu_button_projects' => 'Проекты',
'menu_button_events' => 'События',
'menu_button_organisation' => 'Организация',
// Думающие штуки
'thing_about_it_1' => 'Великие имена создаются на востоке',
'thing_about_it_1_author' => 'Лермонтов М. Ю.',
'thing_about_it_2' => '',
'thing_about_it_3' => '',
'thing_about_it_4' => '',
'thing_about_it_5' => '',
/* 'thing_about_it_' => '',
'thing_about_it__author' => '', */
// Участники // Участники
'members_title' => 'Реестр участников', 'memberships_title' => 'Реестр участников',
'members_description' => 'Участник \- личность имеющая любую форму взаимоотношений со *Свободой*', 'memberships_structor' => '*Структор* \- анархист, представляющий дистрибутив',
'members_button_search' => 'Поиск', 'memberships_autonom' => '*Автоном* \- анархист, представляющий только себя лично',
'memberships_button_search' => 'Поиск',
// Поиск участника // Поиск участника
'member_search_started' => 'Процесс поиска участника дистрибутива запущен', 'membership_search_started' => 'Процесс поиска участника дистрибутива запущен',
'member_search_not_started' => 'Процесс поиска участника дистрибутива не запущен', 'membership_search_not_started' => 'Процесс поиска участника дистрибутива не запущен',
'member_search_ended' => 'Процесс поиска участника дистрибутива завершён', 'membership_search_ended' => 'Процесс поиска участника дистрибутива завершён',
'member_search_not_localized' => 'Не удалось инициализировать локализацию аккаунта участника', 'membership_search_not_localized' => 'Не удалось инициализировать локализацию аккаунта участника',
'member_search_not_named' => 'Нет имени', 'membership_search_not_named' => 'Нет имени',
'member_search_status' => 'Статус', 'membership_search_status' => 'Статус',
'member_search_status_2' => 'Участие', 'membership_search_status_2' => 'Участие',
'member_search_status_2_emoji' => '🧳', 'membership_search_status_2_emoji' => '🧳',
'member_search_status_1' => 'Планирование', 'membership_search_status_1' => 'Планирование',
'member_search_status_1_emoji' => '📅', 'membership_search_status_1_emoji' => '📅',
'member_search_status_0' => 'Неизвестно', 'membership_search_status_0' => 'Неизвестно',
'member_search_status_0_emoji' => '👽', 'membership_search_status_0_emoji' => '👽',
'member_search_continiued' => 'Процесс поиска участника дистрибутива найден и продолжен', 'membership_search_continiued' => 'Процесс поиска участника дистрибутива найден и продолжен',
'member_search_empty' => 'Не найдены участники дистрибутивов', 'membership_search_empty' => 'Не найдены участники дистрибутивов',
'member_search_title' => 'Поиск участника дистрибутива', 'membership_search_title' => 'Поиск участника дистрибутива',
'member_search_distribution' => 'Дистрибутив', 'membership_search_distribution' => 'Дистрибутив',
'member_search_page_next_exists' => 'В реестре есть ещё участники дистрибутивов', 'membership_search_page_next_exists' => 'В реестре есть ещё участники дистрибутивов',
'member_search_page_next_not_exists' => 'В реестре больше нет участников дистрибутивов', 'membership_search_page_next_not_exists' => 'В реестре больше нет участников дистрибутивов',
'member_search_button_name' => 'Имя', 'membership_search_button_name' => 'Имя',
'member_search_name_request_title' => 'Введи имя', 'membership_search_name_request_title' => 'Введи имя',
'member_search_name_request_description' => 'Поиск будет проводиться по именам участников дистрибутивов с использованием функции Левенштейна', 'membership_search_name_request_description' => 'Поиск будет проводиться по именам участников дистрибутивов с использованием функции Левенштейна',
'member_search_name_request_not_acceptable' => 'Не удалось обработать имя', 'membership_search_name_request_not_acceptable' => 'Не удалось обработать имя',
'member_search_name_request_too_short' => 'Длина имени должна быть \>\= 2 и \<\= 128', 'membership_search_name_request_too_short' => 'Длина имени должна быть \>\= 2 и \<\= 128',
'member_search_name_request_too_long' => 'Длина имени должна быть \>\= 2 и \<\= 128', 'membership_search_name_request_too_long' => 'Длина имени должна быть \>\= 2 и \<\= 128',
'member_search_name_request_restricted_characters_title' => "Запрещены любые символы кроме букв", 'membership_search_name_request_restricted_characters_title' => "Запрещены любые символы кроме букв",
'member_search_name_request_restricted_characters_description' => "Удали эти символы:", 'membership_search_name_request_restricted_characters_description' => "Удали эти символы:",
'member_search_name_update_success' => 'Имя заменено:', 'membership_search_name_update_success' => 'Имя заменено:',
'member_search_name_update_fail' => 'Не удалось заменить имя', 'membership_search_name_update_fail' => 'Не удалось заменить имя',
'member_search_button_start' => 'Начать поиск', 'membership_search_button_start' => 'Начать поиск',
'member_search_button_end' => 'Завершить поиск', 'membership_search_button_end' => 'Завершить поиск',
'member_search_button_page_next' => 'Следующая страница', 'membership_search_button_page_next' => 'Следующая страница',
'member_search_button_message' => 'Сообщение', 'membership_search_button_message' => 'Сообщение',
'member_search_button_distribution' => 'Дистрибутив', 'membership_search_button_distribution' => 'Дистрибутив',
'member_search_button_status' => 'Статус', 'membership_search_button_status' => 'Статус',
'member_search_button_status_2' => 'участие', 'membership_search_button_status_2' => 'участие',
'member_search_button_status_2_emoji' => '🧳', 'membership_search_button_status_2_emoji' => '🧳',
'member_search_button_status_1' => 'планирование', 'membership_search_button_status_1' => 'планирование',
'member_search_button_status_1_emoji' => '📅', 'membership_search_button_status_1_emoji' => '📅',
'member_search_button_status_0' => 'неизвестно', 'membership_search_button_status_0' => 'неизвестно',
'member_search_button_status_0_emoji' => '👽', 'membership_search_button_status_0_emoji' => '👽',
// Дистрибутивы // Дистрибутивы
'distributions_title' => 'Реестр дистрибутивов', 'distributions_title' => 'Реестр дистрибутивов',
'distributions_description' => '*Дистрибутив* \- это автономная ячейка Свободы, являющаяся любым видом формирования \(например: коммуна\), но обязательно наследующая *Vhod* протокол, участвующая в глобальных процессах организации и привязанная к местоположению', 'distributions_description' => '*Дистрибутив* \- автономная ячейка Свободы, являющаяся любым видом формирования, подразумевающее безоговорочный солидарный союз со всеми признанными дистрибутивами внутри организации',
'distributions_declared' => 'Объявленные', 'distributions_declared' => 'Объявленные',
'distributions_recognized' => 'Признанные', 'distributions_recognized' => 'Признанные',
'distributions_button_search' => 'Поиск', 'distributions_button_search' => 'Поиск',
@@ -139,7 +162,7 @@ return [
'distribution_search_continiued' => 'Процесс поиска дистрибутива найден и продолжен', 'distribution_search_continiued' => 'Процесс поиска дистрибутива найден и продолжен',
'distribution_search_empty' => 'Не найдены дистрибутивы', 'distribution_search_empty' => 'Не найдены дистрибутивы',
'distribution_search_title' => 'Поиск дистрибутива', 'distribution_search_title' => 'Поиск дистрибутива',
'distribution_search_members' => 'Участники', 'distribution_search_memberships' => 'Участники',
'distribution_search_recognized' => 'Признанные', 'distribution_search_recognized' => 'Признанные',
'distribution_search_planners' => 'Планирующие', 'distribution_search_planners' => 'Планирующие',
'distribution_search_volunteers' => 'Волонтёры', 'distribution_search_volunteers' => 'Волонтёры',
@@ -182,7 +205,7 @@ return [
'distribution_search_button_end' => 'Завершить поиск', 'distribution_search_button_end' => 'Завершить поиск',
'distribution_search_button_page_next' => 'Следующая страница', 'distribution_search_button_page_next' => 'Следующая страница',
'distribution_search_button_map' => 'Карта', 'distribution_search_button_map' => 'Карта',
'distribution_search_button_members' => 'Участники', 'distribution_search_button_memberships' => 'Участники',
'distribution_search_button_volunteers' => 'Волонтёры', 'distribution_search_button_volunteers' => 'Волонтёры',
'distribution_search_button_plan' => 'Запланировать', 'distribution_search_button_plan' => 'Запланировать',
'distribution_search_button_unplan' => 'Отменить планирование', 'distribution_search_button_unplan' => 'Отменить планирование',
@@ -193,15 +216,15 @@ return [
'distribution_search_button_join' => 'Присоединиться', 'distribution_search_button_join' => 'Присоединиться',
'distribution_search_button_leave' => 'Покинуть', 'distribution_search_button_leave' => 'Покинуть',
'distribution_search_joined_title' => 'Ты вступил в дистрибутив', 'distribution_search_joined_title' => 'Ты вступил в дистрибутив',
'distribution_search_joined_description' => 'Ты заявил о том, что являешься участником дистрибутива, теперь тебе надо получить признание от его участников', 'distribution_search_joined_description' => 'Ты заявил о том, что являешься структором дистрибутива',
'distribution_search_already_joined' => 'Ты уже вступил дистрибутив', 'distribution_search_already_joined' => 'Ты уже заявил себя структором дистрибутива',
'distribution_search_leaved' => 'Ты покинул дистрибутив', 'distribution_search_leaved' => 'Ты покинул дистрибутив',
'distribution_search_already_leaved' => 'Ты уже покинул дистрибутив', 'distribution_search_already_leaved' => 'Ты уже покинул дистрибутив',
'distribution_search_button_message' => 'Сообщение', 'distribution_search_button_message' => 'Сообщение',
'distribution_search_km' => 'км', 'distribution_search_km' => 'км',
'distribution_search_mi' => 'мл', 'distribution_search_mi' => 'мл',
'distribution_search_member_not_updated' => 'Не удалось обновить запись участника дистрибутива в базе данных', 'distribution_search_membership_not_updated' => 'Не удалось обновить запись участника дистрибутива в базе данных',
'distribution_search_member_not_created' => 'Не удалось создать запись участника дистрибутива в базе данных', 'distribution_search_membership_not_created' => 'Не удалось создать запись участника дистрибутива в базе данных',
'distribution_search_distribution_not_initialized' => 'Не удалось инициализировать дистрибутив', 'distribution_search_distribution_not_initialized' => 'Не удалось инициализировать дистрибутив',
'distribution_search_message_not_initialized' => 'Не удалось инициализировать сообщение', 'distribution_search_message_not_initialized' => 'Не удалось инициализировать сообщение',
'distribution_search_another_joined' => 'Ты уже являешься участником другого дистрибутива', 'distribution_search_another_joined' => 'Ты уже являешься участником другого дистрибутива',
@@ -253,20 +276,39 @@ return [
'distribution_select_button_cancel' => 'Отменить выбор', 'distribution_select_button_cancel' => 'Отменить выбор',
'distribution_select_button_page_next' => 'Следующая страница', 'distribution_select_button_page_next' => 'Следующая страница',
// Организация
'organisation_title' => 'Организация',
'organisation_description' => 'Интернациональное объединение всех кто хочет жить честно и свободно, где никто ни от кого ничего не требует и ни к чему не принуждает',
'organisation_structor' => '*Структор* \- анархист, представляющий дистрибутив',
'organisation_autonom' => '*Автоном* \- анархист, представляющий только себя лично',
'organisation_warning_legal' => 'Не делайте ничего, что нарушает закон страны в которой вы находитесь, не доверяйте никому и думайте своей головой',
'organisation_warning_administration' => 'На данном этапе развития проекта Антивертикаль администрация сохраняет за собой право единолично принимать решение по удалению потенциально опасных для организации и её участников материалов',
'organisation_button_help' => 'Помощь',
'organisation_button_investor' => 'Инвестор',
'organisation_button_volunteer' => 'Волонтёр',
'organisation_button_structor' => 'Структор',
'organisation_button_structor_distribution' => 'Дистрибутив',
'organisation_button_autonom' => 'Автоном',
// Аккаунт // Аккаунт
'account_title' => 'Аккаунт', 'account_title' => 'Аккаунт',
'account_export' => 'Этот аккаунт может быть экспортирован в основную блокчейн сеть Свободы в будущем', 'account_identifier' => 'Идентификатор',
'account_data' => "⚠️ Твои данные могут быть выданы спецслужбам России\nБудь осторожен и думай своей головой", 'account_export' => 'Доступен экспорт в основную блокчейн сеть',
/* 'account_data' => "⚠️ Твои данные могут быть выданы спецслужбам России\nБудь осторожен и думай своей головой",
'account_security_repository' => 'Информационная безопасность', 'account_security_repository' => 'Информационная безопасность',
'account_security_repository_mirror_github' => 'зеркало', 'account_security_repository_mirror_github' => 'зеркало', */
'account_authorized_system' => 'Доступ к системе', 'account_authorized_system' => 'Доступ к системе',
'account_authorized_messages' => 'Доступ к сообщениям', 'account_authorized_messages' => 'Доступ к сообщениям',
'account_authorized_joins' => 'Доступ к вступлениям', 'account_authorized_authonom' => 'Становиться автономом',
'account_authorized_settings' => 'Доступ к изменению настроек', 'account_authorized_structor' => 'Становиться структором',
'account_authorized_system_accounts' => 'Системный доступ к управлению аккаунтами', 'account_authorized_volunteer' => 'Становиться волонтёром',
'account_authorized_system_distributions' => 'Системный доступ к управлению дистрибутивами', 'account_authorized_investor' => 'Становиться инвестором',
'account_authorized_system_members' => 'Системный доступ к управлению участниками дистрибутивов', 'account_authorized_recruiter' => 'Становиться вербовщиком',
'account_authorized_system_settings' => 'Системный доступ к системным настройкам', 'account_authorized_relations' => 'Доступ к отношениям',
'account_authorized_settings' => 'Доступ к настройкам',
'account_authorized_system_accounts' => 'Доступ к системе аккаунтов',
'account_authorized_system_distributions' => 'Доступ к системе дистрибутивов',
'account_authorized_system_settings' => 'Доступ к системным настройкам',
'account_button_localizations' => 'Локализации', 'account_button_localizations' => 'Локализации',
'account_localization_create_failted_to_initialize_language' => 'Не удалось инициализировать язык', 'account_localization_create_failted_to_initialize_language' => 'Не удалось инициализировать язык',

View File

@@ -0,0 +1,484 @@
<?php
declare(strict_types=1);
namespace svoboda\antivertical\models;
// Files of the project
use svoboda\antivertical\models\core,
svoboda\antivertical\models\connection,
svoboda\antivertical\models\telegram,
svoboda\antivertical\models\membership,
svoboda\antivertical\models\interfaces\ar as active_record,
svoboda\antivertical\models\traits\ar as active_record_trait,
svoboda\antivertical\models\enumerations\language,
svoboda\antivertical\models\enumerations\membership\status,
svoboda\antivertical\models\account\localization;
// Svoboda time
use svoboda\time\statement as svoboda;
// Baza database
use mirzaev\baza\database,
mirzaev\baza\column,
mirzaev\baza\record,
mirzaev\baza\enumerations\encoding,
mirzaev\baza\enumerations\type;
// Built-in libraries
use Exception as exception,
RuntimeException as exception_runtime,
LogicException as exception_logic,
InvalidArgumentException as exception_invalid_argument;
/**
* Account
*
* @uses active_record
* @uses active_record_trait
*
* @package svoboda\antivertical\models
*
* @property string $file Path to the database file
* @property database $database The database
* @property record $record The database record
*
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
*/
final class account extends core implements active_record
{
use active_record_trait;
/**
* File
*
* @var string $database Path to the database file
*/
protected string $file = DATABASES . DIRECTORY_SEPARATOR . 'accounts.baza';
/**
* Database
*
* @var database $database The database
*/
public protected(set) database $database;
/**
* Localization
*
* @var localization $localization The localizations implementator
*/
public protected(set) localization $localization;
/**
* Constructor
*
* @param record|null $record The database record
*
* @return void
*/
public function __construct(?record $record = null)
{
// Initializing the database
$this->database = new database()
->encoding(encoding::utf8)
->columns(
new column('identifier', type::long_long_unsigned),
new column('name', type::string, ['length' => 64]),
new column('language', type::string, ['length' => 2]),
new column('authorized_system', type::char),
new column('authorized_messages', type::char),
new column('authorized_authonom', type::char),
new column('authorized_structor', type::char),
new column('authorized_volunteer', type::char),
new column('authorized_investor', type::char),
new column('authorized_recruiter', type::char),
new column('authorized_settings', type::char),
new column('authorized_system_accounts', type::char),
new column('authorized_system_distributions', type::char),
new column('authorized_system_settings', type::char),
new column('updated', type::integer_unsigned),
new column('created', type::integer_unsigned)
)
->connect($this->file);
// Initializing the localizations implementator
$this->localization = new localization;
// Initializing the database record
if ($record) $this->record = $record;
}
/**
* Initialize
*
* Searches for the account record by the telegram account in the database,
* and if it does not find it, then create the account record and the connection record
*
* @param telegram $telegram The telegram account
*
* @throws exception_runtime if failed to deactivate the connection between missing account and the telegram account
* @throws exception_runtime if failed to connect the account with the telegram account
* @throws exception_runtime if failed to find the created account
* @throws exception_runtime if failed to create the account
*
* @return static The account record implementator
*/
public function initialize(telegram $telegram): static
{
// Initializing the connection model
$connection = new connection;
// Searching for the connection record between theaccount and the telegram account in the database
$connected = $connection->read(filter: fn(record $record) => $record->telegram === $telegram->identifier);
if ($connected instanceof connection) {
// Found the connection record between the account and the telegram account
// Searching for the account in the database
$account = $this->read(filter: fn(record $record) => $record->identifier === $connected->account);
if ($account instanceof static) {
// Found the account
// Exit (success)
return $account;
} else {
// Not found the account
// Deactivating the connection between missing account and the telegram account
$deactivated = $connected->update(
filter: fn(record $record) => $record->identifier === $connected->identifier,
update: function (record &$record) {
$record->active = 0;
$record->updated = svoboda::timestamp();
}
);
if ($deactivated instanceof connection && $deactivated->active === 0) {
// Deactivated the connection between missing account and the telegram account
// Creating the account
goto create;
} else {
// Failed to deactivate the connection between missing account and the telegram account
// Exit (fail)
throw new exception_runtime('Failed to deactivate the connection between missing account and the telegram account');
}
}
} else {
// Not found the connection record between the account and the telegram account
// Creating the account process start
create:
// Creating the account
$identifier = $this->create("$telegram->name_first $telegram->name_second", language::{$telegram->language ?? language::en->name} ?? language::en);
if ($identifier) {
// Created the account
// Searching for the created account in the database
$account = $this->read(filter: fn(record $record) => $record->identifier === $identifier);
if ($account instanceof static) {
// Found the created account
// Connecting the created account with the telegram account
$connected = $connection->create(account: $account->identifier, telegram: $telegram->identifier);
if ($connected) {
// Connected the created account with the telegram account
// Exit (success)
return $account;
} else {
// Not connected the created account with the telegram account
// Exit (fail)
throw new exception_runtime('Failed to connect the account with the telegram account');
}
} else {
// Not found the created account
// Exit (fail)
throw new exception_runtime('Failed to find the created account');
}
} else {
// Not created the account
// Exit (fail)
throw new exception_runtime('Failed to create the account');
}
}
}
/**
* Create
*
* Creates the account record in the database
*
* @param string $name Name
* @param language $language Language for generating views
*
* @return int|false The record identifier, if created
*/
public function create(string $name, language $language): int|false
{
// Initializing the identifier
$identifier = $this->database->count() + 1;
// Initializing the record
$record = $this->database->record(
$identifier,
$name,
$language->name,
ACCOUNT_ACCESS_SYSTEM,
ACCOUNT_ACCESS_MESSAGES,
ACCOUNT_ACCESS_AUTHONOM,
ACCOUNT_ACCESS_STRUCTOR,
ACCOUNT_ACCESS_VOLUNTEER,
ACCOUNT_ACCESS_INVESTOR,
ACCOUNT_ACCESS_RECRUITER,
ACCOUNT_ACCESS_SETTINGS,
ACCOUNT_ACCESS_SYSTEM_ACCOUNTS,
ACCOUNT_ACCESS_SYSTEM_DISTRIBUTIONS,
ACCOUNT_ACCESS_SYSTEM_SETTINGS,
svoboda::timestamp(),
svoboda::timestamp()
);
// Creating the record in the database
$created = $this->database->write($record);
// Exit (success)
return $created ? $identifier : false;
}
/**
* Distribution
*
* Search for the account distribution
*
* @return distribution|false The account distribution, if found
*/
public function distribution(): distribution|false
{
// Searching for the distribution membership
$membership = $this->memberships(amount: 1, offset: 0)[0] ?? false;
if ($membership instanceof membership) {
// Initialized the distribution membership
// Initializing the distribution model
$model = new distribution();
// Searching for the distribution
$distribution = $model->read(filter: fn(record $record) => $record->identifier === $membership->distribution);
// Exit (success/fail)
return $distribution;
}
// Exit (fail)
return false;
}
/**
* Memberships
*
* @param status $status A membership status
* @param int $amount Amount
* @param int $offset Offset
*
* @return array The account memberships
*/
public function memberships(
status $status = status::joined,
int $amount = 100,
int $offset = 0
): array {
// Initializing the membership model
$model = new membership;
// Initializing the account memberships
$memberships = $model->database->read(
filter: fn(record $record) => $record->account === $this->identifier && $record->status === $status->value,
amount: $amount,
offset: $offset
);
// Declaring the buffer of implemented records
$implemented = [];
foreach ($memberships as $record) {
// Iterating over memberships records
// Initializing the implementator object
$implementator = new membership();
if ($implementator instanceof active_record) {
// The implementator object implements the Active Record pattern
// Writing the record into the implementator object
$implementator->record = $record;
} else {
// The implementator object not implements the Active Record pattern
// Exit (fail)
throw new exception_logic('The implementator object not implements the Active Record pattern');
}
// Writing into the buffer of implemented record;
$implemented[] = $implementator;
}
// Exit (success)
return $implemented;
}
/**
* Structors
*
* @param int $amount Amount
* @param int $offset Offset
*
* @return array Structors
*/
public static function structors(int $amount = 100, int $offset = 0): array
{
// Initializing the membership model
$model = new membership;
// Initializing the account memberships
$memberships = $model->database->read(
filter: fn(record $record) => $record->status === status::joined->value,
amount: $amount,
offset: $offset
);
// Exit (success)
return $memberships;
}
/**
* Planned
*
* @param int $amount Amount
* @param int $offset Offset
*
* @return array Planned
*/
public static function planned(int $amount = 100, int $offset = 0): array
{
// Initializing the membership model
$model = new membership;
// Initializing the account memberships
$memberships = $model->database->read(
filter: fn(record $record) => $record->status === status::planned,
amount: $amount,
offset: $offset
);
// Exit (success)
return $memberships;
}
/**
* Autonoms
*
* @param int $amount Amount
* @param int $offset Offset
*
* @return array Autonoms
*/
public static function autonoms(int $amount = 100, int $offset = 0): array
{
// Initializing the membership model
$model = new membership;
// Initializing the account memberships
$memberships = $model->database->read(
filter: fn(record $record) => $record->status === status::joined,
amount: $amount,
offset: $offset
);
// Exit (success)
return [];
}
/**
* Volunteers
*
* @param int $amount Amount
* @param int $offset Offset
*
* @return array Volunteers
*/
public static function volunteers(int $amount = 100, int $offset = 0): array
{
// Initializing the membership model
$model = new membership;
// Initializing the account memberships
$memberships = $model->database->read(
filter: fn(record $record) => $record->status === status::joined,
amount: $amount,
offset: $offset
);
// Exit (success)
return [];
}
/**
* Investors
*
* @param int $amount Amount
* @param int $offset Offset
*
* @return array Investors
*/
public static function investors(int $amount = 100, int $offset = 0): array
{
// Initializing the membership model
$model = new membership;
// Initializing the account memberships
$memberships = $model->database->read(
filter: fn(record $record) => $record->status === status::joined,
amount: $amount,
offset: $offset
);
// Exit (success)
return [];
}
/**
* Recruiters
*
* @param int $amount Amount
* @param int $offset Offset
*
* @return array Recruiters
*/
public static function recruiters(int $amount = 100, int $offset = 0): array
{
// Initializing the membership model
$model = new membership;
// Initializing the account memberships
$memberships = $model->database->read(
filter: fn(record $record) => $record->status === status::joined,
amount: $amount,
offset: $offset
);
// Exit (success)
return [];
}
}

View File

@@ -2,11 +2,11 @@
declare(strict_types=1); declare(strict_types=1);
namespace svoboda\svoboder\models\account; namespace svoboda\antivertical\models\account;
// Files of the project // Files of the project
use svoboda\svoboder\models\core, use svoboda\antivertical\models\core,
svoboda\svoboder\models\enumerations\language; svoboda\antivertical\models\enumerations\language;
// Svoboda time // Svoboda time
use svoboda\time\statement as svoboda; use svoboda\time\statement as svoboda;
@@ -28,7 +28,7 @@ use Exception as exception,
/** /**
* Localization * Localization
* *
* @package svoboda\svoboder\models\account * @package svoboda\antivertical\models\account
* *
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License * @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy> * @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>

View File

@@ -0,0 +1,128 @@
<?php
declare(strict_types=1);
namespace svoboda\antivertical\models;
// Files of the project
use svoboda\antivertical\models\core,
svoboda\antivertical\models\enumerations\entity,
svoboda\antivertical\models\enumerations\membership\status,
svoboda\antivertical\models\interfaces\ar as active_record,
svoboda\antivertical\models\traits\ar as active_record_trait;
// Svoboda time
use svoboda\time\statement as svoboda;
// Baza database
use mirzaev\baza\database,
mirzaev\baza\column,
mirzaev\baza\record,
mirzaev\baza\enumerations\encoding,
mirzaev\baza\enumerations\type;
// Framework for Telegram
use Zanzara\Telegram\Type\User as telegram;
// Built-in libraries
use Exception as exception,
RuntimeException as exception_runtime;
/**
* Connection between account::class and telegram::class
*
* @uses active_record
* @uses active_record_trait
*
* @package svoboda\antivertical\models
*
* @property string $file Path to the database file
* @property database $database The database
* @property record $record The database record
*
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
*/
final class connection extends core implements active_record
{
use active_record_trait;
/**
* File
*
* @var string $database Path to the database file
*/
protected string $file = DATABASES . DIRECTORY_SEPARATOR . 'connection.baza';
/**
* Database
*
* Identifier: The record identifier
* Account: The account identifier
* Telegram: The telegram account identifier
* Updated: Timestamp of the last the record update
* Created: Timestamp of the record creating
*
* @var database $database The database
*/
public protected(set) database $database;
/**
* Constructor
*
* @param record|null $record The database record
*
* @return void
*/
public function __construct(?record $record = null)
{
// Initializing the database
$this->database = new database()
->encoding(encoding::ascii)
->columns(
new column('identifier', type::long_long_unsigned),
new column('account', type::long_long_unsigned),
new column('telegram', type::long_long_unsigned),
new column('active', type::char),
new column('updated', type::integer_unsigned),
new column('created', type::integer_unsigned)
)
->connect($this->file);
// Initializing the database record
if ($record) $this->record = $record;
}
/**
* Create
*
* Creates the member record in the database
*
* @param int $account Identifier of the account
* @param int $telegram Identifier of the telegram account
* @param bool $active Is the connection active?
*
* @return int|false The record identifier, if created
*/
public function create(int $account, int $telegram, bool $active = true): int|false
{
// Initializing the identifier
$identifier = $this->database->count() + 1;
// Initializing the record
$record = $this->database->record(
$identifier,
$account,
$telegram,
(int) $active,
svoboda::timestamp(),
svoboda::timestamp()
);
// Creating the record in the database
$created = $this->database->write($record);
// Exit (success)
return $created ? $identifier : false;
}
}

View File

@@ -2,7 +2,7 @@
declare(strict_types=1); declare(strict_types=1);
namespace svoboda\svoboder\models; namespace svoboda\antivertical\models;
// Framework for PHP // Framework for PHP
use mirzaev\minimal\model; use mirzaev\minimal\model;
@@ -18,7 +18,7 @@ use exception;
/** /**
* Core * Core
* *
* @package svoboda\svoboder\models * @package svoboda\antivertical\models
* *
* @method void __construct() Constructor * @method void __construct() Constructor
* *

View File

@@ -0,0 +1,331 @@
<?php
declare(strict_types=1);
namespace svoboda\antivertical\models;
// Files of the project
use svoboda\antivertical\models\core,
svoboda\antivertical\models\distribution\localization,
svoboda\antivertical\models\distribution\message,
svoboda\antivertical\models\enumerations\language,
svoboda\antivertical\models\interfaces\ar as active_record,
svoboda\antivertical\models\traits\ar as active_record_trait,
svoboda\antivertical\models\enumerations\membership\status;
// Svoboda time
use svoboda\time\statement as svoboda;
// Baza database
use mirzaev\baza\database,
mirzaev\baza\column,
mirzaev\baza\record,
mirzaev\baza\enumerations\encoding,
mirzaev\baza\enumerations\type;
// Framework for Telegram
use Zanzara\Telegram\Type\User as telegram;
// Built-in libraries
use Exception as exception,
RuntimeException as exception_runtime;
/**
* Distribution
*
* @uses active_record
* @uses active_record_trait
*
* @package svoboda\antivertical\models
*
* @property string $file Path to the database file
* @property database $database The database
* @property record $record The database record
*
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
*/
final class distribution extends core implements active_record
{
use active_record_trait;
/**
* File
*
* @var string $database Path to the database file
*/
protected string $file = DATABASES . DIRECTORY_SEPARATOR . 'distributions.baza';
/**
* Database
*
* @var database $database The database
*/
public protected(set) database $database;
/**
* Localization
*
* @var localization $localization The localizations implementator
*/
public protected(set) localization $localization;
/**
* Message
*
* @var localization $localization The messages implementator
*/
public protected(set) message $message;
/**
* Constructor
*
* @param record|null $record The database record
*
* @return void
*/
public function __construct(?record $record = null)
{
// Initializing the database
$this->database = new database()
->encoding(encoding::ascii)
->columns(
new column('identifier', type::long_long_unsigned),
new column('creator', type::long_long_unsigned),
new column('latitude', type::float),
new column('longitude', type::float),
new column('updated', type::integer_unsigned),
new column('created', type::integer_unsigned)
)
->connect($this->file);
// Initializing the localizations implementator
$this->localization = new localization;
// Initializing the messages implementator
$this->message = new message;
// Initializing the database record
if ($record) $this->record = $record;
}
/**
* Create
*
* Creates the distribution record in the database
*
* @param int $creator Identifier of the creator account (svoboda\antivertical\models\account)
* @param float $latitude Latitude
* @param float $longitude Longitude
*
* @return int|false The record identifier, if created
*/
public function create(int $creator, float $latitude = 0, float $longitude = 0): int|false
{
// Initializing the identifier
$identifier = $this->database->count() + 1;
// Initializing the record
$record = $this->database->record(
$identifier,
$creator,
$latitude,
$longitude,
svoboda::timestamp(),
svoboda::timestamp()
);
// Creating the record in the database
$created = $this->database->write($record);
// Exit (success)
return $created ? $identifier : false;
}
/**
* Localization
*
* Initialize the distribution localization
* Priority: $language argument > english > the distribution creator language > first in the localizations registry
*
* @param language $language Language
*
* @return localization|false The distribtion localization, if initialized
*/
public function localization(language $language): localization|false
{
// Initializing localizations
$localizations = $this->localization->database->read(
filter: fn(record $localization) => $localization->distribution === $this->identifier,
amount: DISTRIBUTIONS_SEARCH_DISTRIBUTION_LOCALIZATIONS_AMOUNT
);
if (count($localizations) > 0) {
// Initialized the distributions localizations
foreach ($localizations as $record) {
// Iterating over localizations
if ($record->language === $language->name) {
// Found localization by the account language
// Initializing localization by the account language
$this->localization->record = $record;
// Exit (success)
break;
}
}
if (!isset($this->localization->record)) {
// Not initialized localization by the account language
foreach ($localizations as $record) {
// Iterating over localizations
if ($record->language === 'en') {
// Found localization by english language
// Initializing localization by english language
$this->localization->record = $record;
// Exit (success)
break;
}
}
if (!isset($this->localization->record)) {
// Not initialized localization by english language
// Initializing the account model
$model_account = new account;
// Initializing the distribution creator account
$creator = $model_account->read(filter: fn(record $account) => $account->identifier === $this->creator);
if ($creator instanceof account) {
// Initialized the distribution creator account
foreach ($localizations as $record) {
// Iterating over localizations
if ($record->language === $creator->language) {
// Found localization by the distribution creator account language
// Initializing localization by the distribution creator account language
$values = $record;
// Exit (success)
break;
}
}
}
if (!isset($this->localization->record)) {
// Not initialized localization by the distribution creator account language
// Initializing localization by the first found record
$this->localization->record = $localizations[0];
}
}
}
}
// Exit (success/fail)
return $this->localization;
}
/**
* Structors
*
* Search for the distribution structors
*
* @param int $amount Amount
* @param int $offset Offest
*
* @return array The distribution structors
*/
public function structors(int $amount = 100, int $offset = 0): array
{
// Initializing the membership model
$model_membership = new membership();
// Searching for memberships
$memberships = $model_membership->database->read(
filter: fn(record $record) => $record->distribution === $this->identifier && $record->status === status::joined->value,
amount: $amount,
offset: $offset
);
// Initializing the account model
$model_account = new account();
// Declaring the buffer of found structors
$structors = [];
foreach ($memberships as $membership) {
// Iterating over memberships
// Searching for the structor account
$structor = $model_account->read(filter: fn(record $record) => $record->identifier === $membership->account);
if ($structor instanceof account) {
// Initialized the structor account
// Writing into the buffer of found structors
$structors[] = $structor;
}
}
// Exit (fail)
return $structors;
}
/**
* Planners
*
* Search for the distribution planners
*
* @param int $amount Amount
* @param int $offset Offest
*
* @return array The distribution planners
*/
public function planners(int $amount = 100, int $offset = 0): array
{
// Initializing the membership model
$model_membership = new membership();
// Searching for memberships
$memberships = $model_membership->database->read(
filter: fn(record $record) => $record->distribution === $this->identifier && $record->status === status::planned->value,
amount: $amount,
offset: $offset
);
// Initializing the account model
$model_account = new account();
// Declaring the buffer of found planners
$planners = [];
foreach ($memberships as $membership) {
// Iterating over memberships
// Searching for the planner account
$planner = $model_account->read(filter: fn(record $record) => $record->identifier === $membership->account);
if ($planner instanceof account) {
// Initialized the planner account
// Writing into the buffer of found planners
$planners[] = $planner;
}
}
// Exit (fail)
return $planners;
}
}

View File

@@ -2,11 +2,13 @@
declare(strict_types=1); declare(strict_types=1);
namespace svoboda\svoboder\models\distribution; namespace svoboda\antivertical\models\distribution;
// Files of the project // Files of the project
use svoboda\svoboder\models\core, use svoboda\antivertical\models\core,
svoboda\svoboder\models\enumerations\language; svoboda\antivertical\models\enumerations\language,
svoboda\antivertical\models\interfaces\ar as active_record,
svoboda\antivertical\models\traits\ar as active_record_trait;
// Svoboda time // Svoboda time
use svoboda\time\statement as svoboda; use svoboda\time\statement as svoboda;
@@ -28,13 +30,22 @@ use Exception as exception,
/** /**
* Localization * Localization
* *
* @package svoboda\svoboder\models\distributions * @uses active_record
* @uses active_record_trait
*
* @package svoboda\antivertical\models\distribution
*
* @property string $file Path to the database file
* @property database $database The database
* @property record $record The database record
* *
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License * @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy> * @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
*/ */
final class localization extends core final class localization extends core implements active_record
{ {
use active_record_trait;
/** /**
* File * File
* *

View File

@@ -2,11 +2,11 @@
declare(strict_types=1); declare(strict_types=1);
namespace svoboda\svoboder\models\distribution; namespace svoboda\antivertical\models\distribution;
// Files of the project // Files of the project
use svoboda\svoboder\models\core, use svoboda\antivertical\models\core,
svoboda\svoboder\models\enumerations\entity; svoboda\antivertical\models\enumerations\entity;
// Svoboda time // Svoboda time
use svoboda\time\statement as svoboda; use svoboda\time\statement as svoboda;
@@ -28,7 +28,7 @@ use Exception as exception,
/** /**
* Message * Message
* *
* @package svoboda\svoboder\models\distributions * @package svoboda\antivertical\models\distributions
* *
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License * @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy> * @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>

View File

@@ -2,14 +2,14 @@
declare(strict_types=1); declare(strict_types=1);
namespace svoboda\svoboder\models\enumerations; namespace svoboda\antivertical\models\enumerations;
/** /**
* Entity * Entity
* *
* Types of entities * Types of entities
* *
* @package svoboda\svoboder\models\enumerations * @package svoboda\antivertical\models\enumerations
* *
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License * @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy> * @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>

View File

@@ -2,14 +2,14 @@
declare(strict_types=1); declare(strict_types=1);
namespace svoboda\svoboder\models\enumerations; namespace svoboda\antivertical\models\enumerations;
/** /**
* Language * Language
* *
* Types of languages by ISO 639-1 standart * Types of languages by ISO 639-1 standart
* *
* @package svoboda\svoboder\models\enumerations * @package svoboda\antivertical\models\enumerations
* *
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License * @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy> * @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>

View File

@@ -2,14 +2,14 @@
declare(strict_types=1); declare(strict_types=1);
namespace svoboda\svoboder\models\enumerations\member; namespace svoboda\antivertical\models\enumerations\membership;
/** /**
* Status * Status
* *
* Member status * Membership status
* *
* @package svoboda\svoboder\models\enumerations\member * @package svoboda\antivertical\models\enumerations\membership
* *
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License * @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy> * @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>

View File

@@ -0,0 +1,22 @@
<?php
declare(strict_types=1);
namespace svoboda\antivertical\models\enumerations\relation;
/**
* Type
*
* Relation type
*
* @package svoboda\antivertical\models\enumerations\relation
*
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
*/
enum status: int
{
case unknown = 0;
case recognition = 1;
case unrecognition = 2;
}

View File

@@ -0,0 +1,69 @@
<?php
declare(strict_types=1);
namespace svoboda\antivertical\models\interfaces;
// Files of the project
use svoboda\antivertical\models\core;
// Svoboda time
use svoboda\time\statement as svoboda;
// Baza database
use mirzaev\baza\database,
mirzaev\baza\column,
mirzaev\baza\record,
mirzaev\baza\enumerations\encoding,
mirzaev\baza\enumerations\type;
// Built-in libraries
use Exception as exception,
RuntimeException as exception_runtime,
LogicException as exception_logic,
InvalidArgumentException as exception_invalid_argument;
/**
* AR
*
* The "Active Record" architectural pattern
*
* @see https://en.wikipedia.org/wiki/Active_record_pattern Active Record
*
* @package svoboda\antivertical\models\interfaces
*
* @method static|false read(callable $filter) Read from the database
* @method static|false update() Update the record in the database
*
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
*/
interface ar
{
/**
* Constructor
*
* @throws exception_invalid_argument If not initialized the database columns parameters
*
* @return void
*/
public function __construct();
/**
* Read
*
* Search for the record in the database
*
* @return static|false The record impementator object, if found
*/
public function read(callable $filter): static|false;
/**
* Update
*
* Write the record new values into the database
*
* @return static|false The updated record, if updated (new instance)
*/
public function update(): static|false;
}

View File

@@ -0,0 +1,129 @@
<?php
declare(strict_types=1);
namespace svoboda\antivertical\models;
// Files of the project
use svoboda\antivertical\models\core,
svoboda\antivertical\models\interfaces\ar as active_record,
svoboda\antivertical\models\traits\ar as active_record_trait,
svoboda\antivertical\models\enumerations\entity,
svoboda\antivertical\models\enumerations\membership\status;
// Svoboda time
use svoboda\time\statement as svoboda;
// Baza database
use mirzaev\baza\database,
mirzaev\baza\column,
mirzaev\baza\record,
mirzaev\baza\enumerations\encoding,
mirzaev\baza\enumerations\type;
// Framework for Telegram
use Zanzara\Telegram\Type\User as telegram;
// Built-in libraries
use Exception as exception,
RuntimeException as exception_runtime;
/**
* Membership
*
* @uses active_record
* @uses active_record_trait
*
* @package svoboda\antivertical\models
*
* @property string $file Path to the database file
* @property database $database The database
* @property record $record The database record
*
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
*/
final class membership extends core implements active_record
{
use active_record_trait;
/**
* File
*
* @var string $database Path to the database file
*/
protected string $file = DATABASES . DIRECTORY_SEPARATOR . 'memberships.baza';
/**
* Database
*
* Identifier: The record identifier
* Distribution: The distribution
* Account: The account
* Status: @see status::class
* Updated: Timestamp of the last the record update
* Created: Timestamp of the record creating
*
* @var database $database The database
*/
public protected(set) database $database;
/**
* Constructor
*
* @param record|null $record The database record
*
* @return void
*/
public function __construct(?record $record = null)
{
// Initializing the database
$this->database = new database()
->encoding(encoding::ascii)
->columns(
new column('identifier', type::long_long_unsigned),
new column('distribution', type::long_long_unsigned),
new column('account', type::long_long_unsigned),
new column('status', type::char),
new column('updated', type::integer_unsigned),
new column('created', type::integer_unsigned)
)
->connect($this->file);
// Initializing the database record
if ($record) $this->record = $record;
}
/**
* Create
*
* Creates the membership record in the database
*
* @param int $distribution Identifier of the distribution
* @param int $account Identifier of the account
* @param status $status The distribution membership status
*
* @return int|false The record identifier, if created
*/
public function create(int $distribution, int $account, status $status = status::unknown): int|false
{
// Initializing the identifier
$identifier = $this->database->count() + 1;
// Initializing the record
$record = $this->database->record(
$identifier,
$distribution,
$account,
$status->value,
svoboda::timestamp(),
svoboda::timestamp()
);
// Creating the record in the database
$created = $this->database->write($record);
// Exit (success)
return $created ? $identifier : false;
}
}

View File

@@ -2,12 +2,12 @@
declare(strict_types=1); declare(strict_types=1);
namespace svoboda\svoboder\models; namespace svoboda\antivertical\models;
// Files of the project // Files of the project
use svoboda\svoboder\models\core, use svoboda\antivertical\models\core,
svoboda\svoboder\models\enumerations\entity, svoboda\antivertical\models\enumerations\entity,
svoboda\svoboder\models\enumerations\member\status; svoboda\antivertical\models\enumerations\member\status;
// Svoboda time // Svoboda time
use svoboda\time\statement as svoboda; use svoboda\time\statement as svoboda;
@@ -27,29 +27,29 @@ use Exception as exception,
RuntimeException as exception_runtime; RuntimeException as exception_runtime;
/** /**
* Member * Relation
* *
* @package svoboda\svoboder\models * @package svoboda\antivertical\models
* *
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License * @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy> * @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
*/ */
final class member extends core final class relation extends core
{ {
/** /**
* File * File
* *
* @var string $database Path to the database file * @var string $database Path to the database file
*/ */
protected string $file = DATABASES . DIRECTORY_SEPARATOR . 'members.baza'; protected string $file = DATABASES . DIRECTORY_SEPARATOR . 'relations.baza';
/** /**
* Database * Database
* *
* Identifier: The record identifier * Identifier: The record identifier
* Distribution: The distribution * From: The account identifier
* Account: The account * To: The account identifier
* Status: 1 - planned; 2 - joined * Type: Type
* Updated: Timestamp of the last the record update * Updated: Timestamp of the last the record update
* Created: Timestamp of the record creating * Created: Timestamp of the record creating
* *
@@ -68,10 +68,10 @@ final class member extends core
$this->database = new database() $this->database = new database()
->encoding(encoding::ascii) ->encoding(encoding::ascii)
->columns( ->columns(
new column('identifier', type::integer_unsigned), new column('identifier', type::long_long_unsigned),
new column('distribution', type::integer_unsigned), new column('from', type::long_long_unsigned),
new column('account', type::integer_unsigned), new column('to', type::long_long_unsigned),
new column('status', type::char), new column('type', type::char),
new column('updated', type::integer_unsigned), new column('updated', type::integer_unsigned),
new column('created', type::integer_unsigned) new column('created', type::integer_unsigned)
) )
@@ -83,14 +83,14 @@ final class member extends core
* *
* Creates the member record in the database * Creates the member record in the database
* *
* @param int $distribution Identifier of the distribution * @param int $from Identifier of the account (svoboda\antivertical\models\account)
* @param int $account Identifier of the account * @param int $to Identifier of the account (svoboda\antivertical\models\account)
* @param status $status The distribution memberhip status * @param type $type Type of the relation
* *
* @return int|false The record identifier, if created * @return int|false The record identifier, if created
*/ */
public function create(int $distribution, int $account, status $status = status::unknown): int|false public function create(int $from, int $to, type $type): int|false
{var_dump($this->database->count()); {
// Initializing the identifier // Initializing the identifier
$identifier = $this->database->count() + 1; $identifier = $this->database->count() + 1;

View File

@@ -2,11 +2,13 @@
declare(strict_types=1); declare(strict_types=1);
namespace svoboda\svoboder\models; namespace svoboda\antivertical\models;
// Files of the project // Files of the project
use svoboda\svoboder\models\core, use svoboda\antivertical\models\core,
svoboda\svoboder\models\account\localization; svoboda\antivertical\models\account\localization,
svoboda\antivertical\models\interfaces\ar as active_record,
svoboda\antivertical\models\traits\ar as active_record_trait;
// Svoboda time // Svoboda time
use svoboda\time\statement as svoboda; use svoboda\time\statement as svoboda;
@@ -19,28 +21,37 @@ use mirzaev\baza\database,
mirzaev\baza\enumerations\type; mirzaev\baza\enumerations\type;
// Framework for Telegram // Framework for Telegram
use Zanzara\Telegram\Type\User as telegram; use Zanzara\Telegram\Type\User as model;
// Built-in libraries // Built-in libraries
use Exception as exception, use Exception as exception,
RuntimeException as exception_runtime; RuntimeException as exception_runtime;
/** /**
* Account * Telegram account
* *
* @package svoboda\svoboder\models * @uses active_record
* @uses active_record_trait
*
* @package svoboda\antivertical\models
*
* @property string $file Path to the database file
* @property database $database The database
* @property record $record The database record
* *
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License * @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy> * @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
*/ */
final class account extends core final class telegram extends core implements active_record
{ {
use active_record_trait;
/** /**
* File * File
* *
* @var string $database Path to the database file * @var string $database Path to the database file
*/ */
protected string $file = DATABASES . DIRECTORY_SEPARATOR . 'accounts.baza'; protected string $file = DATABASES . DIRECTORY_SEPARATOR . 'telegram.baza';
/** /**
* Database * Database
@@ -59,30 +70,22 @@ final class account extends core
/** /**
* Constructor * Constructor
* *
* @param record|null $record The database record
*
* @return void * @return void
*/ */
public function __construct() public function __construct(?record $record = null)
{ {
// Initializing the database // Initializing the database
$this->database = new database() $this->database = new database()
->encoding(encoding::utf8) ->encoding(encoding::utf8)
->columns( ->columns(
new column('identifier', type::integer_unsigned), new column('identifier', type::long_long_unsigned),
new column('identifier_telegram', type::integer),
new column('domain', type::string, ['length' => 32]), new column('domain', type::string, ['length' => 32]),
new column('name_first', type::string, ['length' => 64]), new column('name_first', type::string, ['length' => 64]),
new column('name_second', type::string, ['length' => 64]), new column('name_second', type::string, ['length' => 64]),
new column('language', type::string, ['length' => 2]), new column('language', type::string, ['length' => 2]),
new column('robot', type::char), new column('robot', type::char),
new column('authorized_system', type::char),
new column('authorized_messages', type::char),
new column('authorized_joins', type::char),
new column('authorized_settings', type::char),
new column('authorized_system_accounts', type::char),
new column('authorized_system_distributions', type::char),
new column('authorized_system_members', type::char),
/* new column('authorized_system_', type::char), */
new column('authorized_system_settings', type::char),
new column('updated', type::integer_unsigned), new column('updated', type::integer_unsigned),
new column('created', type::integer_unsigned) new column('created', type::integer_unsigned)
) )
@@ -90,50 +93,52 @@ final class account extends core
// Initializing the localizations implementator // Initializing the localizations implementator
$this->localization = new localization; $this->localization = new localization;
// Initializing the database record
if ($record) $this->record = $record;
} }
/** /**
* Initialize * Initialize
* *
* Searches for the account record in the database, and if it does not find it, it creates it * Searches for the telegram account record in the database, and if it does not find it, then create
* *
* @param telegram $telegram The telegram account * @param model $telegram The telegram account
* *
* @throws exception_runtime if update the account record in the database by the telegram account values * @throws exception_runtime if update the telegram account record in the database by the telegram account values
* @throws exception_runtime if failed to find the registered account * @throws exception_runtime if failed to find the created telegram account
* @throws exception_runtime if failed to registrate the account * @throws exception_runtime if failed to create the telegram account
* *
* @return record The account record from the database * @return static The telegram account record implementator
*/ */
public function initialize(telegram $telegram): record public function initialize(model $telegram): static
{ {
// Searching for the account in the database // Searching for the account in the database
$account = $this->database->read(filter: fn(record $record) => $record->identifier_telegram === $telegram->getId(), amount: 1)[0] ?? null; $instance = $this->read(filter: fn(record $record) => $record->identifier === $telegram->getId());
if ($account instanceof record) { if ($instance instanceof static) {
// Found the account record // Found the telegram account record
if ( if (
$account->name_first !== $telegram->getFirstName() || $instance->name_first !== $telegram->getFirstName() ||
$account->name_second !== $telegram->getLastName() || $instance->name_second !== $telegram->getLastName() ||
$account->domain !== $telegram->getUsername() $instance->domain !== $telegram->getUsername()
) { ) {
// The telegram account was updated // The telegram account was updated
// Updating the account in the database // Updating the account in the database
$updated = $this->database->read( $updated = $this->update(
filter: fn(record $record) => $record->identifier_telegram === $telegram->getId(), filter: fn(record $record) => $record->identifier === $telegram->getId(),
update: function (record &$record) use ($telegram) { update: function (record &$record) use ($telegram) {
// Writing new values into the record // Writing new values into the record
$record->name_first = $telegram->getFirstName(); $record->name_first = $telegram->getFirstName();
$record->name_second = $telegram->getLastName(); $record->name_second = $telegram->getLastName();
$record->domain = $telegram->getUsername(); $record->domain = $telegram->getUsername();
$record->updated = svoboda::timestamp(); $record->updated = svoboda::timestamp();
}, }
amount: 1 );
)[0] ?? null;
if ($updated instanceof record && $updated->values() !== $account->values()) { if ($updated instanceof record && $updated->values() !== $instance->record->values()) {
// Updated the account in the database // Updated the account in the database
// Exit (success) // Exit (success)
@@ -147,67 +152,58 @@ final class account extends core
} }
// Exit (success) // Exit (success)
return $account; return $instance;
} else { } else {
// Not found the account record // Not found the account record
if ($this->registrate($telegram)) { if ($this->create($telegram)) {
// Registered the account // Created the account
// Searching for the registered account in the database // Searching for the created telegram account in the database
$account = $this->database->read(filter: fn(record $record) => $record->identifier_telegram === $telegram->getId(), amount: 1)[0] ?? null; $account = $this->read(filter: fn(record $record) => $record->identifier === $telegram->getId());
if ($account instanceof record) { if ($account instanceof static) {
// Found the registered account // Found the created telegram account
// Exit (success) // Exit (success)
return $account; return $account;
} else { } else {
// Not found the registered account // Not found the created telegram account
// Exit (fail) // Exit (fail)
throw new exception_runtime('Failed to find the registered account'); throw new exception_runtime('Failed to find the created telegram account');
} }
} else { } else {
// Not registered the account // Not created the telegram account
// Exit (fail) // Exit (fail)
throw new exception_runtime('Failed to registrate the account'); throw new exception_runtime('Failed to create the telegram account');
} }
} }
} }
/** /**
* Registrate * Create
* *
* Creates the account record in the database * Creates the account record in the database
* *
* @param telegram $telegram The telegram account * @param model $telegram The telegram account
* *
* @return int|false The record identifier, if created * @return int|false The record identifier, if created
*/ */
public function registrate(telegram $telegram): int|false public function create(model $telegram): int|false
{ {
// Initializing the identifier // Initializing the identifier
$identifier = $this->database->count() + 1; $identifier = (int) $telegram->getId();
// Initializing the record // Initializing the record
$record = $this->database->record( $record = $this->database->record(
$identifier, $identifier,
(int) $telegram->getId(), $telegram->getUsername(),
$telegram->getFirstName(), $telegram->getFirstName(),
$telegram->getLastName(), $telegram->getLastName(),
$telegram->getUsername(),
$telegram->getLanguageCode(), $telegram->getLanguageCode(),
(int) $telegram->isBot(), (int) $telegram->isBot(),
1,
1,
1,
1,
0,
0,
0,
0,
svoboda::timestamp(), svoboda::timestamp(),
svoboda::timestamp() svoboda::timestamp()
); );
@@ -218,12 +214,4 @@ final class account extends core
// Exit (success) // Exit (success)
return $created ? $identifier : false; return $created ? $identifier : false;
} }
public function localizations(): array|false
{
// Exit (fail)
return false;
}
} }

View File

@@ -2,12 +2,12 @@
declare(strict_types=1); declare(strict_types=1);
namespace svoboda\svoboder\models\telegram; namespace svoboda\antivertical\models\telegram;
// Files of the project // Files of the project
use svoboda\svoboder\models\core, use svoboda\antivertical\models\core,
svoboda\svoboder\models\account as model, svoboda\antivertical\models\account as model,
svoboda\svoboder\models\enumerations\language; svoboda\antivertical\models\enumerations\language;
// Framework for Telegram // Framework for Telegram
use Zanzara\Context as context, use Zanzara\Context as context,
@@ -22,7 +22,7 @@ use Error as error;
/** /**
* Telegram account * Telegram account
* *
* @package svoboda\svoboder\models\telegram * @package svoboda\antivertical\models\telegram
* *
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License * @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy> * @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
@@ -43,7 +43,7 @@ final class account extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -148,7 +148,7 @@ final class account extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message

View File

@@ -2,14 +2,14 @@
declare(strict_types=1); declare(strict_types=1);
namespace svoboda\svoboder\models\telegram\buttons\account\localization; namespace svoboda\antivertical\models\telegram\buttons\account\localization;
// Files of the project // Files of the project
use svoboda\svoboder\models\core, use svoboda\antivertical\models\core,
svoboda\svoboder\models\enumerations\language, svoboda\antivertical\models\enumerations\language,
svoboda\svoboder\models\account, svoboda\antivertical\models\account,
svoboda\svoboder\models\telegram\selections, svoboda\antivertical\models\telegram\selections,
svoboda\svoboder\models\telegram\processes\account\localization\create as process_account_localization_create; svoboda\antivertical\models\telegram\processes\account\localization\create as process_account_localization_create;
// Framework for Telegram // Framework for Telegram
use Zanzara\Context as context, use Zanzara\Context as context,
@@ -21,7 +21,7 @@ use mirzaev\baza\record;
/** /**
* Telegram account localization create buttons * Telegram account localization create buttons
* *
* @package svoboda\svoboder\models\telegram\buttons\account\localization * @package svoboda\antivertical\models\telegram\buttons\account\localization
* *
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License * @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy> * @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
@@ -42,7 +42,7 @@ final class create extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing language // Initializing language
@@ -144,7 +144,7 @@ final class create extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -168,7 +168,7 @@ final class create extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -216,7 +216,7 @@ final class create extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message

View File

@@ -2,14 +2,14 @@
declare(strict_types=1); declare(strict_types=1);
namespace svoboda\svoboder\models\telegram\buttons\account\localization; namespace svoboda\antivertical\models\telegram\buttons\account\localization;
// Files of the project // Files of the project
use svoboda\svoboder\models\core, use svoboda\antivertical\models\core,
svoboda\svoboder\models\enumerations\language, svoboda\antivertical\models\enumerations\language,
svoboda\svoboder\models\account, svoboda\antivertical\models\account,
svoboda\svoboder\models\telegram\selections, svoboda\antivertical\models\telegram\selections,
svoboda\svoboder\models\telegram\processes\account\localization\update as process_account_localization_update; svoboda\antivertical\models\telegram\processes\account\localization\update as process_account_localization_update;
// Framework for Telegram // Framework for Telegram
use Zanzara\Context as context, use Zanzara\Context as context,
@@ -21,7 +21,7 @@ use mirzaev\baza\record;
/** /**
* Telegram account localization update buttons * Telegram account localization update buttons
* *
* @package svoboda\svoboder\models\telegram\buttons\account\localization * @package svoboda\antivertical\models\telegram\buttons\account\localization
* *
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License * @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy> * @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
@@ -42,7 +42,7 @@ final class update extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -90,7 +90,7 @@ final class update extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message

View File

@@ -2,15 +2,15 @@
declare(strict_types=1); declare(strict_types=1);
namespace svoboda\svoboder\models\telegram\buttons\distribution; namespace svoboda\antivertical\models\telegram\buttons\distribution;
// Files of the project // Files of the project
use svoboda\svoboder\models\core, use svoboda\antivertical\models\core,
svoboda\svoboder\models\account, svoboda\antivertical\models\account,
svoboda\svoboder\models\distribution, svoboda\antivertical\models\distribution,
svoboda\svoboder\models\telegram\processes\language\select as process_language_select, svoboda\antivertical\models\telegram\processes\language\select as process_language_select,
svoboda\svoboder\models\telegram\processes\distribution\declaration as process_distribution_declaration, svoboda\antivertical\models\telegram\processes\distribution\declaration as process_distribution_declaration,
svoboda\svoboder\models\enumerations\language; svoboda\antivertical\models\enumerations\language;
// Framework for Telegram // Framework for Telegram
use Zanzara\Context as context, use Zanzara\Context as context,
@@ -22,7 +22,7 @@ use mirzaev\baza\record;
/** /**
* Telegram distribution declaration buttons * Telegram distribution declaration buttons
* *
* @package svoboda\svoboder\models\telegram\buttons\distribution * @package svoboda\antivertical\models\telegram\buttons\distribution
* *
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License * @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy> * @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
@@ -43,7 +43,7 @@ final class declaration extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing language // Initializing language
@@ -104,7 +104,7 @@ final class declaration extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function ($message) use ($context) { ->then(function ($message) use ($context) {
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
@@ -126,7 +126,7 @@ final class declaration extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -172,7 +172,7 @@ final class declaration extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function ($message) use ($context) { ->then(function ($message) use ($context) {
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
@@ -194,7 +194,7 @@ final class declaration extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -265,7 +265,7 @@ final class declaration extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function ($message) use ($context) { ->then(function ($message) use ($context) {
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();

View File

@@ -2,14 +2,14 @@
declare(strict_types=1); declare(strict_types=1);
namespace svoboda\svoboder\models\telegram\buttons\distribution; namespace svoboda\antivertical\models\telegram\buttons\distribution;
// Files of the project // Files of the project
use svoboda\svoboder\models\core, use svoboda\antivertical\models\core,
svoboda\svoboder\models\distribution, svoboda\antivertical\models\distribution,
svoboda\svoboder\models\member, svoboda\antivertical\models\membership,
svoboda\svoboder\models\telegram\processes\distribution\search as process_distribution_search, svoboda\antivertical\models\telegram\processes\distribution\search as process_distribution_search,
svoboda\svoboder\models\enumerations\member\status; svoboda\antivertical\models\enumerations\membership\status;
// Framework for Telegram // Framework for Telegram
use Zanzara\Context as context, use Zanzara\Context as context,
@@ -24,7 +24,7 @@ use mirzaev\baza\record;
/** /**
* Telegram distribution search buttons * Telegram distribution search buttons
* *
* @package svoboda\svoboder\models\telegram\buttons\distribution * @package svoboda\antivertical\models\telegram\buttons\distribution
* *
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License * @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy> * @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
@@ -45,7 +45,7 @@ final class search extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -101,7 +101,7 @@ final class search extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function ($message) use ($context) { ->then(function ($message) use ($context) {
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
@@ -123,7 +123,7 @@ final class search extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -193,7 +193,7 @@ final class search extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function ($message) use ($context) { ->then(function ($message) use ($context) {
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
@@ -215,7 +215,7 @@ final class search extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -272,7 +272,7 @@ final class search extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function ($message) use ($context) { ->then(function ($message) use ($context) {
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
@@ -294,7 +294,7 @@ final class search extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -330,24 +330,24 @@ final class search extends core
if ($distribution instanceof record) { if ($distribution instanceof record) {
// Initialized the distribution // Initialized the distribution
// Initializing the member model // Initializing the membership model
$model_member = new member; $model_membership = new membership;
// Initializing function of the message join buttom updating // Initializing function of the message join button updating
$update = function (context $context, record $member) use ($account, $localization, $distribution, $name, $recognized, $model_member): void { $update = function (context $context, record $membership) use ($account, $localization, $distribution, $name, $recognized, $model_membership): void {
// Searching for the another member records // Searching for the another membership records
$another = $model_member->database->read( $another = $model_membership->database->read(
filter: fn(record $record) => $record->identifier !== $member->identifier && $record->account === $member->accoount && $record->status !== status::unknown->value, filter: fn(record $record) => $record->identifier !== $membership->identifier && $record->account === $membership->accoount && $record->status !== status::unknown->value,
amount: 1 amount: 1
)[0] ?? null; )[0] ?? null;
// Initializing the updated inline keyboard of the message // Initializing the updated inline keyboard of the message
$keyboard = process_distribution_search::keyboard( $keyboard = process_distribution_search::keyboard(
distribution: $distribution, distribution: $distribution,
member: $another ?? $member, membership: $another ?? $membership,
localization: $localization, localization: $localization,
messages: $account->authorized_messages === 1, messages: $account->authorized_messages === 1,
joins: $account->authorized_joins === 1, memberships: $account->authorized_memberships === 1,
); );
// Initializing the updated text of the message // Initializing the updated text of the message
@@ -368,8 +368,10 @@ final class search extends core
); );
}; };
if (!empty($model_member->database->read( if (!empty($model_membership->database->read(
filter: fn(record $member) => $member->distribution !== $distribution->identifier && $member->account === $account->identifier && $member->status === status::joined->value, filter: fn(record $membership) => $membership->distribution !== $distribution->identifier
&& $membership->account === $account->identifier
&& $membership->status === status::joined->value,
amount: 1 amount: 1
))) { ))) {
// Found joining to another distribution // Found joining to another distribution
@@ -386,8 +388,8 @@ final class search extends core
// Not found joining to another distribution // Not found joining to another distribution
if (!empty($model_member->database->read( if (!empty($model_membership->database->read(
filter: fn(record $member) => $member->distribution !== $distribution->identifier && $member->account === $account->identifier && $member->status === status::planned->value, filter: fn(record $membership) => $membership->distribution !== $distribution->identifier && $membership->account === $account->identifier && $membership->status === status::planned->value,
amount: 1 amount: 1
))) { ))) {
// Found planning to join to another distribution // Found planning to join to another distribution
@@ -403,21 +405,21 @@ final class search extends core
} else { } else {
// Not found planned to join to another distribution // Not found planned to join to another distribution
// Searching for the member record // Searching for the membership record
$member = $model_member->database->read( $membership = $model_membership->database->read(
filter: fn(record $record) => $record->distribution === $distribution->identifier && $record->account === $account->identifier, filter: fn(record $record) => $record->distribution === $distribution->identifier && $record->account === $account->identifier,
amount: 1 amount: 1
)[0] ?? null; )[0] ?? null;
if ($member instanceof record) { if ($membership instanceof record) {
// Found the member of the distribution // Found the membership of the distribution
if ($member->status === status::unknown->value) { if ($membership->status === status::unknown->value) {
// The account has leaved the distribution // The account has leaved the distribution
// Updating the member record // Updating the membership record
$updated = $model_member->database->read( $updated = $model_membership->database->read(
filter: fn(record $record) => $record->identifier === $member->identifier, filter: fn(record $record) => $record->identifier === $membership->identifier,
update: function (record &$record) { update: function (record &$record) {
$record->status = status::planned->value; $record->status = status::planned->value;
$record->updated = svoboda::timestamp(); $record->updated = svoboda::timestamp();
@@ -426,16 +428,16 @@ final class search extends core
)[0] ?? null; )[0] ?? null;
if ($updated) { if ($updated) {
// Updated the member record // Updated the membership record
// Deprecating other records // Deprecating other records
$model_member->database->read( $model_membership->database->read(
filter: fn(record $record) => $record->identifier !== $updated->identifier && $record->account === $updated->account, filter: fn(record $record) => $record->identifier !== $updated->identifier && $record->account === $updated->account,
update: function (record &$record) { update: function (record &$record) {
$record->status = status::unknown->value; $record->status = status::unknown->value;
$record->updated = svoboda::timestamp(); $record->updated = svoboda::timestamp();
}, },
amount: DISTRIBUTIONS_SEARCH_MEMBER_DEPRECATING_RECORDS_AMOUNT amount: DISTRIBUTIONS_SEARCH_MEMBERSHIP_DEPRECATING_RECORDS_AMOUNT
)[0] ?? null; )[0] ?? null;
// Sending the message // Sending the message
@@ -450,10 +452,10 @@ final class search extends core
$context->endConversation(); $context->endConversation();
}); });
} else { } else {
// Not updated the member record // Not updated the membership record
// Sending the message // Sending the message
$context->sendMessage('⚠️ *' . $localization['distribution_search_member_not_updated'] . '*') $context->sendMessage('⚠️ *' . $localization['distribution_search_membership_not_updated'] . '*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -461,83 +463,83 @@ final class search extends core
$context->endConversation(); $context->endConversation();
}); });
} }
} else if ($member->status === status::planned->value) { } else if ($membership->status === status::planned->value) {
// The account has already planned to join to the distribution // The account has already planned to join to the distribution
// Sending the message // Sending the message
$context->sendMessage('⚠️ *' . $localization['distribution_search_already_planned'] . '*') $context->sendMessage('⚠️ *' . $localization['distribution_search_already_planned'] . '*')
->then(function (message $message) use ($context, $update, $member) { ->then(function (message $message) use ($context, $update, $membership) {
// Sended the message // Sended the message
// Updating the message with the plan button // Updating the message with the plan button
$update($context, $member); $update($context, $membership);
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
}); });
} else if ($member->status === status::joined->value) { } else if ($membership->status === status::joined->value) {
// The account has already joined to the distribution // The account has already joined to the distribution
// Sending the message // Sending the message
$context->sendMessage('⚠️ *' . $localization['distribution_search_already_joined'] . '*') $context->sendMessage('⚠️ *' . $localization['distribution_search_already_joined'] . '*')
->then(function (message $message) use ($context, $update, $member) { ->then(function (message $message) use ($context, $update, $membership) {
// Sended the message // Sended the message
// Updating the message with the plan button // Updating the message with the plan button
$update($context, $member); $update($context, $membership);
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
}); });
} }
} else { } else {
// Not found the member of the distribution // Not found the membership of the distribution
// Creating the member record // Creating the membership record
$record = $model_member->create( $record = $model_membership->create(
distribution: $distribution->identifier, distribution: $distribution->identifier,
account: $account->identifier, account: $account->identifier,
status: status::planned status: status::planned
); );
if ($record) { if ($record) {
// Created the member record // Created the membership record
// Searching for the member record // Searching for the membership record
$member = $model_member->database->read( $membership = $model_membership->database->read(
filter: fn(record $member) => $member->identifier === $record, filter: fn(record $membership) => $membership->identifier === $record,
amount: 1 amount: 1
)[0] ?? null; )[0] ?? null;
if ($member instanceof record) { if ($membership instanceof record) {
// Found the member of the distribution // Found the membership of the distribution
// Deprecating other records // Deprecating other records
$model_member->database->read( $model_membership->database->read(
filter: fn(record $record) => $record->identifier !== $member->identifier && $record->account === $member->account, filter: fn(record $record) => $record->identifier !== $membership->identifier && $record->account === $membership->account,
update: function (record &$record) { update: function (record &$record) {
$record->status = status::unknown->value; $record->status = status::unknown->value;
$record->updated = svoboda::timestamp(); $record->updated = svoboda::timestamp();
}, },
amount: DISTRIBUTIONS_SEARCH_MEMBER_DEPRECATING_RECORDS_AMOUNT amount: DISTRIBUTIONS_SEARCH_MEMBERSHIP_DEPRECATING_RECORDS_AMOUNT
)[0] ?? null; )[0] ?? null;
// Sending the message // Sending the message
$context->sendMessage('📅 *' . $localization['distribution_search_planned'] . '*') $context->sendMessage('📅 *' . $localization['distribution_search_planned'] . '*')
->then(function (message $message) use ($context, $update, $member) { ->then(function (message $message) use ($context, $update, $membership) {
// Sended the message // Sended the message
// Updating the message with the plan button // Updating the message with the plan button
$update($context, $member); $update($context, $membership);
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
}); });
} else { } else {
// Not found the member of the distribution // Not found the membership of the distribution
// Sending the message // Sending the message
$context->sendMessage('⚠️ *' . $localization['distribution_search_member_not_created'] . '*') $context->sendMessage('⚠️ *' . $localization['distribution_search_membership_not_created'] . '*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -546,10 +548,10 @@ final class search extends core
}); });
} }
} else { } else {
// Not created the member record // Not created the membership record
// Sending the message // Sending the message
$context->sendMessage('⚠️ *' . $localization['distribution_search_member_not_created'] . '*') $context->sendMessage('⚠️ *' . $localization['distribution_search_membership_not_created'] . '*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -612,7 +614,7 @@ final class search extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -636,7 +638,7 @@ final class search extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -672,18 +674,18 @@ final class search extends core
if ($distribution instanceof record) { if ($distribution instanceof record) {
// Initialized the distribution // Initialized the distribution
// Initializing the member model // Initializing the membership model
$model_member = new member; $model_membership = new membership;
// Initializing function of the message join buttom updating // Initializing function of the message join buttom updating
$update = function (context $context, record $member) use ($account, $localization, $distribution, $name, $recognized): void { $update = function (context $context, record $membership) use ($account, $localization, $distribution, $name, $recognized): void {
// Initializing the updated inline keyboard of the message // Initializing the updated inline keyboard of the message
$keyboard = process_distribution_search::keyboard( $keyboard = process_distribution_search::keyboard(
distribution: $distribution, distribution: $distribution,
member: $member, membership: $membership,
localization: $localization, localization: $localization,
messages: $account->authorized_messages === 1, messages: $account->authorized_messages === 1,
joins: $account->authorized_joins === 1, memberships: $account->authorized_memberships === 1,
); );
// Initializing the updated text of the message // Initializing the updated text of the message
@@ -704,35 +706,35 @@ final class search extends core
); );
}; };
// Searching for the member record // Searching for the membership record
$member = $model_member->database->read( $membership = $model_membership->database->read(
filter: fn(record $record) => $record->distribution === $distribution->identifier && $record->account === $account->identifier, filter: fn(record $record) => $record->distribution === $distribution->identifier && $record->account === $account->identifier,
amount: 1 amount: 1
)[0] ?? null; )[0] ?? null;
if ($member instanceof record) { if ($membership instanceof record) {
// Found the member of the distribution // Found the membership of the distribution
if ($member->status === status::unknown->value) { if ($membership->status === status::unknown->value) {
// The account has leaved the distribution // The account has leaved the distribution
// Sending the message // Sending the message
$context->sendMessage('⚠️ *' . $localization['distribution_search_already_unplanned'] . '*') $context->sendMessage('⚠️ *' . $localization['distribution_search_already_unplanned'] . '*')
->then(function (message $message) use ($context, $update, $member) { ->then(function (message $message) use ($context, $update, $membership) {
// Sended the message // Sended the message
// Updating the message with the plan button // Updating the message with the plan button
$update($context, $member); $update($context, $membership);
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
}); });
} else if ($member->status === status::planned->value) { } else if ($membership->status === status::planned->value) {
// The account has planned to join to the distribution // The account has planned to join to the distribution
// Updating the member record // Updating the membership record
$updated = $model_member->database->read( $updated = $model_membership->database->read(
filter: fn(record $record) => $record->identifier === $member->identifier, filter: fn(record $record) => $record->identifier === $membership->identifier,
update: function (record &$record) { update: function (record &$record) {
$record->status = status::unknown->value; $record->status = status::unknown->value;
$record->updated = svoboda::timestamp(); $record->updated = svoboda::timestamp();
@@ -741,7 +743,7 @@ final class search extends core
)[0] ?? null; )[0] ?? null;
if ($updated) { if ($updated) {
// Updated the member record // Updated the membership record
// Sending the message // Sending the message
$context->sendMessage('❌ *' . $localization['distribution_search_unplanned'] . '*') $context->sendMessage('❌ *' . $localization['distribution_search_unplanned'] . '*')
@@ -755,10 +757,10 @@ final class search extends core
$context->endConversation(); $context->endConversation();
}); });
} else { } else {
// Not updated the member record // Not updated the membership record
// Sending the message // Sending the message
$context->sendMessage('⚠️ *' . $localization['distribution_search_member_not_updated'] . '*') $context->sendMessage('⚠️ *' . $localization['distribution_search_membership_not_updated'] . '*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -766,59 +768,59 @@ final class search extends core
$context->endConversation(); $context->endConversation();
}); });
} }
} else if ($member->status === status::joined->value) { } else if ($membership->status === status::joined->value) {
// The account has already joined to the distribution // The account has already joined to the distribution
// Sending the message // Sending the message
$context->sendMessage('⚠️ *' . $localization['distribution_search_already_joined'] . '*') $context->sendMessage('⚠️ *' . $localization['distribution_search_already_joined'] . '*')
->then(function (message $message) use ($context, $update, $member) { ->then(function (message $message) use ($context, $update, $membership) {
// Sended the message // Sended the message
// Updating the message with the plan button // Updating the message with the plan button
$update($context, $member); $update($context, $membership);
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
}); });
} }
} else { } else {
// Not found the member of the distribution // Not found the membership of the distribution
// Creating the member record // Creating the membership record
$record = $model_member->create( $record = $model_membership->create(
distribution: $distribution->identifier, distribution: $distribution->identifier,
account: $account->identifier, account: $account->identifier,
status: status::unknown status: status::unknown
); );
if ($record) { if ($record) {
// Created the member record // Created the membership record
// Searching for the member record // Searching for the membership record
$member = $model_member->database->read( $membership = $model_membership->database->read(
filter: fn(record $member) => $member->identifier === $record, filter: fn(record $membership) => $membership->identifier === $record,
amount: 1 amount: 1
)[0] ?? null; )[0] ?? null;
if ($member instanceof record) { if ($membership instanceof record) {
// Found the member of the distribution // Found the membership of the distribution
// Sending the message // Sending the message
$context->sendMessage('❌ *' . $localization['distribution_search_unplanned'] . '*') $context->sendMessage('❌ *' . $localization['distribution_search_unplanned'] . '*')
->then(function (message $message) use ($context, $update, $member) { ->then(function (message $message) use ($context, $update, $membership) {
// Sended the message // Sended the message
// Updating the message with the plan button // Updating the message with the plan button
$update($context, $member); $update($context, $membership);
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
}); });
} else { } else {
// Not found the member of the distribution // Not found the membership of the distribution
// Sending the message // Sending the message
$context->sendMessage('⚠️ *' . $localization['distribution_search_member_not_created'] . '*') $context->sendMessage('⚠️ *' . $localization['distribution_search_membership_not_created'] . '*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -827,10 +829,10 @@ final class search extends core
}); });
} }
} else { } else {
// Not created the member record // Not created the membership record
// Sending the message // Sending the message
$context->sendMessage('⚠️ *' . $localization['distribution_search_member_not_created'] . '*') $context->sendMessage('⚠️ *' . $localization['distribution_search_membership_not_created'] . '*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -891,7 +893,7 @@ final class search extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -915,7 +917,7 @@ final class search extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -952,23 +954,23 @@ final class search extends core
// Initialized the distribution // Initialized the distribution
// Initializing the distribution model // Initializing the distribution model
$model_member = new member; $model_membership = new membership;
// Initializing function of the message join buttom updating // Initializing function of the message join buttom updating
$update = function (context $context, record $member) use ($account, $localization, $distribution, $name, $recognized, $model_member): void { $update = function (context $context, record $membership) use ($account, $localization, $distribution, $name, $recognized, $model_membership): void {
// Searching for the another member records // Searching for the another membership records
$another = $model_member->database->read( $another = $model_membership->database->read(
filter: fn(record $record) => $record->identifier !== $member->identifier && $record->account === $member->accoount && $record->status !== status::unknown->value, filter: fn(record $record) => $record->identifier !== $membership->identifier && $record->account === $membership->accoount && $record->status !== status::unknown->value,
amount: 1 amount: 1
)[0] ?? null; )[0] ?? null;
// Initializing the updated inline keyboard of the message // Initializing the updated inline keyboard of the message
$keyboard = process_distribution_search::keyboard( $keyboard = process_distribution_search::keyboard(
distribution: $distribution, distribution: $distribution,
member: $another ?? $member, membership: $another ?? $membership,
localization: $localization, localization: $localization,
messages: $account->authorized_messages === 1, messages: $account->authorized_messages === 1,
joins: $account->authorized_joins === 1, memberships: $account->authorized_memberships === 1,
); );
// Initializing the updated text of the message // Initializing the updated text of the message
@@ -989,8 +991,8 @@ final class search extends core
); );
}; };
if (!empty($model_member->database->read( if (!empty($model_membership->database->read(
filter: fn(record $member) => $member->distribution !== $distribution->identifier && $member->account === $account->identifier && $member->status === status::joined->value, filter: fn(record $membership) => $membership->distribution !== $distribution->identifier && $membership->account === $account->identifier && $membership->status === status::joined->value,
amount: 1 amount: 1
))) { ))) {
// Found joining to another distribution // Found joining to another distribution
@@ -1006,21 +1008,21 @@ final class search extends core
} else { } else {
// Not found joining to another distribution // Not found joining to another distribution
// Searching for the member record // Searching for the membership record
$member = $model_member->database->read( $membership = $model_membership->database->read(
filter: fn(record $member) => $member->distribution === $distribution->identifier && $member->account === $account->identifier, filter: fn(record $membership) => $membership->distribution === $distribution->identifier && $membership->account === $account->identifier,
amount: 1 amount: 1
)[0] ?? null; )[0] ?? null;
if ($member instanceof record) { if ($membership instanceof record) {
// Found the member of the distribution // Found the membership of the distribution
if ($member->status === status::unknown->value || $member->status === status::planned->value) { if ($membership->status === status::unknown->value || $membership->status === status::planned->value) {
// The account has planned to join to the distribution or leaved the distribution // The account has planned to join to the distribution or leaved the distribution
// Updating the member record // Updating the membership record
$updated = $model_member->database->read( $updated = $model_membership->database->read(
filter: fn(record $record) => $record->identifier === $member->identifier, filter: fn(record $record) => $record->identifier === $membership->identifier,
update: function (record &$record) { update: function (record &$record) {
$record->status = status::joined->value; $record->status = status::joined->value;
$record->updated = svoboda::timestamp(); $record->updated = svoboda::timestamp();
@@ -1029,16 +1031,16 @@ final class search extends core
)[0] ?? null; )[0] ?? null;
if ($updated instanceof record) { if ($updated instanceof record) {
// Updated the member record // Updated the membership record
// Deprecating other records // Deprecating other records
$model_member->database->read( $model_membership->database->read(
filter: fn(record $record) => $record->identifier !== $updated->identifier && $record->account === $updated->account, filter: fn(record $record) => $record->identifier !== $updated->identifier && $record->account === $updated->account,
update: function (record &$record) { update: function (record &$record) {
$record->status = status::unknown->value; $record->status = status::unknown->value;
$record->updated = svoboda::timestamp(); $record->updated = svoboda::timestamp();
}, },
amount: DISTRIBUTIONS_SEARCH_MEMBER_DEPRECATING_RECORDS_AMOUNT amount: DISTRIBUTIONS_SEARCH_MEMBERSHIP_DEPRECATING_RECORDS_AMOUNT
)[0] ?? null; )[0] ?? null;
// Initializing the message title // Initializing the message title
@@ -1064,10 +1066,10 @@ final class search extends core
$context->endConversation(); $context->endConversation();
}); });
} else { } else {
// Not updated the member record // Not updated the membership record
// Sending the message // Sending the message
$context->sendMessage('⚠️ *' . $localization['distribution_search_member_not_updated'] . '*') $context->sendMessage('⚠️ *' . $localization['distribution_search_membership_not_updated'] . '*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -1075,51 +1077,51 @@ final class search extends core
$context->endConversation(); $context->endConversation();
}); });
} }
} else if ($member->status === status::joined->value) { } else if ($membership->status === status::joined->value) {
// The account has already joined to the distribution // The account has already joined to the distribution
// Sending the message // Sending the message
$context->sendMessage('⚠️ *' . $localization['distribution_search_already_joined'] . '*') $context->sendMessage('⚠️ *' . $localization['distribution_search_already_joined'] . '*')
->then(function (message $message) use ($context, $update, $member) { ->then(function (message $message) use ($context, $update, $membership) {
// Sended the message // Sended the message
// Updating the message with the join button // Updating the message with the join button
$update($context, $member); $update($context, $membership);
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
}); });
} }
} else { } else {
// Not found the member of the distribution // Not found the membership of the distribution
// Creating the member record // Creating the membership record
$record = $model_member->create( $record = $model_membership->create(
distribution: $distribution->identifier, distribution: $distribution->identifier,
account: $account->identifier, account: $account->identifier,
status: status::joined status: status::joined
); );
if ($record) { if ($record) {
// Created the member record // Created the membership record
// Searching for the member record // Searching for the membership record
$member = $model_member->database->read( $membership = $model_membership->database->read(
filter: fn(record $member) => $member->identifier === $record, filter: fn(record $membership) => $membership->identifier === $record,
amount: 1 amount: 1
)[0] ?? null; )[0] ?? null;
if ($member instanceof record) { if ($membership instanceof record) {
// Found the member of the distribution // Found the membership of the distribution
// Deprecating other records // Deprecating other records
$model_member->database->read( $model_membership->database->read(
filter: fn(record $record) => $record->identifier !== $member->identifier && $record->account === $member->account, filter: fn(record $record) => $record->identifier !== $membership->identifier && $record->account === $membership->account,
update: function (record &$record) { update: function (record &$record) {
$record->status = status::unknown->value; $record->status = status::unknown->value;
$record->updated = svoboda::timestamp(); $record->updated = svoboda::timestamp();
}, },
amount: DISTRIBUTIONS_SEARCH_MEMBER_DEPRECATING_RECORDS_AMOUNT amount: DISTRIBUTIONS_SEARCH_MEMBERSHIP_DEPRECATING_RECORDS_AMOUNT
)[0] ?? null; )[0] ?? null;
// Initializing the message title // Initializing the message title
@@ -1135,20 +1137,20 @@ final class search extends core
$description $description
TXT TXT
)->then(function (message $message) use ($context, $update, $member) { )->then(function (message $message) use ($context, $update, $membership) {
// Sended the message // Sended the message
// Updating the message with the join button // Updating the message with the join button
$update($context, $member); $update($context, $membership);
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
}); });
} else { } else {
// Not found the member of the distribution // Not found the membership of the distribution
// Sending the message // Sending the message
$context->sendMessage('⚠️ *' . $localization['distribution_search_member_not_created'] . '*') $context->sendMessage('⚠️ *' . $localization['distribution_search_membership_not_created'] . '*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -1157,10 +1159,10 @@ final class search extends core
}); });
} }
} else { } else {
// Not created the member record // Not created the membership record
// Sending the message // Sending the message
$context->sendMessage('⚠️ *' . $localization['distribution_search_member_not_created'] . '*') $context->sendMessage('⚠️ *' . $localization['distribution_search_membership_not_created'] . '*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -1222,7 +1224,7 @@ final class search extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -1246,7 +1248,7 @@ final class search extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -1282,18 +1284,18 @@ final class search extends core
if ($distribution instanceof record) { if ($distribution instanceof record) {
// Initialized the distribution // Initialized the distribution
// Initializing the member model // Initializing the membership model
$model_member = new member; $model_membership = new membership;
// Initializing function of the message join buttom updating // Initializing function of the message join buttom updating
$update = function (context $context, record $member) use ($account, $localization, $distribution, $name, $recognized): void { $update = function (context $context, record $membership) use ($account, $localization, $distribution, $name, $recognized): void {
// Initializing the updated inline keyboard of the message // Initializing the updated inline keyboard of the message
$keyboard = process_distribution_search::keyboard( $keyboard = process_distribution_search::keyboard(
distribution: $distribution, distribution: $distribution,
member: $member, membership: $membership,
localization: $localization, localization: $localization,
messages: $account->authorized_messages === 1, messages: $account->authorized_messages === 1,
joins: $account->authorized_joins === 1, memberships: $account->authorized_memberships === 1,
); );
// Initializing the updated text of the message // Initializing the updated text of the message
@@ -1314,35 +1316,35 @@ final class search extends core
); );
}; };
// Searching for the member record // Searching for the membership record
$member = $model_member->database->read( $membership = $model_membership->database->read(
filter: fn(record $record) => $record->distribution === $distribution->identifier && $record->account === $account->identifier, filter: fn(record $record) => $record->distribution === $distribution->identifier && $record->account === $account->identifier,
amount: 1 amount: 1
)[0] ?? null; )[0] ?? null;
if ($member instanceof record) { if ($membership instanceof record) {
// Found the member of the distribution // Found the membership of the distribution
if ($member->status === status::unknown->value || $member->status === status::planned->value) { if ($membership->status === status::unknown->value || $membership->status === status::planned->value) {
// The account has planned to join to the distribution or leaved the distribution // The account has planned to join to the distribution or leaved the distribution
// Sending the message // Sending the message
$context->sendMessage('⚠️ *' . $localization['distribution_search_already_leaved'] . '*') $context->sendMessage('⚠️ *' . $localization['distribution_search_already_leaved'] . '*')
->then(function (message $message) use ($context, $update, $member) { ->then(function (message $message) use ($context, $update, $membership) {
// Sended the message // Sended the message
// Updating the message with the join button // Updating the message with the join button
$update($context, $member); $update($context, $membership);
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
}); });
} else if ($member->status === 2) { } else if ($membership->status === 2) {
// The account has joined to the distribution // The account has joined to the distribution
// Updating the member record // Updating the membership record
$updated = $model_member->database->read( $updated = $model_membership->database->read(
filter: fn(record $record) => $record->identifier === $member->identifier, filter: fn(record $record) => $record->identifier === $membership->identifier,
update: function (record &$record) { update: function (record &$record) {
$record->status = status::unknown->value; $record->status = status::unknown->value;
$record->updated = svoboda::timestamp(); $record->updated = svoboda::timestamp();
@@ -1351,7 +1353,7 @@ final class search extends core
)[0] ?? null; )[0] ?? null;
if ($updated instanceof record) { if ($updated instanceof record) {
// Updated the member record // Updated the membership record
// Sending the message // Sending the message
$context->sendMessage('👋 *' . $localization['distribution_search_leaved'] . '*') $context->sendMessage('👋 *' . $localization['distribution_search_leaved'] . '*')
@@ -1365,10 +1367,10 @@ final class search extends core
$context->endConversation(); $context->endConversation();
}); });
} else { } else {
// Not updated the member record // Not updated the membership record
// Sending the message // Sending the message
$context->sendMessage('⚠️ *' . $localization['distribution_search_member_not_updated'] . '*') $context->sendMessage('⚠️ *' . $localization['distribution_search_membership_not_updated'] . '*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -1378,43 +1380,43 @@ final class search extends core
} }
} }
} else { } else {
// Not found the member of the distribution // Not found the membership of the distribution
// Creating the member record // Creating the membership record
$record = $model_member->create( $record = $model_membership->create(
distribution: $distribution->identifier, distribution: $distribution->identifier,
account: $account->identifier, account: $account->identifier,
status: status::unknown status: status::unknown
); );
if ($record) { if ($record) {
// Created the member record // Created the membership record
// Searching for the member record // Searching for the membership record
$member = $model_member->database->read( $membership = $model_membership->database->read(
filter: fn(record $member) => $member->identifier === $record, filter: fn(record $membership) => $membership->identifier === $record,
amount: 1 amount: 1
)[0] ?? null; )[0] ?? null;
if ($member instanceof record) { if ($membership instanceof record) {
// Found the member of the distribution // Found the membership of the distribution
// Sending the message // Sending the message
$context->sendMessage('👋 *' . $localization['distribution_search_leaved'] . '*') $context->sendMessage('👋 *' . $localization['distribution_search_leaved'] . '*')
->then(function (message $message) use ($context, $update, $member) { ->then(function (message $message) use ($context, $update, $membership) {
// Sended the message // Sended the message
// Updating the message with the join button // Updating the message with the join button
$update($context, $member); $update($context, $membership);
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
}); });
} else { } else {
// Not found the member of the distribution // Not found the membership of the distribution
// Sending the message // Sending the message
$context->sendMessage('⚠️ *' . $localization['distribution_search_member_not_created'] . '*') $context->sendMessage('⚠️ *' . $localization['distribution_search_membership_not_created'] . '*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -1423,10 +1425,10 @@ final class search extends core
}); });
} }
} else { } else {
// Not created the member record // Not created the membership record
// Sending the message // Sending the message
$context->sendMessage('⚠️ *' . $localization['distribution_search_member_not_created'] . '*') $context->sendMessage('⚠️ *' . $localization['distribution_search_membership_not_created'] . '*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -1487,7 +1489,7 @@ final class search extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message

View File

@@ -2,11 +2,11 @@
declare(strict_types=1); declare(strict_types=1);
namespace svoboda\svoboder\models\telegram\buttons\distribution; namespace svoboda\antivertical\models\telegram\buttons\distribution;
// Files of the project // Files of the project
use svoboda\svoboder\models\core, use svoboda\antivertical\models\core,
svoboda\svoboder\models\telegram\processes\distribution\select as process_distribution_select; svoboda\antivertical\models\telegram\processes\distribution\select as process_distribution_select;
// Framework for Telegram // Framework for Telegram
use Zanzara\Context as context, use Zanzara\Context as context,
@@ -18,7 +18,7 @@ use mirzaev\baza\record;
/** /**
* Telegram distribution select buttons * Telegram distribution select buttons
* *
* @package svoboda\svoboder\models\telegram\buttons\distribution * @package svoboda\antivertical\models\telegram\buttons\distribution
* *
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License * @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy> * @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
@@ -39,7 +39,7 @@ final class select extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -95,7 +95,7 @@ final class select extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function ($message) use ($context) { ->then(function ($message) use ($context) {
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
@@ -117,7 +117,7 @@ final class select extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -187,7 +187,7 @@ final class select extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function ($message) use ($context) { ->then(function ($message) use ($context) {
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
@@ -209,7 +209,7 @@ final class select extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -266,7 +266,7 @@ final class select extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function ($message) use ($context) { ->then(function ($message) use ($context) {
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();

View File

@@ -2,16 +2,16 @@
declare(strict_types=1); declare(strict_types=1);
namespace svoboda\svoboder\models\telegram\buttons\member; namespace svoboda\antivertical\models\telegram\buttons\membership;
// Files of the project // Files of the project
use svoboda\svoboder\models\core, use svoboda\antivertical\models\core,
svoboda\svoboder\models\account, svoboda\antivertical\models\account,
svoboda\svoboder\models\distribution, svoboda\antivertical\models\distribution,
svoboda\svoboder\models\telegram\processes\distribution\select as process_distribution_select, svoboda\antivertical\models\telegram\processes\distribution\select as process_distribution_select,
svoboda\svoboder\models\telegram\processes\member\search as process_member_search, svoboda\antivertical\models\telegram\processes\membership\search as process_membership_search,
svoboda\svoboder\models\enumerations\member\status, svoboda\antivertical\models\enumerations\membership\status,
svoboda\svoboder\models\enumerations\language; svoboda\antivertical\models\enumerations\language;
// Framework for Telegram // Framework for Telegram
use Zanzara\Context as context, use Zanzara\Context as context,
@@ -23,9 +23,9 @@ use Zanzara\Context as context,
use mirzaev\baza\record; use mirzaev\baza\record;
/** /**
* Telegram member search buttons * Telegram membership search buttons
* *
* @package svoboda\svoboder\models\telegram\buttons\member * @package svoboda\antivertical\models\telegram\buttons\membership
* *
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License * @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy> * @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
@@ -46,7 +46,7 @@ final class search extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -56,7 +56,7 @@ final class search extends core
// Initialized localization // Initialized localization
// Reading from the telegram user buffer // Reading from the telegram user buffer
$context->getUserDataItem(process_member_search::PROCESS) $context->getUserDataItem(process_membership_search::PROCESS)
->then(function ($search) use ($context, $account, $localization) { ->then(function ($search) use ($context, $account, $localization) {
// Readed from the telegram user buffer // Readed from the telegram user buffer
@@ -64,10 +64,10 @@ final class search extends core
// Found started search process // Found started search process
// Initializing title for the message // Initializing title for the message
$title = '📄 *' . $localization[process_member_search::PROCESS . '_name_request_title'] . '*'; $title = '📄 *' . $localization[process_membership_search::PROCESS . '_name_request_title'] . '*';
// Initializing description for the message // Initializing description for the message
$description = $localization[process_member_search::PROCESS . '_name_request_description']; $description = $localization[process_membership_search::PROCESS . '_name_request_description'];
// Sending the message // Sending the message
$context->sendMessage(<<<TXT $context->sendMessage(<<<TXT
@@ -78,14 +78,14 @@ final class search extends core
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
// Writing into the member search buffer // Writing into the membership search buffer
$context->nextStep([process_member_search::class, 'name']); $context->nextStep([process_membership_search::class, 'name']);
}); });
} else { } else {
// Not found started search process // Not found started search process
// Sending the message // Sending the message
$context->sendMessage('⚠️ *' . $localization[process_member_search::PROCESS . '_not_started'] . '*'); $context->sendMessage('⚠️ *' . $localization[process_membership_search::PROCESS . '_not_started'] . '*');
} }
}); });
} else { } else {
@@ -102,7 +102,7 @@ final class search extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function ($message) use ($context) { ->then(function ($message) use ($context) {
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
@@ -124,7 +124,7 @@ final class search extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -134,7 +134,7 @@ final class search extends core
// Initialized localization // Initialized localization
// Reading from the telegram user buffer // Reading from the telegram user buffer
$context->getUserDataItem(process_member_search::PROCESS) $context->getUserDataItem(process_membership_search::PROCESS)
->then(function ($search) use ($context, $account, $localization) { ->then(function ($search) use ($context, $account, $localization) {
// Readed from the telegram user buffer // Readed from the telegram user buffer
@@ -153,12 +153,12 @@ final class search extends core
$search['distribution'] = $distribution; $search['distribution'] = $distribution;
// Writing to the telegram user buffer // Writing to the telegram user buffer
$context->setUserDataItem(process_member_search::PROCESS, $search) $context->setUserDataItem(process_membership_search::PROCESS, $search)
->then(function () use ($context) { ->then(function () use ($context) {
// Writed into the telegram user buffer // Writed into the telegram user buffer
// Sending the list of found distributions and menu // Sending the list of found distributions and menu
process_member_search::menu($context); process_membership_search::menu($context);
}); });
} else { } else {
// Not initialized the distribution // Not initialized the distribution
@@ -172,25 +172,25 @@ final class search extends core
]; ];
// Writing to the telegram user buffer // Writing to the telegram user buffer
$context->setUserDataItem(process_member_search::PROCESS, $search) $context->setUserDataItem(process_membership_search::PROCESS, $search)
->then(function () use ($context) { ->then(function () use ($context) {
// Writed into the telegram user buffer // Writed into the telegram user buffer
// Sending the list of found distributions and menu // Sending the list of found distributions and menu
process_member_search::menu($context); process_membership_search::menu($context);
}); });
}, },
cancel: function (context $context) { cancel: function (context $context) {
// Sending the list of found distributions and menu // Sending the list of found distributions and menu
process_member_search::menu($context); process_membership_search::menu($context);
}, },
description: $localization[process_member_search::PROCESS . '_distribution_selection_description'] description: $localization[process_membership_search::PROCESS . '_distribution_selection_description']
); );
} else { } else {
// Not found started search process // Not found started search process
// Sending the message // Sending the message
$context->sendMessage('⚠️ *' . $localization[process_member_search::PROCESS . '_not_started'] . '*'); $context->sendMessage('⚠️ *' . $localization[process_membership_search::PROCESS . '_not_started'] . '*');
} }
}); });
} else { } else {
@@ -207,7 +207,7 @@ final class search extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function ($message) use ($context) { ->then(function ($message) use ($context) {
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
@@ -229,7 +229,7 @@ final class search extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -239,7 +239,7 @@ final class search extends core
// Initialized localization // Initialized localization
// Reading from the telegram user buffer // Reading from the telegram user buffer
$context->getUserDataItem(process_member_search::PROCESS) $context->getUserDataItem(process_membership_search::PROCESS)
->then(function ($search) use ($context, $account, $localization) { ->then(function ($search) use ($context, $account, $localization) {
// Readed from the telegram user buffer // Readed from the telegram user buffer
@@ -250,7 +250,7 @@ final class search extends core
$keyboard = [[]]; $keyboard = [[]];
// Initializing the amount of buttons in one row // Initializing the amount of buttons in one row
$amount = MEMBERS_SEARCH_STATUS_ROW_AMOUNT ?? 8; $amount = MEMBERSHIPS_SEARCH_STATUS_ROW_AMOUNT ?? 8;
// Initializing the rows iterator // Initializing the rows iterator
$row = 0; $row = 0;
@@ -258,6 +258,9 @@ final class search extends core
foreach (status::cases() as $status) { foreach (status::cases() as $status) {
// Iterating over statuses // Iterating over statuses
// Skipping the unknown status
if ($status === status::unknown) continue;
// Moving to the next row // Moving to the next row
if (count($keyboard[$row]) >= $amount) ++$row; if (count($keyboard[$row]) >= $amount) ++$row;
@@ -266,14 +269,14 @@ final class search extends core
// Generating the button and writing into the keyboard buffer // Generating the button and writing into the keyboard buffer
$keyboard[$row][] = [ $keyboard[$row][] = [
'text' => $status->emoji() . ' ' . $localization[process_member_search::PROCESS . "_button_status_$status->value"], 'text' => $status->emoji() . ' ' . $localization[process_membership_search::PROCESS . "_button_status_$status->value"],
'callback_data' => process_member_search::PROCESS . "_status_$status->name" 'callback_data' => process_membership_search::PROCESS . "_status_$status->name"
]; ];
} }
// Sending the message // Sending the message
$context->sendMessage( $context->sendMessage(
'👤 *' . $localization[process_member_search::PROCESS . '_status_select_title'] . '*', '👤 *' . $localization[process_membership_search::PROCESS . '_status_select_title'] . '*',
[ [
'reply_markup' => [ 'reply_markup' => [
'inline_keyboard' => $keyboard, 'inline_keyboard' => $keyboard,
@@ -285,7 +288,7 @@ final class search extends core
// Not found started search process // Not found started search process
// Sending the message // Sending the message
$context->sendMessage('⚠️ *' . $localization[process_member_search::PROCESS . '_not_started'] . '*'); $context->sendMessage('⚠️ *' . $localization[process_membership_search::PROCESS . '_not_started'] . '*');
} }
}); });
} else { } else {
@@ -302,7 +305,7 @@ final class search extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function ($message) use ($context) { ->then(function ($message) use ($context) {
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();

View File

@@ -2,15 +2,16 @@
declare(strict_types=1); declare(strict_types=1);
namespace svoboda\svoboder\models\telegram; namespace svoboda\antivertical\models\telegram;
// Files of the project // Files of the project
use svoboda\svoboder\models\core, use svoboda\antivertical\models\core,
svoboda\svoboder\models\account, svoboda\antivertical\models\telegram,
svoboda\svoboder\models\distribution, svoboda\antivertical\models\account,
svoboda\svoboder\models\member, svoboda\antivertical\models\distribution,
svoboda\svoboder\models\telegram\processes\language\select as process_language_select, svoboda\antivertical\models\membership,
svoboda\svoboder\models\enumerations\language; svoboda\antivertical\models\telegram\processes\language\select as process_language_select,
svoboda\antivertical\models\enumerations\language;
// Framework for Telegram // Framework for Telegram
use Zanzara\Context as context, use Zanzara\Context as context,
@@ -23,7 +24,7 @@ use mirzaev\baza\record;
/** /**
* Telegram commands * Telegram commands
* *
* @package svoboda\svoboder\models\telegram * @package svoboda\antivertical\models\telegram
* *
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License * @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy> * @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
@@ -44,7 +45,7 @@ final class commands extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -53,26 +54,26 @@ final class commands extends core
if ($localization) { if ($localization) {
// Initialized localization // Initialized localization
// Initializing the title // Initializing title for the message
$title = '📋 *' . $localization['menu_title'] . '*'; $title = '📡 *' . $localization['menu_title'] . '*';
// Initializing accounts // Initializing accounts
$accounts = '*' . $localization['menu_accounts'] . ':* ' . ((new account)->database->count() ?? 0); $accounts = '*' . $localization['menu_accounts'] . ':* ' . ((new account)->database->count() ?? 0);
// Initializing the member model // Initializing the membership model
$model_member = new member; $model_membership = new membership;
// Searching for members records // Searching for memberships records
$records = $model_member->database->read( $records = $model_membership->database->read(
filter: function (record $member, array $records = []) { filter: function (record $membership, array $records = []) {
if ($member->status === 2) { if ($membership->status === 2) {
// The account joined to the distribution // The account joined to the distribution
foreach ($records as $record) { foreach ($records as $record) {
// Iterating over readed records // Iterating over readed records
if ($record->identifier === $member->identifier) { if ($record->identifier === $membership->identifier) {
// Found a dublicate of the member // Found a dublicate of the membership
// Exit (success) // Exit (success)
return false; return false;
@@ -86,36 +87,79 @@ final class commands extends core
// Exit (success) // Exit (success)
return false; return false;
}, },
amount: MENU_MEMBERS_AMOUNT amount: MENU_MEMBERSHIPS_AMOUNT
) ?? []; ) ?? [];
// Initializing members
$members = '*' . $localization['menu_members'] . ':* ' . count($records);
// Initializing distributions // Initializing distributions
$distributions = '*' . $localization['menu_distributions'] . ':* ' . ((new distribution)->database->count() ?? 0); $distributions = '*' . $localization['menu_distributions'] . ':* ' . ((new distribution)->database->count() ?? 0);
// Initializing amount of planned
$planned = count(account::planned(PHP_INT_MAX));
// Initializing amount of structors
$structors = '*' . $localization['menu_structors'] . ':* ' . count(account::structors(PHP_INT_MAX)) . ($planned > 0 ? " + $planned" : '');
// Initializing amount of autonoms
$autonoms = '*' . $localization['menu_autonoms'] . ':* ' . count(account::autonoms(PHP_INT_MAX));
// Initializing amount of volunteers
$volunteers = '*' . $localization['menu_volunteers'] . ':* ' . count(account::volunteers(PHP_INT_MAX));
// Initializing amount of investors
$investors = '*' . $localization['menu_investors'] . ':* ' . count(account::investors(PHP_INT_MAX));
// Initializing amount of recruiters
$recruiters = '*' . $localization['menu_recruiters'] . ':* ' . count(account::recruiters(PHP_INT_MAX));
// Initializing the data syncronization for the message // Initializing the data syncronization for the message
$syncronization = '⛓️‍💥 ' . $localization['menu_not_syncronized']; $syncronization = '⛓️‍💥 ' . $localization['menu_not_syncronized'];
// Initializing the database syncronization for the message
$database = '⚠️ ' . $localization['menu_warning_database'];
// Initializing channels
$channels = [];
// Initializing chats
$chats = [];
// Initializing projects
$projects = [];
// Initializing events
$events = [];
// Thinking stuff
$thing_about_index = rand(1, 1);
$thing_about_it = $localization['thing_about_it_' . $thing_about_index] ?? null;
$thing_about_author = $localization['thing_about_it_' . $thing_about_index . '_author'] ?? null;
$thinking_stuff = !empty($thing_about_it) ? "\n\n**>\"" . ($thing_about_it . (!empty($thing_about_author) ? "\"\n>\n>_*" . preg_replace('/\./', '\.', $thing_about_author) . '*_||' : '')) : '';
// Sending the message // Sending the message
$context->sendMessage( $context->sendMessage(
<<<TXT <<<TXT
$title $title
$accounts $accounts
$members
$distributions $distributions
$structors
$autonoms
$volunteers
$investors
$recruiters
$syncronization $syncronization
$database$thinking_stuff
TXT, TXT,
[ [
'reply_markup' => [ 'reply_markup' => [
'inline_keyboard' => [ 'inline_keyboard' => [
[ [
[ [
'text' => '🔥 ' . $localization['menu_button_projects'], 'text' => '🔥 ' . $localization['menu_button_channel'],
'callback_data' => 'projects' 'url' => 'https://t.me/antivertical'
], ],
[ [
'text' => '🗺 ' . $localization['menu_button_map'], 'text' => '🗺 ' . $localization['menu_button_map'],
@@ -129,18 +173,40 @@ final class commands extends core
] ]
], ],
[ [
/* [
'text' => '🏗 ' . $localization['menu_button_projects'],
'callback_data' => 'prjects'
], */
[ [
'text' => '🐣 ' . $localization['menu_button_members'], 'text' => '🚸 ' . $localization['menu_button_chats'] . ': ' . count($chats),
'callback_data' => 'members' 'url' => 'https://t.me/chats_antivertical_bot'
],
[
'text' => '📣 ' . $localization['menu_button_channels'] . ': ' . count($channels),
'url' => 'https://t.me/channels_antivertical_bot'
],
],
[
[
'text' => '🏗 ' . $localization['menu_button_projects'] . ': ' . count($projects),
'callback_data' => 'projects'
],
[
'text' => '📅 ' . $localization['menu_button_events'] . ': ' . count($events),
'url' => 'https://t.me/events_antivertical_bot'
],
],
[
[
'text' => '🐣 ' . $localization['menu_button_memberships'],
'callback_data' => 'memberships'
], ],
[ [
'text' => '🏘 ' . $localization['menu_button_distributions'], 'text' => '🏘 ' . $localization['menu_button_distributions'],
'callback_data' => 'distributions' 'callback_data' => 'distributions'
] ]
],
[
[
'text' => '🌏 ' . $localization['menu_button_organisation'],
'callback_data' => 'organisation'
],
] ]
], ],
'disable_notification' => true, 'disable_notification' => true,
@@ -165,7 +231,7 @@ final class commands extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
@@ -189,7 +255,7 @@ final class commands extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing the title // Initializing the title
@@ -197,7 +263,7 @@ final class commands extends core
// Sending the message // Sending the message
$context->sendMessage(<<<TXT $context->sendMessage(<<<TXT
*⚠️ Failed to initialize your Telegram account* *⚠️ Failed to initialize the account*
TXT) TXT)
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// //
@@ -206,7 +272,7 @@ final class commands extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
@@ -215,22 +281,22 @@ final class commands extends core
} }
/** /**
* Members * Memberships
* *
* Responce for the command: "/members" * Responce for the command: "/memberships"
* *
* Sends the members menu * Sends the memberships menu
* *
* @param context $context Request data from Telegram * @param context $context Request data from Telegram
* *
* @return void * @return void
*/ */
public static function members(context $context): void public static function memberships(context $context): void
{ {
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing language // Initializing language
@@ -246,25 +312,25 @@ final class commands extends core
// Initialized localization // Initialized localization
// Initializing the message title // Initializing the message title
$title = '🐣 *' . $localization['members_title'] . '*'; $title = '🐣 *' . $localization['memberships_title'] . '*';
// Initializing the message description // Initializing the message description
$description = $localization['members_description']; $structor = $localization['memberships_structor'];
// Sending the message // Sending the message
$context->sendMessage( $context->sendMessage(
<<<TXT <<<TXT
$title $title
$description $structor
TXT, TXT,
[ [
'reply_markup' => [ 'reply_markup' => [
'inline_keyboard' => [ 'inline_keyboard' => [
[ [
[ [
'text' => '🔎 ' . $localization['members_button_search'], 'text' => '🔎 ' . $localization['memberships_button_search'],
'callback_data' => 'member_search_start' 'callback_data' => 'membership_search_start'
] ]
] ]
], ],
@@ -297,7 +363,7 @@ final class commands extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
@@ -322,7 +388,7 @@ final class commands extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing language // Initializing language
@@ -405,7 +471,7 @@ final class commands extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
@@ -413,6 +479,185 @@ final class commands extends core
} }
} }
/**
* Organisation
*
* Responce for the command: "/organisation"
*
* Sends information about organisation with menu
*
* @param context $context Request data from Telegram
*
* @return void
*/
public static function organisation(context $context): void
{
// Initializing the telegram account
$telegram = $context->get('telegram');
if ($telegram instanceof telegram) {
// Initialized the telegram account
// Initializing the account
$account = $context->get('account');
if ($account instanceof account) {
// Initialized the account
// Initializing language
$language = $context->get('language');
if ($language instanceof language) {
// Initialized language
// Initializing localization
$localization = $context->get('localization');
if ($localization) {
// Initialized localization
// Initializing title for the message
$title = match (rand(1, 3)) {
1 => '🌏 ',
2 => '🌍 ',
3 => '🌎 '
} . '*' . $localization['organisation_title'] . '*';
// Initializing the organisation description for the message
$description = $localization['organisation_description'];
// Initializing the structor description for the message
$structor = $localization['organisation_structor'];
// Initializing the autonom description for the message
$autonom = $localization['organisation_autonom'];
// Initializing the warning for the message
$warning_legal = '⚠️ ' . $localization['organisation_warning_legal'];
// Initializing the warning for the message
$warning_administration = '⚠️ ' . $localization['organisation_warning_administration'];
// Initiailzing the account distribution
$distribution = $account->distribution();
// Declaring the membership keyboard
$keyboard_membership = [];
if ($distribution instanceof distribution) {
// Structor
// Initializing the account distribution localization
$distribution_localization = $distribution->localization(language: $language);
// Initializing the distribution structors
$distribution_structors = count($distribution->structors(PHP_INT_MAX) ?? []);
// Initializing the distribution plannert
$distribution_planners = count($distribution->planners(PHP_INT_MAX) ?? []);
// Initializing the membership keyboard
$keyboard_membership = [
[
[
'text' => '🏘 ' . $localization['organisation_button_structor_distribution'] . ': ' . $distribution_localization->name . ' (' . $distribution_structors . ($distribution_planners > 0 ? ' + ' . $distribution_planners : '') . ')',
'callback_data' => 'distributions'
]
]
];
} else if (false) {
// Autonom
} else if (false) {
// Volunteer
} else {
// Stranger
// Initializing the membership keyboard
$keyboard_membership = [
[
[
'text' => '🧱 ' . $localization['organisation_button_structor'],
'callback_data' => 'distributions'
],
[
'text' => '🐣 ' . $localization['organisation_button_autonom'],
'callback_data' => 'autonom'
]
]
];
}
// Sending the message
$context->sendMessage(
<<<TXT
$title
$description
$structor
$autonom
$warning_legal
$warning_administration
TXT,
[
'reply_markup' => [
'inline_keyboard' => $keyboard_membership,
'remove_keyboard' => true,
'disable_notification' => true
],
'link_preview_options' => [
'is_disabled' => true
]
]
);
} else {
// Not initialized localization
// Sending the message
$context->sendMessage('⚠️ *Failed to initialize localization*')
->then(function (message $message) use ($context) {
// Ending the conversation process
$context->endConversation();
});
}
} else {
// Not initialized language
// Sending the message
$context->sendMessage('⚠️ *Failed to initialize language*')
->then(function (message $message) use ($context) {
// Sended the message
// Ending the conversation process
$context->endConversation();
});
}
} else {
// Not initialized the account
// Sending the message
$context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) {
// Ending the conversation process
$context->endConversation();
});
}
} else {
// Not initialized the telegram account
// Sending the message
$context->sendMessage('⚠️ *Failed to initialize the telegram account*')
->then(function (message $message) use ($context) {
// Ending the conversation process
$context->endConversation();
});
}
}
/** /**
* Account * Account
* *
@@ -426,10 +671,16 @@ final class commands extends core
*/ */
public static function account(context $context): void public static function account(context $context): void
{ {
// Initializing the telegram account
$telegram = $context->get('telegram');
if ($telegram instanceof telegram) {
// Initialized the telegram account
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -441,11 +692,14 @@ final class commands extends core
// Initializing title for the message // Initializing title for the message
$title = '🫵 ' . $localization['account_title']; $title = '🫵 ' . $localization['account_title'];
// Declaring buufer of rows about authorizations // Initializing the account identifier row for the message
$identifier = '*' . $localization['account_identifier'] . ":* $account->identifier \($telegram->identifier\)";
// Declaring the buffer of authorizations
$authorizations = ''; $authorizations = '';
// Initializing rows about authorization // Initializing rows about authorization
foreach ($account->values() as $key => $value) { foreach ($account->record->values() as $key => $value) {
// Iterating over account parameters // Iterating over account parameters
if (str_starts_with($key, 'authorized_')) { if (str_starts_with($key, 'authorized_')) {
@@ -454,35 +708,52 @@ final class commands extends core
// Skipping system authorizations // Skipping system authorizations
if (str_starts_with($key, 'authorized_system_')) continue; if (str_starts_with($key, 'authorized_system_')) continue;
// Writing into buffer of rows about authorizations // Writing into the buffer of authorizations
$authorizations .= ($value ? '✅' : '❎') . ' *' . ($localization["account_$key"] ?? $key) . ':* ' . ($value ? $localization['yes'] : $localization['no']) . "\n"; $authorizations .= ($value ? '✅' : '❎') . ' *' . ($localization["account_$key"] ?? preg_replace('/_/', '\\_', $key)) . ':* ' . ($value ? $localization['yes'] : $localization['no']) . "\n";
} }
} }
// Trimming the last line break character // Trimming the last line break character
$authorizations = trim($authorizations, "\n"); $authorizations = trim($authorizations, "\n");
// Declaring the buffer of system authorizations
$authorizations_system = '';
// Initializing rows about authorization
foreach ($account->record->values() as $key => $value) {
// Iterating over account parameters
if (str_starts_with($key, 'authorized_')) {
// Iterating over account authorizations
if (str_starts_with($key, 'authorized_system_') && $value) {
// System authorization
// Writing into the buffer of system authorizations
$authorizations_system .= ($value ? '🔐' : '🔒') . ' *' . ($localization["account_$key"] ?? preg_replace('/_/', '\\_', $key)) . ':* ' . ($value ? $localization['yes'] : $localization['no']) . "\n";
}
}
}
// Trimming the last line break character
$authorizations_system = trim($authorizations_system, "\n");
// Initializing the line break for the buffer of system authorizations
if (!empty($authorizations_system)) $authorizations_system = "\n\n" . $authorizations_system;
// Initializing the data export for the message // Initializing the data export for the message
$export = '📤 ' . $localization['account_export']; $export = '📤 ' . $localization['account_export'];
// Initializing the data security for the message
$data = $localization['account_data'];
// Initializing the data security repository for the message
$security = '📁 [' . $localization['account_security_repository'] . '](https://git.svoboda.works/mirzaev/security) \([' . $localization['account_security_repository_mirror_github'] . '](https://github.com/mature-woman/security)\)';
// Sending the message // Sending the message
$context->sendMessage( $context->sendMessage(
<<<TXT <<<TXT
$title $title
$authorizations $identifier
$authorizations$authorizations_system
$export $export
$data
$security
TXT, TXT,
[ [
'reply_markup' => [ 'reply_markup' => [
@@ -516,7 +787,17 @@ final class commands extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) {
// Ending the conversation process
$context->endConversation();
});
}
} else {
// Not initialized the telegram account
// Sending the message
$context->sendMessage('⚠️ *Failed to initialize the telegram account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
@@ -540,7 +821,7 @@ final class commands extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing language // Initializing language
@@ -590,7 +871,7 @@ final class commands extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -616,7 +897,7 @@ final class commands extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -670,7 +951,7 @@ final class commands extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
@@ -694,7 +975,7 @@ final class commands extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -772,7 +1053,7 @@ final class commands extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
@@ -796,7 +1077,7 @@ final class commands extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -827,7 +1108,7 @@ final class commands extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();

View File

@@ -2,13 +2,13 @@
declare(strict_types=1); declare(strict_types=1);
namespace svoboda\svoboder\models\telegram; namespace svoboda\antivertical\models\telegram;
// Files of the project // Files of the project
use svoboda\svoboder\models\core, use svoboda\antivertical\models\core,
svoboda\svoboder\models\account, svoboda\antivertical\models\account,
svoboda\svoboder\models\distribution as model, svoboda\antivertical\models\distribution as model,
svoboda\svoboder\models\enumerations\language; svoboda\antivertical\models\enumerations\language;
// Framework for Telegram // Framework for Telegram
use Zanzara\Context as context, use Zanzara\Context as context,
@@ -20,7 +20,7 @@ use mirzaev\baza\record;
/** /**
* Telegram distribution * Telegram distribution
* *
* @package svoboda\svoboder\models\telegram * @package svoboda\antivertical\models\telegram
* *
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License * @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy> * @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
@@ -31,7 +31,7 @@ final class distribution extends core
* Distributions * Distributions
* *
* Sends a message with a list of distributions to * Sends a message with a list of distributions to
* which the account is a creator, member, planned or volunteer * which the account is a creator, membership, planned or volunteer
* *
* @param context $context Request data from Telegram * @param context $context Request data from Telegram
* *
@@ -42,7 +42,7 @@ final class distribution extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -60,11 +60,11 @@ final class distribution extends core
// Initializing accounts // Initializing accounts
$accounts = '*' . $localization['menu_accounts'] . ':* ' . ($model_account->database->count() ?? 0); $accounts = '*' . $localization['menu_accounts'] . ':* ' . ($model_account->database->count() ?? 0);
// Initializing members // Initializing memberships
$members = '*' . $localization['menu_members'] . ':* ' . 0; $memberships = '*' . $localization['menu_memberships'] . ':* ' . 0;
// Initializing trusted members // Initializing trusted memberships
$members_trusted = '*' . $localization['menu_members_trusted'] . ':* ' . 0; $memberships_trusted = '*' . $localization['menu_memberships_trusted'] . ':* ' . 0;
// Initializing planners // Initializing planners
$planners = '*' . $localization['menu_planners'] . ':* ' . 0; $planners = '*' . $localization['menu_planners'] . ':* ' . 0;
@@ -91,8 +91,8 @@ final class distribution extends core
$accounts $accounts
$members $memberships
$members_trusted $memberships_trusted
$planners $planners
$volunteers $volunteers
@@ -125,7 +125,7 @@ final class distribution extends core
'callback_data' => 'prjects' 'callback_data' => 'prjects'
], */ ], */
[ [
'text' => '🐣 ' . $localization['menu_button_members'], 'text' => '🐣 ' . $localization['menu_button_memberships'],
'callback_data' => 'message' 'callback_data' => 'message'
], ],
[ [
@@ -138,8 +138,7 @@ final class distribution extends core
'remove_keyboard' => true 'remove_keyboard' => true
], ],
] ]
) )->then(function (message $message) use ($context) {
->then(function (message $message) use ($context) {
// Sended the message // Sended the message
}); });
} else { } else {
@@ -156,7 +155,7 @@ final class distribution extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();

View File

@@ -2,12 +2,13 @@
declare(strict_types=1); declare(strict_types=1);
namespace svoboda\svoboder\models\telegram; namespace svoboda\antivertical\models\telegram;
// Files of the project // Files of the project
use svoboda\svoboder\models\core, use svoboda\antivertical\models\core,
svoboda\svoboder\models\account, svoboda\antivertical\models\account,
svoboda\svoboder\models\enumerations\language; svoboda\antivertical\models\telegram,
svoboda\antivertical\models\enumerations\language;
// Framework for Telegram // Framework for Telegram
use Zanzara\Context as context, use Zanzara\Context as context,
@@ -23,13 +24,59 @@ use Error as error;
/** /**
* Telegram middlewares * Telegram middlewares
* *
* @package svoboda\svoboder\models\telegram * @package svoboda\antivertical\models\telegram
* *
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License * @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy> * @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
*/ */
final class middlewares extends core final class middlewares extends core
{ {
/**
* Telegram account (middleware)
*
* Initialize or registrate the account and write it to the `telegram` variable inside the `$context`
*
* @param context $context
* @param node $next
*
* @return void
*/
public static function telegram(context $context, node $next): void
{
// Is the process stopped?
if ($context->get('stop')) return;
// Initializing the telegram account
$telegram = $context->getEffectiveUser();
// Initializing the telegram model
$model = new telegram();
// Initializing the telegram accont instance
$instance = $model->initialize($telegram);
if ($instance instanceof telegram) {
// Initialized the telegram account
// Writing the account into the context variable
$context->set('telegram', $instance);
// Continuation of the process
$next($context);
} else {
// Not initialized the account
// Sending the message
$context->sendMessage('⚠️ *Failed to initialize the telegram account*')
->then(function (message $message) use ($context) {
// Sended the message
// Ending the conversation process
$context->endConversation();
});
}
}
/** /**
* Account (middleware) * Account (middleware)
* *
@@ -46,17 +93,22 @@ final class middlewares extends core
if ($context->get('stop')) return; if ($context->get('stop')) return;
// Initializing the telegram account // Initializing the telegram account
$telegram = $context->getEffectiveUser(); $telegram = $context->get('telegram');
if ($telegram instanceof telegram) {
// Initialized the account
// Initializing the account model
$model = new account();
// Initializing the account // Initializing the account
/* $account = new account()->initialize($telegram); */ $instance = $model->initialize($telegram);
$account = (new account())->initialize($telegram);
if ($account instanceof record) { if ($instance instanceof account) {
// Initialized the account // Initialized the account
// Writing the account into the context variable // Writing the account into the context variable
$context->set('account', $account); $context->set('account', $instance);
// Continuation of the process // Continuation of the process
$next($context); $next($context);
@@ -64,7 +116,19 @@ final class middlewares extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) {
// Sended the message
// Ending the conversation process
$context->endConversation();
});
}
} else {
// Not initialized the telegram account
// Sending the message
$context->sendMessage('⚠️ *Failed to initialize the telegram account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -92,7 +156,7 @@ final class middlewares extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
if ($account->language) { if ($account->language) {
@@ -120,7 +184,7 @@ final class middlewares extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -148,7 +212,7 @@ final class middlewares extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing the language // Initializing the language
@@ -213,7 +277,7 @@ final class middlewares extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -241,7 +305,7 @@ final class middlewares extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
if ($account->authorized_system) { if ($account->authorized_system) {
@@ -286,7 +350,7 @@ final class middlewares extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -314,7 +378,7 @@ final class middlewares extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
if ($account->authorized_contact) { if ($account->authorized_contact) {
@@ -359,7 +423,7 @@ final class middlewares extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -370,16 +434,16 @@ final class middlewares extends core
} }
/** /**
* Join (middleware) * Membership (middleware)
* *
* Check the account for access to join to distributions * Check the account for access to memberships
* *
* @param context $context * @param context $context
* @param node $next * @param node $next
* *
* @return void * @return void
*/ */
public static function join(context $context, node $next): void public static function memberships(context $context, node $next): void
{ {
// Is the process stopped? // Is the process stopped?
if ($context->get('stop')) return; if ($context->get('stop')) return;
@@ -387,7 +451,7 @@ final class middlewares extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -396,16 +460,16 @@ final class middlewares extends core
if ($localization) { if ($localization) {
// Initialized localization // Initialized localization
if ($account->authorized_joins) { if ($account->authorized_memberships) {
// Authorized the account to joint to distributions // Authorized the account to create memberships
// Continuation of the process // Continuation of the process
$next($context); $next($context);
} else { } else {
// Not authorized the account to joint to distributions // Not authorized the account to create memberships
// Sending the message // Sending the message
$context->sendMessage('⛔ *' . $localization['not_authorized_joins'] . '*') $context->sendMessage('⛔ *' . $localization['not_authorized_memberships'] . '*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -432,7 +496,7 @@ final class middlewares extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -460,7 +524,7 @@ final class middlewares extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
if ($account->authorized_settings) { if ($account->authorized_settings) {
@@ -505,7 +569,7 @@ final class middlewares extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -533,7 +597,7 @@ final class middlewares extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
if ($account->authorized_system_settings) { if ($account->authorized_system_settings) {
@@ -578,7 +642,7 @@ final class middlewares extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -606,7 +670,7 @@ final class middlewares extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
if ($account->authorized_system_distributions) { if ($account->authorized_system_distributions) {
@@ -651,7 +715,7 @@ final class middlewares extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message

View File

@@ -2,15 +2,15 @@
declare(strict_types=1); declare(strict_types=1);
namespace svoboda\svoboder\models\telegram\processes\account\localization; namespace svoboda\antivertical\models\telegram\processes\account\localization;
// Files of the project // Files of the project
use svoboda\svoboder\models\core, use svoboda\antivertical\models\core,
svoboda\svoboder\models\account, svoboda\antivertical\models\account,
svoboda\svoboder\models\telegram\account as telegram_account, svoboda\antivertical\models\telegram\account as telegram_account,
svoboda\svoboder\models\telegram\buttons\account\localization\create as button_account_localization_create, svoboda\antivertical\models\telegram\buttons\account\localization\create as button_account_localization_create,
svoboda\svoboder\models\enumerations\language, svoboda\antivertical\models\enumerations\language,
svoboda\svoboder\models\telegram\commands; svoboda\antivertical\models\telegram\commands;
// Framework for Telegram // Framework for Telegram
use Zanzara\Context as context, use Zanzara\Context as context,
@@ -25,7 +25,7 @@ use Error as error;
/** /**
* Account localization create process * Account localization create process
* *
* @package svoboda\svoboder\models\telegram\processes\account\localization * @package svoboda\antivertical\models\telegram\processes\account\localization
* *
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License * @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy> * @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
@@ -53,7 +53,7 @@ final class create extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing language // Initializing language
@@ -179,7 +179,7 @@ final class create extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
@@ -202,7 +202,7 @@ final class create extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -268,7 +268,7 @@ final class create extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -293,7 +293,7 @@ final class create extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing language // Initializing language
@@ -408,7 +408,7 @@ final class create extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -433,7 +433,7 @@ final class create extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing language // Initializing language
@@ -558,7 +558,7 @@ final class create extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -583,7 +583,7 @@ final class create extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing language // Initializing language
@@ -683,7 +683,7 @@ final class create extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -707,7 +707,7 @@ final class create extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -899,7 +899,7 @@ final class create extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message

View File

@@ -2,15 +2,15 @@
declare(strict_types=1); declare(strict_types=1);
namespace svoboda\svoboder\models\telegram\processes\account\localization; namespace svoboda\antivertical\models\telegram\processes\account\localization;
// Files of the project // Files of the project
use svoboda\svoboder\models\core, use svoboda\antivertical\models\core,
svoboda\svoboder\models\account, svoboda\antivertical\models\account,
svoboda\svoboder\models\telegram\account as telegram_account, svoboda\antivertical\models\telegram\account as telegram_account,
svoboda\svoboder\models\telegram\buttons\account\localization\update as button_account_localization_update, svoboda\antivertical\models\telegram\buttons\account\localization\update as button_account_localization_update,
svoboda\svoboder\models\enumerations\language, svoboda\antivertical\models\enumerations\language,
svoboda\svoboder\models\telegram\commands; svoboda\antivertical\models\telegram\commands;
// Framework for Telegram // Framework for Telegram
use Zanzara\Context as context, use Zanzara\Context as context,
@@ -28,7 +28,7 @@ use Error as error;
/** /**
* Account localization update process * Account localization update process
* *
* @package svoboda\svoboder\models\telegram\processes\account\localization * @package svoboda\antivertical\models\telegram\processes\account\localization
* *
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License * @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy> * @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
@@ -57,7 +57,7 @@ final class update extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing language // Initializing language
@@ -162,7 +162,7 @@ final class update extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
@@ -185,7 +185,7 @@ final class update extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -251,7 +251,7 @@ final class update extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -276,7 +276,7 @@ final class update extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing language // Initializing language
@@ -394,7 +394,7 @@ final class update extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -419,7 +419,7 @@ final class update extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing language // Initializing language
@@ -548,7 +548,7 @@ final class update extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -572,7 +572,7 @@ final class update extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -764,7 +764,7 @@ final class update extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message

View File

@@ -2,14 +2,15 @@
declare(strict_types=1); declare(strict_types=1);
namespace svoboda\svoboder\models\telegram\processes\distribution; namespace svoboda\antivertical\models\telegram\processes\distribution;
// Files of the project // Files of the project
use svoboda\svoboder\models\core, use svoboda\antivertical\models\core,
svoboda\svoboder\models\distribution, svoboda\antivertical\models\account,
svoboda\svoboder\models\enumerations\language, svoboda\antivertical\models\distribution,
svoboda\svoboder\models\telegram\commands, svoboda\antivertical\models\enumerations\language,
svoboda\svoboder\models\telegram\buttons\distribution\declaration as button_distribution_declaration; svoboda\antivertical\models\telegram\commands,
svoboda\antivertical\models\telegram\buttons\distribution\declaration as button_distribution_declaration;
// Framework for Telegram // Framework for Telegram
use Zanzara\Context as context, use Zanzara\Context as context,
@@ -24,7 +25,7 @@ use Error as error;
/** /**
* Distribution declaration process * Distribution declaration process
* *
* @package svoboda\svoboder\models\telegram\processes\distribution * @package svoboda\antivertical\models\telegram\processes\distribution
* *
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License * @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy> * @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
@@ -52,7 +53,7 @@ final class declaration extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing language // Initializing language
@@ -136,7 +137,7 @@ final class declaration extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
@@ -159,7 +160,7 @@ final class declaration extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -225,7 +226,7 @@ final class declaration extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -250,7 +251,7 @@ final class declaration extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing language // Initializing language
@@ -387,7 +388,7 @@ final class declaration extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -412,7 +413,7 @@ final class declaration extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing language // Initializing language
@@ -541,7 +542,7 @@ final class declaration extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function ($message) use ($context) { ->then(function ($message) use ($context) {
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
@@ -564,7 +565,7 @@ final class declaration extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing language // Initializing language
@@ -658,7 +659,7 @@ final class declaration extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
@@ -680,7 +681,7 @@ final class declaration extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -888,7 +889,7 @@ final class declaration extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
@@ -910,7 +911,7 @@ final class declaration extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -1109,7 +1110,7 @@ final class declaration extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();

View File

@@ -2,12 +2,12 @@
declare(strict_types=1); declare(strict_types=1);
namespace svoboda\svoboder\models\telegram\processes\distribution; namespace svoboda\antivertical\models\telegram\processes\distribution;
// Files of the project // Files of the project
use svoboda\svoboder\models\core, use svoboda\antivertical\models\core,
svoboda\svoboder\models\enumerations\language, svoboda\antivertical\models\enumerations\language,
svoboda\svoboder\models\telegram\commands; svoboda\antivertical\models\telegram\commands;
// Framework for Telegram // Framework for Telegram
use Zanzara\Context as context, use Zanzara\Context as context,
@@ -19,7 +19,7 @@ use mirzaev\baza\record;
/** /**
* Distribution localization process * Distribution localization process
* *
* @package svoboda\svoboder\models\telegram\processes\distribution * @package svoboda\antivertical\models\telegram\processes\distribution
* *
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License * @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy> * @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
@@ -40,7 +40,7 @@ final class localization extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing language // Initializing language
@@ -130,7 +130,7 @@ final class localization extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
@@ -152,7 +152,7 @@ final class localization extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing language // Initializing language
@@ -227,7 +227,7 @@ final class localization extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();

View File

@@ -2,17 +2,17 @@
declare(strict_types=1); declare(strict_types=1);
namespace svoboda\svoboder\models\telegram\processes\distribution; namespace svoboda\antivertical\models\telegram\processes\distribution;
// Files of the project // Files of the project
use svoboda\svoboder\models\core, use svoboda\antivertical\models\core,
svoboda\svoboder\models\account, svoboda\antivertical\models\account,
svoboda\svoboder\models\distribution, svoboda\antivertical\models\distribution,
svoboda\svoboder\models\member, svoboda\antivertical\models\membership,
svoboda\svoboder\models\telegram\buttons\distribution\search as button_distribution_search, svoboda\antivertical\models\telegram\buttons\distribution\search as button_distribution_search,
svoboda\svoboder\models\enumerations\language, svoboda\antivertical\models\enumerations\language,
svoboda\svoboder\models\telegram\commands, svoboda\antivertical\models\telegram\commands,
svoboda\svoboder\models\traits\coordinates; svoboda\antivertical\models\traits\coordinates;
// Event-driven library for PHP // Event-driven library for PHP
use function React\Async\await; use function React\Async\await;
@@ -31,7 +31,7 @@ use Exception as exception,
/** /**
* Distribution search process * Distribution search process
* *
* @package svoboda\svoboder\models\telegram\processes\distribution * @package svoboda\antivertical\models\telegram\processes\distribution
* *
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License * @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy> * @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
@@ -63,7 +63,7 @@ final class search extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing language // Initializing language
@@ -152,7 +152,7 @@ final class search extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -176,7 +176,7 @@ final class search extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -236,7 +236,7 @@ final class search extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -260,7 +260,7 @@ final class search extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing language // Initializing language
@@ -445,8 +445,8 @@ final class search extends core
if (count($distributions) > 0) { if (count($distributions) > 0) {
// Initialized distributions // Initialized distributions
// Initializing the member model // Initializing the membership model
$model_member = new member; $model_membership = new membership;
foreach ($distributions as $distribution) { foreach ($distributions as $distribution) {
// Iterating over found distributions // Iterating over found distributions
@@ -545,25 +545,25 @@ final class search extends core
}); });
} }
// Searching for the member record // Searching for the membership record
$member = $model_member->database->read( $membership = $model_membership->database->read(
filter: fn(record $member) => $member->distribution === $distribution->identifier && $member->account === $account->identifier, filter: fn(record $membership) => $membership->distribution === $distribution->identifier && $membership->account === $account->identifier,
amount: 1 amount: 1
)[0] ?? null; )[0] ?? null;
// Searching for the another member records // Searching for the another membership records
$another = $model_member->database->read( $another = $model_membership->database->read(
filter: fn(record $member) => $member->distribution !== $distribution->identifier && $member->account === $account->identifier && $member->status !== 0, filter: fn(record $membership) => $membership->distribution !== $distribution->identifier && $membership->account === $account->identifier && $membership->status !== 0,
amount: 1 amount: 1
)[0] ?? null; )[0] ?? null;
// Initializing buffer of keyboard // Initializing buffer of keyboard
$keyboard = static::keyboard( $keyboard = static::keyboard(
distribution: $distribution, distribution: $distribution,
member: $another ?? $member, membership: $another ?? $membership,
localization: $localization, localization: $localization,
messages: $account->authorized_messages === 1, messages: $account->authorized_messages === 1,
joins: $account->authorized_joins === 1, memberships: $account->authorized_memberships === 1,
); );
/* if ($account->authorized_system_distributions) { /* if ($account->authorized_system_distributions) {
@@ -734,7 +734,7 @@ final class search extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -758,7 +758,7 @@ final class search extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -950,7 +950,7 @@ final class search extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -974,7 +974,7 @@ final class search extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -1175,7 +1175,7 @@ final class search extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
@@ -1197,7 +1197,7 @@ final class search extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -1375,7 +1375,7 @@ final class search extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -1409,23 +1409,23 @@ final class search extends core
// Initializing accepting status for the message // Initializing accepting status for the message
$recognized = $recognized ? '🪽' : ''; $recognized = $recognized ? '🪽' : '';
// Initializing the member model // Initializing the membership model
$model_member = new member; $model_membership = new membership;
// Searching for members records // Searching for memberships records
$members = $model_member->database->read( $memberships = $model_membership->database->read(
filter: fn(record $record) => $record->distribution === $distribution->identifier, filter: fn(record $record) => $record->distribution === $distribution->identifier,
amount: DISTRIBUTIONS_SEARCH_MEMBERS_AMOUNT amount: DISTRIBUTIONS_SEARCH_MEMBERSHIPS_AMOUNT
) ?? []; ) ?? [];
// Initializing amount of recognized members for the message // Initializing amount of recognized memberships for the message
$members_recognized = '*' . $localization[static::PROCESS . '_recognized'] . ':* ' . 0; $memberships_recognized = '*' . $localization[static::PROCESS . '_recognized'] . ':* ' . 0;
// Initializing amount of members for the message // Initializing amount of memberships for the message
$amount = '*' . $localization[static::PROCESS . '_members'] . ':* ' . count(array_filter($members, fn(record $member) => $member?->status === 2)); $amount = '*' . $localization[static::PROCESS . '_memberships'] . ':* ' . count(array_filter($memberships, fn(record $membership) => $membership?->status === 2));
// Initializing planners // Initializing planners
$planners = '*' . $localization[static::PROCESS . '_planners'] . ':* ' . count(array_filter($members, fn(record $member) => $member?->status === 1)); $planners = '*' . $localization[static::PROCESS . '_planners'] . ':* ' . count(array_filter($memberships, fn(record $membership) => $membership?->status === 1));
// Initializing volunteers // Initializing volunteers
$volunteers = '*' . $localization[static::PROCESS . '_volunteers'] . ':* ' . 0; $volunteers = '*' . $localization[static::PROCESS . '_volunteers'] . ':* ' . 0;
@@ -1441,7 +1441,7 @@ final class search extends core
$distribution->identifier *$name* $recognized $distribution->identifier *$name* $recognized
$amount $amount
$members_recognized $memberships_recognized
$planners $planners
$volunteers $volunteers
@@ -1457,21 +1457,21 @@ final class search extends core
* Generate inline keyboard for the distribution * Generate inline keyboard for the distribution
* *
* @param record $distribution The distribution * @param record $distribution The distribution
* @param record|null $member The distribution member * @param record|null $membership The distribution membership
* @param array $localization The account localization * @param array $localization The account localization
* @param bool $planned Is the account planned to join to the distribution? * @param bool $planned Is the account planned to join to the distribution?
* @param bool $joined Is the account joined to the distribution? * @param bool $joined Is the account joined to the distribution?
* @param bool $messages Generate messages buttons? (is the account allowed to send messages?) * @param bool $messages Generate messages buttons? (is the account allowed to send messages?)
* @param bool $joins Generate joining buttons? (is the account allowed to join?) * @param bool $memberships Generate memberships buttons? (is the account allowed to join?)
* *
* @return array Generated inline keyboard * @return array Generated inline keyboard
*/ */
public static function keyboard( public static function keyboard(
record $distribution, record $distribution,
?record $member, ?record $membership,
array $localization, array $localization,
bool $messages = false, bool $messages = false,
bool $joins = false, bool $memberships = false,
): array { ): array {
// Initializing the buffer of keyboard // Initializing the buffer of keyboard
$keyboard = [ $keyboard = [
@@ -1494,8 +1494,8 @@ final class search extends core
'callback_data' => static::PROCESS . '_volunteers' 'callback_data' => static::PROCESS . '_volunteers'
], ],
[ [
'text' => '🐣 ' . $localization[static::PROCESS . '_button_members'], 'text' => '🐣 ' . $localization[static::PROCESS . '_button_memberships'],
'callback_data' => static::PROCESS . '_members' 'callback_data' => static::PROCESS . '_memberships'
] ]
] ]
] ]
@@ -1506,17 +1506,17 @@ final class search extends core
], ],
], */; ], */;
if ($joins) { if ($memberships) {
// Requested joining buttons // Requested memberships buttons
if ($member instanceof record) { if ($membership instanceof record) {
// Initialized the member // Initialized the membership
if ($member->distribution === $distribution->identifier) { if ($membership->distribution === $distribution->identifier) {
// The member distribution matched the distribution // The membership distribution matched the distribution
if ($member->status === 2) { if ($membership->status === 2) {
// The member was joined to the distribution // The membership was joined to the distribution
// Writing the joining buttons into the buffer of keyboard // Writing the joining buttons into the buffer of keyboard
$keyboard[] = [ $keyboard[] = [
@@ -1525,8 +1525,8 @@ final class search extends core
'callback_data' => static::PROCESS . '_leave' 'callback_data' => static::PROCESS . '_leave'
] ]
]; ];
} else if ($member->status === 1) { } else if ($membership->status === 1) {
// The member was planning to join to the distribution // The membership was planning to join to the distribution
// Writing the joining buttons into the buffer of keyboard // Writing the joining buttons into the buffer of keyboard
$keyboard[] = [ $keyboard[] = [
@@ -1540,7 +1540,7 @@ final class search extends core
] ]
]; ];
} else { } else {
// The member status is unknown // The membership status is unknown
// Writing the joining buttons into the buffer of keyboard // Writing the joining buttons into the buffer of keyboard
$keyboard[] = [ $keyboard[] = [
@@ -1555,16 +1555,16 @@ final class search extends core
]; ];
} }
} else { } else {
// The member distribution not matched the distribution // The membership distribution not matched the distribution
if ($member->status === 2) { if ($membership->status === 2) {
// The member was joined to the distribution // The membership was joined to the distribution
} else if ($member->status === 1) { } else if ($membership->status === 1) {
// The member was planning to join to the distribution // The membership was planning to join to the distribution
} else { } else {
// The member status is unknown // The membership status is unknown
// Writing the joining buttons into the buffer of keyboard // Writing the joining buttons into the buffer of keyboard
$keyboard[] = [ $keyboard[] = [
@@ -1580,7 +1580,7 @@ final class search extends core
} }
} }
} else { } else {
// Not initialized the member // Not initialized the membership
// Writing the joining buttons into the buffer of keyboard // Writing the joining buttons into the buffer of keyboard
$keyboard[] = [ $keyboard[] = [

View File

@@ -2,17 +2,17 @@
declare(strict_types=1); declare(strict_types=1);
namespace svoboda\svoboder\models\telegram\processes\distribution; namespace svoboda\antivertical\models\telegram\processes\distribution;
// Files of the project // Files of the project
use svoboda\svoboder\models\core, use svoboda\antivertical\models\core,
svoboda\svoboder\models\account, svoboda\antivertical\models\account,
svoboda\svoboder\models\distribution, svoboda\antivertical\models\distribution,
svoboda\svoboder\models\member, svoboda\antivertical\models\membership,
svoboda\svoboder\models\telegram\buttons\distribution\select as button_distribution_select, svoboda\antivertical\models\telegram\buttons\distribution\select as button_distribution_select,
svoboda\svoboder\models\enumerations\language, svoboda\antivertical\models\enumerations\language,
svoboda\svoboder\models\telegram\commands, svoboda\antivertical\models\telegram\commands,
svoboda\svoboder\models\traits\coordinates; svoboda\antivertical\models\traits\coordinates;
// Event-driven library for PHP // Event-driven library for PHP
use function React\Async\await; use function React\Async\await;
@@ -31,7 +31,7 @@ use Exception as exception,
/** /**
* Distribution select process * Distribution select process
* *
* @package svoboda\svoboder\models\telegram\processes\distribution * @package svoboda\antivertical\models\telegram\processes\distribution
* *
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License * @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy> * @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
@@ -67,7 +67,7 @@ final class select extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing language // Initializing language
@@ -173,7 +173,7 @@ final class select extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -198,7 +198,7 @@ final class select extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing language // Initializing language
@@ -260,7 +260,7 @@ final class select extends core
// Searching for the distribution localizations records // Searching for the distribution localizations records
$distribution_localizations = $model_distribution->localization->database->read( $distribution_localizations = $model_distribution->localization->database->read(
filter: fn(record $localization) => $localization->distribution === $distribution['distribution']->identifier, filter: fn(record $localization) => $localization->distribution === $distribution['distribution']->identifier,
amount: MEMBERS_SEARCH_DISTRIBUTION_LOCALIZATIONS_AMOUNT amount: MEMBERSHIPS_SEARCH_DISTRIBUTION_LOCALIZATIONS_AMOUNT
); );
if (count($distribution_localizations) > 0) { if (count($distribution_localizations) > 0) {
@@ -399,7 +399,7 @@ final class select extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -424,7 +424,7 @@ final class select extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -481,7 +481,7 @@ final class select extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -506,7 +506,7 @@ final class select extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -563,7 +563,7 @@ final class select extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -587,7 +587,7 @@ final class select extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing language // Initializing language
@@ -772,8 +772,8 @@ final class select extends core
if (count($distributions) > 0) { if (count($distributions) > 0) {
// Initialized distributions // Initialized distributions
// Initializing the member model // Initializing the membership model
$model_member = new member; $model_membership = new membership;
foreach ($distributions as $distribution) { foreach ($distributions as $distribution) {
// Iterating over found distributions // Iterating over found distributions
@@ -872,9 +872,9 @@ final class select extends core
}); });
} }
// Search for the member record // Search for the membership record
$member = $model_member->database->read( $membership = $model_membership->database->read(
filter: fn(record $member) => $member->distribution === $distribution->identifier && $member->account === $account->identifier, filter: fn(record $membership) => $membership->distribution === $distribution->identifier && $membership->account === $account->identifier,
amount: 1 amount: 1
)[0] ?? null; )[0] ?? null;
@@ -1048,7 +1048,7 @@ final class select extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -1072,7 +1072,7 @@ final class select extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -1264,7 +1264,7 @@ final class select extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -1288,7 +1288,7 @@ final class select extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -1489,7 +1489,7 @@ final class select extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
@@ -1511,7 +1511,7 @@ final class select extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -1689,7 +1689,7 @@ final class select extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message

View File

@@ -2,11 +2,11 @@
declare(strict_types=1); declare(strict_types=1);
namespace svoboda\svoboder\models\telegram\processes\language; namespace svoboda\antivertical\models\telegram\processes\language;
// Files of the project // Files of the project
use svoboda\svoboder\models\core, use svoboda\antivertical\models\core,
svoboda\svoboder\models\enumerations\language; svoboda\antivertical\models\enumerations\language;
// Framework for Telegram // Framework for Telegram
use Zanzara\Context as context, use Zanzara\Context as context,
@@ -18,7 +18,7 @@ use mirzaev\baza\record;
/** /**
* Telegram language select * Telegram language select
* *
* @package svoboda\svoboder\models\telegram\processes\language * @package svoboda\antivertical\models\telegram\processes\language
* *
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License * @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy> * @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
@@ -43,7 +43,7 @@ final class select extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing language // Initializing language
@@ -96,7 +96,7 @@ final class select extends core
$keyboard[$row === 0 && empty($keyboard[0]) ? 0 : ++$row] = [ $keyboard[$row === 0 && empty($keyboard[0]) ? 0 : ++$row] = [
[ [
'text' => '🗂 ' . $localization['select_language_button_add'], 'text' => '🗂 ' . $localization['select_language_button_add'],
'url' => 'https://git.svoboda.works/svoboda/svoboder/src/branch/stable/svoboda/svoboder/system/localizations' 'url' => 'https://git.svoboda.works/svoboda/antivertical/src/branch/stable/svoboda/antivertical/system/localizations'
] ]
]; ];
@@ -138,7 +138,7 @@ final class select extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message

View File

@@ -2,18 +2,18 @@
declare(strict_types=1); declare(strict_types=1);
namespace svoboda\svoboder\models\telegram\processes\member; namespace svoboda\antivertical\models\telegram\processes\membership;
// Files of the project // Files of the project
use svoboda\svoboder\models\core, use svoboda\antivertical\models\core,
svoboda\svoboder\models\account, svoboda\antivertical\models\account,
svoboda\svoboder\models\member, svoboda\antivertical\models\membership,
svoboda\svoboder\models\distribution, svoboda\antivertical\models\distribution,
svoboda\svoboder\models\telegram\buttons\member\search as button_member_search, svoboda\antivertical\models\telegram\buttons\membership\search as button_membership_search,
svoboda\svoboder\models\enumerations\member\status, svoboda\antivertical\models\enumerations\membership\status,
svoboda\svoboder\models\enumerations\language, svoboda\antivertical\models\enumerations\language,
svoboda\svoboder\models\telegram\commands, svoboda\antivertical\models\telegram\commands,
svoboda\svoboder\models\traits\coordinates; svoboda\antivertical\models\traits\coordinates;
// Event-driven library for PHP // Event-driven library for PHP
use function React\Async\await; use function React\Async\await;
@@ -30,9 +30,9 @@ use Exception as exception,
Error as error; Error as error;
/** /**
* Member search process * Membership search process
* *
* @package svoboda\svoboder\models\telegram\processes\member * @package svoboda\antivertical\models\telegram\processes\membership
* *
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License * @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy> * @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
@@ -48,12 +48,12 @@ final class search extends core
* *
* @var const string PROCESS Name of the process in the telegram user buffer * @var const string PROCESS Name of the process in the telegram user buffer
*/ */
public const string PROCESS = 'member_search'; public const string PROCESS = 'membership_search';
/** /**
* Start * Start
* *
* Starting the member search process * Starting the membership search process
* *
* @param context $context Request data from Telegram * @param context $context Request data from Telegram
* *
@@ -64,7 +64,7 @@ final class search extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing language // Initializing language
@@ -123,7 +123,7 @@ final class search extends core
// Searching for the distribution localizations records // Searching for the distribution localizations records
$distribution_localizations = $model_distribution->localization->database->read( $distribution_localizations = $model_distribution->localization->database->read(
filter: fn(record $localization) => $localization->distribution === $distribution['distribution']->identifier, filter: fn(record $localization) => $localization->distribution === $distribution['distribution']->identifier,
amount: MEMBERS_SEARCH_DISTRIBUTION_LOCALIZATIONS_AMOUNT amount: MEMBERSHIPS_SEARCH_DISTRIBUTION_LOCALIZATIONS_AMOUNT
); );
if (count($distribution_localizations) > 0) { if (count($distribution_localizations) > 0) {
@@ -221,20 +221,20 @@ final class search extends core
->then(function () use ($context) { ->then(function () use ($context) {
// Writing into the telegram user buffer // Writing into the telegram user buffer
// Sending the list of found member and menu // Sending the list of found membership and menu
static::menu($context); static::menu($context);
}); });
} else { } else {
// Not initialized the distribution // Not initialized the distribution
// Sending the list of found member and menu // Sending the list of found membership and menu
static::menu($context); static::menu($context);
} }
}); });
} else { } else {
// Not found started search process // Not found started search process
// Initializing the member search buffer // Initializing the membership search buffer
$search = [ $search = [
'name' => null, 'name' => null,
'distribution' => $distribution, 'distribution' => $distribution,
@@ -252,7 +252,7 @@ final class search extends core
->then(function (message $message) use ($context, $account, $localization) { ->then(function (message $message) use ($context, $account, $localization) {
// Sended the message // Sended the message
// Sending the list of found member and menu // Sending the list of found membership and menu
static::menu($context); static::menu($context);
}); });
}); });
@@ -286,7 +286,7 @@ final class search extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -299,7 +299,7 @@ final class search extends core
/** /**
* End * End
* *
* Ending the member search process * Ending the membership search process
* *
* @param context $context Request data from Telegram * @param context $context Request data from Telegram
* *
@@ -310,7 +310,7 @@ final class search extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -340,8 +340,8 @@ final class search extends core
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
// Sending the members menu // Sending the memberships menu
commands::members($context); commands::memberships($context);
}); });
}); });
} else { } else {
@@ -350,8 +350,8 @@ final class search extends core
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
// Sending the members menu // Sending the memberships menu
commands::members($context); commands::memberships($context);
} }
}); });
} else { } else {
@@ -370,7 +370,7 @@ final class search extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -383,7 +383,7 @@ final class search extends core
/** /**
* Search * Search
* *
* Sends the list of found members and menu with parameters: name, distribution, status * Sends the list of found memberships and menu with parameters: name, distribution, status
* *
* @param context $context Request data from Telegram * @param context $context Request data from Telegram
* *
@@ -396,7 +396,7 @@ final class search extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing language // Initializing language
@@ -423,19 +423,19 @@ final class search extends core
$keyboard = [ $keyboard = [
[ [
[ [
'text' => empty($search['name']) ? '🔴 ' . $localization[static::PROCESS . '_button_name'] : '🟢 ' . $localization['member_search_button_name'] . ': ' . $search['name'], 'text' => empty($search['name']) ? '🔴 ' . $localization[static::PROCESS . '_button_name'] : '🟢 ' . $localization['membership_search_button_name'] . ': ' . $search['name'],
'callback_data' => static::PROCESS . '_name' 'callback_data' => static::PROCESS . '_name'
] ]
], ],
[ [
[ [
'text' => empty($search['distribution']['distribution']) || empty($search['distribution']['localization']) ? '🔴 ' . $localization[static::PROCESS . '_button_distribution'] : '🟢 ' . $localization['member_search_button_distribution'] . ': ' . $search['distribution']['localization']->name, 'text' => empty($search['distribution']['distribution']) || empty($search['distribution']['localization']) ? '🔴 ' . $localization[static::PROCESS . '_button_distribution'] : '🟢 ' . $localization['membership_search_button_distribution'] . ': ' . $search['distribution']['localization']->name,
'callback_data' => static::PROCESS . '_distribution' 'callback_data' => static::PROCESS . '_distribution'
] ]
], ],
[ [
[ [
'text' => ($search['status']->emoji() ?? status::unknown->emoji()) . ' ' . $localization['member_search_button_status'] . ': ' . $localization['member_search_button_status_' . ($search['status']->value ?? status::unknown->value)], 'text' => ($search['status']->emoji() ?? status::unknown->emoji()) . ' ' . $localization['membership_search_button_status'] . ': ' . $localization['membership_search_button_status_' . ($search['status']->value ?? status::unknown->value)],
'callback_data' => static::PROCESS . '_status' 'callback_data' => static::PROCESS . '_status'
] ]
], ],
@@ -446,11 +446,11 @@ final class search extends core
->then(function () use ($context, $account, $language, $localization, $search, $keyboard) { ->then(function () use ($context, $account, $language, $localization, $search, $keyboard) {
// Deinitialized the conversation process // Deinitialized the conversation process
// Initializing the member model // Initializing the membership model
$model_member = new member; $model_membership = new membership;
// Initializing amount of readed members per page // Initializing amount of readed memberships per page
$page = MEMBERS_SEARCH_PAGE; $page = MEMBERSHIPS_SEARCH_PAGE;
if ( if (
empty($search['name']) && empty($search['name']) &&
@@ -460,8 +460,8 @@ final class search extends core
) { ) {
// Each search parameter is empty // Each search parameter is empty
// Search for members // Search for memberships
$members = $model_member->database->read( $memberships = $model_membership->database->read(
amount: $page + 1, amount: $page + 1,
offset: $search['page'] < 1 ? 0 : $page * $search['page'] offset: $search['page'] < 1 ? 0 : $page * $search['page']
); );
@@ -471,9 +471,9 @@ final class search extends core
// Initializing the account model // Initializing the account model
$model_account = new account; $model_account = new account;
// Search for members // Search for memberships
$members = $model_member->database->read( $memberships = $model_membership->database->read(
filter: function (record $member) use ($search, $model_account) { filter: function (record $membership) use ($search, $model_account) {
// Initializing the matched buffer // Initializing the matched buffer
$matched = false; $matched = false;
@@ -482,8 +482,8 @@ final class search extends core
// Initializing the account localizations // Initializing the account localizations
$localizations = $model_account->localization->database->read( $localizations = $model_account->localization->database->read(
filter: fn(record $localization) => $localization->account === $member->account, filter: fn(record $localization) => $localization->account === $membership->account,
amount: MEMBERS_SEARCH_ACCOUNT_LOCALIZATIONS_AMOUNT amount: MEMBERSHIPS_SEARCH_ACCOUNT_LOCALIZATIONS_AMOUNT
); );
// Initializing the result status // Initializing the result status
@@ -498,7 +498,7 @@ final class search extends core
foreach ($parts as $part) { foreach ($parts as $part) {
// Iterating over localization name parts // Iterating over localization name parts
if (levenshtein($part, $search['name']) <= MEMBERS_SEARCH_MEMBER_NAME_LEVENSHTEIN_DISTANCE) { if (levenshtein($part, $search['name']) <= MEMBERSHIPS_SEARCH_membership_NAME_LEVENSHTEIN_DISTANCE) {
// Names matched by Levenshtein function // Names matched by Levenshtein function
// Reinitializing the matched buffer // Reinitializing the matched buffer
@@ -526,7 +526,7 @@ final class search extends core
if (!empty($search['distribution']['distribution'])) { if (!empty($search['distribution']['distribution'])) {
// Requested search by distribution // Requested search by distribution
if ($member->distribution === $search['distribution']['distribution']?->identifier) { if ($membership->distribution === $search['distribution']['distribution']?->identifier) {
// Distributions matched // Distributions matched
// Reinitializing the matched buffer // Reinitializing the matched buffer
@@ -542,7 +542,7 @@ final class search extends core
if ($search['status'] instanceof status) { if ($search['status'] instanceof status) {
// Requested search by status // Requested search by status
if ($member->status === $search['status']->value) { if ($membership->status === $search['status']->value) {
// Statuses matched // Statuses matched
// Reinitializing the matched buffer // Reinitializing the matched buffer
@@ -564,10 +564,10 @@ final class search extends core
} }
// Initializing the next page existence status // Initializing the next page existence status
$next = count($members) > $page; $next = count($memberships) > $page;
// Deleting the additional readed members // Deleting the additional readed memberships
unset($members[$page]); unset($memberships[$page]);
// Initializing the title // Initializing the title
$title = '🔍 *' . $localization[static::PROCESS . '_title'] . '*'; $title = '🔍 *' . $localization[static::PROCESS . '_title'] . '*';
@@ -584,14 +584,14 @@ final class search extends core
'remove_keyboard' => true 'remove_keyboard' => true
], ],
] ]
)->then(function (message $message) use ($context, $account, $language, $localization, $search, $page, $next, $members) { )->then(function (message $message) use ($context, $account, $language, $localization, $search, $page, $next, $memberships) {
// Sended the message // Sended the message
if (count($members) > 0) { if (count($memberships) > 0) {
// Initialized members // Initialized memberships
foreach ($members as $member) { foreach ($memberships as $membership) {
// Iterating over found members // Iterating over found memberships
// Declaring the buffer of localized values // Declaring the buffer of localized values
$values = null; $values = null;
@@ -601,12 +601,12 @@ final class search extends core
// Initializing localizations // Initializing localizations
$localizations = $model_account->localization->database->read( $localizations = $model_account->localization->database->read(
filter: fn(record $localization) => $localization->account === $member->account, filter: fn(record $localization) => $localization->account === $membership->account,
amount: MEMBERS_SEARCH_ACCOUNT_LOCALIZATIONS_AMOUNT amount: MEMBERSHIPS_SEARCH_ACCOUNT_LOCALIZATIONS_AMOUNT
); );
if (count($localizations) > 0) { if (count($localizations) > 0) {
// Initialized the members localizations // Initialized the memberships localizations
foreach ($localizations as $record) { foreach ($localizations as $record) {
// Iterating over localizations // Iterating over localizations
@@ -645,22 +645,22 @@ final class search extends core
// Initializing the account model // Initializing the account model
$model_account = new account; $model_account = new account;
// Initializing the member account // Initializing the membership account
$member_account = $model_account->database->read( $membership_account = $model_account->database->read(
filter: fn(record $account) => $account->identifier === $member->account, filter: fn(record $account) => $account->identifier === $membership->account,
amount: 1 amount: 1
)[0] ?? null; )[0] ?? null;
if ($member_account instanceof record) { if ($membership_account instanceof account) {
// Initialized the member account // Initialized the membership account
foreach ($localizations as $record) { foreach ($localizations as $record) {
// Iterating over localizations // Iterating over localizations
if ($record->language === $member_account->language) { if ($record->language === $membership_account->language) {
// Found localization by the member account language // Found localization by the membership account language
// Initializing localization by the member account language // Initializing localization by the membership account language
$values = $record; $values = $record;
// Exit (success) // Exit (success)
@@ -670,7 +670,7 @@ final class search extends core
} }
if (is_null($values)) { if (is_null($values)) {
// Not initialized localization by the member account language // Not initialized localization by the membership account language
// Initializing localization by the first found record // Initializing localization by the first found record
$values = $localizations[0]; $values = $localizations[0];
@@ -678,7 +678,7 @@ final class search extends core
} }
} }
} else { } else {
// Not initialized the members localizations // Not initialized the memberships localizations
// Sending the message // Sending the message
$context->sendMessage('⚠️ *' . $localization[static::PROCESS . '_not_localized'] . '*') $context->sendMessage('⚠️ *' . $localization[static::PROCESS . '_not_localized'] . '*')
@@ -692,7 +692,7 @@ final class search extends core
// Initializing buffer of keyboard // Initializing buffer of keyboard
$keyboard = static::keyboard( $keyboard = static::keyboard(
member: $member, membership: $membership,
localization: $localization, localization: $localization,
messages: $account->authorized_messages === 1, messages: $account->authorized_messages === 1,
); );
@@ -718,7 +718,7 @@ final class search extends core
static::message( static::message(
context: $context, context: $context,
language: $language, language: $language,
member: $member, membership: $membership,
localization: $localization, localization: $localization,
name: $values?->name, name: $values?->name,
recognized: false recognized: false
@@ -794,7 +794,7 @@ final class search extends core
}); });
} }
} else { } else {
// Not initialized members // Not initialized memberships
// Sending the message // Sending the message
$context->sendMessage( $context->sendMessage(
@@ -834,8 +834,8 @@ final class search extends core
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
// Sending the members menu // Sending the memberships menu
commands::members($context); commands::memberships($context);
}); });
} }
}); });
@@ -867,7 +867,7 @@ final class search extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -880,7 +880,7 @@ final class search extends core
/** /**
* Name * Name
* *
* Write name into the member search buffer * Write name into the membership search buffer
* *
* @param context $context Request data from Telegram * @param context $context Request data from Telegram
* *
@@ -891,7 +891,7 @@ final class search extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -947,7 +947,7 @@ final class search extends core
// Initializing the old name // Initializing the old name
$old = empty($search['name']) ? '_' . $localization['empty'] . '_' : $search['name']; $old = empty($search['name']) ? '_' . $localization['empty'] . '_' : $search['name'];
// Writing into the member search process buffer // Writing into the membership search process buffer
$search['name'] = $new; $search['name'] = $new;
// Writing to the telegram user buffer // Writing to the telegram user buffer
@@ -1001,7 +1001,7 @@ final class search extends core
$context->endConversation(); $context->endConversation();
// Requesting to enter name again // Requesting to enter name again
button_member_search::name($context); button_membership_search::name($context);
}); });
} }
} else { } else {
@@ -1016,7 +1016,7 @@ final class search extends core
$context->endConversation(); $context->endConversation();
// Requesting to enter name again // Requesting to enter name again
button_member_search::name($context); button_membership_search::name($context);
}); });
} }
} else { } else {
@@ -1031,7 +1031,7 @@ final class search extends core
$context->endConversation(); $context->endConversation();
// Requesting to enter name again // Requesting to enter name again
button_member_search::name($context); button_membership_search::name($context);
}); });
} }
} else { } else {
@@ -1046,7 +1046,7 @@ final class search extends core
$context->endConversation(); $context->endConversation();
// Requesting to enter name again // Requesting to enter name again
button_member_search::name($context); button_membership_search::name($context);
}); });
} }
} else { } else {
@@ -1060,8 +1060,8 @@ final class search extends core
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();
// Sending the members menu // Sending the memberships menu
commands::members($context); commands::memberships($context);
}); });
} }
}); });
@@ -1081,7 +1081,7 @@ final class search extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -1094,10 +1094,10 @@ final class search extends core
/** /**
* Status * Status
* *
* Write status into the member search buffer * Write status into the membership search buffer
* *
* @param context $context Request data from Telegram * @param context $context Request data from Telegram
* @param status $status The member status * @param status $status The membership status
* *
* @return void * @return void
*/ */
@@ -1106,7 +1106,7 @@ final class search extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -1126,7 +1126,7 @@ final class search extends core
// Initializing the old status // Initializing the old status
$old = empty($search['status']) ? '_' . $localization['empty'] . '_' : $search['status']->emoji() . ' ' . $localization[static::PROCESS . '_status_' . $search['status']->value]; $old = empty($search['status']) ? '_' . $localization['empty'] . '_' : $search['status']->emoji() . ' ' . $localization[static::PROCESS . '_status_' . $search['status']->value];
// Writing into the member search process buffer // Writing into the membership search process buffer
$search['status'] = $status; $search['status'] = $status;
// Writing to the telegram user buffer // Writing to the telegram user buffer
@@ -1176,7 +1176,7 @@ final class search extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Sended the message // Sended the message
@@ -1190,20 +1190,20 @@ final class search extends core
/** /**
* Message text * Message text
* *
* Generate text with the distribution member infornation * Generate text with the distribution membership infornation
* *
* @param context $context Request data from Telegram * @param context $context Request data from Telegram
* @param record $member The distribution member * @param record $membership The distribution membership
* @param language $language The account language * @param language $language The account language
* @param array $localization The account localization * @param array $localization The account localization
* @param string|null $name Localized name of the member * @param string|null $name Localized name of the membership
* @param bool $recognized Add the icon for recognized distribution member? * @param bool $recognized Add the icon for recognized distribution membership?
* *
* @return string Generated text * @return string Generated text
*/ */
public static function message( public static function message(
context $context, context $context,
record $member, record $membership,
language $language, language $language,
array $localization, array $localization,
?string $name = null, ?string $name = null,
@@ -1221,7 +1221,7 @@ final class search extends core
// Searching for the distribution // Searching for the distribution
$distribution = $model_distribution->database->read( $distribution = $model_distribution->database->read(
filter: fn(record $distribution) => $distribution->identifier === $member->distribution, filter: fn(record $distribution) => $distribution->identifier === $membership->distribution,
amount: 1 amount: 1
)[0] ?? null; )[0] ?? null;
@@ -1231,7 +1231,7 @@ final class search extends core
// Searching for the distribution localizations records // Searching for the distribution localizations records
$distribution_localizations = $model_distribution->localization->database->read( $distribution_localizations = $model_distribution->localization->database->read(
filter: fn(record $localization) => $localization->distribution === $distribution->identifier, filter: fn(record $localization) => $localization->distribution === $distribution->identifier,
amount: MEMBERS_SEARCH_DISTRIBUTION_LOCALIZATIONS_AMOUNT amount: MEMBERSHIPS_SEARCH_DISTRIBUTION_LOCALIZATIONS_AMOUNT
); );
// Declaring the buffer of the distribution localization // Declaring the buffer of the distribution localization
@@ -1327,20 +1327,20 @@ final class search extends core
// Initializing relation for the message // Initializing relation for the message
$relation = '*' . $localization[static::PROCESS . '_distribution'] . ':* ' . $distribution_localization->name; $relation = '*' . $localization[static::PROCESS . '_distribution'] . ':* ' . $distribution_localization->name;
// Initializing the member status // Initializing the membership status
$status = status::from($member->status) ?? status::unknown; $status = status::from($membership->status) ?? status::unknown;
// Initializing status for the message // Initializing status for the message
$_status = '*' . $localization[static::PROCESS . '_status'] . ':* ' . $status->emoji() . ' ' . $localization[static::PROCESS . "_status_$status->value"]; $_status = '*' . $localization[static::PROCESS . '_status'] . ':* ' . $status->emoji() . ' ' . $localization[static::PROCESS . "_status_$status->value"];
/* // Initializing amount of recognized members for the message /* // Initializing amount of recognized memberships for the message
$members_recognized = '*' . $localization[static::PROCESS . '_recognized'] . ':* ' . 0; $memberships_recognized = '*' . $localization[static::PROCESS . '_recognized'] . ':* ' . 0;
// Initializing amount of members for the message // Initializing amount of memberships for the message
$amount = '*' . $localization[static::PROCESS . '_members'] . ':* ' . count(array_filter($members, fn(record $member) => $member?->status === 2)); $amount = '*' . $localization[static::PROCESS . '_memberships'] . ':* ' . count(array_filter($memberships, fn(record $membership) => $membership?->status === 2));
// Initializing planners // Initializing planners
$planners = '*' . $localization[static::PROCESS . '_planners'] . ':* ' . count(array_filter($members, fn(record $member) => $member?->status === 1)); $planners = '*' . $localization[static::PROCESS . '_planners'] . ':* ' . count(array_filter($memberships, fn(record $membership) => $membership?->status === 1));
// Initializing volunteers // Initializing volunteers
$volunteers = '*' . $localization[static::PROCESS . '_volunteers'] . ':* ' . 0; $volunteers = '*' . $localization[static::PROCESS . '_volunteers'] . ':* ' . 0;
@@ -1353,7 +1353,7 @@ final class search extends core
// Exit (success) // Exit (success)
return <<<TXT return <<<TXT
$distribution->identifier:$member->identifier:$member->account *$name* $recognized $distribution->identifier:$membership->identifier:$membership->account *$name* $recognized
$relation $relation
$_status $_status
@@ -1371,16 +1371,16 @@ final class search extends core
/** /**
* Keyboard (inline) * Keyboard (inline)
* *
* Generate inline keyboard for the member * Generate inline keyboard for the membership
* *
* @param record $member The member * @param record $membership The membership
* @param array $localization The account localization * @param array $localization The account localization
* @param bool $messages Generate messages buttons? (is the account allowed to send messages?) * @param bool $messages Generate messages buttons? (is the account allowed to send messages?)
* *
* @return array Generated inline keyboard * @return array Generated inline keyboard
*/ */
public static function keyboard( public static function keyboard(
record $member, record $membership,
array $localization, array $localization,
bool $messages = false, bool $messages = false,
): array { ): array {

View File

@@ -2,13 +2,13 @@
declare(strict_types=1); declare(strict_types=1);
namespace svoboda\svoboder\models\telegram; namespace svoboda\antivertical\models\telegram;
// Files of the project // Files of the project
use svoboda\svoboder\models\core, use svoboda\antivertical\models\core,
svoboda\svoboder\models\account, svoboda\antivertical\models\account,
svoboda\svoboder\models\enumerations\language, svoboda\antivertical\models\enumerations\language,
svoboda\svoboder\models\telegram\middlewares; svoboda\antivertical\models\telegram\middlewares;
// Framework for Telegram // Framework for Telegram
use Zanzara\Zanzara, use Zanzara\Zanzara,
@@ -25,7 +25,7 @@ use Error as error;
/** /**
* Telegram settings * Telegram settings
* *
* @package svoboda\svoboder\models\telegram * @package svoboda\antivertical\models\telegram
* *
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License * @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy> * @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
@@ -47,7 +47,7 @@ final class settings extends core
// Initializing the account // Initializing the account
$account = $context->get('account'); $account = $context->get('account');
if ($account instanceof record) { if ($account instanceof account) {
// Initialized the account // Initialized the account
// Initializing localization // Initializing localization
@@ -146,7 +146,7 @@ final class settings extends core
// Not initialized the account // Not initialized the account
// Sending the message // Sending the message
$context->sendMessage('⚠️ *Failed to initialize your Telegram account*') $context->sendMessage('⚠️ *Failed to initialize the account*')
->then(function (message $message) use ($context) { ->then(function (message $message) use ($context) {
// Ending the conversation process // Ending the conversation process
$context->endConversation(); $context->endConversation();

View File

@@ -0,0 +1,157 @@
<?php
declare(strict_types=1);
namespace svoboda\antivertical\models\traits;
// Files of the project
use svoboda\antivertical\models\core;
// Svoboda time
use svoboda\time\statement as svoboda;
// Baza database
use mirzaev\baza\database,
mirzaev\baza\column,
mirzaev\baza\record,
mirzaev\baza\enumerations\encoding,
mirzaev\baza\enumerations\type;
// Built-in libraries
use Exception as exception,
RuntimeException as exception_runtime,
LogicException as exception_logic,
InvalidArgumentException as exception_invalid_argument;
/**
* AR
*
* The "Active Record" architectural pattern
*
* @see https://en.wikipedia.org/wiki/Active_record_pattern Active Record
*
* @package svoboda\antivertical\models\traits
*
* @method self __construct(?record $record) Constructor
* @method static|false read(callable $filter) Read from the database
* @method static|false update() Update the record in the database
* @method void __set(string $name, mixed $value = null) Write into the database record property
* @method mixed __get(string $name) Read from the database record property
* @method bool __isset(string $name) Check that the database record property is initialized
*
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
*/
trait ar
{
/**
* Read
*
* Search for the record in the database
*
* @return static|false The record impementator object, if found
*/
public function read(callable $filter): static|false
{
// Reading from the database
$record = $this->database->read(
filter: $filter,
amount: 1,
offset: 0
)[0] ?? false;
if ($record instanceof record) {
// Initialized the record
// Exit (success)
return new static($record);
}
// Exit (fail)
return false;
}
/**
* Update
*
* Write the record new values into the database
*
* @return static|false The updated record, if updated (new instance)
*/
public function update(): static|false
{
// Writing into the database
$record = $this->database->read(
filter: fn(record $record) => $record->identifier === $this->record->identifier,
update: function (record &$record) {
$this->record->updated = svoboda::timestamp();
$record = $this->record;
},
amount: 1,
offset: 0
)[0] ?? false;
if ($record instanceof record) {
// Initialized the record
// Exit (success)
return new static($record);
}
// Exit (fail)
return false;
}
/**
* Write
*
* Write into the database record property
*
* @param string $name Name of the property
* @param mixed $value Value of the property
*
* @return void
*/
public function __set(string $name, mixed $value = null): void
{
match ($name) {
'record' => $this->record = $value,
default => $this->record->{$name} = $value
};
}
/**
* Read
*
* Read from the database record property
*
* @param string $name Name of the property
*
* @return mixed Content of the property, if they are found
*/
public function __get(string $name): mixed
{
return match ($name) {
'record' => $this->record,
default => $this->record->{$name}
};
}
/**
* Check for initialization
*
* Check that the database record property is initialized
*
* @param string $name Name of the property
*
* @return bool The property is initialized?
*/
public function __isset(string $name): bool
{
// Check of initialization of the property and exit (success)
return match ($name) {
'record' => isset($this->record),
default => isset($this->record->{$name})
};
}
}

View File

@@ -2,7 +2,7 @@
declare(strict_types=1); declare(strict_types=1);
namespace svoboda\svoboder\models\traits; namespace svoboda\antivertical\models\traits;
/** /**
* Coordinates * Coordinates
@@ -11,7 +11,7 @@ namespace svoboda\svoboder\models\traits;
* *
* @method int|float distance(float $from_latitude, float $from_longitude, float $to_latitude, float $to_longitude, int $planet) * @method int|float distance(float $from_latitude, float $from_longitude, float $to_latitude, float $to_longitude, int $planet)
* *
* @package svoboda\svoboder\models\traits * @package svoboda\antivertical\models\traits
* *
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License * @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy> * @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>

View File

@@ -2,23 +2,23 @@
declare(strict_types=1); declare(strict_types=1);
namespace svoboda\svoboder; namespace svoboda\antivertical;
// Files of the project // Files of the project
use svoboda\svoboder\models\distribution, use svoboda\antivertical\models\distribution,
svoboda\svoboder\models\localization\distribution as distribution_localization, svoboda\antivertical\models\localization\distribution as distribution_localization,
svoboda\svoboder\models\telegram\middlewares, svoboda\antivertical\models\telegram\middlewares,
svoboda\svoboder\models\telegram\commands, svoboda\antivertical\models\telegram\commands,
svoboda\svoboder\models\telegram\buttons, svoboda\antivertical\models\telegram\buttons,
svoboda\svoboder\models\telegram\selections, svoboda\antivertical\models\telegram\selections,
svoboda\svoboder\models\telegram\settings, svoboda\antivertical\models\telegram\settings,
svoboda\svoboder\models\enumerations\language, svoboda\antivertical\models\enumerations\language,
svoboda\svoboder\models\telegram\processes\distribution\registration as process_distribution_registration, svoboda\antivertical\models\telegram\processes\distribution\registration as process_distribution_registration,
svoboda\svoboder\models\telegram\processes\distribution\search as process_distribution_search, svoboda\antivertical\models\telegram\processes\distribution\search as process_distribution_search,
svoboda\svoboder\models\telegram\buttons\distribution\registration as button_distribution_registration, svoboda\antivertical\models\telegram\buttons\distribution\registration as button_distribution_registration,
svoboda\svoboder\models\telegram\buttons\distribution\search as button_distribution_search, svoboda\antivertical\models\telegram\buttons\distribution\search as button_distribution_search,
svoboda\svoboder\models\telegram\buttons\distribution\administration as button_distribution_administration, svoboda\antivertical\models\telegram\buttons\distribution\administration as button_distribution_administration,
svoboda\svoboder\models\telegram\processes\distribution\localization as process_distribution_localization; svoboda\antivertical\models\telegram\processes\distribution\localization as process_distribution_localization;
// Framework for PHP // Framework for PHP
use mirzaev\minimal\core, use mirzaev\minimal\core,

View File

@@ -2,32 +2,32 @@
declare(strict_types=1); declare(strict_types=1);
namespace svoboda\svoboder; namespace svoboda\antivertical;
// Files of the project // Files of the project
use svoboda\svoboder\models\distribution, use svoboda\antivertical\models\distribution,
svoboda\svoboder\models\localization\distribution as distribution_localization, svoboda\antivertical\models\localization\distribution as distribution_localization,
svoboda\svoboder\models\telegram\middlewares, svoboda\antivertical\models\telegram\middlewares,
svoboda\svoboder\models\telegram\commands, svoboda\antivertical\models\telegram\commands,
svoboda\svoboder\models\telegram\buttons, svoboda\antivertical\models\telegram\buttons,
svoboda\svoboder\models\telegram\account, svoboda\antivertical\models\telegram\account,
svoboda\svoboder\models\telegram\settings, svoboda\antivertical\models\telegram\settings,
svoboda\svoboder\models\enumerations\member\status, svoboda\antivertical\models\enumerations\membership\status,
svoboda\svoboder\models\enumerations\language, svoboda\antivertical\models\enumerations\language,
svoboda\svoboder\models\telegram\processes\member\search as process_member_search, svoboda\antivertical\models\telegram\processes\membership\search as process_membership_search,
svoboda\svoboder\models\telegram\buttons\member\search as button_member_search, svoboda\antivertical\models\telegram\buttons\membership\search as button_membership_search,
svoboda\svoboder\models\telegram\processes\distribution\declaration as process_distribution_declaration, svoboda\antivertical\models\telegram\processes\distribution\declaration as process_distribution_declaration,
svoboda\svoboder\models\telegram\processes\distribution\search as process_distribution_search, svoboda\antivertical\models\telegram\processes\distribution\search as process_distribution_search,
svoboda\svoboder\models\telegram\processes\distribution\select as process_distribution_select, svoboda\antivertical\models\telegram\processes\distribution\select as process_distribution_select,
svoboda\svoboder\models\telegram\buttons\distribution\declaration as button_distribution_declaration, svoboda\antivertical\models\telegram\buttons\distribution\declaration as button_distribution_declaration,
svoboda\svoboder\models\telegram\buttons\distribution\search as button_distribution_search, svoboda\antivertical\models\telegram\buttons\distribution\search as button_distribution_search,
svoboda\svoboder\models\telegram\buttons\distribution\select as button_distribution_select, svoboda\antivertical\models\telegram\buttons\distribution\select as button_distribution_select,
svoboda\svoboder\models\telegram\processes\account\localization\create as process_account_localization_create, svoboda\antivertical\models\telegram\processes\account\localization\create as process_account_localization_create,
svoboda\svoboder\models\telegram\processes\account\localization\update as process_account_localization_update, svoboda\antivertical\models\telegram\processes\account\localization\update as process_account_localization_update,
svoboda\svoboder\models\telegram\buttons\account\localization\create as button_account_localization_create, svoboda\antivertical\models\telegram\buttons\account\localization\create as button_account_localization_create,
svoboda\svoboder\models\telegram\buttons\account\localization\update as button_account_localization_update, svoboda\antivertical\models\telegram\buttons\account\localization\update as button_account_localization_update,
svoboda\svoboder\models\telegram\buttons\distribution\administration as button_distribution_administration, svoboda\antivertical\models\telegram\buttons\distribution\administration as button_distribution_administration,
svoboda\svoboder\models\telegram\processes\distribution\localization as process_distribution_localization; svoboda\antivertical\models\telegram\processes\distribution\localization as process_distribution_localization;
// Framework for Telegram // Framework for Telegram
use Zanzara\Zanzara as zanzara, use Zanzara\Zanzara as zanzara,
@@ -78,6 +78,7 @@ $robot = new Zanzara(TELEGRAM_KEY, $config);
$robot->onUpdate(function (Context $context): void {}); $robot->onUpdate(function (Context $context): void {});
// Initializing the robot middlewares // Initializing the robot middlewares
$robot->middleware([middlewares::class, 'telegram']);
$robot->middleware([middlewares::class, 'account']); $robot->middleware([middlewares::class, 'account']);
$robot->middleware([middlewares::class, 'language']); $robot->middleware([middlewares::class, 'language']);
$robot->middleware([middlewares::class, 'localization']); $robot->middleware([middlewares::class, 'localization']);
@@ -86,17 +87,18 @@ $robot->middleware([middlewares::class, 'system']);
// Initializing the robot commands handlers // Initializing the robot commands handlers
$robot->onCommand('start', [commands::class, 'menu']); $robot->onCommand('start', [commands::class, 'menu']);
$robot->onCommand('menu', [commands::class, 'menu']); $robot->onCommand('menu', [commands::class, 'menu']);
$robot->onCommand('members', [commands::class, 'members']); $robot->onCommand('memberships', [commands::class, 'memberships']);
$robot->onCommand('account', [commands::class, 'account']); $robot->onCommand('account', [commands::class, 'account']);
$robot->onCommand('distributions', [commands::class, 'distributions']); $robot->onCommand('distributions', [commands::class, 'distributions']);
/* $robot->onCommand('request', [telegram::class, 'request_start'])->middleware([telegram::class, 'request']); */ /* $robot->onCommand('request', [telegram::class, 'request_start'])->middleware([telegram::class, 'request']); */
/* $robot->onCommand('svoboda', [commands::class, 'svoboda']); /* $robot->onCommand('svoboda', [commands::class, 'svoboda']);
$robot->onCommand('members', [commands::class, 'members']); */ $robot->onCommand('memberships', [commands::class, 'memberships']); */
$robot->onCommand('language', [commands::class, 'language'])->middleware([middlewares::class, 'settings']); $robot->onCommand('language', [commands::class, 'language'])->middleware([middlewares::class, 'settings']);
$robot->onCommand('repository', [commands::class, 'repository']); $robot->onCommand('repository', [commands::class, 'repository']);
/* $robot->onCommand('projects', [commands::class, 'projects']); */ /* $robot->onCommand('projects', [commands::class, 'projects']); */
$robot->onCommand('author', [commands::class, 'author']); $robot->onCommand('author', [commands::class, 'author']);
$robot->onCommand('society', [commands::class, 'society']); $robot->onCommand('society', [commands::class, 'society']);
$robot->onCommand('organisation', [commands::class, 'organisation']);
/* $robot->onCommand('system_settings', [commands::class, 'system_settings'])->middleware([middlewares::class, 'system_settings']); */ /* $robot->onCommand('system_settings', [commands::class, 'system_settings'])->middleware([middlewares::class, 'system_settings']); */
// Initializing the robot buttons handlers // Initializing the robot buttons handlers
@@ -107,12 +109,12 @@ $robot->onCbQueryData(['distribution_search_name'], [button_distribution_search:
$robot->onCbQueryData(['distribution_search_end'], [process_distribution_search::class, 'end']); $robot->onCbQueryData(['distribution_search_end'], [process_distribution_search::class, 'end']);
$robot->onCbQueryData(['distribution_search_location'], [button_distribution_search::class, 'location']); $robot->onCbQueryData(['distribution_search_location'], [button_distribution_search::class, 'location']);
$robot->onCbQueryData(['distribution_search_distance'], [button_distribution_search::class, 'distance']); $robot->onCbQueryData(['distribution_search_distance'], [button_distribution_search::class, 'distance']);
$robot->onCbQueryData(['distribution_search_plan'], [button_distribution_search::class, 'plan'])->middleware([middlewares::class, 'join']); $robot->onCbQueryData(['distribution_search_plan'], [button_distribution_search::class, 'plan'])->middleware([middlewares::class, 'memberships']);
$robot->onCbQueryData(['distribution_search_unplan'], [button_distribution_search::class, 'unplan'])->middleware([middlewares::class, 'join']); $robot->onCbQueryData(['distribution_search_unplan'], [button_distribution_search::class, 'unplan'])->middleware([middlewares::class, 'memberships']);
$robot->onCbQueryData(['distribution_search_join'], [button_distribution_search::class, 'join'])->middleware([middlewares::class, 'join']); $robot->onCbQueryData(['distribution_search_join'], [button_distribution_search::class, 'join'])->middleware([middlewares::class, 'memberships']);
$robot->onCbQueryData(['distribution_search_leave'], [button_distribution_search::class, 'leave'])->middleware([middlewares::class, 'join']); $robot->onCbQueryData(['distribution_search_leave'], [button_distribution_search::class, 'leave'])->middleware([middlewares::class, 'memberships']);
$robot->onCbQueryData(['distribution_search_location'], [button_distribution_search::class, 'location']); $robot->onCbQueryData(['distribution_search_location'], [button_distribution_search::class, 'location']);
$robot->onCbQueryData(['distribution_search_members'], [process_member_search::class, 'start']); $robot->onCbQueryData(['distribution_search_memberships'], [process_membership_search::class, 'start']);
$robot->onCbQueryData(['distribution_select_name'], [button_distribution_select::class, 'name']); $robot->onCbQueryData(['distribution_select_name'], [button_distribution_select::class, 'name']);
$robot->onCbQueryData(['distribution_select_location'], [button_distribution_select::class, 'location']); $robot->onCbQueryData(['distribution_select_location'], [button_distribution_select::class, 'location']);
@@ -157,14 +159,14 @@ foreach (language::cases() as $language) {
// Initializing the robot distributions menu buttons handlers // Initializing the robot distributions menu buttons handlers
/* $robot->onCbQueryData(['distributions_search_start'], [process_distribution_search::class, 'start']); */ /* $robot->onCbQueryData(['distributions_search_start'], [process_distribution_search::class, 'start']); */
$robot->onCbQueryData(['members'], [commands::class, 'members']); // Remake to buttons? $robot->onCbQueryData(['memberships'], [commands::class, 'memberships']); // Remake to buttons?
$robot->onCbQueryData(['member_search_start'], [process_member_search::class, 'start']); $robot->onCbQueryData(['membership_search_start'], [process_membership_search::class, 'start']);
$robot->onCbQueryData(['member_search_name'], [button_member_search::class, 'name']); $robot->onCbQueryData(['membership_search_name'], [button_membership_search::class, 'name']);
$robot->onCbQueryData(['member_search_distribution'], [button_member_search::class, 'distribution']); $robot->onCbQueryData(['membership_search_distribution'], [button_membership_search::class, 'distribution']);
foreach (status::cases() as $status) foreach (status::cases() as $status)
$robot->onCbQueryData(['member_search_status_' . $status->name], fn(context $context) => process_member_search::status($context, $status)); $robot->onCbQueryData(['membership_search_status_' . $status->name], fn(context $context) => process_membership_search::status($context, $status));
$robot->onCbQueryData(['member_search_status'], [button_member_search::class, 'status']); $robot->onCbQueryData(['membership_search_status'], [button_membership_search::class, 'status']);
$robot->onCbQueryData(['member_search_end'], [process_member_search::class, 'end']); $robot->onCbQueryData(['membership_search_end'], [process_membership_search::class, 'end']);
$robot->onCbQueryData(['account_localizations'], [account::class, 'localizations']); $robot->onCbQueryData(['account_localizations'], [account::class, 'localizations']);
$robot->onCbQueryData(['account_localization_create_start'], [process_account_localization_create::class, 'start']); $robot->onCbQueryData(['account_localization_create_start'], [process_account_localization_create::class, 'start']);
@@ -181,6 +183,9 @@ $robot->onCbQueryData(['account_localization_create_name'], [button_account_loca
$robot->onCbQueryData(['account_localization_update_name'], [button_account_localization_update::class, 'name']); $robot->onCbQueryData(['account_localization_update_name'], [button_account_localization_update::class, 'name']);
/* $robot->onCbQueryData(['account_localizations_search'], [process_account_localization_search::class, 'start']); */ /* $robot->onCbQueryData(['account_localizations_search'], [process_account_localization_search::class, 'start']); */
$robot->onCbQueryData(['organisation'], [commands::class, 'organisation']); // Remake to buttons?
// Initializing the robot settings language buttons handlers // Initializing the robot settings language buttons handlers
foreach (language::cases() as $language) { foreach (language::cases() as $language) {
// Iterating over languages // Iterating over languages

View File

@@ -0,0 +1,37 @@
<?php
define('MENU_MEMBERSHIPS_AMOUNT', 10000000);
define('DISTRIBUTIONS_SEARCH_PAGE', 3);
define('DISTRIBUTIONS_SEARCH_DISTRIBUTION_DISTANCE', 300);
define('DISTRIBUTIONS_SEARCH_DISTRIBUTION_LOCALIZATIONS_AMOUNT', 100);
define('DISTRIBUTIONS_SEARCH_DISTRIBUTION_NAME_LEVENSHTEIN_DISTANCE', 4);
define('DISTRIBUTIONS_SEARCH_MEMBERSHIP_DEPRECATING_RECORDS_AMOUNT', 500);
define('DISTRIBUTIONS_SEARCH_MEMBERSHIPS_AMOUNT', 10000000);
define('DISTRIBUTIONS_SELECT_PAGE', 10);
define('DISTRIBUTIONS_SELECT_DISTRIBUTION_DISTANCE', 300);
define('DISTRIBUTIONS_SELECT_DISTRIBUTION_LOCALIZATIONS_AMOUNT', 100);
define('DISTRIBUTIONS_SELECT_DISTRIBUTION_NAME_LEVENSHTEIN_DISTANCE', 4);
define('DISTRIBUTIONS_SELECT_MEMBERSHIP_DEPRECATING_RECORDS_AMOUNT', 500);
define('DISTRIBUTIONS_SELECT_MEMBERSHIPS_AMOUNT', 10000000);
define('MEMBERSHIPS_SEARCH_PAGE', 3);
define('MEMBERSHIPS_SEARCH_DISTRIBUTION_LOCALIZATIONS_AMOUNT', 100);
define('MEMBERSHIPS_SEARCH_ACCOUNT_LOCALIZATIONS_AMOUNT', 100);
define('MEMBERSHIPS_SEARCH_MEMBERSHIP_NAME_LEVENSHTEIN_DISTANCE', 4);
define('MEMBERSHIPS_SEARCH_STATUS_ROW_AMOUNT', 3);
define('ACCOUNT_LOCALIZATION_ACCOUNT_LOCALIZATIONS_AMOUNT', 100);
define('ACCOUNT_LOCALIZATION_CREATE_ACCOUNT_LOCALIZATIONS_AMOUNT', 100);
define('ACCOUNT_ACCESS_SYSTEM', 1);
define('ACCOUNT_ACCESS_MESSAGES', 1);
define('ACCOUNT_ACCESS_AUTHONOM', 1);
define('ACCOUNT_ACCESS_STRUCTOR', 1);
define('ACCOUNT_ACCESS_VOLUNTEER', 1);
define('ACCOUNT_ACCESS_INVESTOR', 1);
define('ACCOUNT_ACCESS_RECRUITER', 1);
define('ACCOUNT_ACCESS_SETTINGS', 1);
define('ACCOUNT_ACCESS_SYSTEM_ACCOUNTS', 0);
define('ACCOUNT_ACCESS_SYSTEM_DISTRIBUTIONS', 0);
define('ACCOUNT_ACCESS_SYSTEM_SETTINGS', 0);

View File

Before

Width:  |  Height:  |  Size: 46 KiB

After

Width:  |  Height:  |  Size: 46 KiB

View File

@@ -0,0 +1,89 @@
<?php
declare(strict_types=1);
namespace svoboda\svoboder\tests;
// Files of the project
use svoboda\svoboder\models\account,
svoboda\svoboder\models\distribution,
svoboda\svoboder\models\telegram;
// Enabling debugging
/* ini_set('error_reporting', E_ALL);
ini_set('display_errors', 1);
ini_set('display_startup_errors', 1); */
// Initializing path to the public directory
define('INDEX', __DIR__ . DIRECTORY_SEPARATOR . '..' . DIRECTORY_SEPARATOR . 'system' . DIRECTORY_SEPARATOR . 'public');
// Initializing path to the root directory
define('ROOT', INDEX . DIRECTORY_SEPARATOR . '..' . DIRECTORY_SEPARATOR . '..' . DIRECTORY_SEPARATOR . '..' . DIRECTORY_SEPARATOR . '..' . DIRECTORY_SEPARATOR);
// Initializing path to the settings directory
define('SETTINGS', INDEX . DIRECTORY_SEPARATOR . '..' . DIRECTORY_SEPARATOR . 'settings');
// Initializing path to the storage directory
define('STORAGE', INDEX . DIRECTORY_SEPARATOR . '..' . DIRECTORY_SEPARATOR . 'storage');
// Initializing path to the databases directory
define('DATABASES', INDEX . DIRECTORY_SEPARATOR . '..' . DIRECTORY_SEPARATOR . 'databases');
// Initializing path to the localizations directory
define('LOCALIZATIONS', INDEX . DIRECTORY_SEPARATOR . '..' . DIRECTORY_SEPARATOR . 'localizations');
// Initiailizing telegram key
define('TELEGRAM_KEY', require(SETTINGS . DIRECTORY_SEPARATOR . 'telegram.php'));
// Initializing dependencies
require ROOT . 'vendor' . DIRECTORY_SEPARATOR . 'autoload.php';
// Initializing system settings
require SETTINGS . DIRECTORY_SEPARATOR . 'system.php';
echo <<<TXT
###############################
########### ACCOUNT ###########
###############################
\n
TXT;
// Initializing the account model
$model = new account;
var_dump($model->database->read(
/* filter: fn (record $record) => $record-), */
amount: 1000000
));
echo <<<TXT
\n\n
###############################
###### TELEGRAM ACCOUNT #######
###############################
\n
TXT;
// Initializing the telegram account model
$model = new telegram;
var_dump($model->database->read(
/* filter: fn (record $record) => $record-), */
amount: 1000000
));
echo <<<TXT
\n\n
###############################
######## DISTRIBUTION #########
###############################
\n
TXT;
// Initializing the distribution model
$model = new distribution;
var_dump($model->database->read(
/* filter: fn (record $record) => $record-), */
amount: 1000000
));

Binary file not shown.

View File

@@ -1,126 +0,0 @@
<?php
declare(strict_types=1);
namespace svoboda\svoboder\models;
// Files of the project
use svoboda\svoboder\models\core,
svoboda\svoboder\models\distribution\localization,
svoboda\svoboder\models\distribution\message;
// Svoboda time
use svoboda\time\statement as svoboda;
// Baza database
use mirzaev\baza\database,
mirzaev\baza\column,
mirzaev\baza\record,
mirzaev\baza\enumerations\encoding,
mirzaev\baza\enumerations\type;
// Framework for Telegram
use Zanzara\Telegram\Type\User as telegram;
// Built-in libraries
use Exception as exception,
RuntimeException as exception_runtime;
/**
* Distribution
*
* @package svoboda\svoboder\models
*
* @license http://www.wtfpl.net/ Do What The Fuck You Want To Public License
* @author Arsen Mirzaev Tatyano-Muradovich <arsen@mirzaev.sexy>
*/
final class distribution extends core
{
/**
* File
*
* @var string $database Path to the database file
*/
protected string $file = DATABASES . DIRECTORY_SEPARATOR . 'distributions.baza';
/**
* Database
*
* @var database $database The database
*/
public protected(set) database $database;
/**
* Localization
*
* @var localization $localization The localizations implementator
*/
public protected(set) localization $localization;
/**
* Message
*
* @var localization $localization The messages implementator
*/
public protected(set) message $message;
/**
* Constructor
*
* @return void
*/
public function __construct()
{
// Initializing the database
$this->database = new database()
->encoding(encoding::ascii)
->columns(
new column('identifier', type::integer_unsigned),
new column('creator', type::integer_unsigned),
new column('latitude', type::float),
new column('longitude', type::float),
new column('updated', type::integer_unsigned),
new column('created', type::integer_unsigned)
)
->connect($this->file);
// Initializing the localizations implementator
$this->localization = new localization;
// Initializing the messages implementator
$this->message = new message;
}
/**
* Create
*
* Creates the distribution record in the database
*
* @param int $creator Identifier of the creator account
* @param float $latitude Latitude
* @param float $longitude Longitude
*
* @return int|false The record identifier, if created
*/
public function create(int $creator, float $latitude = 0, float $longitude = 0): int|false
{
// Initializing the identifier
$identifier = $this->database->count() + 1;
// Initializing the record
$record = $this->database->record(
$identifier,
$creator,
$latitude,
$longitude,
svoboda::timestamp(),
svoboda::timestamp()
);
// Creating the record in the database
$created = $this->database->write($record);
// Exit (success)
return $created ? $identifier : false;
}
}

View File

@@ -1,25 +0,0 @@
<?php
define('MENU_MEMBERS_AMOUNT', 10000000);
define('DISTRIBUTIONS_SEARCH_PAGE', 3);
define('DISTRIBUTIONS_SEARCH_DISTRIBUTION_DISTANCE', 300);
define('DISTRIBUTIONS_SEARCH_DISTRIBUTION_LOCALIZATIONS_AMOUNT', 100);
define('DISTRIBUTIONS_SEARCH_DISTRIBUTION_NAME_LEVENSHTEIN_DISTANCE', 4);
define('DISTRIBUTIONS_SEARCH_MEMBER_DEPRECATING_RECORDS_AMOUNT', 500);
define('DISTRIBUTIONS_SEARCH_MEMBERS_AMOUNT', 10000000);
define('DISTRIBUTIONS_SELECT_PAGE', 10);
define('DISTRIBUTIONS_SELECT_DISTRIBUTION_DISTANCE', 300);
define('DISTRIBUTIONS_SELECT_DISTRIBUTION_LOCALIZATIONS_AMOUNT', 100);
define('DISTRIBUTIONS_SELECT_DISTRIBUTION_NAME_LEVENSHTEIN_DISTANCE', 4);
define('DISTRIBUTIONS_SELECT_MEMBER_DEPRECATING_RECORDS_AMOUNT', 500);
define('DISTRIBUTIONS_SELECT_MEMBERS_AMOUNT', 10000000);
define('MEMBERS_SEARCH_PAGE', 3);
define('MEMBERS_SEARCH_DISTRIBUTION_LOCALIZATIONS_AMOUNT', 100);
define('MEMBERS_SEARCH_ACCOUNT_LOCALIZATIONS_AMOUNT', 100);
define('MEMBERS_SEARCH_MEMBER_NAME_LEVENSHTEIN_DISTANCE', 4);
define('MEMBERS_SEARCH_STATUS_ROW_AMOUNT', 3);
define('ACCOUNT_LOCALIZATION_ACCOUNT_LOCALIZATIONS_AMOUNT', 100);
define('ACCOUNT_LOCALIZATION_CREATE_ACCOUNT_LOCALIZATIONS_AMOUNT', 100);