You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
258 lines
8.4 KiB
258 lines
8.4 KiB
<?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/>.
|
|
|
|
/**
|
|
* Variable Envelope Return Path management.
|
|
*
|
|
* @package core_message
|
|
* @copyright 2014 Andrew Nicols <andrew@nicols.co.uk>
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|
*/
|
|
|
|
namespace core\message\inbound;
|
|
|
|
defined('MOODLE_INTERNAL') || die();
|
|
|
|
/**
|
|
* Variable Envelope Return Path manager class.
|
|
*
|
|
* @copyright 2014 Andrew Nicols <andrew@nicols.co.uk>
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|
*/
|
|
class manager {
|
|
|
|
/**
|
|
* Whether the Inbound Message interface is enabled.
|
|
*
|
|
* @return bool
|
|
*/
|
|
public static function is_enabled() {
|
|
global $CFG;
|
|
|
|
// Check whether Inbound Message is enabled at all.
|
|
if (!isset($CFG->messageinbound_enabled) || !$CFG->messageinbound_enabled) {
|
|
return false;
|
|
}
|
|
|
|
// Check whether the outgoing mailbox and domain are configured properly.
|
|
if (!isset($CFG->messageinbound_mailbox) || empty($CFG->messageinbound_mailbox)) {
|
|
return false;
|
|
}
|
|
|
|
if (!isset($CFG->messageinbound_domain) || empty($CFG->messageinbound_domain)) {
|
|
return false;
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Update the database to create, update, and remove handlers.
|
|
*
|
|
* @param string $componentname - The frankenstyle component name.
|
|
*/
|
|
public static function update_handlers_for_component($componentname) {
|
|
global $DB;
|
|
|
|
$componentname = \core_component::normalize_componentname($componentname);
|
|
$existinghandlers = $DB->get_recordset('messageinbound_handlers', array('component' => $componentname));
|
|
foreach ($existinghandlers as $handler) {
|
|
if (!class_exists($handler->classname)) {
|
|
self::remove_messageinbound_handler($handler);
|
|
}
|
|
}
|
|
$existinghandlers->close();
|
|
|
|
self::create_missing_messageinbound_handlers_for_component($componentname);
|
|
}
|
|
|
|
/**
|
|
* Load handler instances for all of the handlers defined in db/messageinbound_handlers.php for the specified component.
|
|
*
|
|
* @param string $componentname - The name of the component to fetch the handlers for.
|
|
* @return \core\message\inbound\handler[] - List of handlers for this component.
|
|
*/
|
|
public static function load_default_handlers_for_component($componentname) {
|
|
$componentname = \core_component::normalize_componentname($componentname);
|
|
$dir = \core_component::get_component_directory($componentname);
|
|
|
|
if (!$dir) {
|
|
return array();
|
|
}
|
|
|
|
$file = $dir . '/db/messageinbound_handlers.php';
|
|
if (!file_exists($file)) {
|
|
return array();
|
|
}
|
|
|
|
$handlers = null;
|
|
require_once($file);
|
|
|
|
if (!isset($handlers)) {
|
|
return array();
|
|
}
|
|
|
|
$handlerinstances = array();
|
|
|
|
foreach ($handlers as $handler) {
|
|
$record = (object) $handler;
|
|
$record->component = $componentname;
|
|
if ($handlerinstance = self::handler_from_record($record)) {
|
|
$handlerinstances[] = $handlerinstance;
|
|
} else {
|
|
throw new \coding_exception("Inbound Message Handler not found for '{$componentname}'.");
|
|
}
|
|
}
|
|
|
|
return $handlerinstances;
|
|
}
|
|
|
|
/**
|
|
* Update the database to contain a list of handlers for a component,
|
|
* adding any handlers which do not exist in the database.
|
|
*
|
|
* @param string $componentname - The frankenstyle component name.
|
|
*/
|
|
public static function create_missing_messageinbound_handlers_for_component($componentname) {
|
|
global $DB;
|
|
$componentname = \core_component::normalize_componentname($componentname);
|
|
|
|
$expectedhandlers = self::load_default_handlers_for_component($componentname);
|
|
foreach ($expectedhandlers as $handler) {
|
|
$recordexists = $DB->record_exists('messageinbound_handlers', array(
|
|
'component' => $componentname,
|
|
'classname' => $handler->classname,
|
|
));
|
|
|
|
if (!$recordexists) {
|
|
$record = self::record_from_handler($handler);
|
|
$record->component = $componentname;
|
|
$DB->insert_record('messageinbound_handlers', $record);
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Remove the specified handler.
|
|
*
|
|
* @param \core\message\inbound\handler $handler The handler to remove
|
|
*/
|
|
public static function remove_messageinbound_handler($handler) {
|
|
global $DB;
|
|
|
|
// Delete Inbound Message datakeys.
|
|
$DB->delete_records('messageinbound_datakeys', array('handler' => $handler->id));
|
|
|
|
// Delete Inbound Message handlers.
|
|
$DB->delete_records('messageinbound_handlers', array('id' => $handler->id));
|
|
}
|
|
|
|
/**
|
|
* Create a flat stdClass for the handler, appropriate for inserting
|
|
* into the database.
|
|
*
|
|
* @param \core\message\inbound\handler $handler The handler to retrieve the record for.
|
|
* @return \stdClass
|
|
*/
|
|
public static function record_from_handler($handler) {
|
|
$record = new \stdClass();
|
|
$record->id = $handler->id;
|
|
$record->component = $handler->component;
|
|
$record->classname = get_class($handler);
|
|
if (strpos($record->classname, '\\') !== 0) {
|
|
$record->classname = '\\' . $record->classname;
|
|
}
|
|
$record->defaultexpiration = $handler->defaultexpiration;
|
|
$record->validateaddress = $handler->validateaddress;
|
|
$record->enabled = $handler->enabled;
|
|
|
|
return $record;
|
|
}
|
|
|
|
/**
|
|
* Load the Inbound Message handler details for a given record.
|
|
*
|
|
* @param \stdClass $record The record to retrieve the handler for.
|
|
* @return \core\message\inbound\handler or false
|
|
*/
|
|
protected static function handler_from_record($record) {
|
|
$classname = $record->classname;
|
|
if (strpos($classname, '\\') !== 0) {
|
|
$classname = '\\' . $classname;
|
|
}
|
|
if (!class_exists($classname)) {
|
|
return false;
|
|
}
|
|
|
|
$handler = new $classname;
|
|
if (isset($record->id)) {
|
|
$handler->set_id($record->id);
|
|
}
|
|
$handler->set_component($record->component);
|
|
|
|
// Overload fields which can be modified.
|
|
if (isset($record->defaultexpiration)) {
|
|
$handler->set_defaultexpiration($record->defaultexpiration);
|
|
}
|
|
|
|
if (isset($record->validateaddress)) {
|
|
$handler->set_validateaddress($record->validateaddress);
|
|
}
|
|
|
|
if (isset($record->enabled)) {
|
|
$handler->set_enabled($record->enabled);
|
|
}
|
|
|
|
return $handler;
|
|
}
|
|
|
|
/**
|
|
* Load the Inbound Message handler details for a given classname.
|
|
*
|
|
* @param string $classname The name of the class for the handler.
|
|
* @return \core\message\inbound\handler or false
|
|
*/
|
|
public static function get_handler($classname) {
|
|
global $DB;
|
|
|
|
if (strpos($classname, '\\') !== 0) {
|
|
$classname = '\\' . $classname;
|
|
}
|
|
|
|
$record = $DB->get_record('messageinbound_handlers', array('classname' => $classname), '*', IGNORE_MISSING);
|
|
if (!$record) {
|
|
return false;
|
|
}
|
|
return self::handler_from_record($record);
|
|
}
|
|
|
|
/**
|
|
* Load the Inbound Message handler with a given ID
|
|
*
|
|
* @param int $id
|
|
* @return \core\message\inbound\handler or false
|
|
*/
|
|
public static function get_handler_from_id($id) {
|
|
global $DB;
|
|
|
|
$record = $DB->get_record('messageinbound_handlers', array('id' => $id), '*', IGNORE_MISSING);
|
|
if (!$record) {
|
|
return false;
|
|
}
|
|
return self::handler_from_record($record);
|
|
}
|
|
|
|
}
|
|
|