Интеграция с Moodle

Материал из Апекс-ВУЗ

Аутентификация через БД Апекс-ВУЗ

В разделе Администрирование – Плагины – Аутентификация включаем плагин «Внешняя база данных». Настройки:

Сервер базы данных, Название базы данных, Пользователь базы данных, Пароль – указать как параметры подключения к БД Апекс-ВУЗ

Таблица:

(select u.login, u.password, s.family_name, CONCAT('student-', s.id) as id, s.name, s.surname from student_students s left join system_users u on u.id = s.user_id where s.user_id IS NOT NULL AND s.active = 1 union all select u.login, u.password, s.family_name, CONCAT('staff-', s.id) as id, s.name, s.surname from state_staff s left join system_users u on u.id = s.user_id where s.user_id IS NOT NULL AND s.active = 1) auth

Поле логина: login

Поле пароля: password

Формат пароля: Шифровать строки с помощью односторонней хэш-функции

Команда настройки SQL: SET NAMES 'utf8'

При удалении пользователя во внешнем источнике: Заблокировать внешнюю учетную запись

Обновить пользователей: Да

Сопоставление данных (Имя): name

Обновление локальной учетной записи (Имя): При каждом входе

Сопоставление данных (Фамилия): family_name

Обновление локальной учетной записи (Фамилия): При каждом входе

Сопоставление данных (Индивидуальный номер): id

Обновление локальной учетной записи (Индивидуальный номер): При каждом входе

Проверяем настройки нажатием на кнопку «Проверить настройки»

Синхронизация базы данных пользователей

Администрирование – Сервер – Задачи – Планировщик задач. Включаем раз в 5 минут запуск скрипта синхронизации - Задача синхронизации пользователей (\auth_db\task\sync_users):

Минута - */5 Остальные поля - * Снимаем флажок «Отключить задачу»

Добавляем в crontab запуск скрипта планировщика Moodle: Запускаем команду crontab -e, добавляем строку, если ее нет

  • * * * * /usr/bin/php /var/www/html/admin/cli/cron.php

(/var/www/html нужно заменить на адрес папки Moodle).

Через 5 минут проверяем, появились ли новые пользователи в разделе Администрирование – Пользователи – Учетные записи – Список пользователей, пробуем авторизоваться под одним из них.

Создание категории курсов

В разделе Администрирование – Курсы – Управление курсами и категориями создаем категорию «Дисциплины из Апекс-ВУЗ» с идентификационным номером av.

Автоматическое создание курсов и записи на курс

В разделе Администрирование – Плагины – Зачисления на курсы включаем плагин «Внешняя база данных». Настройки:

Сервер базы данных, Название базы данных, Пользователь базы данных, Пароль – указать как параметры подключения к БД Апекс-ВУЗ

Команда настройки SQL: SET NAMES 'utf8' Локальное поле категории: idnumber

Внешняя таблица информацией о записи на курсы:

((SELECT CONCAT(‘student-‘, s.id), CONCAT("av-course-", cd.discipline_id) AS discipline FROM student_students s LEFT JOIN load_groups g ON s.group_id = g.id LEFT JOIN plan_curriculum_disciplines cd ON g.education_plan_id = cd.education_plan_id WHERE g.education_plan_id IS NOT NULL AND cd.discipline_id IS NOT NULL) UNION ALL (SELECT s.id, CONCAT("av-course-", cd.discipline_id, '/', dccd.discipline_course_id) AS discipline FROM student_students s LEFT JOIN load_groups g ON s.group_id = g.id LEFT JOIN plan_curriculum_disciplines cd ON g.education_plan_id = cd.education_plan_id LEFT JOIN plan_discipline_courses_curriculum_disciplines dccd ON cd.id = dccd.curriculum_discipline_id WHERE g.education_plan_id IS NOT NULL AND cd.discipline_id IS NOT NULL AND dccd.discipline_course_id IS NOT NULL)) courses

Поле курса во внешней таблице: discipline Поле пользователя во внешней таблице: id

Отдаленная таблица новых курсов:

((SELECT DISTINCT(CONCAT("av-course-", cd.discipline_id)) as discipline, d.name, d.name_short FROM plan_curriculum_disciplines cd LEFT JOIN plan_disciplines d ON d.id = cd.discipline_id LEFT JOIN plan_education_plans p ON p.id = cd.education_plan_id WHERE p.status = 1 AND cd.level = 3 AND cd.type NOT IN (8, 16)) UNION ALL (SELECT DISTINCT(CONCAT("av-course-", dc.discipline_id, '/', dc.id)) as discipline, dc.name, dc.name_short FROM plan_discipline_courses dc WHERE dc.discipline_id IN (SELECT DISTINCT(cd.discipline_id) as discipline FROM plan_curriculum_disciplines cd LEFT JOIN plan_disciplines d ON d.id = cd.discipline_id LEFT JOIN plan_education_plans p ON p.id = cd.education_plan_id WHERE p.status = 1 AND cd.level = 3 AND cd.type NOT IN (8, 16)))) courses

Поле полного имени нового курса: name Поле, содержащее название нового курса: name_short Поле номера ID нового курса: discipline Категория нового курса по умолчанию: Дисциплины из Апекс-ВУЗ

По желанию – создать шаблон нового курса и указать его короткое имя в поле «Шаблон нового курса».

Проверяем настройки нажатием на кнопку «Проверить настройки»

Синхронизация курсов

Администрирование – Сервер – Задачи – Планировщик задач. Включаем раз в 5 минут запуск скрипта синхронизации - Synchronise external database enrolments task (\enrol_database\task\sync_enrolments):

Минута - */5 Остальные поля - * Снимаем флажок «Отключить задачу»

Отключение подтверждения e-mail

Апекс-ВУЗ не хранит адреса электронной почты обучающихся, поэтому при интеграции они не будут переданы в Moodle. При первой авторизации Moodle будет запрашивать смену адреса электронной почты и требовать ее подтверждения. Если не все обучающиеся имеют электронную почту, желательно отключить подтверждение, чтобы они могли указывать любую непроверенную почту.

Для этого необходимо перейти в раздел Администрирование – Безопасность – Политики безопасности сайта и снять флажок «Подтверждение изменения электронной почты».