Activity modules
Activity modules are a fundamental course feature and are usually the primary delivery method for learning content in Moodle.
The plugintype of an Activity module is mod
, and the frankenstyle name of a plugin is therefore mod_[modname]
.
All activity module plugins are located in the /mod/
folder of Moodle.
The term [modname]
is used as a placeholder in this documentation and should be replaced with the name of your activity module.
Folder layout
Activity modules reside in the /mod
directory.
Each module is in a separate subdirectory and consists of a number of mandatory files and any other files the developer is going to use.
Below is an example of the file structure for the folder
plugin.
View an example directory layout for the folder
plugin.
.
├── backup
│ ├── moodle1
│ │ └── lib.php
│ └── moodle2
│ ├── backup_folder_activity_task.class.php
│ ├── backup_folder_stepslib.php
│ ├── restore_folder_activity_task.class.php
│ └── restore_folder_stepslib.php
├── classes
│ ├── analytics
│ │ └── indicator
│ │ ├── activity_base.php
│ │ ├── cognitive_depth.php
│ │ └── social_breadth.php
│ ├── content
│ │ └── exporter.php
│ ├── event
│ │ ├── all_files_downloaded.php
│ │ ├── course_module_instance_list_viewed.php
│ │ ├── course_module_viewed.php
│ │ └── folder_updated.php
│ ├── external.php
│ ├── privacy
│ │ └── provider.php
│ └── search
│ └── activity.php
├── db
│ ├── access.php
│ ├── install.php
│ ├── install.xml
│ ├── log.php
│ ├── services.php
│ └── upgrade.php
├── download_folder.php
├── edit.php
├── edit_form.php
├── index.php
├── lang
│ └── en
│ └── folder.php
├── lib.php
├── locallib.php
├── mod_form.php
├── module.js
├── phpunit.xml
├── pix
│ ├── icon.png
│ └── icon.svg
├── readme.txt
├── renderer.php
├── settings.php
├── styles.css
├── tests
│ ├── backup
│ │ └── restore_date_test.php
│ ├── behat
│ │ └── folder_activity_completion.feature
│ ├── event
│ │ └── events_test.php
│ ├── externallib_test.php
│ ├── generator
│ │ └── lib.php
│ ├── generator_test.php
│ ├── lib_test.php
│ ├── phpunit.xml
│ └── search
│ └── search_test.php
├── version.php
└── view.php
Standard Files and their Functions
There are several files that are crucial to Moodle. These files are used to install your module and then integrate it into Moodle. Each file has a particular function, some of the files are optional, and are only created if you want to use the functionality it offers. Below are the list of most commonly used files.
Backup Folder
Plugin Backup configuration
File path: /backup/
If your plugin stores data then you may need to implement the Backup feature which allows the activity to backed up, restored, and duplicated.
For more information on Backup and restore, see the following:
access.php
- Capability defaults
Plugin capabilities
File path: /db/access.php
The db/access.php
file contains the initial configuration for a plugin's access control rules.
Access control is handled in Moodle by the use of Roles, and Capabilities. You can read more about these in the Access API documentation.
If you make changes to the initial configuration of existing access control rules, these will only take effect for new installations of your plugin. Any existing installation will not be updated with the latest configuration.
Updating existing capability configuration for an installed site is not recommended as it may have already been modified by an administrator.
For activities the following capabilities are required:
mod/[modname]:addinstance
: Controls whether a user may create a new instance of the activitymod/[modname]:view
: Controls whether a user may view an instance of the activity
The example below shows the recommended configuration for the addinstance
and view
capabilities.
This configuration will allow:
- editing teachers and managers to create new instances, but not non-editing teachers.
- all roles to view the activity.
Granting the view capability to archetypes like guest
does not allow any user to view all activities. Users are still subject to standard access controls like course enrolment.
For further information on what each attribute in that capabilities array means visit NEWMODULE Adding capabilities.
View example
<?php
$capabilities = [
'mod/[modname]:addinstance' => [
'riskbitmask' => RISK_XSS,
'captype' => 'write',
'contextlevel' => CONTEXT_COURSE,
'archetypes' => [
'editingteacher' => CAP_ALLOW,
'manager' => CAP_ALLOW,
],
'clonepermissionsfrom' => 'moodle/course:manageactivities',
],
'mod/[modname]:view' => [
'captype' => 'read',
'contextlevel' => CONTEXT_MODULE,
'archetypes' => [
'guest' => CAP_ALLOW,
'student' => CAP_ALLOW,
'teacher' => CAP_ALLOW,
'editingteacher' => CAP_ALLOW,
'manager' => CAP_ALLOW,
],
],
];
events.php
- Event observers
Event observer definitions
File path: /db/events.php
Moodle supports a feature known as _ Event observers _ to allow components to make changes when certain events take place.
The db/events.php
file allows you define any event subscriptions that your plugin needs to listen for.
Event subscriptions are a convenient way to observe events generated elsewhere in Moodle.
You should not use event subscriptions to subscribe to events belonging to other plugins, without defining a dependency upon that plugin.
See the Component communication principles documentation for a description of some of the risks of doing so.
View example
<?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/**
* Event observer definitions for the plugintype_pluginname plugin.
*
* @package plugintype_pluginname
* @copyright Year, You Name <your@email.address>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
$observers = [
[
'eventname' => '\core\event\course_module_created',
'callback' => '\plugintype_pluginname\event\observer\course_module_created::store',
'priority' => 1000,
],
];
install.xml
- Database installation
Database schema
File path: /db/install.xml
The install.xml
file is used to define any database tables, fields, indexes, and keys, which should be created for a plugin during its initial installation.
When creating or updating the install.xml
you must use the built-in XMLDB editor within Moodle.
Moodle requires that you create a table for your plugin whose name exactly matches the plugin name. For example, the certificate
activity module must have a database table named certificate
. Certain fields within this table are
also required:
Field name | Properties | Keys / Indexes | Notes |
---|---|---|---|
id | INT(10), auto sequence | primary key for the table | |
course | INT(10) | foreign key to the course table | |
name | CHAR(255) | Holds the user-specified name of the activity instance | |
timemodified | INT(10) | The timestamp of when the activity was last modified | |
intro | TEXT | A standard field to hold the user-defined activity description (see FEATURE_MOD_INTRO ) | |
introformat | INT(4) | A standard field to hold the format of the field |
upgrade.php
- Upgrade steps
Upgrade steps
File path: /db/upgrade.php
The db/upgrade.php
file contains upgrade steps, including database schema changes, changes to settings, and other steps which must be performed during upgrade.
See the Upgrade API documentation for further information.
When making changes to the database schema you must use the build-in XMLDB editor within Moodle. This can be used to generate php upgrade steps.
The install.xml schema must match the schema generated by the upgrade at all times.
To create an upgrade step you must:
- Use the XMLDB editor to create the definition of the new fields
- Update the
install.xml
from the XMLDB editor - Generate the PHP upgrade steps from within the XMLDB Editor
- Update the version number in your
version.php
In many cases you will be able to combine multiple upgrade steps into a single version change.
When a version number increment is detected during an upgrade, the xmldb_[pluginname]_upgrade
function is called with the old version number as the first argument.
See the Upgrade API documentation for more information on the upgrade process.
View example
<?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/**
* Upgrade steps for the mod_[modname] plugin.
*
* @package mod_[modname]
* @copyright Year, You Name <your@email.address>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
function xmldb_certificate_upgrade($oldversion = 0) {
if ($oldversion < 2012091800) {
// Add new fields to certificate table.
$table = new xmldb_table('certificate');
$field = new xmldb_field('showcode');
$field->set_attributes(XMLDB_TYPE_INTEGER, '1', XMLDB_UNSIGNED, XMLDB_NOTNULL, null, '0', 'savecert');
if (!$dbman->field_exists($table, $field)) {
$dbman->add_field($table, $field);
}
// Add new fields to certificate_issues table.
$table = new xmldb_table('certificate_issues');
$field = new xmldb_field('code');
$field->set_attributes(XMLDB_TYPE_CHAR, '50', null, null, null, null, 'certificateid');
if (!$dbman->field_exists($table, $field)) {
$dbman->add_field($table, $field);
}
// Certificate savepoint reached.
upgrade_mod_savepoint(true, 2012091800, 'certificate');
}
// Everything has succeeded to here. Return true.
return true;
}
mobile.php
- Moodle Mobile Remote Add-ons
MoodleMobile version of the plugin
File path: /db/mobile.php
The Moodle Mobile remote add-on is the mobile app version of the plugin that will be loaded when a user accesses the plugin on the app.
A plugin can include several Mobile add-ons. Each add-on must indicate a unique name.
See the Moodle App Plugins development guide for more information on configuring your plugin for the Moodle App.
/lang/en/[modname].php
- Language string definitions
Language files
File path: /lang/en/[modname].php
Each plugin must define a set of language strings with, at a minimum, an English translation. These are specified in the plugin's lang/en
directory in a file named after the plugin. For example the LDAP authentication plugin:
// Plugin type: `auth`
// Plugin name: `ldap`
// Frankenstyle plugin name: `auth_ldap`
// Plugin location: `auth/ldap`
// Language string location: `auth/ldap/lang/en/auth_ldap.php`
Every plugin must define the name of the plugin, or its pluginname
.
The get_string
API can be used to translate a string identifier back into a translated string.
get_string('pluginname', '[plugintype]_[pluginname]');
- See the String API documentation for more information on language files.
View example
<?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/**
* Languages configuration for the mod_[modname] plugin.
*
* @package mod_[modname]
* @copyright Year, You Name <your@email.address>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
$string['pluginname'] = 'The name of your activity';
lib.php
- Library functions
Global plugin functions
File path: /lib.php
The lib.php
file is a legacy file which acts as a bridge between Moodle core, and the plugin. In recent plugins it is should only used to define callbacks and related functionality which currently is not supported as an auto-loadable class.
All functions defined in this file must meet the requirements set out in the relevant section of the Coding style.
Moodle core often loads all the lib.php files of a given plugin types. For performance reasons, it is strongly recommended to keep this file as small as possible and have just required code implemented in it. All the plugin's internal logic should be implemented in the auto-loaded classes.
For an Activity, you must define the following three functions, which are described below:
function [modname]_add_instance($instancedata, $mform = null): int;
function [modname]_update_instance($instancedata, $mform): bool;
function [modname]_delete_instance($id): bool;
- The
[modname]_add_instance()
function is called when the activity creation form is submitted. This function is only called when adding an activity and should contain any logic required to add the activity. - The
[modname]_update_instance()
function is called when the activity editing form is submitted. - The
[modname]_delete_instance()
function is called when the activity deletion is confirmed. It is responsible for removing all data associated with the instance.
The lib.php
file is one of the older parts of Moodle and functionality is gradually being migrated to class-based function calls.
Activity module support functions
Activity modules can implement a global function to provide additional information about the module features. These functions are optional and can be used to provide additional features or to modify the behaviour of the activity module.
function [modname]_supports(string $feature): bool|string|null;
The function [modname]_supports
is used to check if the activity module supports a particular feature. The function should return true
if the feature is supported, false
if it is not supported, null
if the feature is unknown, or string for the module purpose for some features.
Each feature is identified by a constant, which is defined in the lib /moodlelib.php
file. Some of the available features are:
FEATURE_GROUPS
andFEATURE_GROUPINGS
: The activity module supports groups and groupings.FEATURE_SHOW_DESCRIPTION
: The activity module supports showing the description on the course page.FEATURE_QUICKCREATE
: The activity[modname]_add_instance()
function is able to create an instance without showing a form using the default settings. It is used by thecore_courseformat_create_module
webservice to know which activities are compatible. If this feature is supported, the activity module should provide aquickcreatename
string in the language file that will be used as the name of the instance created.FEATURE_COMPLETION
: The activity module supports activity completion. For now this feature only affects the bulk completion settings. However, in the future (MDL-83027) activities can set to false to disable all completion settings.
View example
function [modname]_supports($feature) {
return match ($feature) {
FEATURE_GROUPS => true,
FEATURE_GROUPINGS => true,
FEATURE_MOD_INTRO => true,
FEATURE_COMPLETION_TRACKS_VIEWS => true,
FEATURE_GRADE_HAS_GRADE => true,
FEATURE_BACKUP_MOODLE2 => true,
FEATURE_SHOW_DESCRIPTION => true,
FEATURE_MOD_PURPOSE => MOD_PURPOSE_COLLABORATION,
default => null,
};
}
To have your Activity plugin classified in the right Activity category, you must define the function [modname]_supports
and add the FEATURE_MOD_PURPOSE
constant:View example
function [modname]_supports(string $feature) {
switch ($feature) {
[...]
case FEATURE_MOD_PURPOSE:
return MOD_PURPOSE_XXXXXX;
default:
return null;
}
}
The available activity purposes for this feature are:
- Administration (
MOD_PURPOSE_ADMINISTRATION
)
Tools for course administration, such as attendance tracking or appointment scheduling. - Assessment (
MOD_PURPOSE_ASSESSMENT
)
Activities that allow the evaluation and measurement of student understanding and performance.
- Core activities in this category: Assignment, Quiz, Workshop.
- Collaboration (
MOD_PURPOSE_COLLABORATION
)
Tools for collaborative learning that encourage knowledge sharing, discussions, and teamwork.
- Core activities in this category: Database, Forum, Glossary, Wiki.
- Communication (
MOD_PURPOSE_COMMUNICATION
)
Activities that facilitate real-time communication, asynchronous interaction, and feedback collection.
- Core activities in this category: BigBlueButton, Chat, Choice, Feedback, Survey.
- Interactive content (
MOD_PURPOSE_INTERACTIVECONTENT
)
Engaging interactive activities that encourage active learner participation.
- Core activities in this category: H5P, IMS package, Lesson, SCORM package.
- Resources (
MOD_PURPOSE_CONTENT
)
Activities and tools to organise and display course materials like documents, web links, and multimedia.
- Core activities in this category: Book, File, Folder, Page, URL, Text and media area.
- Other (
MOD_PURPOSE_OTHER
)
Other types of activities.
mod_form.php
- Instance create/edit form
Activity creation/editing form
File path: /mod_form.php
This file is used when adding/editing a module to a course. It contains the elements that will be displayed on the form responsible for creating/installing an instance of your module. The class in the file should be called mod_[modname]_mod_form
.
The mod_[modname]_mod_form
is a current exception to the class autoloading rules.
This will be addressed in MDL-74472.
The following example gives a sample implementation of the creation form. It does not contain the full file.
View example
<?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/**
* Activity creation/editing form for the mod_[modname] plugin.
*
* @package mod_[modname]
* @copyright Year, You Name <your@email.address>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
require_once($CFG->dirroot.'/course/moodleform_mod.php');
require_once($CFG->dirroot.'/mod/certificate/lib.php');
class mod_certificate_mod_form extends moodleform_mod {
function definition() {
global $CFG, $DB, $OUTPUT;
$mform =& $this->_form;
// Section header title according to language file.
$mform->addElement('header', 'general', get_string('general', 'certificate'));
// Add a text input for the name of the certificate.
$mform->addElement('text', 'name', get_string('certificatename', 'certificate'), ['size' => '64']);
$mform->setType('name', PARAM_TEXT);
$mform->addRule('name', null, 'required', null, 'client');
// Add a select menu for the 'use code' setting.
$ynoptions = [
0 => get_string('no'),
1 => get_string('yes'),
];
$mform->addElement('select', 'usecode', get_string('usecode', 'certificate'), $ynoptions);
$mform->setDefault('usecode', 0);
$mform->addHelpButton('usecode', 'usecode', 'certificate');
// Standard Moodle course module elements (course, category, etc.).
$this->standard_coursemodule_elements();
// Standard Moodle form buttons.
$this->add_action_buttons();
}
function validation($data, $files) {
$errors = array();
// Validate the 'name' field.
if (empty($data['name'])) {
$errors['name'] = get_string('errornoname', 'certificate');
}
return $errors;
}
function data_preprocessing(&$default_values) {
// Set default values for the form fields.
$default_values['name'] = 'Default Certificate Name';
$default_values['usecode'] = 1;
}
function definition_after_data() {
$mform = $this->_form;
$data = $this->get_data();
// Disable the 'name' field if 'usecode' is set to 1.
if ($data && !empty($data->usecode)) {
$mform->disabledIf('name', 'usecode', 'eq', 1);
}
}
function preprocess_data($data) {
// Modify the 'name' data before saving.
$data->name = strtoupper($data->name);
return $data;
}
}
index.php
- Instance list
Activity index
File path: /index.php
The index.php
should be used to list all instances of an activity that the current user has access to in the specified course.
View example
<?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/**
* Activity index for the mod_[modname] plugin.
*
* @package mod_[modname]
* @copyright Year, You Name <your@email.address>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
require_once('../../config.php');
// The `id` parameter is the course id.
$id = required_param('id', PARAM_INT);
// Fetch the requested course.
$course = $DB->get_record('course', ['id'=> $id], '*', MUST_EXIST);
// Require that the user is logged into the course.
require_course_login($course);
$modinfo = get_fast_modinfo($course);
foreach ($modinfo->get_instances_of('[modinfo]') as $instanceid => $cm) {
// Display information about your activity.
}
view.php
- View an activity
Activity view page
File path: /view.php
Moodle will automatically generate links to view the activity using the /view.php
page and passing in an id
value. The id
passed is the course module ID, which can be used to fetch all remaining data for the activity instance.
View example
<?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/**
* Activity view page for the plugintype_pluginname plugin.
*
* @package plugintype_pluginname
* @copyright Year, You Name <your@email.address>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
require('../../config.php');
$id = required_param('id', PARAM_INT);
[$course, $cm] = get_course_and_cm_from_cmid($id, '[modname]');
$instance = $DB->get_record('[modname]', ['id'=> $cm->instance], '*', MUST_EXIST);
version.php
Version metadata
File path: /version.php
The version.php contains metadata about the plugin.
It is used during the installation and upgrade of the plugin.
This file contains metadata used to describe the plugin, and includes information such as:
- the version number
- a list of dependencies
- the minimum Moodle version required
- maturity of the plugin
View example
<?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/**
* Version metadata for the mod_[modname] plugin.
*
* @package mod_[modname]
* @copyright Year, You Name <your@email.address>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
defined('MOODLE_INTERNAL') || die();
$plugin->version = TODO;
$plugin->requires = TODO;
$plugin->supported = TODO; // Available as of Moodle 3.9.0 or later.
$plugin->incompatible = TODO; // Available as of Moodle 3.9.0 or later.
$plugin->component = 'TODO_FRANKENSTYLE';
$plugin->maturity = MATURITY_STABLE;
$plugin->release = 'TODO';
$plugin->dependencies = [
'mod_forum' => 2022042100,
'mod_data' => 2022042100
];