Projects for new developers

Jump to: navigation, search

Getting started

Moodle uses PHP, JavaScript, SQL and a number of other Web languages, so learning those is a good place to start.

When you have some basic PHP programming skills, you may wish to start learning about how to Moodle code is organised. It is recommended that you complete the Introduction to Moodle Programming course on To access this you will need to have an account on first.

If you are looking for projects suggested in the tracker, look for issues with the 'addon_candidate' label.

If you are looking to make a quick contribution, look for tracker issues with marked as easy.

Please consider adopting a plugin seeking a new maintainer. See the Plugins adoption programme.

As you become more involved in Moodle development, you might like to learn more about the coding conventions used and how changes to Moodle core code are processed.

Potential projects

This evolving page lists possible Moodle projects for new developers derived from community suggestions.

If you have any ideas for new features in Moodle which might be suitable as projects for new developers, please see New feature ideas.

Plagiarism plugin (Moorsp)

There are various commercial plugins available that use the Plagiarism API in Moodle, but because these plagiarism systems can require paid subscriptions, testing them can be difficult. I'd like to see a basic plugin developed (called Moorsp) that could be used for testing the Plagiarism API and provides a structure that can be built on in future to add further functionality.

The initial aim of this project is not to develop a new Plagiarism checking tool but to develop a tool that provides complete Behat and unit tests for the Moodle Plagiarism API.

All files uploaded to Moodle are stored on disk using the contenthash of the file as the filename - this means that if a user uploads the exact file multiple times in different locations only one file is stored on disk. The plugin should implement a check to see if the exact file has been submitted to any other courses/activities and display related information if another match has been found.

Existing Plagiarism plugins (turnitin, urkund, compilatio etc) make use of the legacy log feature of the events api - the new plugin should use the new api and not rely on legacy logs.


  • All Plagiarism API functions should be implemented.
  • Support for Assign, forum and Workshop modules should be implemented.
  • Full Unit test coverage of all plugin functions.
  • Full Behat tests for Assign, forum and workshop modules should be implemented to ensure that all Plagiarism API functions are working as expected.
  • The code should pass 100% of the Moodle codechecking tools to ensure the code meets with Moodle Guidelines.
  • The code should be perform well with appropriate use of the Moodle caching tools.

Future Improvements (outside scope of initial project)

  • Add Plagiarism API to the Moodle Glossary plugin.
  • Implement functions that allow the plugin to post content to an external source - a future open source moorsp server that will receive content and generate a similarity report - we may be able to re-purpose some of the code from the old plagiarism_crot plugin to do this.
Skills required: PHP
Difficulty level: Medium
Possible mentor: Dan Marsden
Discussion: [1]
Initial code structure: [2]

Javascript basic SCORM 1.2 player for the Mobile app

Currently there are several Javascript SCORM players with basic support for SCORM 1.2:

The aim of this project is to fix and package inside an Angular module one of those players to be included in the official Moodle Mobile app.

This will allow the app to play SCORM files in online and offline mode.

The player should be able to:

  • Parse the imsmanifest.xml file in order to display the available Organizations and structures inside the package.
  • Display a basic SCORM player with a basic menu tree.
  • Implement a basic runtime support in order to be able to retrieve the SCOs tracking from the Moodle site.
  • Store in the app local storage the user interactions (API runtime) to be synchronized when the user is online again.
Skills required: HTML5, Javascript, AngularJS
Difficulty level: Medium-High
Possible mentor: Juan Leyva

Javascript basic IMS CP player for the Mobile app

This is a minor project related to the previous one, it can be described as an initial step for implementing the SCORM player.

Detailed information about the IMS CP format can be found here: [3]

The Mobile app should be able to download the package, extract it and open the contents in a basic player similar to the Moodle one. The manifest XML file should be parsed in order to obtain a navigation TOC:

IMSCP Sample.png

Contents will be opened in an iframe, the TOC links will target the iframe.

Skills required: HTML5, Javascript, AngularJS
Difficulty level: Low
Possible mentor: Juan Leyva

Improved enrol_meta plugin

Current enrol_meta plugin provides functionality to automatically synchronise enrolments between two courses. See Course meta link. Teacher creates an instance of enroment method in the meta course and links it to one child course. Later cron job ensures that any enrolment change in the child course is pushed to the parent.

Unfortunately user interface is very inconvenient. The main problem is inability to bulk select courses and/or order courses on the Enrolment methods page. Plus it lacks important functionality to synchronise suspended/expired enrolments. See the number of highly voted issues MDL-27628, MDL-17929, MDL-32161, MDL-31451

The proposal is to re-write this enrolment plugin completely. One instance of the plugin should allow to link multiple child courses and additionally synchronise each of them with a group in the meta course. Ideally it should also allow to synchronise all courses in the category.

This project requires development of both user interface (JS) and backend (PHP).

Skills required: PHP, Javascript (YUI)
Difficulty level: Medium
Possible mentor: Marina Glancy

Allow to crop/resize/rotate images when inserting them

This project is inspired by MDL-32183. There are two options on how to implement this functionality - as a repository plugin or as an atto plugin.

Skills required: Javascript (YUI), PHP
Difficulty level: Medium
Possible mentor: Marina Glancy

See also