Files
moodle-availability_ipaddress/README.md

3.6 KiB

Moodle - availability ip address plugin

CI Status

Enhance activity security by restricting access based on IP address. This plugin allows you to control the availability of any chosen activity, making it accessible only to users from specified IP addresses.

Author

ldesignmedia

Moodle400 Moodle401 Moodle402 Moodle403 Moodle404 Moodle405 Moodle500

PHP7.3 PHP7.4 PHP8.0 PHP8.1 PHP8.2

List of features

  • Supports comma separate list of ip-addresses
  • Subnet support, eg 192.168.1.0/24
  • Inline ip-address validation
  • Turning on/off with eye icon, without losing the input value.

Installation

  1. Copy this plugin to the availability\condition\ipaddress folder on the server
  2. Login as administrator
  3. Go to Site Administrator > Notification
  4. Install the plugin

Usage

  1. Add or edit an activity in a Moodle course.
  2. Go to the section "Restrict access"
  3. Click IP address in the modal
  4. There's a new input field that supports a list of comma separated ip address e.g. 127.0.0.1, 192.168.1.0/24
    1. The users with matching ip addresses can view the activity.
  5. Save the activity

TODO

  • Behat tests ip validation

Security

If you discover any security related issues, please email luuk@ldesignmedia.nl instead of using the issue tracker.

License

The GNU GENERAL PUBLIC LICENSE. Please see License File for more information.

Contributing

Contributions are welcome and will be fully credited. We accept contributions via Pull Requests on Github.

Changelog

5.0.3 (15.03.2026)
  • Fixed PHP 7.3 compatibility issue that broke Moodle 4.0.x servers (#13)
  • Removed typed properties (PHP 7.4+) to support PHP 7.3+
  • Lowered environment.xml PHP requirement from 7.4 to 7.3
5.0.2 (04.08.2025)
  • Added support for pre-configuring IP ranges by admins
5.0.1 (22.05.2025)
  • Tested on Moodle 5.0
4.5.0 (04.04.2025)
  • Tested on Moodle 4.5
4.4.0 (20.07.2024)
  • Tested on Moodle 4.4
4.0.2 (28.05.2022)
4.0.1 (28.05.2022)
3.9.0 (11.02.2022)
  • Added ip-range support @juacas