Moodle
Siehe auch
- Ansible-Rolle Moodle:
Installation per Kommandozeile
cd /var/www/html/moodle
sudo -u apache /usr/bin/php /var/www/html/moodle/admin/cli/install.php \
--chmod=2750 \
--lang=en \
--wwwroot=https://learning.example.com \
--dataroot=/data \
--dbtype=mariadb \
--dbhost=localhost \
--dbname=moodle \
--dbuser=moodle \
--dbpass=linuxfabrik \
--dbport=3306 \
--dbsocket=/var/lib/mysql/mysql.sock \
--prefix=mdl_ \
--fullname='Full Site Name' \
--shortname='ShortName' \
--summary='The summary to be displayed on the front page' \
--adminuser=moodle-admin \
--adminpass=linuxfabrik \
--adminemail=admin@example.com \
--sitepreset=sitepreset \
--supportemail=support@example.com \
--upgradekey= \
--non-interactive \
--agree-license
Moodle install.php Cheat Sheet:
Command line Moodle installer, creates config.php and initializes database.
Please note you must execute this script with the same uid as apache
or use chmod/chown after installation.
Site defaults may be changed via local/defaults.php.
Options:
--chmod=OCTAL-MODE Permissions of new directories created within dataroot.
Default is 2777. You may want to change it to 2770
or 2750 or 750. See chmod man page for details.
--lang=CODE Installation and default site language.
--wwwroot=URL Web address for the Moodle site,
required in non-interactive mode.
--dataroot=DIR Location of the moodle data folder,
must not be web accessible. Default is moodledata
in the parent directory.
--dbtype=TYPE Database type. Default is mysqli
--dbhost=HOST Database host. Default is localhost
--dbname=NAME Database name. Default is moodle
--dbuser=USERNAME Database user. Default is root
--dbpass=PASSWORD Database password. Default is blank
--dbport=NUMBER Use database port.
--dbsocket=PATH Use database socket, 1 means default. Available for some databases only.
--prefix=STRING Table prefix for above database tables. Default is mdl_
--fullname=STRING The fullname of the site
--shortname=STRING The shortname of the site
--summary=STRING The summary to be displayed on the front page
--adminuser=USERNAME Username for the moodle admin account. Default is admin
--adminpass=PASSWORD Password for the moodle admin account,
required in non-interactive mode.
--adminemail=STRING Email address for the moodle admin account.
--sitepreset=STRING Admin site preset to be applied during the installation process.
--supportemail=STRING Email address for support and help.
--upgradekey=STRING The upgrade key to be set in the config.php, leave empty to not set it.
--non-interactive No interactive questions, installation fails if any
problem encountered.
--agree-license Indicates agreement with software license,
required in non-interactive mode.
--allow-unstable Install even if the version is not marked as stable yet,
required in non-interactive mode.
--skip-database Stop the installation before installing the database.
-h, --help Print out this help
Example:
$sudo -u www-data /usr/bin/php admin/cli/install.php --lang=cs
Moodle auf der Kommandozeile konfigurieren
Das Tool verarbeitet Key/Value-Paare.
Alle Einstellungen auslesen:
sudo -u apache php /var/www/html/moodle/admin/cli/cfg.php
Updates und Upgrades
Siehe auch https://docs.moodle.org/404/en/Administration_via_command_line.
Neue Version der PHP-Dateien ins /var/www/html/moodle
kopieren, z.B. per LFOps-Rolle:
sudo -u apache php /var/www/html/moodle/admin/cli/maintenance.php --enable
ansible-playbook --inventory hosts.yml linuxfabrik.lfops.setup_moodle --tags=moodle --extra-vars="moodle__github_version=v4.1.15"
Dann:
sudo -u apache php /var/www/html/moodle/admin/cli/upgrade.php --non-interactive
sudo -u apache php /var/www/html/moodle/admin/cli/maintenance.php --disable
Moosh
Die Administrationsmöglichkeiten mit Moodle-Bordmitteln auf der Kommandozeile sind (zumindest bis Version 4.1 LTS) sehr beschränkt. Beispielsweise ist das Anlegen von Benutzern nicht möglich. Hier hilft Moosh.
cd /var/www/html/moodle
sudo -u apache php /opt/moosh/moosh.php --user=moodle-admin --list-commands
Bemerkung
Die Reihenfolge der Parameter und Argumente ist wichtig:
sudo -u apache php /opt/moosh/moosh.php `user-create --firstname=Linus --lastname=Löffel --city=Zurich --country=Switzerland linus
moosh.php
Das Kommando wie
user-create
Die Parameter wie
--firstname=Linus --lastname=Löffel --city=Zurich --country=Switzerland
Das Argument wie
linus
(oder der Plugin-Name)
Anderes Beispiel: sudo -u apache php /opt/moosh/moosh.php config-set objectclass inetorgperson auth_ldap - der letzte Parameter hier steht für das zu konfigurierende Modul.
Moosh Cheat Sheet:
activity-add
activity-config-set
activity-delete
activity-move
admin-login
admin-remove-orphaned-modules
apache-parse-extendedlog
apache-parse-missing-files
apache-parse-perflog
audit-passwords
auth-list
auth-manage
backup-info
badge-create
badge-delete
badge-delete-duplicates
base-path
block-add
block-manage
cache-add-mem-store
cache-add-redis-store
cache-clear
cache-config-get
cache-course-rebuild
cache-edit-mappings
cache-test
category-config-set
category-create
category-delete
category-export
category-import
category-list
category-move
category-resortcourses
category-sortordertofirst
chkdatadir
code-check
cohort-create
cohort-enrol
cohort-enrolfile
cohort-unenrol
config-get
config-plugin-export
config-plugin-import
config-plugins
config-set
context-rebuild
course-backup
course-cleanup
course-config-set
course-create
course-delete
course-enableselfenrol
course-enrol
course-enrolbyname
course-image-generate
course-info
course-last-visited
course-list
course-move
course-reset
course-restore
course-unenrol
data-stats
db-stats
debug-off
debug-on
delete-missingplugins
dev-langusage
dev-versionbump
download-moodle
event-fire
event-list
file-check
file-datacheck
file-dbcheck
file-delete
file-hash-delete
file-list
file-path
file-upload
filter-set
fontawesome-refreshcache
form-add
forum-newdiscussion
framework-import
generate-availability
generate-block
generate-cfg
generate-enrol
generate-filemanager
generate-files
generate-form
generate-gradeexport
generate-gradereport
generate-lang
generate-local
generate-messageoutput
generate-module
generate-moosh
generate-qtype
generate-userprofilefield
generate-ws
gradebook-export
gradebook-import
gradecategory-create
gradecategory-list
gradeitem-create
gradeitem-list
group-assigngrouping
group-create
group-delete
group-empty
group-list
group-memberadd
grouping-create
info
info-context
info-plugins
label-create
lang-compare
lang-stats
language-install
languages-update
log-analyse
maintenance-off
maintenance-on
module-config
module-copy
module-manage
module-reinstall
nagios-check
nginx-parse-extendedlog
perf-analyse
php-eval
plugin-download
plugin-install
plugin-list
plugin-uninstall
plugins-usage
question-delete
question-import
questionbank-import
questioncategory-create
quiz-delete-attempts
random-label
report-concurrency
restore-settings
role-create
role-delete
role-export
role-import
role-list
role-reset
role-update-capability
role-update-contextlevel
section-config-set
sql-cli
sql-dump
sql-run
string-replace-encoded
task-lock-check
theme-info
theme-settings-export
theme-settings-import
top
user-assign-system-role
user-create
user-delete
user-export
user-import-pictures
user-list
user-login
user-mod
user-online
user-unassign-system-role
userprofilefields-export
userprofilefields-import
webservice-call
Moodle, Moosh und LDAP
dnf -y install php-ldap
sudo -u apache php /opt/moosh/moosh.php auth-manage enable ldap
sudo -u apache php /opt/moosh/moosh.php config-get auth_ldap
# LDAP Server Settings
sudo -u apache php /opt/moosh/moosh.php config-set host_url ldap://ldap.example.com auth_ldap
sudo -u apache php /opt/moosh/moosh.php config-set bind_dn cn=admin,dc=example,dc=com auth_ldap
sudo -u apache php /opt/moosh/moosh.php config-set bind_pw linuxfabrik auth_ldap
sudo -u apache php /opt/moosh/moosh.php config-set contexts ou=users,dc=example,dc=com auth_ldap
# LDAP User Attribute Mappings
sudo -u apache php /opt/moosh/moosh.php config-set user_attribute uid auth_ldap
sudo -u apache php /opt/moosh/moosh.php config-set memberattribute member auth_ldap
sudo -u apache php /opt/moosh/moosh.php config-set objectclass inetOrgPerson auth_ldap
# LDAP User Login and Password Handling
sudo -u apache php /opt/moosh/moosh.php config-set changepasswordurl "" auth_ldap
sudo -u apache php /opt/moosh/moosh.php config-set user_type "" auth_ldap
# Other Optional Settings
sudo -u apache php /opt/moosh/moosh.php config-set search_sub 1 auth_ldap
sudo -u apache php /opt/moosh/moosh.php config-set opt_deref 0 auth_ldap
Built on 2025-01-06