Search moodle.org's
Developer Documentation

See Release Notes

  • Bug fixes for general core bugs in 4.0.x will end 8 May 2023 (12 months).
  • Bug fixes for security issues in 4.0.x will end 13 November 2023 (18 months).
  • PHP version: minimum PHP 7.3.0 Note: the minimum PHP version has increased since Moodle 3.10. PHP 7.4.x is also supported.

Differences Between: [Versions 400 and 401] [Versions 400 and 402] [Versions 400 and 403]

Class to manage subscriptions.

Copyright: 2014 onwards Ankit Agarwal <ankit.agrr@gmail.com>
License: http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
File Size: 563 lines (21 kb)
Included or required:0 times
Referenced: 0 times
Includes or requires: 0 files

Defines 1 class


Class: subscription_manager  - X-Ref

Class to manage subscriptions.

create_subscription($ruleid, $courseid, $cmid, $userid = 0)   X-Ref
Subscribe a user to a given rule.

return: bool|int returns id of the created subscription.
param: int $ruleid  Rule id.
param: int $courseid Course id.
param: int $cmid Course module id.
param: int $userid User who is subscribing, defaults to $USER.

delete_subscription($subscriptionorid, $checkuser = true)   X-Ref
Delete a subscription.

return: bool
param: subscription|int $subscriptionorid an instance of subscription class or id.
param: bool $checkuser Check if the subscription belongs to current user before deleting.

delete_user_subscriptions($userid)   X-Ref
Delete all subscriptions for a user.

return: mixed
param: int $userid user id.

delete_cm_subscriptions($cmid)   X-Ref
Delete all subscriptions for a course module.

return: mixed
param: int $cmid cm id.

remove_all_subscriptions_for_rule($ruleid, $coursecontext = null)   X-Ref
Delete all subscribers for a given rule.

return: bool
param: int $ruleid rule id.
param: \context|null $coursecontext the context of the course - this is passed when we

remove_all_subscriptions_in_course($coursecontext)   X-Ref
Delete all subscriptions in a course.

This is called after a course was deleted, context no longer exists but we kept the object

param: \context_course $coursecontext the context of the course

get_subscription($subscriptionorid)   X-Ref
Get a subscription instance for an given subscription id.

return: subscription returns a instance of subscription class.
param: subscription|int $subscriptionorid an instance of subscription class or id.

get_user_subscriptions_for_course($courseid, $limitfrom = 0, $limitto = 0, $userid = 0,$order = 's.timecreated DESC' )   X-Ref
Get an array of subscriptions for a given user in a given course.

return: array list of subscriptions
param: int $courseid course id.
param: int $limitfrom Limit from which to fetch rules.
param: int $limitto  Limit to which rules need to be fetched.
param: int $userid Id of the user for which the subscription needs to be fetched. Defaults to $USER;
param: string $order Order to sort the subscriptions.

count_user_subscriptions_for_course($courseid, $userid = 0)   X-Ref
Get count of subscriptions for a given user in a given course.

return: int number of subscriptions
param: int $courseid course id.
param: int $userid Id of the user for which the subscription needs to be fetched. Defaults to $USER;

get_user_subscriptions($limitfrom = 0, $limitto = 0, $userid = 0,$order = 's.courseid ASC, r.name' )   X-Ref
Get an array of subscriptions for a given user.

return: array list of subscriptions
param: int $limitfrom Limit from which to fetch rules.
param: int $limitto  Limit to which rules need to be fetched.
param: int $userid Id of the user for which the subscription needs to be fetched. Defaults to $USER;
param: string $order Order to sort the subscriptions.

count_user_subscriptions($userid = 0)   X-Ref
Get count of subscriptions for a given user.

return: int number of subscriptions
param: int $userid Id of the user for which the subscription needs to be fetched. Defaults to $USER;

get_subscriptions_by_event(\stdClass $event)   X-Ref
Return a list of subscriptions for a given event.

return: array
param: \stdClass $event the event object.

get_subscription_join_rule_sql($count = false)   X-Ref
Return sql to join rule and subscription table.

return: string the sql.
param: bool $count Weather if this is a count query or not.

get_instances($arr)   X-Ref
Helper method to convert db records to instances.

return: array of subscriptions as instances.
param: array $arr of subscriptions.

count_rule_subscriptions($ruleid)   X-Ref
Get count of subscriptions for a given rule.

return: int number of subscriptions
param: int $ruleid rule id of the subscription.

event_has_subscriptions($eventname, $courseid)   X-Ref
Returns true if an event in a particular course has a subscription.

return: bool returns true if the event has subscriptions in a given course, false otherwise.
param: string $eventname the name of the event
param: int $courseid the course id

activate_subscriptions(array $ids)   X-Ref
Activates a group of subscriptions based on an input array of ids.

return: bool true if the operation was successful, false otherwise.
param: array $ids of subscription ids.

deactivate_subscriptions(array $ids)   X-Ref
Deactivates a group of subscriptions based on an input array of ids.

return: bool true if the operation was successful, false otherwise.
param: array $ids of subscription ids.

delete_stale_subscriptions($userid = 0)   X-Ref
Deletes subscriptions which have been inactive for a period of time.

return: bool true if the operation was successful, false otherwise.
param: int $userid if provided, only this user's stale subscriptions will be deleted.

subscription_is_active(subscription $subscription)   X-Ref
Check whether a subscription is active.

return: bool true if the subscription is active, false otherwise.
param: \tool_monitor\subscription $subscription instance.