Оплёт — различия между версиями
Gary (обсуждение | вклад) (→Автоматическое назначение) |
Sonya (обсуждение | вклад) (→Связанные лектио) |
||
(не показано 25 промежуточных версий 2 участников) | |||
Строка 32: | Строка 32: | ||
:Также обсуждалось, что эти новые модули могут быть реализованы отдельными приложениями. | :Также обсуждалось, что эти новые модули могут быть реализованы отдельными приложениями. | ||
− | === | + | ===Федерация=== |
− | :Идентификационный сервер | + | :Для взаимодействия с другими приложениями [[Брацко Облако|Брацка Облака]], ''Оплёт'' включает или должен включать в себя три федерационных блока: |
+ | :#Идентификационный сервер, собранный на базе [[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]] в качестве параллельного канала идентификации и авторизации. | |
− | |||
− | == | + | ===Основной сервер=== |
+ | :Основной сервер для взаимосвязи ''Оплёта'' с пользовательскими приложениями через [[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]], которые используются в [[Брацка Правка|Брацкой Правке]]. |
==Определение ролей== | ==Определение ролей== | ||
Строка 74: | Строка 76: | ||
|- | |- | ||
!Неавторизованный | !Неавторизованный | ||
− | |NetAnyone||Отсутствие условий -- любой посетитель сети Интернет (как зарегистрированный, так и нет), который не авторизовался в Оплёте.||rowspan=" | + | |NetAnyone||Отсутствие условий -- любой посетитель сети Интернет (как зарегистрированный, так и нет), который не авторизовался в Оплёте.||rowspan="7"|Смотри [[#Автоматические доступы|Автоматические доступы]] |
|- | |- | ||
!Подписчик | !Подписчик | ||
|NetProspect||Подписка на рассылку делает неавторизованного пользователя ''Подписчиком''. | |NetProspect||Подписка на рассылку делает неавторизованного пользователя ''Подписчиком''. | ||
+ | |- | ||
+ | !Клиент | ||
+ | |NetCustomer||Пожертвование или покупка в магазине [[Careerprise Shop]] | ||
|- | |- | ||
!Интересующийся | !Интересующийся | ||
− | |NetConsumer||Запись на курс [[Брацка Вводка]] -- эта роль присваивается автоматически любому слушателю вводного курса временно, на | + | |NetConsumer||Запись на курс [[Брацка Вводка]] -- эта роль присваивается автоматически любому слушателю вводного курса временно, на шесть месяцев. |
|- | |- | ||
− | ! | + | !Студент |
− | | | + | |CertStudent||Завершение курса [[Брацка Вводка]] |
|- | |- | ||
!Пользователь | !Пользователь | ||
|CertUser||Завершение курса [[Брацки Техобзор]] | |CertUser||Завершение курса [[Брацки Техобзор]] | ||
|- | |- | ||
− | ! | + | !Стажёр |
− | | | + | |CertFellow||Завершение семинара [[Выбор Профессии]] |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
|} | |} | ||
Строка 149: | Строка 145: | ||
:*#Заводит пользователя на [[Брацка Учебка|Брацкой Учебке]], создаёт [[Псевдоним пользователя Оплёта|Корпоративный псевдоним]] и даёт доступ к курсу [[Брацка Вводка]]; | :*#Заводит пользователя на [[Брацка Учебка|Брацкой Учебке]], создаёт [[Псевдоним пользователя Оплёта|Корпоративный псевдоним]] и даёт доступ к курсу [[Брацка Вводка]]; | ||
:*#Отдаёт задание [[Брацка Пошта|Брацкой Поште]] выслать пользователю сообщение о создании учётной карточки, доступе к курсу [[Брацка Вводка]] и личному кабинету. | :*#Отдаёт задание [[Брацка Пошта|Брацкой Поште]] выслать пользователю сообщение о создании учётной карточки, доступе к курсу [[Брацка Вводка]] и личному кабинету. | ||
− | :*'''Подписка на рассылки''': Если пользователь отдаёт свой имэйл в качестве заявки на подписку на рассылку на любом из вэб-сайтов [[Брацка | + | :*'''Подписка на рассылки''': Если пользователь отдаёт свой имэйл в качестве заявки на подписку на рассылку на любом из вэб-сайтов [[Брацка Вебка|Брацкой Вебки]], ''Оплёт'': |
:*#Проверяет, существует ли такой пользователь в базе данных; | :*#Проверяет, существует ли такой пользователь в базе данных; | ||
:*#Если: | :*#Если: | ||
Строка 176: | Строка 172: | ||
===Запись на вводный курс=== | ===Запись на вводный курс=== | ||
− | :Регистрация через запись на вводный курс -- единственная регистрация, по которой пользователь получает временный статус, который действителен в течение 3-х месяцев. Если пользователь не окончил курс в течение этого времени, то его регистрация аннулируется. Если пользователь на любом из вэб-сайтов [[Брацка | + | :Регистрация через запись на вводный курс -- единственная регистрация, по которой пользователь получает временный статус, который действителен в течение 3-х месяцев. Если пользователь не окончил курс в течение этого времени, то его регистрация аннулируется. Если пользователь на любом из вэб-сайтов [[Брацка Вебка|Брацкой Вебки]] кликает на кнопки типа "Трудоустроиться", "Выучиться", "Стать волонтёром", "Стать партнёром" и так далее, ''Оплёт'': |
:#Заводит временную учётную карточку со сведениями о том, (1) какая кнопка была нажата и (2) какой язык был использован; | :#Заводит временную учётную карточку со сведениями о том, (1) какая кнопка была нажата и (2) какой язык был использован; | ||
:#В принудительном порядке предлагает пользователю ввести тот логин и пароль, который будет удобен этому пользователю; | :#В принудительном порядке предлагает пользователю ввести тот логин и пароль, который будет удобен этому пользователю; | ||
Строка 241: | Строка 237: | ||
==Пользовательский интерфэйс== | ==Пользовательский интерфэйс== | ||
+ | С живыми пользователями, ''Оплёт'' сообщается тремя путями: | ||
+ | #Через [[#Пользовательский интерфэйс|интерфэйс личного кабинета]]; | ||
+ | #Почтовый сервис. Пока настроен [[sendmail]], но почта приходит в спам. Установлен, но не настроен [[Postfix]]. Задача настройки пока отложена. На полноценную почту планируется позже нанять специалиста. Возможно, экономически целесообразнее будет собрать [[Брацка Пошта|Брацкую Пошту]]. | ||
+ | #Для тех пользователей, которые пользуются социальным логином, настроен [[OAuth 2.0]] протокол. В данный момент есть проблемы прописывания "социальных пользователей" в ''Оплёте''. | ||
+ | |||
Незарегистрированный пользователь видит только титульную страницу: | Незарегистрированный пользователь видит только титульную страницу: | ||
*На шапке слева -- Opplet; справа -- SignUp (клик регистрирует пользователя в роли Временный); | *На шапке слева -- Opplet; справа -- SignUp (клик регистрирует пользователя в роли Временный); | ||
Строка 275: | Строка 276: | ||
===Рассылки=== | ===Рассылки=== | ||
:''Оплёт'' управляет данными о том, на какие рассылки подписан пользователь. | :''Оплёт'' управляет данными о том, на какие рассылки подписан пользователь. | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
==Авторизация доступов== | ==Авторизация доступов== | ||
Строка 298: | Строка 288: | ||
:*#Если пользователь при первоначальной записи выбирал кнопку: | :*#Если пользователь при первоначальной записи выбирал кнопку: | ||
:*#*"Трудоустроиться", то ''Оплёт'' загружает страницу "Поздравляем с успешным завершением курса. Вы выражали интерес к трудоустройству. Вы желаете трудоустроиться через Брацкую Школу, не платя за услуги из своего кармана, или заказать платные услуги по трудоустройству? Кстати, если Ваш интерес поменялся, в [[#Личный кабинет|Личном кабинете]] Вы всегда можете изменить своё решение." с кнопками "Трудоустроиться через Брацкую Школу", "Заказать платные услуги по трудоустройству" и "Что-то ещё"; | :*#*"Трудоустроиться", то ''Оплёт'' загружает страницу "Поздравляем с успешным завершением курса. Вы выражали интерес к трудоустройству. Вы желаете трудоустроиться через Брацкую Школу, не платя за услуги из своего кармана, или заказать платные услуги по трудоустройству? Кстати, если Ваш интерес поменялся, в [[#Личный кабинет|Личном кабинете]] Вы всегда можете изменить своё решение." с кнопками "Трудоустроиться через Брацкую Школу", "Заказать платные услуги по трудоустройству" и "Что-то ещё"; | ||
− | :*#*#Если пользователь выбрал кнопку: "Трудоустроиться через Брацкую Школу", то ''Оплёт'' обновляет информацию учётной карточки. Регистрация в этом случае следует правилам описанным на вики-странице [[Лестница к Профессии]]. ''Оплёт'' перенаправляет этого пользователя на семинар [[Выбор Профессии]]. После завершения этого семинара, ''Оплёт'' даёт пользователю доступ к [[Брацка | + | :*#*#Если пользователь выбрал кнопку: "Трудоустроиться через Брацкую Школу", то ''Оплёт'' обновляет информацию учётной карточки. Регистрация в этом случае следует правилам описанным на вики-странице [[Лестница к Профессии]]. ''Оплёт'' перенаправляет этого пользователя на семинар [[Выбор Профессии]]. После завершения этого семинара, ''Оплёт'' даёт пользователю доступ к [[Брацка Вебка|Брацкой Вебке]], [[Брацка Пошта|Брацкой Поште]] и [[Брацка Справа|Брацкой Справе]], а также зачисляет его в слушатели [[Семь Технологических Искусств]] и [[Семь Административных Искусств]]; |
:*#*#Если пользователь выбрал кнопку: "Заказать платные услуги по трудоустройству", то ''Оплёт'' обновляет информацию учётной карточки и перенаправляет этого пользователя в [[Careerprise Shop]]; | :*#*#Если пользователь выбрал кнопку: "Заказать платные услуги по трудоустройству", то ''Оплёт'' обновляет информацию учётной карточки и перенаправляет этого пользователя в [[Careerprise Shop]]; | ||
:*#*#Если пользователь выбрал кнопку: "Что-то ещё", то ''Оплёт'' обновляет информацию учётной карточки и перенаправляет этого пользователя в [[#Личный кабинет|Личный кабинет]]; | :*#*#Если пользователь выбрал кнопку: "Что-то ещё", то ''Оплёт'' обновляет информацию учётной карточки и перенаправляет этого пользователя в [[#Личный кабинет|Личный кабинет]]; | ||
:*#*"Выучиться", то ''Оплёт'' загружает страницу "Поздравляем с успешным завершением курса. Вы желаете совмещать учёбу и работу в Брацкой Школе, не платя за услуги из своего кармана, или заказать платные услуги образования? Кстати, если Ваш интерес поменялся, в [[#Личный кабинет|Личном кабинете]] Вы всегда можете изменить своё решение." с кнопками "Учиться и работать в Брацкой Школе", "Заказать платные услуги образования", "Что-то ещё"; | :*#*"Выучиться", то ''Оплёт'' загружает страницу "Поздравляем с успешным завершением курса. Вы желаете совмещать учёбу и работу в Брацкой Школе, не платя за услуги из своего кармана, или заказать платные услуги образования? Кстати, если Ваш интерес поменялся, в [[#Личный кабинет|Личном кабинете]] Вы всегда можете изменить своё решение." с кнопками "Учиться и работать в Брацкой Школе", "Заказать платные услуги образования", "Что-то ещё"; | ||
− | :*#*#Если пользователь выбрал кнопку: "Учиться и работать в Брацкой Школе", то ''Оплёт'' обновляет информацию учётной карточки и перенаправляет его на семинар [[Выбор Профессии]]. После завершения этого семинара, ''Оплёт'' даёт пользователю доступ к [[Брацка | + | :*#*#Если пользователь выбрал кнопку: "Учиться и работать в Брацкой Школе", то ''Оплёт'' обновляет информацию учётной карточки и перенаправляет его на семинар [[Выбор Профессии]]. После завершения этого семинара, ''Оплёт'' даёт пользователю доступ к [[Брацка Вебка|Брацкой Вебке]], [[Брацка Пошта|Брацкой Поште]] и [[Брацка Справа|Брацкой Справе]], а также зачисляет его в слушатели [[Семь Технологических Искусств]] и [[Семь Административных Искусств]]; |
:*#*#Если пользователь выбрал кнопку: "Заказать платные услуги образования", то ''Оплёт'' обновляет информацию учётной карточки и перенаправляет этого пользователя на [[Careerprise Shop]]; | :*#*#Если пользователь выбрал кнопку: "Заказать платные услуги образования", то ''Оплёт'' обновляет информацию учётной карточки и перенаправляет этого пользователя на [[Careerprise Shop]]; | ||
:*#*#Если пользователь выбрал кнопку: "Что-то ещё", то [[Оплёт]] обновляет информацию учётной карточки и перенаправляет этого пользователя в [[#Личный кабинет|Личный кабинет]]; | :*#*#Если пользователь выбрал кнопку: "Что-то ещё", то [[Оплёт]] обновляет информацию учётной карточки и перенаправляет этого пользователя в [[#Личный кабинет|Личный кабинет]]; | ||
Строка 317: | Строка 307: | ||
===Автоматические доступы=== | ===Автоматические доступы=== | ||
:{|class="wikitable" width=100% style="text-align:center;" | :{|class="wikitable" width=100% style="text-align:center;" | ||
− | ![[#Роли|Роль]]!!''Оплёт''!![[Брацка Учебка|Учебка]]!![[Брацка Правка|Правка]]!![[Брацка Бачка|Бачка]]!![[Брацки Жици|Жици]]!![[Брацка Справа|Справа]]!![[Брацка Пошта|Пошта]]!![[Брацка | + | ![[#Роли|Роль]]!!''Оплёт''!![[Брацка Учебка|Учебка]]!![[Брацка Правка|Правка]]!![[Брацка Бачка|Бачка]]!![[Брацки Жици|Жици]]!![[Брацка Справа|Справа]]!![[Брацка Пошта|Пошта]]!![[Брацка Вебка|Вебка]]!![[Брацка Крынка|Крынка]] |
|- | |- | ||
|[[#Роли|Неавторизованный]] | |[[#Роли|Неавторизованный]] | ||
Строка 369: | Строка 359: | ||
:#Есть нерешённая проблема по роли подписчика. Можно либо не создавать пользователя вовсе, так как пользователь с любой ролью может быть подписчиком и это скорее не роль, а свойство профиля клиента. Отписку же проводить через отписной имэйл, а не заходом в личный кабинет. Либо создавать пользователя понимая, что подписчик -- это только тот, кто пока далее подписки не пошёл и другой роли пока не получил. | :#Есть нерешённая проблема по роли подписчика. Можно либо не создавать пользователя вовсе, так как пользователь с любой ролью может быть подписчиком и это скорее не роль, а свойство профиля клиента. Отписку же проводить через отписной имэйл, а не заходом в личный кабинет. Либо создавать пользователя понимая, что подписчик -- это только тот, кто пока далее подписки не пошёл и другой роли пока не получил. | ||
:#Работу над проблемами планируется перенести на [[Redmine]] или [[Брацка Крынка|Брацкую Крынку]], для чего основной разработчик должен провести тренинг. | :#Работу над проблемами планируется перенести на [[Redmine]] или [[Брацка Крынка|Брацкую Крынку]], для чего основной разработчик должен провести тренинг. | ||
+ | |||
+ | ==Связанные лектио== | ||
+ | *[[Структура Облака]] | ||
+ | *[[Что Есть Оплёт]] | ||
+ | *[[Учебка в Облаке]] | ||
+ | *[[Составные Защиты]] | ||
+ | *[[Новые Технологии]] | ||
+ | *[[Степени Разработок]] |
Текущая версия на 15:12, 25 сентября 2022
Оплёт (Opplet; WorldOpp Middleware) -- федеративное, промежуточное и связующее программное обеспечение, которое обслуживает все пользовательские приложения Брацкого Облака (здесь и далее по тексту -- Облака), для которого Оплёт специально создан. Оплёт и пользовательские приложения образуют единую федеративную систему, в которой Оплёт играет роль федерального центра. Оплёт предоставляет приложениям Облака те Услуги, которые переданы от приложений Оплёту. Фактически Оплёт делает Облако единым Облаком.
Содержание
Функции
Федеративные услуги
- Федеративные услуги -- это исключительные услуги Oплёта. Ни одно из пользовательских приложений не имеет возможности предоставлять эти услуги индивидуальным пользователям. Личные кабинеты пользователей, которые некоторые приложения типа Брацкой Правки или Брацкой Учебки могут иметь собственные кабинеты. Кабинеты этих приложений дополняют личный кабинет Оплёта, но не заменяют его. Оплёт автоматически заполняет все те поля пользователей, которые могут требовать отдельные приложения. Оплёт предоставляет следующие федеративные услуги:
Услуги Описание Потребители Ведение личного кабинета Оплёт даёт пользователям возможность управлять той частью их учётных записей, которая называется "Личным кабинетом" Индивидуальные пользователи Идентификация пользователей, Регистрация новых пользователей, Авторизация доступов пользователей к отдельным приложениям, Определение ролей пользователей и другие услуги Оплёт получает запросы пользовательских приложений Облака посредством API, обрабатывает их, используя учётные карточки, и отдаёт обработанные запросы тем же путём, которым эти запросы были получены. Пользовательские приложения
Безопасность
- Сотрудники и авторизованные пользователи могут иметь обычный доступ через вэб-броузеры только к своим профилям. Всё остальное Центральное обслуживание доступно исключительно администраторам по PKI.
Дополнительные функции
- Служить одной из площадок для дальнейшего развития профессиональных навыков участников учебных программ.
Структура
Ядро
- Ядро приложения составляет движок управления пользователями и сервер для пользовательских данных MariaDB.
Модули
- Обсуждалось создание трёх новых модулей Оплёта:
- Для управления данными тех событий, которые важны для пользователей -- лекции, семинары, практика и так далее;
- Для управления экзаменационными вопросами. Вопросы бы отражались для отдельного пользователя вне зависимости от курса и приложения;
- Для автоматической записи на курсы. Функционал для записи на один курс по окончанию другого существует в Moodle, но его не достаточно для создания учебных програм, учитывающих специфические пожелания студента.
- Также обсуждалось, что эти новые модули могут быть реализованы отдельными приложениями.
Федерация
- Для взаимодействия с другими приложениями Брацка Облака, Оплёт включает или должен включать в себя три федерационных блока:
- Идентификационный сервер, собранный на базе 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 в качестве параллельного канала идентификации и авторизации.
Основной сервер
- Основной сервер для взаимосвязи Оплёта с пользовательскими приложениями через 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, которые используются в Брацкой Правке.
Определение ролей
Определение ролей пользователей должно происходить в одном из двух режимах:
- В автоматическом режиме должны назначаться федеративные пользовательские роли, например, слушателя Брацкой Вводки; и
- В ручном режиме должны назначаться роли, которые специфичны именно для Оплёта. В данный момент, единственная такая назначаемая роль -- это администратор Оплёта. Позже могут быть добавлены роли администраторов отдельных модулей.
Автоматическое назначение
- Сами пользовательские роли должны быть разработаны далее. Предварительно, будут задействованы девять ролей:
Роль Условие автоматического получения роли Автоматические доступы Русский English Неавторизованный NetAnyone Отсутствие условий -- любой посетитель сети Интернет (как зарегистрированный, так и нет), который не авторизовался в Оплёте. Смотри Автоматические доступы Подписчик NetProspect Подписка на рассылку делает неавторизованного пользователя Подписчиком. Клиент NetCustomer Пожертвование или покупка в магазине Careerprise Shop Интересующийся NetConsumer Запись на курс Брацка Вводка -- эта роль присваивается автоматически любому слушателю вводного курса временно, на шесть месяцев. Студент CertStudent Завершение курса Брацка Вводка Пользователь CertUser Завершение курса Брацки Техобзор Стажёр CertFellow Завершение семинара Выбор Профессии
Ручное назначение
Приложение Роль Доступы Русский English Оплёт Бюрократ Bureaucrat Помимо всех доступов пользователя, бюрократ имеет доступ к учётным карточкам и, в частности, может регистрировать в ручном режиме новых пользователей, редактировать их карточки и назначать роли за исключением бюрократов и сисопов. Сисоп Sysop Сисоп (системный оператор) может всё.
Регистрация
Создание и ведение учётных карточек пользователей, то есть, фактически, управление базами данных всех сотрудников и клиентов Брацкой Школы, является ключевой функцией Оплёта. Выполнение всех услуг, переданных от отдельных пользовательских приложений Оплёту, зависит от качественных данных о том, что каждый пользователь Облака может делать на Облаке. Сам Оплёт, в свою очередь, поддерживается облачной инфраструктурой.
Обычные и корпоративные карточки
- Существует два типа учётных карточек:
- Обычные учётные карточки, которые не содержат Корпоративных псевдонимов, заводятся автоматически в один этап и могут дать доступ к некоторым, но не всем пользовательским приложениям;
- Корпоративные учётные карточки, которые содержат всё, что обычные учётные карточки содержат и, в дополнение, хранят Корпоративные псевдонимы, а также регистрационные имена и корпоративные имэйлы, основанные на них. Корпоративные карточки заводятся либо (1) автоматически в два этапа -- временные для участия в курсах Брацка Вводка, Брацки Техобзор и постоянные после завершения этих курсов, либо (2) вручную в один этап. Карточки этого типа нужны для доступа к Брацкой Поште, Брацкой Крынке, а также служебным частям Брацкой Справы.
Методы регистрации
- Регистрация новых пользователей, фактически, заведение новых учётных карточек этих пользователей, должна производиться двумя методами:
Метод регистрации Обычные учётные карточки Корпоративные учётные карточки В автоматическом режиме Вход через стороннюю идентификацию, Подписку на рассылки, Покупка в магазине, Пожертвование - Запись на вводный курс (временно); и
- Завершение вводного курса (постоянно)
В ручном режиме Not available Ручная регистрация
Создание обычных карточек
- Вход через стороннюю идентификацию: Если пользователь заходит в Облако через Стороннюю идентификацию, Оплёт:
- Собирает информацию об имени пользователя и его электронном адресе;
- Проверяет, существует ли такой пользователь в базе данных;
- Если пользователь не существует в базе, то Оплёт заводит новую учётную карточку;
- Заводит пользователя на Брацкой Учебке, создаёт Корпоративный псевдоним и даёт доступ к курсу Брацка Вводка;
- Отдаёт задание Брацкой Поште выслать пользователю сообщение о создании учётной карточки, доступе к курсу Брацка Вводка и личному кабинету.
- Подписка на рассылки: Если пользователь отдаёт свой имэйл в качестве заявки на подписку на рассылку на любом из вэб-сайтов Брацкой Вебки, Оплёт:
- Проверяет, существует ли такой пользователь в базе данных;
- Если:
- Пользователь существует, то Оплёт добавляет ту рассылку, на которую подписался пользователь, к его учётной карточке;
- Пользователь не существует в базе, то Оплёт заводит новую учётную карточку и добавляет к ней ту рассылку, на которую подписался новый пользователь;
- Заводит пользователя на Брацкой Учебке, создаёт Корпоративный псевдоним, идентификатор и пароль, а также даёт доступ к курсу Брацка Вводка;
- Отдаёт задание Брацкой Поште выслать пользователю подтверждение подписки, сообщение о создании учётной карточки, доступе к курсу Брацка Вводка и личному кабинету;
- В случае, если на Брацкую Пошту приходит сообщение об:
- Отсутствии существования указанного пользователем имэйла, проверяет, есть ли на карточке другие записи и:
- Если другие записи есть, и одна из них -- имэйл, то Оплёт отдаёт задание Брацкой Поште выслать пользователю запрос правильности имэйла;
- Если другие записи есть, но ни одна из них -- имэйл, то Оплёт просто помечает ошибку на учётной карточке;
- Если других записей нет, то Оплёт переводит учётную карточку в проблемные;
- Отказе от какой-либо рассылки, Оплёт удаляет эту рассылку с учётной карточки.
- Отсутствии существования указанного пользователем имэйла, проверяет, есть ли на карточке другие записи и:
- Покупка в магазине: Если пользователь совершил покупку в Careerprise Shop, Оплёт заводит пользователя в качестве клиента Брацкой Школы на клиентском модуле Брацкой Справы.
- Пожертвование: Если пользователь совершил пожертвование в Careerprise Shop, Оплёт заводит пользователя в качестве клиента Брацкой Школы на клиентском модуле Брацкой Справы.
- Вход через стороннюю идентификацию: Если пользователь заходит в Облако через Стороннюю идентификацию, Оплёт:
Корпоративные псевдонимы
- Основная вики-страница: Псевдоним пользователя Оплёта
- Корпоративные псевдонимы создаются по формуле Имя Фамилия-На-Ых-Фамилия и прописываются в карточках сотрудников.
Регистрационные имена пользователей
- Регистрационные имена пользователей заводятся исключительно английскими буквами на основе псевдонима по следующему принципу: полное имя + точка + минимальное количество букв фамилии на -ых, достаточное для соблюдения условия уникальности. Например,
mina.n
Корпоративные имэйлы
- Корпоративные имэйлы пользователей заводятся на основе Регистрационного имени пользователя по следующему принципу: регистрационное‑имя‑пользователя@opplet.net. Например,
mina.n@opplet.net
Запись на вводный курс
- Регистрация через запись на вводный курс -- единственная регистрация, по которой пользователь получает временный статус, который действителен в течение 3-х месяцев. Если пользователь не окончил курс в течение этого времени, то его регистрация аннулируется. Если пользователь на любом из вэб-сайтов Брацкой Вебки кликает на кнопки типа "Трудоустроиться", "Выучиться", "Стать волонтёром", "Стать партнёром" и так далее, Оплёт:
- Заводит временную учётную карточку со сведениями о том, (1) какая кнопка была нажата и (2) какой язык был использован;
- В принудительном порядке предлагает пользователю ввести тот логин и пароль, который будет удобен этому пользователю;
- В добровольном порядке предлагает пользователю ввести внешний имэйл;
- Проверяет, не является ли пользователь роботом;
- Заводит его пользователем Брацкой Учебки, Брацки Жици и Брацкой Бачки;
- Создаёт идентификатор и пароль, затем проверяет способ идентификации и учётную карточку на наличие электронного адреса. Если карточка:
- Содержит адрес и пользователь использовал стороннюю идентификацию, то Оплёт отдаёт задание Брацкой Поште выслать имэйл с информацией об идентификаторе и пароле на имеющийся адрес, зачисляет и перенаправляет этого пользователя на вводную лекцию Курса;
- Содержит адрес и пользователь использовал внутреннюю идентификацию, то Оплёт загружает такую страницу или зону: "Для Вас создан временный идентификатор -- zhenjas -- и пароль -- 01ZhenjaS20, которые будут актуальны в течение следующих 3х месяцев, которые даются на завершение курса". Для Вашего удобства, информация об идентификаторе и пароле отправлены на тот электронный адрес, который указан в Вашем личном кабинете," отдаёт задание Брацкой Поште выслать имэйл с информацией об идентификаторе и пароле на имеющийся адрес, зачисляет и перенаправляет этого пользователя на вводную лекцию Курса;
- Не содержит адрес, то Оплёт загружает такую страницу или зону: "Для Вас создан временный идентификатор -- zhenjas -- и пароль -- 01ZhenjaS20, которые будут актуальны в течение следующих 3х месяцев, которые даются на завершение курса. Пожалуйста, сохраните этот идентификатор и пароль или отправьте их себе на электронную почту." с двумя кнопками: "Я сохранил это идентификатор и пароль" и "Отправьте идентификатор и пароль на мою электронную почту";
- Если пользователь выбирает:
- "Отправьте идентификатор и пароль на мою электронную почту", то Оплёт запрашивает имэйл-адрес пользователя, отдаёт задание Брацка Пошта выслать имэйл-подтверждение на введённый адрес, зачисляет и перенаправляет этого пользователя на вводную лекцию Курса;
- "Я сохранил это идентификатор и пароль", то Оплёт зачисляет и перенаправляет этого пользователя на вводную лекцию Курса.
- Курс начинается с текста "Добро пожаловать в Брацкую Школу. Чтобы сохранить в тайне личные данные, все участники пользуются корпоративными псевдонимами. Вы зачислены на вводный курс, Брацка Вводка, под псевдонимом Женя Семашко. Если Вы хотите поменять имя, повторите процедуру регистрации с начала."
Ручная регистрация
- Любой пользователь может быть создан вручную, а не только в автоматическом режиме.
Поля учётных карточек
Часть полей учётных карточек может заполняться пользователем при его желании, но не обязательны к заполнению. Часть тех полей, которые заполняются автоматически, может изменяться пользователем, в то время как некоторые поля не могут быть изменены.
Необязательные
Поле Тип Примечание Имя (если необходимо для документов об окончании) Текст Заполняется при желании пользователя Фамилия (если необходима для документов об окончании) Внешний имэйл (если есть желание получать уведомления) Текст со значком @ и как минимум одной точкой после него Язык(и) Выбор из списка Автоматически вписывается и сохраняется язык входа, который может быть изменён или добавлен пользователем вручную.
Изменяемые
Поле Примечание Логин (изменить?) Поля с возможностью изменения Пароль (изменить?) Завершённые курсы (убрать?) Список с возможностью исключения Курсы в прогрессе (отменить?) Доступные приложения (отменить?) Рассылки (изменить?) Список с возможностью исключения и добавления
Неизменяемые
Поле Примечание Идентификационный номер пользователя Генерируется автоматически и проверяется на уникальность Регистрационное имя пользователя Генерируется автоматически по логике Регистрационных имён пользователей Псевдоним пользователя Оплёта Генерируется автоматически по логике Псевдонимов пользователя Оплёта Корпоративный имэйл Генерируется автоматически по логике Корпоративных имэйлов
Пользовательский интерфэйс
С живыми пользователями, Оплёт сообщается тремя путями:
- Через интерфэйс личного кабинета;
- Почтовый сервис. Пока настроен sendmail, но почта приходит в спам. Установлен, но не настроен Postfix. Задача настройки пока отложена. На полноценную почту планируется позже нанять специалиста. Возможно, экономически целесообразнее будет собрать Брацкую Пошту.
- Для тех пользователей, которые пользуются социальным логином, настроен OAuth 2.0 протокол. В данный момент есть проблемы прописывания "социальных пользователей" в Оплёте.
Незарегистрированный пользователь видит только титульную страницу:
- На шапке слева -- Opplet; справа -- SignUp (клик регистрирует пользователя в роли Временный);
- В основном поле -- два поля Login и Password;
- В подвале слева -- © Opplet [текущий год]; справа -- Powered by Yii Framework
Ведение личного кабинета
- Личный кабинет является той частью учётной карточки пользователя, к которой пользователь имеет доступ и право редактирования.
Интересы
- Оплёт собирает информацию о поведении пользователя, особенно, какие кнопки пользователь выбирает находясь на Облаке, для формирования центра действий именуемого "Интересы". Центр действий включает в себя 6 групп:
- Учёба и трудоустройство
- Трудоустройство (без учёбы)
- Волонтёрство
- Партнёрство
- Учёба (без трудоустройства)
- Благотворительность
- Активные группы занимают отдельные зоны и включают кнопку "Сделать зону неактивной"; неактивные -- даны иконками под общим заголовком Ещё.
Личные данные
- Личные данные включают в себя следующие поля:
- Имя (как должно появляться на документах об окончании)
- Фамилия (как должна появляться на документах об окончании)
- Корпоративный псевдоним
- Имэйл
Приложения
- Приложения, которые доступны для пользователя, зависят от действий пользователя согласно Автоматическому назначению ролей, если доступы не установлены вручную. Если пользовательские приложения предоставляют пользователям доступ к личным кабинетам внутри приложений, то ссылки от личного кабинета идут на них.
Языки
- Оплёт собирает информацию о том, какие языки выбирает пользователь и об языках его операционных систем пользователя, для формирования центра управления языками.
Рассылки
- Оплёт управляет данными о том, на какие рассылки подписан пользователь.
Авторизация доступов
Авторизация пользователей разрешает доступы:
- Автоматические к пользовательским ресурсам, например, к Брацкой Поште или Брацки Жици. Завершение вводного курса необходимо для автоматических доступов;
- Ручные к административным ресурсам, например, к отдельным проектам Брацкой Крынки.
Завершение вводного курса
- Если в течение 3х месяцев пользователь:
- Успешно завершает Курс, то Оплёт:
- Заводит его пользователем Брацкой Правки и зачисляет на семинар Выбор Профессии;
- Если пользователь при первоначальной записи выбирал кнопку:
- "Трудоустроиться", то Оплёт загружает страницу "Поздравляем с успешным завершением курса. Вы выражали интерес к трудоустройству. Вы желаете трудоустроиться через Брацкую Школу, не платя за услуги из своего кармана, или заказать платные услуги по трудоустройству? Кстати, если Ваш интерес поменялся, в Личном кабинете Вы всегда можете изменить своё решение." с кнопками "Трудоустроиться через Брацкую Школу", "Заказать платные услуги по трудоустройству" и "Что-то ещё";
- Если пользователь выбрал кнопку: "Трудоустроиться через Брацкую Школу", то Оплёт обновляет информацию учётной карточки. Регистрация в этом случае следует правилам описанным на вики-странице Лестница к Профессии. Оплёт перенаправляет этого пользователя на семинар Выбор Профессии. После завершения этого семинара, Оплёт даёт пользователю доступ к Брацкой Вебке, Брацкой Поште и Брацкой Справе, а также зачисляет его в слушатели Семь Технологических Искусств и Семь Административных Искусств;
- Если пользователь выбрал кнопку: "Заказать платные услуги по трудоустройству", то Оплёт обновляет информацию учётной карточки и перенаправляет этого пользователя в Careerprise Shop;
- Если пользователь выбрал кнопку: "Что-то ещё", то Оплёт обновляет информацию учётной карточки и перенаправляет этого пользователя в Личный кабинет;
- "Выучиться", то Оплёт загружает страницу "Поздравляем с успешным завершением курса. Вы желаете совмещать учёбу и работу в Брацкой Школе, не платя за услуги из своего кармана, или заказать платные услуги образования? Кстати, если Ваш интерес поменялся, в Личном кабинете Вы всегда можете изменить своё решение." с кнопками "Учиться и работать в Брацкой Школе", "Заказать платные услуги образования", "Что-то ещё";
- Если пользователь выбрал кнопку: "Учиться и работать в Брацкой Школе", то Оплёт обновляет информацию учётной карточки и перенаправляет его на семинар Выбор Профессии. После завершения этого семинара, Оплёт даёт пользователю доступ к Брацкой Вебке, Брацкой Поште и Брацкой Справе, а также зачисляет его в слушатели Семь Технологических Искусств и Семь Административных Искусств;
- Если пользователь выбрал кнопку: "Заказать платные услуги образования", то Оплёт обновляет информацию учётной карточки и перенаправляет этого пользователя на Careerprise Shop;
- Если пользователь выбрал кнопку: "Что-то ещё", то Оплёт обновляет информацию учётной карточки и перенаправляет этого пользователя в Личный кабинет;
- "Стать волонтёром", то Оплёт загружает страницу "Поздравляем с успешным завершением курса. Вы выражали желание стать волонтёром Брацкой Школы, потому мы зачисляем Вас на семинар Как стать волонтёром Брацкой Школы. Кстати, если Ваш интерес поменялся, в Личном кабинете Вы всегда можете изменить своё решение." с кнопками "Зачислить на семинар "Как стать волонтёром"", "Что-то ещё";
- Если пользователь выбрал кнопку: "Зачислить на семинар "Как стать волонтёром"", то Оплёт перенаправляет его на семинар Как стать волонтёром Брацкой Школы. После завершения этого семинара, Оплёт даёт пользователю доступ к Брацкой Поште и Брацкой Справе, а также заводит его в качестве кандидата в волонтёры Брацкой Школы на рекрутинговом модуле Брацкой Справы;
- Если пользователь выбрал кнопку: "Что-то ещё", то Оплёт обновляет информацию учётной карточки и перенаправляет этого пользователя в Личный кабинет;
- "Стать партнёром", то Оплёт загружает страницу "Поздравляем с успешным завершением курса. Вы выражали желание стать партнёром Брацкой Школы, потому мы зачисляем Вас на семинар Как стать партнёром Брацкой Школы. Партнёром может быть любой работодатель, поставщик услуг по подготовке кадров и рекрутингу или любое иное лицо, заинтересованное в развитии Брацкой Школы. Кстати, если Ваш интерес поменялся, в Личном кабинете Вы всегда можете изменить своё решение." с кнопками "Зачислить на семинар "Как стать партнёром"", "Что-то ещё";
- Если пользователь выбрал кнопку: "Зачислить на семинар "Как стать партнёром"", то Оплёт перенаправляет его на семинар Как стать партнёром Брацкой Школы. После завершения этого семинара, Оплёт заводит пользователя в качестве кандидата в партнёры Брацкой Школы на клиентском модуле Брацкой Справы;
- Если пользователь выбрал кнопку: "Что-то ещё", то Оплёт обновляет информацию учётной карточки и перенаправляет этого пользователя в Личный кабинет.
- "Трудоустроиться", то Оплёт загружает страницу "Поздравляем с успешным завершением курса. Вы выражали интерес к трудоустройству. Вы желаете трудоустроиться через Брацкую Школу, не платя за услуги из своего кармана, или заказать платные услуги по трудоустройству? Кстати, если Ваш интерес поменялся, в Личном кабинете Вы всегда можете изменить своё решение." с кнопками "Трудоустроиться через Брацкую Школу", "Заказать платные услуги по трудоустройству" и "Что-то ещё";
- Не завершает Курс и:
- Идентифицировался внутренне, то Оплёт удаляет его учётную карточку;
- Идентифицировался сторонне, то Оплёт оставляет его учётную карточку актуальной, но исключает из Курса и высылает соответствующее сообщение на электронный адрес.
- Успешно завершает Курс, то Оплёт:
Автоматические доступы
Роль Оплёт Учебка Правка Бачка Жици Справа Пошта Вебка Крынка Неавторизованный Нет доступа далее входной страницы Доступ к просмотру всех материалов Доступ к просмотру открытых материалов Нет доступа далее входной страницы Временный Только на 3 месяца Доступ в качестве пользователя Нет доступа далее входной страницы Подписчик Любой имеет доступ к личному кабинету Доступ к курсу Брацка Вводка Доступ в качестве пользователя Доступ в качестве пользователя Клиент Доступ в качестве клиента Нет доступа далее входной страницы Кандидат Доступ к семинарам Как стать партнёром, волонтёром и трудоустроиться Студент Доступ к Семь Технологических Искусств и Семь Административных Искусств Волонтёр Партнёр Доступ в качестве пользователя Сотрудник Доступ к любым курсам Доступ в качестве пользователя
Ручные доступы
- Любые роли могут быть назначены в ручном режиме согласно иерархии ролей Оплёта.
Технические детали
Оплёт написан на Yii (сейчас версия 2.0.8). Наиболее современная версия -- 2.0.41, но обновление "ломает" сайт, нужно проверить что менялось и заменить у себя.
Перспективные услуги
- Перспективно, Оплёт должен предоставлять следующие услуги:
- Регулировать загрузку, хранение и использование версий исходных кодов, скорее всего, совместно с инсталляцией Redmine;
- Регулировать загрузку, хранение и использование версий баз данных и снимков облаков;
- Вести календарь событий и обеспечивать организацию мероприятий.
Требования к разработке
- Создать базу данных mysite
- Зальем дамп таблицы users (код дампа ниже)
- Сделаем форму регистрации и обработчик на PHP
- Сделаем форму входа и обработчик
- Сделаем мини-профиль после логина
Текущие проблемы и направления их решений
- Схема данных OpenLDAP требует заполнения обязательных полей профилей пользователя. Так как Оплёт не требует ни имэйлов, ни имён, они генерируются, проверяются на уникальность и присваиваются автоматически. Так же как номера записи и типы обьектов.
- Говоря о стратегии, она -- в максимальном уменьшении заполняемых вручную полей и в максимальном увеличении той информации, которая может собираться автоматически -- точки входа, логи, даже клики, языки и так далее.
- Есть нерешённая проблема по роли подписчика. Можно либо не создавать пользователя вовсе, так как пользователь с любой ролью может быть подписчиком и это скорее не роль, а свойство профиля клиента. Отписку же проводить через отписной имэйл, а не заходом в личный кабинет. Либо создавать пользователя понимая, что подписчик -- это только тот, кто пока далее подписки не пошёл и другой роли пока не получил.
- Работу над проблемами планируется перенести на Redmine или Брацкую Крынку, для чего основной разработчик должен провести тренинг.