Skip to content

leonstr/moodle-utils

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

25 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Moodle utilities

Some utilities for use with Moodle.

  • latest: A Bash script to replace the existing Moodle source code with the latest version while retaining any additional (non-core) plugins.
  • ldap_test.php: A script to help identify and troubleshoot the settings for LDAP authentication in Moodle.
  • moodledata_orphans.php: List files in Moodledata filedir directory that aren't in the Moodle database.
  • new_test_site: Create a new Moodle test site.

latest

Warning: This script will delete the files and directories in the Moodle source code directory and replace it with the latest source code.

A script to replace the current version of Moodle in your site's source code directory with the latest files but keeps any additional (non-core) plugins. If you have added any files or directories to the Moodle source code directory they will be deleted by this script.

This script was written as a proof-of-concept to show how the Moodle source code directory can be correctly prepared -- notably ensuring all files and directories from the previous Moodle version are removed but retaining any additional plugins -- as an example to anyone writing their own packaging system.

ldap_test.php

A script to help identify and troubleshoot the settings for LDAP authentication in Moodle.

Setting up LDAP authentication can require some trial-and-error to work out: 1) the settings needed for Moodle to connect to the LDAP server and 2) the user attributes needed to populate Moodle's user fields. In this script you specify the following constants:

  • HOST_URL -- e.g. 'ldap://ldap1.example.corp'
  • BIND_DN -- e.g. 'cn=ldapuser,dc=example,dc=corp'
  • BIND_PW -- e.g. 'yourpassword'
  • CONTEXTS -- e.g. 'dc=example,dc=com'
  • FILTERS -- e.g. '(objectClass=user)'
  • ATTRIBUTES -- e.g. 'uid, cn, mail'

Then run the script. If the settings work the user fields from the LDAP server will be listed. If the settings don't work there should be an error message which hopefully will help identify which setting is failing. You can also see which users would be created before running the Moodle sync script.

It uses the Start TLS extension. If you get an error like "Unable to start TLS" this may be because the LDAP server's certificate is not signed by a certificate authority (CA). You can either import the LDAP server's certificate to the client system (i.e. Moodle web server) or try adding TLS_REQCERT allow to ldap.conf to skip verification.

Note: The LDAP page size extension is not supported so the users returned may be limited, e.g. only first 250 users may be returned depending on the LDAP server's settings.

Usage

First edit ldap_test.php setting the constants listed above then run:

php -f /path/to/ldap_test.php

moodledata_orphans.php

List files in Moodledata filedir directory that aren't in the Moodle database.

Moodle stores course files in the filedir directory renamed to the file's content hash so that the same file is only stored once with each instance referenced in the mdl_files table. When there are no references left the file should be deleted. In some cases a file can exist in filedir without a reference in mdl_files in which case Moodle doesn't know it's there and is not using it. In this case the file can almost certainly be removed. This script lists these files.

It must be run from the Moodle source code directory.

Warning: Although the listed files can probably be deleted it is recommended that you backup these files beforehand.

Usage:

php /PATH/TO/moodledata_orphans.php [-b] [-p]

-b: Bare output. Suppresses the "Not in database: " prefix.

-p: Show full path. Files are listed with the $CFG-\>dataroot prefix. Without -p only the relative path from filedir is shown.

Examples:

Assuming Moodle source code is in /var/www/moodle and moodledata_orphans.php is in /home/user1:

cd /var/www/moodle
php /home/user1/moodledata_orphans.php

With options -b and -p output is suitable for piping to a command. For example to delete the orphan files (after making a backup!):

cd /var/www/moodle
php /home/user1/moodledata_orphans.php -b -p | xargs rm

new_test_site

Create a new Moodle test site.

Assumes a CentOS 7 server with the correct version of PHP and extensions installed, and MariaDB installed and running.

This script:

  • Creates a database for the site based on the site domain name, e.g. moodle1_example_com.
  • Creates a database user for the site with the same name as the database, e.g. moodle1_example_com.
  • Creates the site in /var/www using the site domain name, e.g. /var/www/moodle1.example.com.
  • Downloads the Moodle source using git clone. It looks for a local reference repository in /usr/share/repos/moodle and uses this if present.
  • Sets the SELinux context for the Moodledata directory (httpd_sys_rw_content_t).
  • Runs the Moodle install script, admin/cli/install.php.
  • Creates a self-signed certificate and key pair for the site domain name, e.g. /etc/pki/tls/certs/moodle1.example.com.crt and /etc/pki/tls/private/moodle1.example.com.key.
  • Creates an Apache config file in /etc/httpd/conf.d using the site domain name, e.g. moodle1.example.com.conf.

The site's admin user has the password Password-1.

You then need to add DNS records or hosts file entries in order to access the site.

Usage:

new_test_site [[-b branch-ver] | [ -t tag]] [-g git-repo] domain-name

-b branch-ver: two-digit branch to use, e.g. 31 which corresponds to MOODLE_31_STABLE. Cannot be used if -t is used.

-t tag: Git tag corresponding to the naming scheme Moodle uses for specific versions, e.g. v3.5.6. Cannot be used if -b is used

-g git-repo: Git repository to use. By default git://git.moodle.org/moodle.git is used, but if this port is blocked, this option allows an alternative, e.g. https://github.com/moodle/moodle.git.

Examples:

New test site:

new_test_site moodle1.example.com

New Moodle 3.5 test site using the alternative GitHub repo:

new_test_site -b 35 -g https://github.com/moodle/moodle.git moodle2.example.com

New Moodle 3.6.2 test site:

new_test_site -t v3.6.2 moodle3.example.com

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published