-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathmessage_output_telegram.php
128 lines (112 loc) · 4.33 KB
/
message_output_telegram.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
<?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/>.
/**
* Telegram message plugin version information.
*
* @package message_telegram
* @author Mike Churchward
* @copyright 2017 onwards Mike Churchward (mike.churchward@poetgroup.org)
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
defined('MOODLE_INTERNAL') || die();
require_once($CFG->dirroot.'/message/output/lib.php');
require_once($CFG->dirroot.'/lib/filelib.php');
/**
* The telegram message processor
*
* @package message_telegram
* @copyright 2017 onwards Mike Churchward (mike.churchward@poetgroup.org)
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
class message_output_telegram extends message_output {
/**
* Constructor to add needed properties to the Slack app.
*/
public function __construct() {
$this->manager = new message_telegram\manager();
}
/**
* Processes the message and sends a notification via telegram
*
* @param stdClass $eventdata the event data submitted by the message sender plus $eventdata->savedmessageid
* @return true if ok, false if error
*/
public function send_message($eventdata) {
global $CFG;
// Skip any messaging of suspended and deleted users.
if (($eventdata->userto->auth === 'nologin') || $eventdata->userto->suspended || $eventdata->userto->deleted) {
return true;
}
if (!empty($CFG->noemailever)) {
// Hidden setting for development sites, set in config.php if needed.
debugging('$CFG->noemailever is active, no telegram message sent.', DEBUG_MINIMAL);
return true;
}
return $this->manager->send_message($eventdata->fullmessage, $eventdata->userto->id);
}
/**
* Creates necessary fields in the messaging config form.
*
* @param array $preferences An object of user preferences
*/
public function config_form($preferences) {
global $USER;
// If Telegram has not been configured, do nothing.
if (!$this->is_system_configured()) {
return get_string('notconfigured', 'message_telegram');
} else {
return $this->manager->config_form($preferences, $USER->id);
}
}
/**
* Parses the submitted form data and saves it into preferences array.
*
* @param stdClass $form preferences form class
* @param array $preferences preferences array
*/
public function process_form($form, &$preferences) {
return $this->manager->set_chatid();
}
/**
* Loads the config data from database to put on the form during initial form display.
*
* @param object $preferences preferences object
* @param int $userid the user id
*/
public function load_data(&$preferences, $userid) {
$preferences->telegram_chatid = get_user_preferences('message_processor_telegram_chatid', '', $userid);
}
/**
* Tests whether the Telegram settings have been configured on user level
* @param object $user the user object, defaults to $USER.
* @return bool has the user made all the necessary settings
* in their profile to allow this plugin to be used.
*/
public function is_user_configured($user = null) {
global $USER;
if ($user === null) {
$user = $USER;
}
return ($this->manager->is_chatid_set($user->id));
}
/**
* Tests whether the Telegram settings have been configured
* @return boolean true if Telegram is configured
*/
public function is_system_configured() {
return (!empty(get_config('message_telegram', 'sitebotname')) && !empty(get_config('message_telegram', 'sitebottoken')));
}
}