Відмінності між версіями «Оплет»

Матеріал з Брацка Правка
Перейти до: навігація, пошук
(Автоматическое назначение)
(Сервер LDAP)
 
(Не показані 46 проміжних версій 3 користувачів)
Рядок 1: Рядок 1:
[[Оплёт]] ([[Opplet]]; WorldOpp Middleware) -- федеративное, промежуточное и связующее программное обеспечение, которое обслуживает все пользовательские приложения [[Брацко Облако|Брацкого Облака]] (здесь и далее по тексту -- ''Облака''), для которого ''Оплёт'' специально создан. ''Оплёт'' и пользовательские приложения образуют единую федеративную систему, в которой ''Оплёт'' играет роль федерального центра. ''Оплёт'' предоставляет приложениям ''Облака'' те [[#Федеративные услуги|Услуги]], которые переданы от приложений ''Оплёту''. Фактически ''Оплёт'' делает ''Облако'' единым ''Облаком''.
+
[[Оплет]] ([[Opplet]]; WorldOpp Middleware) -- федеративне, проміжне та сполучне програмне забезпечення, яке обслуговує всі користувацькі додатки [[Брацька Хмара|Брацької Хмари]] (тут і далі за текстом - "Хмари"), для якого ''Оплет'' спеціально створено. ''Оплет'' і користувацькі додатки утворюють єдину федеративну систему, у якій ''Оплет'' грає роль федерального центру. ''Оплет'' надає додаткам ''Хмари'' ті [[#Федеративные услуги|Послуги]],які передані від додатків ''Оплету''. Фактично ''Оплет'' робить ''Хмара'' єдиною ''Хмарою''.
  
  
==Функции==
+
==Функції==
  
===Федеративные услуги===
+
===Федеративні послуги===
:Федеративные услуги -- это исключительные услуги ''Oплёта''. Ни одно из пользовательских приложений не имеет возможности предоставлять эти услуги индивидуальным пользователям. Личные кабинеты пользователей, которые некоторые приложения типа [[Брацка Правка|Брацкой Правки]] или [[Брацка Учебка|Брацкой Учебки]] могут иметь собственные кабинеты. Кабинеты этих приложений дополняют личный кабинет ''Оплёта'', но не заменяют его. ''Оплёт'' автоматически заполняет все те поля пользователей, которые могут требовать отдельные приложения. ''Оплёт'' предоставляет следующие федеративные услуги:
+
:Федеративні послуги - це виняткові послуги "Оплету". Жодна з додатків користувача не має можливості надавати ці послуги індивідуальним користувачам. Особисті кабінети користувачів, які деякі додатки типу [[Брацька Правка|Брацької Правки]] або [[Брацка Учебка|Брацької Учебки]] можуть мати власні кабінети. Кабінети цих додатків доповнюють особистий кабінет "Оплету", але не замінюють його. ''Оплет'' автоматично заповнює всі поля користувачів, які можуть вимагати окремі програми. ''Оплет'' надає такі федеративні послуги:
 
:{|class="wikitable" width=100% style="text-align:center;"
 
:{|class="wikitable" width=100% style="text-align:center;"
!Услуги!!Описание!!Потребители
+
!Послуги!!Опис!!Споживачі
 
|-
 
|-
|[[#Ведение личного кабинета|Ведение личного кабинета]]||''Оплёт'' даёт пользователям возможность управлять той частью их учётных записей, которая называется "Личным кабинетом"||Индивидуальные пользователи
+
|[[#Ведение личного кабинета|Ведення особистого кабінету]]||''Оплет'' дає користувачам можливість керувати тією частиною їх облікових записів, яка називається "Особистим кабінетом"||Індивідуальні користувачі
 
|-
 
|-
|[[#Идентификация|Идентификация пользователей]], [[#Регистрация|Регистрация новых пользователей]], [[#Авторизация доступов|Авторизация доступов пользователей к отдельным приложениям]], [[#Определение ролей|Определение ролей пользователей]] и [[#Перспективные услуги|другие услуги]]||''Оплёт'' получает запросы пользовательских приложений ''Облака'' посредством [[API]], обрабатывает их, используя учётные карточки, и отдаёт обработанные запросы тем же путём, которым эти запросы были получены.||Пользовательские приложения
+
|[[#Идентификация|Ідентифікація користувачів]], [[#Регистрация|Регістрація користувачів]], [[#Авторизация доступов|Авторизація доступу користувачів до окремих додатків]], [[#Определение ролей|Визначення ролей користувачів]] и [[#Перспективные услуги|Інші послуги]]||''Оплет'' отримує запити додатків користувача ''Хмари'' за допомогою [[API]], обробляє їх, використовуючи облікові картки, і віддає оброблені запити тим самим шляхом, яким ці запити було отримано.||Додатки користувача
 
|}
 
|}
  
===Безопасность===
+
===Безпека===
:Сотрудники и авторизованные пользователи могут иметь обычный доступ через вэб-броузеры только к своим профилям. Всё остальное [[#Центральное обслуживание|Центральное обслуживание]] доступно исключительно администраторам  по [[PKI]].
+
:Співробітники та авторизовані користувачі можуть мати звичайний доступ через веб-броузери лише до своїх профілів. Все інше [[#Центральное обслуживание|Центральне обслуговування]] доступно виключно адміністраторам по [[PKI]].
  
===Дополнительные функции===
+
===Додаткові функції===
:#Служить одной из площадок для дальнейшего развития профессиональных навыков участников учебных программ.
+
:#Служити одним із майданчиків для подальшого розвитку професійних навичок учасників навчальних програм.
  
 
==Структура==
 
==Структура==
  
 
===Ядро===
 
===Ядро===
:Ядро приложения составляет движок управления пользователями и сервер для пользовательских данных [[MariaDB]].
+
:Ядро програми складає двигун управління користувачами і сервер для даних користувача [[MariaDB]].
  
===Модули===
+
===Модулі===
:Обсуждалось создание двух модулей ''Оплёта'' -- одно для управления данными важных для пользователей событий и другое для управления экзаменационными вопросами.
+
:Обговорювалося створення трьох нових модулів ''Оплет''':
 +
:#Для управління даними тих подій, які важливі для користувачів - лекції, семінари, практика тощо;
 +
:#Для управління екзаменаційними питаннями. Питання б відображалися для окремого користувача незалежно від курсу та програми;
 +
:#Для автоматичного запису на курси. Функціонал для запису на один курс після закінчення іншого існує в [[Moodle]], але його недостатньо для створення навчальних програм, що враховують специфічні побажання студента.
 +
:Також обговорювалося, що ці нові модулі можуть бути реалізовані окремими програмами.
  
===Сервер LDAP===
+
===Федерація===
:Исторически, сервер [[OpenLDAP]] используется как дополнительный канал для предоставления федеративных данных пользователей пользовательским приложениям.
+
:Для взаємодії з іншими програмами [[Брацька Хмара|Брацької Хмари]], ''Оплет'' включає або повинен включати три федераційних блоку:
 +
:#Ідентифікаційний сервер, зібраний на базі [[WSO2 Identity Server]];
 +
:#Розподілену базу даних для основних даних додатків користувача. Для її зв'язку з додатками планується задіяти інтеграційну платформу [[WSO2 Enterprise Integrator]];
 +
:#Сервер [[OpenLDAP]], історично задіяний як додатковий канал для ідентифікації.
 +
 
 +
==Обслуговування програм==
 +
Надання іншим програмам [[Брацька Хмара|Брацької Хмари]] ідентифікаційних та авторизаційних даних - це одна з основних функцій "Оплету". По суті, ''Оплет'' є надавачем послуг з ідентифікації (Identity service provider или ISP)для брацьких додатків. Ці послуги ''Оплет'' здійснює за допомогою:
 +
#Ідентифікаційний сервер, зібраний на базі [[WSO2 Identity Server]];
 +
#Сервера [[OpenLDAP]], задіяного як додатковий канал для ідентифікації та авторизації.
  
===Идентификация===
+
Спочатку, ''Оплет'' працював з [[simpleSAMLphp]]. Через обмеження [[SAML]], [[simpleSAMLphp]] пізніше був замінений сервером [[OpenLDAP]]. Поточний проект - підключити ''Оплет'' до ідентифікаційного сервера [[WSO2]] ([[WSO2 identity Server]] або [[WSO2 IS]]), залишивши [[OpenLDAP]] як паралельний канал ідентифікації та авторизації.
:Идентификационный сервер собран на базе [[WSO2 Identity Server]].
 
  
===Федерация===
+
===Основний сервер===
:Планируется создать распределённую базу данных для основных данных пользовательских приложений. Для её связи с приложениями планируется задействовать интеграционную платформу [[WSO2 Enterprise Integrator]].
+
:Основний сервер для взаємозв'язку ''Оплет'' з додатками користувача через [[OpenLDAP]] реалізується на базі [[WSO2 Identity Server]]. При створенні та зміні користувача в оплеті, ці ж події прописуються в сервері. Так як керування здійснюється виключно з шифруванням, для ''сервера'' повинен бути налаштований [[TSL]]:
  
==Взаимодействие==
+
:[[WSO2 identity Server]] встановлений 5.11.0. Дані зберігаються у чотирьох [[H2 DBMS]]. Функціональність [[SSO]] - рідна для [[WSO2 identity Server]]'а.
  
===С пользовательскими приложениями===
+
:Рішення як ''Оплет'' буде взаємодіяти з іншими службовими програмами такими, як [[OpenStack Keystone]] та [[Amazon Cognito]], поки не прийнято. Майбутня ідентифікація має бути побудована на наявному програмному забезпеченні:
:Исторически, ''Оплёт'' работал с [[simpleSAMLphp]] и, позже, сервером [[OpenLDAP]]. Текущий проект -- подключить его к идентификационному серверу [[WSO2]] ([[WSO2 identity Server]] или [[WSO2 IS]]), оставив [[OpenLDAP]] в качестве дополнительного канала авторизации.
+
:*У випадку суспільної хмари можна використовувати [[Amazon Cognito]] у [[AWS]] або [[Microsoft Azure Active Directory]] у [[Microsoft Azure]];
 +
:*У разі використання приватної хмари буде задіяно [[OpenStack Keystone]] з виведенням на [[LDAP]]. Keystone - це служба OpenStack, яка забезпечує аутентифікацію [[API]]-клієнта, виявлення сервісів та розподілену авторизацію з кількома орендарями, впроваджуючи [[OpenStack Identity API]]. Він підтримує [[LDAP]], [[OAuth]], [[OpenID Connect]], [[SAML]] та [[SQL]]. Keystone насправді не реалізує жодних функцій керування користувачами; швидше, він надає інтерфейси, що підключаються, щоб організації могли використовувати свої поточні служби автентифікації або вибирати з безлічі систем управління ідентифікацією, які знаходяться на ринку.
  
:''Оплёт'' сообщается с пользовательскими приложениями через [[OpenLDAP]] и будет сообщаться через [[WSO2 Identity Server]]. При создании и изменении пользователя в ''Оплёте'', эти же события прописываются в ''серверах''. Так как управление производится исключительно с шифрованием, для ''серверов'' настроен [[TSL]]:
+
:Користувачі, які не є співробітниками [[Брацька Школа|Брацької Школи]],повинні мати можливість входу в хмару через ідентифікацію в соціальних мережах [[social login]], наприклад, [[Facebook Connect]], та інших сервісах, що користуються[[OpenID Connect]].
:*[[OpenLDAP]] установлен 2.4; записи хранятся в [[LDIF]] в незашифрованом виде. Ограничение [[OpenLDAP]] -- для удобного перехода с одного приложения на другое, невозможно настроить [[SSO]] без дополнительных приложений. Также существуют проблемы использования [[OpenLDAP]] с [[Брацка Пошта|Брацкой Поштой]] и новыми версиями [[MediaWiki]], которые используются в [[Брацка Правка|Брацкой Правке]].
 
:*[[WSO2 identity Server]] установлен 5.11.0. Данные хранятся в четырёх [[H2 DBMS]]. Функциональность [[SSO]] -- родная для [[WSO2 identity Server]].
 
  
===С индивидуальными пользователями===
+
:Використовуючи сторонню ідентифікацію, співробітники не можуть заходити на [[Брацка Пошта|Брацьку Пошту]], [[Брацка Крынка|Брацьку Кринку]], а також службові частини [[Брацка Справа|Брацької Справи]].
:''Оплёт'' сообщается тремя путями:
 
:#Через [[#Пользовательский интерфэйс|интерфэйс личного кабинета]];
 
:#Почтовый сервис. Пока настроен [[sendmail]], но почта приходит в спам. Установлен, но не настроен [[Postfix]]. Задача настройки пока отложена. На полноценную почту планируется позже нанять специалиста. Возможно, экономически целесообразнее будет собрать [[Брацка Пошта|Брацкую Пошту]].
 
:#Для тех пользователей, которые пользуются социальным логином, настроен [[OAuth 2.0]] протокол. В данный момент есть проблемы прописывания "социальных пользователей" в ''Оплёте''.
 
  
===Со служебными программами===
+
===Сервер LDAP===
:Решение как ''Оплёт'' будет взамодействовать с другими служебными программами такими, как [[OpenStack Keystone]] и [[Amazon Cognito]], пока не принято.
+
:[[OpenLDAP]] встановлено 2.4; записи зберігаються в [[LDIF]] у незашифрованому вигляді. Сервер LDAP працює паралельно з основним сервером. Обмеження [[OpenLDAP]] -- для зручного переходу з однієї програми на іншу неможливо налаштувати [[SSO]] без додаткових програм. Також існують проблеми використання [[OpenLDAP]] з [[Брацка Пошта|Брацькою Поштою]] та  новими версіями [[MediaWiki]], які використовуються в [[Брацка Правка|Брацькій Правці]].
  
 
==Определение ролей==
 
==Определение ролей==
Рядок 70: Рядок 76:
 
|-
 
|-
 
!Неавторизованный
 
!Неавторизованный
|NetAnyone||Отсутствие условий -- любой посетитель сети Интернет (как зарегистрированный, так и нет), который не авторизовался в Оплёте.||rowspan="9"|Смотри [[#Автоматические доступы|Автоматические доступы]]
+
|NetAnyone||Отсутствие условий -- любой посетитель сети Интернет (как зарегистрированный, так и нет), который не авторизовался в Оплёте.||rowspan="7"|Смотри [[#Автоматические доступы|Автоматические доступы]]
 
|-
 
|-
 
!Подписчик
 
!Подписчик
|Subscriber||Подписка на рассылку делает неавторизованного пользователя ''Подписчиком''.
+
|NetProspect||Подписка на рассылку делает неавторизованного пользователя ''Подписчиком''.
|-
 
!Временный
 
|Temp||Запись на курс [[Брацки Вводны Курс]] -- эта роль присваивается автоматически любому слушателю вводного курса временно, на три месяца.
 
 
|-
 
|-
 
!Клиент
 
!Клиент
|Client||Пожертвование или покупка в магазине [[Careerprise Shop]]
+
|NetCustomer||Пожертвование или покупка в магазине [[Careerprise Shop]]
 
|-
 
|-
!Кандидат
+
!Интересующийся
|Candidate||Завершение курса [[Техобзорны Курс]]
+
|NetConsumer||Запись на курс [[Брацка Вводка]] -- эта роль присваивается автоматически любому слушателю вводного курса временно, на шесть месяцев.
 
|-
 
|-
!Партнёр
+
!Студент
|Partner||Завершение семинара [[Как стать партнёром Брацкой Школы|Как стать партнёром]]
+
|CertStudent||Завершение курса [[Брацка Вводка]]
|-
 
!Волонтёр
 
|Volunteer||Завершение семинара [[Как стать волонтёром Брацкой Школы|Как стать волонтёром]]
 
 
|-
 
|-
!Студент
+
!Пользователь
|Enrolled||Завершение семинара [[Выбор Профессии|Как трудоустроиться]]
+
|CertUser||Завершение курса [[Брацки Техобзор]]
 
|-
 
|-
!Сотрудник
+
!Стажёр
|Associate||Завершение [[Семь Технологических Искусств]] и [[Семь Административных Искусств]] -- эта роль присваивается автоматически любому выпускнику этих курсов постоянно.
+
|CertFellow||Завершение семинара [[Выбор Профессии]]
 
|}
 
|}
  
Рядок 121: Рядок 121:
 
:Существует два типа учётных карточек:
 
:Существует два типа учётных карточек:
 
:#'''Обычные учётные карточки''', которые не содержат [[Псевдоним пользователя Оплёта|Корпоративных псевдонимов]], заводятся автоматически в один этап и могут дать доступ к некоторым, но не всем пользовательским приложениям;
 
:#'''Обычные учётные карточки''', которые не содержат [[Псевдоним пользователя Оплёта|Корпоративных псевдонимов]], заводятся автоматически в один этап и могут дать доступ к некоторым, но не всем пользовательским приложениям;
:#'''Корпоративные учётные карточки''', которые содержат всё, что обычные учётные карточки содержат и, в дополнение, хранят [[Псевдоним пользователя Оплёта|Корпоративные псевдонимы]], а также [[#Регистрационные имена пользователей|регистрационные имена]] и [[#Корпоративные имэйлы|корпоративные имэйлы]], основанные на них. Корпоративные карточки заводятся либо (1) автоматически в два этапа -- временные для участия в курсах [[Брацки Вводны Курс]], [[Техобзорны Курс]] и постоянные после завершения этих курсов, либо (2) вручную в один этап. Карточки этого типа нужны для доступа к [[Брацка Пошта|Брацкой Поште]], [[Брацка Крынка|Брацкой Крынке]], а также служебным частям [[Брацка Справа|Брацкой Справы]].
+
:#'''Корпоративные учётные карточки''', которые содержат всё, что обычные учётные карточки содержат и, в дополнение, хранят [[Псевдоним пользователя Оплёта|Корпоративные псевдонимы]], а также [[#Регистрационные имена пользователей|регистрационные имена]] и [[#Корпоративные имэйлы|корпоративные имэйлы]], основанные на них. Корпоративные карточки заводятся либо (1) автоматически в два этапа -- временные для участия в курсах [[Брацка Вводка]], [[Брацки Техобзор]] и постоянные после завершения этих курсов, либо (2) вручную в один этап. Карточки этого типа нужны для доступа к [[Брацка Пошта|Брацкой Поште]], [[Брацка Крынка|Брацкой Крынке]], а также служебным частям [[Брацка Справа|Брацкой Справы]].
  
 
===Методы регистрации===
 
===Методы регистрации===
Рядок 143: Рядок 143:
 
:*#Проверяет, существует ли такой пользователь в базе данных;
 
:*#Проверяет, существует ли такой пользователь в базе данных;
 
:*#Если пользователь не существует в базе, то ''Оплёт'' заводит новую учётную карточку;
 
:*#Если пользователь не существует в базе, то ''Оплёт'' заводит новую учётную карточку;
:*#Заводит пользователя на [[Брацка Учебка|Брацкой Учебке]], создаёт [[Псевдоним пользователя Оплёта|Корпоративный псевдоним]] и даёт доступ к курсу [[Брацки Вводны Курс]];
+
:*#Заводит пользователя на [[Брацка Учебка|Брацкой Учебке]], создаёт [[Псевдоним пользователя Оплёта|Корпоративный псевдоним]] и даёт доступ к курсу [[Брацка Вводка]];
:*#Отдаёт задание [[Брацка Пошта|Брацкой Поште]] выслать пользователю сообщение о создании учётной карточки, доступе к курсу [[Брацки Вводны Курс]] и личному кабинету.
+
:*#Отдаёт задание [[Брацка Пошта|Брацкой Поште]] выслать пользователю сообщение о создании учётной карточки, доступе к курсу [[Брацка Вводка]] и личному кабинету.
:*'''Подписка на рассылки''': Если пользователь отдаёт свой имэйл в качестве заявки на подписку на рассылку на любом из вэб-сайтов [[Брацка Вэбка|Брацкой Вэбки]], ''Оплёт'':
+
:*'''Подписка на рассылки''': Если пользователь отдаёт свой имэйл в качестве заявки на подписку на рассылку на любом из вэб-сайтов [[Брацка Вебка|Брацкой Вебки]], ''Оплёт'':
 
:*#Проверяет, существует ли такой пользователь в базе данных;
 
:*#Проверяет, существует ли такой пользователь в базе данных;
 
:*#Если:
 
:*#Если:
 
:*#*Пользователь существует, то ''Оплёт'' добавляет ту рассылку, на которую подписался пользователь, к его учётной карточке;
 
:*#*Пользователь существует, то ''Оплёт'' добавляет ту рассылку, на которую подписался пользователь, к его учётной карточке;
 
:*#*Пользователь не существует в базе, то ''Оплёт'' заводит новую учётную карточку и добавляет к ней ту рассылку, на которую подписался новый пользователь;
 
:*#*Пользователь не существует в базе, то ''Оплёт'' заводит новую учётную карточку и добавляет к ней ту рассылку, на которую подписался новый пользователь;
:*#Заводит пользователя на [[Брацка Учебка|Брацкой Учебке]], создаёт [[Псевдоним пользователя Оплёта|Корпоративный псевдоним]], идентификатор и пароль, а также даёт доступ к курсу [[Брацки Вводны Курс]];
+
:*#Заводит пользователя на [[Брацка Учебка|Брацкой Учебке]], создаёт [[Псевдоним пользователя Оплёта|Корпоративный псевдоним]], идентификатор и пароль, а также даёт доступ к курсу [[Брацка Вводка]];
:*#Отдаёт задание [[Брацка Пошта|Брацкой Поште]] выслать пользователю подтверждение подписки, сообщение о создании учётной карточки, доступе к курсу [[Брацки Вводны Курс]] и личному кабинету;
+
:*#Отдаёт задание [[Брацка Пошта|Брацкой Поште]] выслать пользователю подтверждение подписки, сообщение о создании учётной карточки, доступе к курсу [[Брацка Вводка]] и личному кабинету;
 
:*#В случае, если на [[Брацка Пошта|Брацкую Пошту]] приходит сообщение об:
 
:*#В случае, если на [[Брацка Пошта|Брацкую Пошту]] приходит сообщение об:
 
:*#*Отсутствии существования указанного пользователем имэйла, проверяет, есть ли на карточке другие записи и:
 
:*#*Отсутствии существования указанного пользователем имэйла, проверяет, есть ли на карточке другие записи и:
Рядок 172: Рядок 172:
  
 
===Запись на вводный курс===
 
===Запись на вводный курс===
:Регистрация через запись на вводный курс -- единственная регистрация, по которой пользователь получает временный статус, который действителен в течение 3-х месяцев. Если пользователь не окончил курс в течение этого времени, то его регистрация аннулируется. Если пользователь на любом из вэб-сайтов [[Брацка Вэбка|Брацкой Вэбки]] кликает на кнопки типа "Трудоустроиться", "Выучиться", "Стать волонтёром", "Стать партнёром" и так далее, ''Оплёт'':
+
:Регистрация через запись на вводный курс -- единственная регистрация, по которой пользователь получает временный статус, который действителен в течение 3-х месяцев. Если пользователь не окончил курс в течение этого времени, то его регистрация аннулируется. Если пользователь на любом из вэб-сайтов [[Брацка Вебка|Брацкой Вебки]] кликает на кнопки типа "Трудоустроиться", "Выучиться", "Стать волонтёром", "Стать партнёром" и так далее, ''Оплёт'':
 
:#Заводит временную учётную карточку со сведениями о том, (1) какая кнопка была нажата и (2) какой язык был использован;
 
:#Заводит временную учётную карточку со сведениями о том, (1) какая кнопка была нажата и (2) какой язык был использован;
 
:#В принудительном порядке предлагает пользователю ввести тот логин и пароль, который будет удобен этому пользователю;
 
:#В принудительном порядке предлагает пользователю ввести тот логин и пароль, который будет удобен этому пользователю;
Рядок 185: Рядок 185:
 
:#*#"Отправьте идентификатор и пароль на мою электронную почту", то ''Оплёт'' запрашивает имэйл-адрес пользователя, отдаёт задание [[Брацка Пошта]] выслать имэйл-подтверждение на введённый адрес, зачисляет и перенаправляет этого пользователя на вводную лекцию ''Курса'';
 
:#*#"Отправьте идентификатор и пароль на мою электронную почту", то ''Оплёт'' запрашивает имэйл-адрес пользователя, отдаёт задание [[Брацка Пошта]] выслать имэйл-подтверждение на введённый адрес, зачисляет и перенаправляет этого пользователя на вводную лекцию ''Курса'';
 
:#*#"Я сохранил это идентификатор и пароль", то ''Оплёт'' зачисляет и перенаправляет этого пользователя на вводную лекцию ''Курса''.
 
:#*#"Я сохранил это идентификатор и пароль", то ''Оплёт'' зачисляет и перенаправляет этого пользователя на вводную лекцию ''Курса''.
:#Курс начинается с текста "Добро пожаловать в Брацкую Школу. Чтобы сохранить в тайне личные данные, все участники пользуются корпоративными псевдонимами. Вы зачислены на вводный курс [[Брацки Вводны Курс]] под псевдонимом ''Женя Семашко''. Если Вы хотите поменять имя, повторите процедуру регистрации с начала."
+
:#Курс начинается с текста "Добро пожаловать в Брацкую Школу. Чтобы сохранить в тайне личные данные, все участники пользуются корпоративными псевдонимами. Вы зачислены на вводный курс, [[Брацка Вводка]], под псевдонимом ''Женя Семашко''. Если Вы хотите поменять имя, повторите процедуру регистрации с начала."
  
 
===Ручная регистрация===
 
===Ручная регистрация===
Рядок 237: Рядок 237:
  
 
==Пользовательский интерфэйс==
 
==Пользовательский интерфэйс==
 +
С живыми пользователями, ''Оплёт'' сообщается тремя путями:
 +
#Через [[#Пользовательский интерфэйс|интерфэйс личного кабинета]];
 +
#Почтовый сервис. Пока настроен [[sendmail]], но почта приходит в спам. Установлен, но не настроен [[Postfix]]. Задача настройки пока отложена. На полноценную почту планируется позже нанять специалиста. Возможно, экономически целесообразнее будет собрать [[Брацка Пошта|Брацкую Пошту]].
 +
#Для тех пользователей, которые пользуются социальным логином, настроен [[OAuth 2.0]] протокол. В данный момент есть проблемы прописывания "социальных пользователей" в ''Оплёте''.
 +
 
Незарегистрированный пользователь видит только титульную страницу:
 
Незарегистрированный пользователь видит только титульную страницу:
 
*На шапке слева -- Opplet; справа -- SignUp (клик регистрирует пользователя в роли Временный);
 
*На шапке слева -- Opplet; справа -- SignUp (клик регистрирует пользователя в роли Временный);
Рядок 271: Рядок 276:
 
===Рассылки===
 
===Рассылки===
 
:''Оплёт'' управляет данными о том, на какие рассылки подписан пользователь.
 
:''Оплёт'' управляет данными о том, на какие рассылки подписан пользователь.
 
==Идентификация==
 
===Внутренняя===
 
:Сейчас идентификация пользователей идёт через [[simpleSAMLphp]], что сильно ограничивает возможности системы. Будущая идентификация должна быть построена на имеющемся в наличии программном обеспечении:
 
:*В случае общественного облака может быть использован [[Amazon Cognito]] в [[AWS]] или [[Microsoft Azure Active Directory]] в [[Microsoft Azure]];
 
:*В случае использования частного облака, будет задействован [[OpenStack Keystone]] с выводом на [[LDAP]]. Keystone - это служба OpenStack, которая обеспечивает аутентификацию [[API]]-клиента, обнаружение сервисов и распределенную авторизацию с несколькими арендаторами, внедряя [[OpenStack Identity API]]. Он поддерживает [[LDAP]], [[OAuth]], [[OpenID Connect]], [[SAML]] и [[SQL]]. Keystone на самом деле не реализует никаких функций управления пользователями; скорее, он предоставляет подключаемые интерфейсы, чтобы организации могли использовать свои текущие службы аутентификации или выбирать из множества систем управления идентификацией, которые находятся на рынке.
 
 
===Сторонняя===
 
:Пользователи, не являющиеся сотрудниками [[Брацка Школа|Брацкой Школы]], должны иметь возможность входа в ''Облако'' через идентификацию в социальных сетях [[social login]], например, [[Facebook Connect]], и других сервисах, пользующихся [[OpenID Connect]].
 
 
:Используя стороннюю идентификацию, сотрудники не могут заходить на [[Брацка Пошта|Брацкую Пошту]], [[Брацка Крынка|Брацкую Крынку]], а также служебные части [[Брацка Справа|Брацкую Справу]].
 
  
 
==Авторизация доступов==
 
==Авторизация доступов==
Рядок 294: Рядок 288:
 
:*#Если пользователь при первоначальной записи выбирал кнопку:
 
:*#Если пользователь при первоначальной записи выбирал кнопку:
 
:*#*"Трудоустроиться", то ''Оплёт'' загружает страницу "Поздравляем с успешным завершением курса. Вы выражали интерес к трудоустройству. Вы желаете трудоустроиться через Брацкую Школу, не платя за услуги из своего кармана, или заказать платные услуги по трудоустройству? Кстати, если Ваш интерес поменялся, в [[#Личный кабинет|Личном кабинете]] Вы всегда можете изменить своё решение." с кнопками "Трудоустроиться через Брацкую Школу", "Заказать платные услуги по трудоустройству" и "Что-то ещё";
 
:*#*"Трудоустроиться", то ''Оплёт'' загружает страницу "Поздравляем с успешным завершением курса. Вы выражали интерес к трудоустройству. Вы желаете трудоустроиться через Брацкую Школу, не платя за услуги из своего кармана, или заказать платные услуги по трудоустройству? Кстати, если Ваш интерес поменялся, в [[#Личный кабинет|Личном кабинете]] Вы всегда можете изменить своё решение." с кнопками "Трудоустроиться через Брацкую Школу", "Заказать платные услуги по трудоустройству" и "Что-то ещё";
:*#*#Если пользователь выбрал кнопку: "Трудоустроиться через Брацкую Школу", то ''Оплёт'' обновляет информацию учётной карточки. Регистрация в этом случае следует правилам описанным на вики-странице [[Лестница к Профессии]]. ''Оплёт'' перенаправляет этого пользователя на семинар [[Выбор Профессии]]. После завершения этого семинара, ''Оплёт'' даёт пользователю доступ к [[Брацка Вэбка|Брацкой Вэбке]], [[Брацка Пошта|Брацкой Поште]] и [[Брацка Справа|Брацкой Справе]], а также зачисляет его в слушатели [[Семь Технологических Искусств]] и [[Семь Административных Искусств]];
+
:*#*#Если пользователь выбрал кнопку: "Трудоустроиться через Брацкую Школу", то ''Оплёт'' обновляет информацию учётной карточки. Регистрация в этом случае следует правилам описанным на вики-странице [[Лестница к Профессии]]. ''Оплёт'' перенаправляет этого пользователя на семинар [[Выбор Профессии]]. После завершения этого семинара, ''Оплёт'' даёт пользователю доступ к [[Брацка Вебка|Брацкой Вебке]], [[Брацка Пошта|Брацкой Поште]] и [[Брацка Справа|Брацкой Справе]], а также зачисляет его в слушатели [[Семь Технологических Искусств]] и [[Семь Административных Искусств]];
 
:*#*#Если пользователь выбрал кнопку: "Заказать платные услуги по трудоустройству", то ''Оплёт'' обновляет информацию учётной карточки и перенаправляет этого пользователя в [[Careerprise Shop]];
 
:*#*#Если пользователь выбрал кнопку: "Заказать платные услуги по трудоустройству", то ''Оплёт'' обновляет информацию учётной карточки и перенаправляет этого пользователя в [[Careerprise Shop]];
 
:*#*#Если пользователь выбрал кнопку: "Что-то ещё", то ''Оплёт'' обновляет информацию учётной карточки и перенаправляет этого пользователя в [[#Личный кабинет|Личный кабинет]];
 
:*#*#Если пользователь выбрал кнопку: "Что-то ещё", то ''Оплёт'' обновляет информацию учётной карточки и перенаправляет этого пользователя в [[#Личный кабинет|Личный кабинет]];
 
:*#*"Выучиться", то ''Оплёт'' загружает страницу "Поздравляем с успешным завершением курса. Вы желаете совмещать учёбу и работу в Брацкой Школе, не платя за услуги из своего кармана, или заказать платные услуги образования? Кстати, если Ваш интерес поменялся, в [[#Личный кабинет|Личном кабинете]] Вы всегда можете изменить своё решение." с кнопками "Учиться и работать в Брацкой Школе", "Заказать платные услуги образования", "Что-то ещё";
 
:*#*"Выучиться", то ''Оплёт'' загружает страницу "Поздравляем с успешным завершением курса. Вы желаете совмещать учёбу и работу в Брацкой Школе, не платя за услуги из своего кармана, или заказать платные услуги образования? Кстати, если Ваш интерес поменялся, в [[#Личный кабинет|Личном кабинете]] Вы всегда можете изменить своё решение." с кнопками "Учиться и работать в Брацкой Школе", "Заказать платные услуги образования", "Что-то ещё";
:*#*#Если пользователь выбрал кнопку: "Учиться и работать в Брацкой Школе", то ''Оплёт'' обновляет информацию учётной карточки и перенаправляет его на семинар [[Выбор Профессии]]. После завершения этого семинара, ''Оплёт'' даёт пользователю доступ к [[Брацка Вэбка|Брацкой Вэбке]], [[Брацка Пошта|Брацкой Поште]] и [[Брацка Справа|Брацкой Справе]], а также зачисляет его в слушатели [[Семь Технологических Искусств]] и [[Семь Административных Искусств]];
+
:*#*#Если пользователь выбрал кнопку: "Учиться и работать в Брацкой Школе", то ''Оплёт'' обновляет информацию учётной карточки и перенаправляет его на семинар [[Выбор Профессии]]. После завершения этого семинара, ''Оплёт'' даёт пользователю доступ к [[Брацка Вебка|Брацкой Вебке]], [[Брацка Пошта|Брацкой Поште]] и [[Брацка Справа|Брацкой Справе]], а также зачисляет его в слушатели [[Семь Технологических Искусств]] и [[Семь Административных Искусств]];
 
:*#*#Если пользователь выбрал кнопку: "Заказать платные услуги образования", то ''Оплёт'' обновляет информацию учётной карточки и перенаправляет этого пользователя на [[Careerprise Shop]];
 
:*#*#Если пользователь выбрал кнопку: "Заказать платные услуги образования", то ''Оплёт'' обновляет информацию учётной карточки и перенаправляет этого пользователя на [[Careerprise Shop]];
 
:*#*#Если пользователь выбрал кнопку: "Что-то ещё", то [[Оплёт]] обновляет информацию учётной карточки и перенаправляет этого пользователя в [[#Личный кабинет|Личный кабинет]];
 
:*#*#Если пользователь выбрал кнопку: "Что-то ещё", то [[Оплёт]] обновляет информацию учётной карточки и перенаправляет этого пользователя в [[#Личный кабинет|Личный кабинет]];
Рядок 313: Рядок 307:
 
===Автоматические доступы===
 
===Автоматические доступы===
 
:{|class="wikitable" width=100% style="text-align:center;"
 
:{|class="wikitable" width=100% style="text-align:center;"
![[#Роли|Роль]]!!''Оплёт''!![[Брацка Учебка|Учебка]]!![[Брацка Правка|Правка]]!![[Брацка Бачка|Бачка]]!![[Брацки Жици|Жици]]!![[Брацка Справа|Справа]]!![[Брацка Пошта|Пошта]]!![[Брацка Вэбка|Вэбка]]!![[Брацка Крынка|Крынка]]
+
![[#Роли|Роль]]!!''Оплёт''!![[Брацка Учебка|Учебка]]!![[Брацка Правка|Правка]]!![[Брацка Бачка|Бачка]]!![[Брацки Жици|Жици]]!![[Брацка Справа|Справа]]!![[Брацка Пошта|Пошта]]!![[Брацка Вебка|Вебка]]!![[Брацка Крынка|Крынка]]
 
|-
 
|-
 
|[[#Роли|Неавторизованный]]
 
|[[#Роли|Неавторизованный]]
Рядок 322: Рядок 316:
 
|-
 
|-
 
|[[#Роли|Подписчик]]
 
|[[#Роли|Подписчик]]
|rowspan="7"|Любой имеет доступ к личному кабинету||rowspan="2"|Доступ к курсу [[Брацки Вводны Курс]]||rowspan="7"|Доступ в качестве пользователя||rowspan="7"|Доступ в качестве пользователя
+
|rowspan="7"|Любой имеет доступ к личному кабинету||rowspan="2"|Доступ к курсу [[Брацка Вводка]]||rowspan="7"|Доступ в качестве пользователя||rowspan="7"|Доступ в качестве пользователя
 
|-
 
|-
 
|[[#Роли|Клиент]]
 
|[[#Роли|Клиент]]
Рядок 365: Рядок 359:
 
:#Есть нерешённая проблема по роли подписчика. Можно либо не создавать пользователя вовсе, так как пользователь с любой ролью может быть подписчиком и это скорее не роль, а свойство профиля клиента. Отписку же проводить через отписной имэйл, а не заходом в личный кабинет. Либо создавать пользователя понимая, что подписчик -- это только тот, кто пока далее подписки не пошёл и другой роли пока не получил.
 
:#Есть нерешённая проблема по роли подписчика. Можно либо не создавать пользователя вовсе, так как пользователь с любой ролью может быть подписчиком и это скорее не роль, а свойство профиля клиента. Отписку же проводить через отписной имэйл, а не заходом в личный кабинет. Либо создавать пользователя понимая, что подписчик -- это только тот, кто пока далее подписки не пошёл и другой роли пока не получил.
 
:#Работу над проблемами планируется перенести на [[Redmine]] или [[Брацка Крынка|Брацкую Крынку]], для чего основной разработчик должен провести тренинг.
 
:#Работу над проблемами планируется перенести на [[Redmine]] или [[Брацка Крынка|Брацкую Крынку]], для чего основной разработчик должен провести тренинг.
 +
 +
==Связанные лектио==
 +
*[[Структура Облака]]
 +
*[[Что Есть Оплёт]]
 +
*[[Учебка в Облаке]]
 +
*[[Составные Защиты]]
 +
*[[Новые Технологии]]
 +
*[[Степени Разработок]]

Поточна версія на 20:12, 5 лютого 2023

Оплет (Opplet; WorldOpp Middleware) -- федеративне, проміжне та сполучне програмне забезпечення, яке обслуговує всі користувацькі додатки Брацької Хмари (тут і далі за текстом - "Хмари"), для якого Оплет спеціально створено. Оплет і користувацькі додатки утворюють єдину федеративну систему, у якій Оплет грає роль федерального центру. Оплет надає додаткам Хмари ті Послуги,які передані від додатків Оплету. Фактично Оплет робить Хмара єдиною Хмарою.


Зміст

Функції

Федеративні послуги

Федеративні послуги - це виняткові послуги "Оплету". Жодна з додатків користувача не має можливості надавати ці послуги індивідуальним користувачам. Особисті кабінети користувачів, які деякі додатки типу Брацької Правки або Брацької Учебки можуть мати власні кабінети. Кабінети цих додатків доповнюють особистий кабінет "Оплету", але не замінюють його. Оплет автоматично заповнює всі поля користувачів, які можуть вимагати окремі програми. Оплет надає такі федеративні послуги:
Послуги Опис Споживачі
Ведення особистого кабінету Оплет дає користувачам можливість керувати тією частиною їх облікових записів, яка називається "Особистим кабінетом" Індивідуальні користувачі
Ідентифікація користувачів, Регістрація користувачів, Авторизація доступу користувачів до окремих додатків, Визначення ролей користувачів и Інші послуги Оплет отримує запити додатків користувача Хмари за допомогою API, обробляє їх, використовуючи облікові картки, і віддає оброблені запити тим самим шляхом, яким ці запити було отримано. Додатки користувача

Безпека

Співробітники та авторизовані користувачі можуть мати звичайний доступ через веб-броузери лише до своїх профілів. Все інше Центральне обслуговування доступно виключно адміністраторам по PKI.

Додаткові функції

  1. Служити одним із майданчиків для подальшого розвитку професійних навичок учасників навчальних програм.

Структура

Ядро

Ядро програми складає двигун управління користувачами і сервер для даних користувача MariaDB.

Модулі

Обговорювалося створення трьох нових модулів Оплет':
  1. Для управління даними тих подій, які важливі для користувачів - лекції, семінари, практика тощо;
  2. Для управління екзаменаційними питаннями. Питання б відображалися для окремого користувача незалежно від курсу та програми;
  3. Для автоматичного запису на курси. Функціонал для запису на один курс після закінчення іншого існує в Moodle, але його недостатньо для створення навчальних програм, що враховують специфічні побажання студента.
Також обговорювалося, що ці нові модулі можуть бути реалізовані окремими програмами.

Федерація

Для взаємодії з іншими програмами Брацької Хмари, Оплет включає або повинен включати три федераційних блоку:
  1. Ідентифікаційний сервер, зібраний на базі WSO2 Identity Server;
  2. Розподілену базу даних для основних даних додатків користувача. Для її зв'язку з додатками планується задіяти інтеграційну платформу WSO2 Enterprise Integrator;
  3. Сервер OpenLDAP, історично задіяний як додатковий канал для ідентифікації.

Обслуговування програм

Надання іншим програмам Брацької Хмари ідентифікаційних та авторизаційних даних - це одна з основних функцій "Оплету". По суті, Оплет є надавачем послуг з ідентифікації (Identity service provider или ISP)для брацьких додатків. Ці послуги Оплет здійснює за допомогою:

  1. Ідентифікаційний сервер, зібраний на базі WSO2 Identity Server;
  2. Сервера OpenLDAP, задіяного як додатковий канал для ідентифікації та авторизації.

Спочатку, Оплет працював з simpleSAMLphp. Через обмеження SAML, simpleSAMLphp пізніше був замінений сервером OpenLDAP. Поточний проект - підключити Оплет до ідентифікаційного сервера WSO2 (WSO2 identity Server або WSO2 IS), залишивши OpenLDAP як паралельний канал ідентифікації та авторизації.

Основний сервер

Основний сервер для взаємозв'язку Оплет з додатками користувача через OpenLDAP реалізується на базі WSO2 Identity Server. При створенні та зміні користувача в оплеті, ці ж події прописуються в сервері. Так як керування здійснюється виключно з шифруванням, для сервера повинен бути налаштований TSL:
WSO2 identity Server встановлений 5.11.0. Дані зберігаються у чотирьох H2 DBMS. Функціональність SSO - рідна для WSO2 identity Server'а.
Рішення як Оплет буде взаємодіяти з іншими службовими програмами такими, як OpenStack Keystone та Amazon Cognito, поки не прийнято. Майбутня ідентифікація має бути побудована на наявному програмному забезпеченні:
  • У випадку суспільної хмари можна використовувати Amazon Cognito у AWS або Microsoft Azure Active Directory у Microsoft Azure;
  • У разі використання приватної хмари буде задіяно OpenStack Keystone з виведенням на LDAP. Keystone - це служба OpenStack, яка забезпечує аутентифікацію API-клієнта, виявлення сервісів та розподілену авторизацію з кількома орендарями, впроваджуючи OpenStack Identity API. Він підтримує LDAP, OAuth, OpenID Connect, SAML та SQL. Keystone насправді не реалізує жодних функцій керування користувачами; швидше, він надає інтерфейси, що підключаються, щоб організації могли використовувати свої поточні служби автентифікації або вибирати з безлічі систем управління ідентифікацією, які знаходяться на ринку.
Користувачі, які не є співробітниками Брацької Школи,повинні мати можливість входу в хмару через ідентифікацію в соціальних мережах social login, наприклад, Facebook Connect, та інших сервісах, що користуютьсяOpenID Connect.
Використовуючи сторонню ідентифікацію, співробітники не можуть заходити на Брацьку Пошту, Брацьку Кринку, а також службові частини Брацької Справи.

Сервер LDAP

OpenLDAP встановлено 2.4; записи зберігаються в LDIF у незашифрованому вигляді. Сервер LDAP працює паралельно з основним сервером. Обмеження OpenLDAP -- для зручного переходу з однієї програми на іншу неможливо налаштувати SSO без додаткових програм. Також існують проблеми використання OpenLDAP з Брацькою Поштою та новими версіями MediaWiki, які використовуються в Брацькій Правці.

Определение ролей

Определение ролей пользователей должно происходить в одном из двух режимах:

  1. В автоматическом режиме должны назначаться федеративные пользовательские роли, например, слушателя Брацкой Вводки; и
  2. В ручном режиме должны назначаться роли, которые специфичны именно для Оплёта. В данный момент, единственная такая назначаемая роль -- это администратор Оплёта. Позже могут быть добавлены роли администраторов отдельных модулей.

Автоматическое назначение

Сами пользовательские роли должны быть разработаны далее. Предварительно, будут задействованы девять ролей:
Роль Условие автоматического получения роли Автоматические доступы
Русский English
Неавторизованный NetAnyone Отсутствие условий -- любой посетитель сети Интернет (как зарегистрированный, так и нет), который не авторизовался в Оплёте. Смотри Автоматические доступы
Подписчик NetProspect Подписка на рассылку делает неавторизованного пользователя Подписчиком.
Клиент NetCustomer Пожертвование или покупка в магазине Careerprise Shop
Интересующийся NetConsumer Запись на курс Брацка Вводка -- эта роль присваивается автоматически любому слушателю вводного курса временно, на шесть месяцев.
Студент CertStudent Завершение курса Брацка Вводка
Пользователь CertUser Завершение курса Брацки Техобзор
Стажёр CertFellow Завершение семинара Выбор Профессии

Ручное назначение

Приложение Роль Доступы
Русский English
Оплёт Бюрократ Bureaucrat Помимо всех доступов пользователя, бюрократ имеет доступ к учётным карточкам и, в частности, может регистрировать в ручном режиме новых пользователей, редактировать их карточки и назначать роли за исключением бюрократов и сисопов.
Сисоп Sysop Сисоп (системный оператор) может всё.

Регистрация

Создание и ведение учётных карточек пользователей, то есть, фактически, управление базами данных всех сотрудников и клиентов Брацкой Школы, является ключевой функцией Оплёта. Выполнение всех услуг, переданных от отдельных пользовательских приложений Оплёту, зависит от качественных данных о том, что каждый пользователь Облака может делать на Облаке. Сам Оплёт, в свою очередь, поддерживается облачной инфраструктурой.

Обычные и корпоративные карточки

Существует два типа учётных карточек:
  1. Обычные учётные карточки, которые не содержат Корпоративных псевдонимов, заводятся автоматически в один этап и могут дать доступ к некоторым, но не всем пользовательским приложениям;
  2. Корпоративные учётные карточки, которые содержат всё, что обычные учётные карточки содержат и, в дополнение, хранят Корпоративные псевдонимы, а также регистрационные имена и корпоративные имэйлы, основанные на них. Корпоративные карточки заводятся либо (1) автоматически в два этапа -- временные для участия в курсах Брацка Вводка, Брацки Техобзор и постоянные после завершения этих курсов, либо (2) вручную в один этап. Карточки этого типа нужны для доступа к Брацкой Поште, Брацкой Крынке, а также служебным частям Брацкой Справы.

Методы регистрации

Регистрация новых пользователей, фактически, заведение новых учётных карточек этих пользователей, должна производиться двумя методами:
Метод регистрации Обычные учётные карточки Корпоративные учётные карточки
В автоматическом режиме Вход через стороннюю идентификацию, Подписку на рассылки, Покупка в магазине, Пожертвование
В ручном режиме Not available Ручная регистрация

Создание обычных карточек

  • Вход через стороннюю идентификацию: Если пользователь заходит в Облако через Стороннюю идентификацию, Оплёт:
    1. Собирает информацию об имени пользователя и его электронном адресе;
    2. Проверяет, существует ли такой пользователь в базе данных;
    3. Если пользователь не существует в базе, то Оплёт заводит новую учётную карточку;
    4. Заводит пользователя на Брацкой Учебке, создаёт Корпоративный псевдоним и даёт доступ к курсу Брацка Вводка;
    5. Отдаёт задание Брацкой Поште выслать пользователю сообщение о создании учётной карточки, доступе к курсу Брацка Вводка и личному кабинету.
  • Подписка на рассылки: Если пользователь отдаёт свой имэйл в качестве заявки на подписку на рассылку на любом из вэб-сайтов Брацкой Вебки, Оплёт:
    1. Проверяет, существует ли такой пользователь в базе данных;
    2. Если:
      • Пользователь существует, то Оплёт добавляет ту рассылку, на которую подписался пользователь, к его учётной карточке;
      • Пользователь не существует в базе, то Оплёт заводит новую учётную карточку и добавляет к ней ту рассылку, на которую подписался новый пользователь;
    3. Заводит пользователя на Брацкой Учебке, создаёт Корпоративный псевдоним, идентификатор и пароль, а также даёт доступ к курсу Брацка Вводка;
    4. Отдаёт задание Брацкой Поште выслать пользователю подтверждение подписки, сообщение о создании учётной карточки, доступе к курсу Брацка Вводка и личному кабинету;
    5. В случае, если на Брацкую Пошту приходит сообщение об:
      • Отсутствии существования указанного пользователем имэйла, проверяет, есть ли на карточке другие записи и:
        1. Если другие записи есть, и одна из них -- имэйл, то Оплёт отдаёт задание Брацкой Поште выслать пользователю запрос правильности имэйла;
        2. Если другие записи есть, но ни одна из них -- имэйл, то Оплёт просто помечает ошибку на учётной карточке;
        3. Если других записей нет, то Оплёт переводит учётную карточку в проблемные;
      • Отказе от какой-либо рассылки, Оплёт удаляет эту рассылку с учётной карточки.
  • Покупка в магазине: Если пользователь совершил покупку в Careerprise Shop, Оплёт заводит пользователя в качестве клиента Брацкой Школы на клиентском модуле Брацкой Справы.
  • Пожертвование: Если пользователь совершил пожертвование в Careerprise Shop, Оплёт заводит пользователя в качестве клиента Брацкой Школы на клиентском модуле Брацкой Справы.

Корпоративные псевдонимы

Основная вики-страница: Псевдоним пользователя Оплёта
Корпоративные псевдонимы создаются по формуле Имя Фамилия-На-Ых-Фамилия и прописываются в карточках сотрудников.

Регистрационные имена пользователей

Регистрационные имена пользователей заводятся исключительно английскими буквами на основе псевдонима по следующему принципу: полное имя + точка + минимальное количество букв фамилии на -ых, достаточное для соблюдения условия уникальности. Например, mina.n

Корпоративные имэйлы

Корпоративные имэйлы пользователей заводятся на основе Регистрационного имени пользователя по следующему принципу: регистрационное‑имя‑пользователя@opplet.net. Например, mina.n@opplet.net

Запись на вводный курс

Регистрация через запись на вводный курс -- единственная регистрация, по которой пользователь получает временный статус, который действителен в течение 3-х месяцев. Если пользователь не окончил курс в течение этого времени, то его регистрация аннулируется. Если пользователь на любом из вэб-сайтов Брацкой Вебки кликает на кнопки типа "Трудоустроиться", "Выучиться", "Стать волонтёром", "Стать партнёром" и так далее, Оплёт:
  1. Заводит временную учётную карточку со сведениями о том, (1) какая кнопка была нажата и (2) какой язык был использован;
  2. В принудительном порядке предлагает пользователю ввести тот логин и пароль, который будет удобен этому пользователю;
  3. В добровольном порядке предлагает пользователю ввести внешний имэйл;
  4. Проверяет, не является ли пользователь роботом;
  5. Заводит его пользователем Брацкой Учебки, Брацки Жици и Брацкой Бачки;
  6. Создаёт идентификатор и пароль, затем проверяет способ идентификации и учётную карточку на наличие электронного адреса. Если карточка:
    • Содержит адрес и пользователь использовал стороннюю идентификацию, то Оплёт отдаёт задание Брацкой Поште выслать имэйл с информацией об идентификаторе и пароле на имеющийся адрес, зачисляет и перенаправляет этого пользователя на вводную лекцию Курса;
    • Содержит адрес и пользователь использовал внутреннюю идентификацию, то Оплёт загружает такую страницу или зону: "Для Вас создан временный идентификатор -- zhenjas -- и пароль -- 01ZhenjaS20, которые будут актуальны в течение следующих 3х месяцев, которые даются на завершение курса". Для Вашего удобства, информация об идентификаторе и пароле отправлены на тот электронный адрес, который указан в Вашем личном кабинете," отдаёт задание Брацкой Поште выслать имэйл с информацией об идентификаторе и пароле на имеющийся адрес, зачисляет и перенаправляет этого пользователя на вводную лекцию Курса;
    • Не содержит адрес, то Оплёт загружает такую страницу или зону: "Для Вас создан временный идентификатор -- zhenjas -- и пароль -- 01ZhenjaS20, которые будут актуальны в течение следующих 3х месяцев, которые даются на завершение курса. Пожалуйста, сохраните этот идентификатор и пароль или отправьте их себе на электронную почту." с двумя кнопками: "Я сохранил это идентификатор и пароль" и "Отправьте идентификатор и пароль на мою электронную почту";
    • Если пользователь выбирает:
      1. "Отправьте идентификатор и пароль на мою электронную почту", то Оплёт запрашивает имэйл-адрес пользователя, отдаёт задание Брацка Пошта выслать имэйл-подтверждение на введённый адрес, зачисляет и перенаправляет этого пользователя на вводную лекцию Курса;
      2. "Я сохранил это идентификатор и пароль", то Оплёт зачисляет и перенаправляет этого пользователя на вводную лекцию Курса.
  7. Курс начинается с текста "Добро пожаловать в Брацкую Школу. Чтобы сохранить в тайне личные данные, все участники пользуются корпоративными псевдонимами. Вы зачислены на вводный курс, Брацка Вводка, под псевдонимом Женя Семашко. Если Вы хотите поменять имя, повторите процедуру регистрации с начала."

Ручная регистрация

Любой пользователь может быть создан вручную, а не только в автоматическом режиме.

Поля учётных карточек

Часть полей учётных карточек может заполняться пользователем при его желании, но не обязательны к заполнению. Часть тех полей, которые заполняются автоматически, может изменяться пользователем, в то время как некоторые поля не могут быть изменены.

Необязательные

Поле Тип Примечание
Имя (если необходимо для документов об окончании) Текст Заполняется при желании пользователя
Фамилия (если необходима для документов об окончании)
Внешний имэйл (если есть желание получать уведомления) Текст со значком @ и как минимум одной точкой после него
Язык(и) Выбор из списка Автоматически вписывается и сохраняется язык входа, который может быть изменён или добавлен пользователем вручную.

Изменяемые

Поле Примечание
Логин (изменить?) Поля с возможностью изменения
Пароль (изменить?)
Завершённые курсы (убрать?) Список с возможностью исключения
Курсы в прогрессе (отменить?)
Доступные приложения (отменить?)
Рассылки (изменить?) Список с возможностью исключения и добавления

Неизменяемые

Поле Примечание
Идентификационный номер пользователя Генерируется автоматически и проверяется на уникальность
Регистрационное имя пользователя Генерируется автоматически по логике Регистрационных имён пользователей
Псевдоним пользователя Оплёта Генерируется автоматически по логике Псевдонимов пользователя Оплёта
Корпоративный имэйл Генерируется автоматически по логике Корпоративных имэйлов

Пользовательский интерфэйс

С живыми пользователями, Оплёт сообщается тремя путями:

  1. Через интерфэйс личного кабинета;
  2. Почтовый сервис. Пока настроен sendmail, но почта приходит в спам. Установлен, но не настроен Postfix. Задача настройки пока отложена. На полноценную почту планируется позже нанять специалиста. Возможно, экономически целесообразнее будет собрать Брацкую Пошту.
  3. Для тех пользователей, которые пользуются социальным логином, настроен OAuth 2.0 протокол. В данный момент есть проблемы прописывания "социальных пользователей" в Оплёте.

Незарегистрированный пользователь видит только титульную страницу:

  • На шапке слева -- Opplet; справа -- SignUp (клик регистрирует пользователя в роли Временный);
  • В основном поле -- два поля Login и Password;
  • В подвале слева -- © Opplet [текущий год]; справа -- Powered by Yii Framework

Ведение личного кабинета

Личный кабинет является той частью учётной карточки пользователя, к которой пользователь имеет доступ и право редактирования.

Интересы

Оплёт собирает информацию о поведении пользователя, особенно, какие кнопки пользователь выбирает находясь на Облаке, для формирования центра действий именуемого "Интересы". Центр действий включает в себя 6 групп:
  1. Учёба и трудоустройство
  2. Трудоустройство (без учёбы)
  3. Волонтёрство
  4. Партнёрство
  5. Учёба (без трудоустройства)
  6. Благотворительность
Активные группы занимают отдельные зоны и включают кнопку "Сделать зону неактивной"; неактивные -- даны иконками под общим заголовком Ещё.

Личные данные

Личные данные включают в себя следующие поля:
  1. Имя (как должно появляться на документах об окончании)
  2. Фамилия (как должна появляться на документах об окончании)
  3. Корпоративный псевдоним
  4. Имэйл

Приложения

Приложения, которые доступны для пользователя, зависят от действий пользователя согласно Автоматическому назначению ролей, если доступы не установлены вручную. Если пользовательские приложения предоставляют пользователям доступ к личным кабинетам внутри приложений, то ссылки от личного кабинета идут на них.

Языки

Оплёт собирает информацию о том, какие языки выбирает пользователь и об языках его операционных систем пользователя, для формирования центра управления языками.

Рассылки

Оплёт управляет данными о том, на какие рассылки подписан пользователь.

Авторизация доступов

Авторизация пользователей разрешает доступы:

  1. Автоматические к пользовательским ресурсам, например, к Брацкой Поште или Брацки Жици. Завершение вводного курса необходимо для автоматических доступов;
  2. Ручные к административным ресурсам, например, к отдельным проектам Брацкой Крынки.

Завершение вводного курса

Если в течение 3х месяцев пользователь:
  • Успешно завершает Курс, то Оплёт:
    1. Заводит его пользователем Брацкой Правки и зачисляет на семинар Выбор Профессии;
    2. Если пользователь при первоначальной записи выбирал кнопку:
      • "Трудоустроиться", то Оплёт загружает страницу "Поздравляем с успешным завершением курса. Вы выражали интерес к трудоустройству. Вы желаете трудоустроиться через Брацкую Школу, не платя за услуги из своего кармана, или заказать платные услуги по трудоустройству? Кстати, если Ваш интерес поменялся, в Личном кабинете Вы всегда можете изменить своё решение." с кнопками "Трудоустроиться через Брацкую Школу", "Заказать платные услуги по трудоустройству" и "Что-то ещё";
        1. Если пользователь выбрал кнопку: "Трудоустроиться через Брацкую Школу", то Оплёт обновляет информацию учётной карточки. Регистрация в этом случае следует правилам описанным на вики-странице Лестница к Профессии. Оплёт перенаправляет этого пользователя на семинар Выбор Профессии. После завершения этого семинара, Оплёт даёт пользователю доступ к Брацкой Вебке, Брацкой Поште и Брацкой Справе, а также зачисляет его в слушатели Семь Технологических Искусств и Семь Административных Искусств;
        2. Если пользователь выбрал кнопку: "Заказать платные услуги по трудоустройству", то Оплёт обновляет информацию учётной карточки и перенаправляет этого пользователя в Careerprise Shop;
        3. Если пользователь выбрал кнопку: "Что-то ещё", то Оплёт обновляет информацию учётной карточки и перенаправляет этого пользователя в Личный кабинет;
      • "Выучиться", то Оплёт загружает страницу "Поздравляем с успешным завершением курса. Вы желаете совмещать учёбу и работу в Брацкой Школе, не платя за услуги из своего кармана, или заказать платные услуги образования? Кстати, если Ваш интерес поменялся, в Личном кабинете Вы всегда можете изменить своё решение." с кнопками "Учиться и работать в Брацкой Школе", "Заказать платные услуги образования", "Что-то ещё";
        1. Если пользователь выбрал кнопку: "Учиться и работать в Брацкой Школе", то Оплёт обновляет информацию учётной карточки и перенаправляет его на семинар Выбор Профессии. После завершения этого семинара, Оплёт даёт пользователю доступ к Брацкой Вебке, Брацкой Поште и Брацкой Справе, а также зачисляет его в слушатели Семь Технологических Искусств и Семь Административных Искусств;
        2. Если пользователь выбрал кнопку: "Заказать платные услуги образования", то Оплёт обновляет информацию учётной карточки и перенаправляет этого пользователя на Careerprise Shop;
        3. Если пользователь выбрал кнопку: "Что-то ещё", то Оплёт обновляет информацию учётной карточки и перенаправляет этого пользователя в Личный кабинет;
      • "Стать волонтёром", то Оплёт загружает страницу "Поздравляем с успешным завершением курса. Вы выражали желание стать волонтёром Брацкой Школы, потому мы зачисляем Вас на семинар Как стать волонтёром Брацкой Школы. Кстати, если Ваш интерес поменялся, в Личном кабинете Вы всегда можете изменить своё решение." с кнопками "Зачислить на семинар "Как стать волонтёром"", "Что-то ещё";
        1. Если пользователь выбрал кнопку: "Зачислить на семинар "Как стать волонтёром"", то Оплёт перенаправляет его на семинар Как стать волонтёром Брацкой Школы. После завершения этого семинара, Оплёт даёт пользователю доступ к Брацкой Поште и Брацкой Справе, а также заводит его в качестве кандидата в волонтёры Брацкой Школы на рекрутинговом модуле Брацкой Справы;
        2. Если пользователь выбрал кнопку: "Что-то ещё", то Оплёт обновляет информацию учётной карточки и перенаправляет этого пользователя в Личный кабинет;
      • "Стать партнёром", то Оплёт загружает страницу "Поздравляем с успешным завершением курса. Вы выражали желание стать партнёром Брацкой Школы, потому мы зачисляем Вас на семинар Как стать партнёром Брацкой Школы. Партнёром может быть любой работодатель, поставщик услуг по подготовке кадров и рекрутингу или любое иное лицо, заинтересованное в развитии Брацкой Школы. Кстати, если Ваш интерес поменялся, в Личном кабинете Вы всегда можете изменить своё решение." с кнопками "Зачислить на семинар "Как стать партнёром"", "Что-то ещё";
        1. Если пользователь выбрал кнопку: "Зачислить на семинар "Как стать партнёром"", то Оплёт перенаправляет его на семинар Как стать партнёром Брацкой Школы. После завершения этого семинара, Оплёт заводит пользователя в качестве кандидата в партнёры Брацкой Школы на клиентском модуле Брацкой Справы;
        2. Если пользователь выбрал кнопку: "Что-то ещё", то Оплёт обновляет информацию учётной карточки и перенаправляет этого пользователя в Личный кабинет.
  • Не завершает Курс и:
    1. Идентифицировался внутренне, то Оплёт удаляет его учётную карточку;
    2. Идентифицировался сторонне, то Оплёт оставляет его учётную карточку актуальной, но исключает из Курса и высылает соответствующее сообщение на электронный адрес.

Автоматические доступы

Роль Оплёт Учебка Правка Бачка Жици Справа Пошта Вебка Крынка
Неавторизованный Нет доступа далее входной страницы Доступ к просмотру всех материалов Доступ к просмотру открытых материалов Нет доступа далее входной страницы
Временный Только на 3 месяца Доступ в качестве пользователя Нет доступа далее входной страницы
Подписчик Любой имеет доступ к личному кабинету Доступ к курсу Брацка Вводка Доступ в качестве пользователя Доступ в качестве пользователя
Клиент Доступ в качестве клиента Нет доступа далее входной страницы
Кандидат Доступ к семинарам Как стать партнёром, волонтёром и трудоустроиться
Студент Доступ к Семь Технологических Искусств и Семь Административных Искусств
Волонтёр
Партнёр Доступ в качестве пользователя
Сотрудник Доступ к любым курсам Доступ в качестве пользователя

Ручные доступы

Любые роли могут быть назначены в ручном режиме согласно иерархии ролей Оплёта.

Технические детали

Оплёт написан на Yii (сейчас версия 2.0.8). Наиболее современная версия -- 2.0.41, но обновление "ломает" сайт, нужно проверить что менялось и заменить у себя.

Перспективные услуги

Перспективно, Оплёт должен предоставлять следующие услуги:
  1. Регулировать загрузку, хранение и использование версий исходных кодов, скорее всего, совместно с инсталляцией Redmine;
  2. Регулировать загрузку, хранение и использование версий баз данных и снимков облаков;
  3. Вести календарь событий и обеспечивать организацию мероприятий.

Требования к разработке

  • Создать базу данных mysite
  • Зальем дамп таблицы users (код дампа ниже)
  • Сделаем форму регистрации и обработчик на PHP
  • Сделаем форму входа и обработчик
  • Сделаем мини-профиль после логина

Текущие проблемы и направления их решений

  1. Схема данных OpenLDAP требует заполнения обязательных полей профилей пользователя. Так как Оплёт не требует ни имэйлов, ни имён, они генерируются, проверяются на уникальность и присваиваются автоматически. Так же как номера записи и типы обьектов.
  2. Говоря о стратегии, она -- в максимальном уменьшении заполняемых вручную полей и в максимальном увеличении той информации, которая может собираться автоматически -- точки входа, логи, даже клики, языки и так далее.
  3. Есть нерешённая проблема по роли подписчика. Можно либо не создавать пользователя вовсе, так как пользователь с любой ролью может быть подписчиком и это скорее не роль, а свойство профиля клиента. Отписку же проводить через отписной имэйл, а не заходом в личный кабинет. Либо создавать пользователя понимая, что подписчик -- это только тот, кто пока далее подписки не пошёл и другой роли пока не получил.
  4. Работу над проблемами планируется перенести на Redmine или Брацкую Крынку, для чего основной разработчик должен провести тренинг.

Связанные лектио