2023-08-13 11:40:35 +02:00
|
|
|
<?php declare(strict_types=1);
|
2022-12-30 21:54:44 +01:00
|
|
|
|
2023-08-13 11:40:35 +02:00
|
|
|
/**
|
|
|
|
* This file is part of MadelineProto.
|
|
|
|
* MadelineProto is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
|
|
|
|
* MadelineProto 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 Affero General Public License for more details.
|
|
|
|
* You should have received a copy of the GNU General Public License along with MadelineProto.
|
|
|
|
* If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
* @author Daniil Gentili <daniil@daniil.it>
|
|
|
|
* @copyright 2016-2023 Daniil Gentili <daniil@daniil.it>
|
|
|
|
* @license https://opensource.org/licenses/AGPL-3.0 AGPLv3
|
|
|
|
* @link https://docs.madelineproto.xyz MadelineProto documentation
|
|
|
|
*/
|
2020-09-22 11:48:12 +02:00
|
|
|
|
|
|
|
namespace danog\MadelineProto;
|
|
|
|
|
|
|
|
use danog\MadelineProto\Settings\AppInfo;
|
|
|
|
use danog\MadelineProto\Settings\Auth;
|
|
|
|
use danog\MadelineProto\Settings\Connection;
|
|
|
|
use danog\MadelineProto\Settings\Database\Memory as DatabaseMemory;
|
|
|
|
use danog\MadelineProto\Settings\DatabaseAbstract;
|
|
|
|
use danog\MadelineProto\Settings\Files;
|
2020-09-26 17:11:41 +02:00
|
|
|
use danog\MadelineProto\Settings\Ipc;
|
2020-09-22 11:48:12 +02:00
|
|
|
use danog\MadelineProto\Settings\Logger;
|
2024-05-20 17:42:04 +02:00
|
|
|
use danog\MadelineProto\Settings\Metrics;
|
2020-09-22 11:48:12 +02:00
|
|
|
use danog\MadelineProto\Settings\Peer;
|
|
|
|
use danog\MadelineProto\Settings\RPC;
|
|
|
|
use danog\MadelineProto\Settings\SecretChats;
|
|
|
|
use danog\MadelineProto\Settings\Serialization;
|
2023-06-18 22:40:43 +02:00
|
|
|
use danog\MadelineProto\Settings\Templates;
|
2020-09-22 11:48:12 +02:00
|
|
|
use danog\MadelineProto\Settings\TLSchema;
|
2020-11-29 20:02:50 +01:00
|
|
|
use danog\MadelineProto\Settings\VoIP;
|
2020-09-22 11:48:12 +02:00
|
|
|
|
2020-10-07 19:31:52 +02:00
|
|
|
/**
|
|
|
|
* Settings class used for configuring MadelineProto.
|
|
|
|
*/
|
2023-01-15 12:05:38 +01:00
|
|
|
final class Settings extends SettingsAbstract
|
2020-09-22 11:48:12 +02:00
|
|
|
{
|
|
|
|
/**
|
|
|
|
* App information.
|
|
|
|
*/
|
|
|
|
protected AppInfo $appInfo;
|
|
|
|
/**
|
|
|
|
* Cryptography settings.
|
|
|
|
*/
|
|
|
|
protected Auth $auth;
|
|
|
|
/**
|
|
|
|
* Connection settings.
|
|
|
|
*/
|
|
|
|
protected Connection $connection;
|
|
|
|
/**
|
|
|
|
* File management settings.
|
|
|
|
*/
|
|
|
|
protected Files $files;
|
2024-05-07 15:27:07 +02:00
|
|
|
/**
|
2024-05-20 17:42:04 +02:00
|
|
|
* Metrics settings.
|
2024-05-07 15:27:07 +02:00
|
|
|
*/
|
2024-05-20 17:42:04 +02:00
|
|
|
protected Metrics $metrics;
|
2020-09-26 17:11:41 +02:00
|
|
|
/**
|
|
|
|
* IPC server settings.
|
|
|
|
*/
|
|
|
|
protected Ipc $ipc;
|
2020-09-22 11:48:12 +02:00
|
|
|
/**
|
|
|
|
* Logger settings.
|
|
|
|
*/
|
|
|
|
protected Logger $logger;
|
|
|
|
/**
|
|
|
|
* Peer database settings.
|
|
|
|
*/
|
|
|
|
protected Peer $peer;
|
|
|
|
/**
|
|
|
|
* RPC settings.
|
|
|
|
*/
|
|
|
|
protected RPC $rpc;
|
|
|
|
/**
|
|
|
|
* Secret chat settings.
|
|
|
|
*/
|
|
|
|
protected SecretChats $secretChats;
|
|
|
|
/**
|
|
|
|
* Serialization settings.
|
|
|
|
*/
|
|
|
|
protected Serialization $serialization;
|
|
|
|
/**
|
|
|
|
* TL schema settings.
|
|
|
|
*/
|
|
|
|
protected TLSchema $schema;
|
|
|
|
/**
|
|
|
|
* DatabaseAbstract settings.
|
|
|
|
*/
|
|
|
|
protected DatabaseAbstract $db;
|
2023-06-18 22:40:43 +02:00
|
|
|
/**
|
|
|
|
* Template settings.
|
|
|
|
*/
|
|
|
|
protected Templates $templates;
|
2020-11-29 20:02:50 +01:00
|
|
|
/**
|
|
|
|
* VoIP settings.
|
|
|
|
*/
|
|
|
|
protected VoIP $voip;
|
2020-09-22 11:48:12 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Constructor.
|
|
|
|
*/
|
|
|
|
public function __construct()
|
|
|
|
{
|
|
|
|
$this->appInfo = new AppInfo;
|
|
|
|
$this->auth = new Auth;
|
|
|
|
$this->connection = new Connection;
|
|
|
|
$this->files = new Files;
|
|
|
|
$this->logger = new Logger;
|
|
|
|
$this->peer = new Peer;
|
2024-05-20 17:42:04 +02:00
|
|
|
$this->metrics = new Metrics;
|
2020-09-22 11:48:12 +02:00
|
|
|
$this->rpc = new RPC;
|
|
|
|
$this->secretChats = new SecretChats;
|
|
|
|
$this->serialization = new Serialization;
|
|
|
|
$this->schema = new TLSchema;
|
|
|
|
$this->db = new DatabaseMemory;
|
2023-06-18 22:40:43 +02:00
|
|
|
$this->templates = new Templates;
|
2020-09-26 17:11:41 +02:00
|
|
|
$this->ipc = new IPc;
|
2020-11-29 20:02:50 +01:00
|
|
|
$this->voip = new VoIP;
|
|
|
|
}
|
2022-12-08 20:16:40 +01:00
|
|
|
public function __wakeup(): void
|
2020-11-29 20:02:50 +01:00
|
|
|
{
|
|
|
|
if (!isset($this->voip)) {
|
|
|
|
$this->voip = new VoIP;
|
|
|
|
}
|
2024-05-20 17:42:04 +02:00
|
|
|
if (!isset($this->metrics)) {
|
|
|
|
$this->metrics = new Metrics;
|
2024-05-07 15:27:07 +02:00
|
|
|
}
|
2020-09-22 11:48:12 +02:00
|
|
|
}
|
|
|
|
/**
|
|
|
|
* Merge another instance of settings.
|
|
|
|
*
|
|
|
|
* @param SettingsAbstract $settings Settings
|
|
|
|
*/
|
|
|
|
public function merge(SettingsAbstract $settings): void
|
|
|
|
{
|
|
|
|
if (!$settings instanceof self) {
|
2020-09-24 20:49:34 +02:00
|
|
|
if ($settings instanceof AppInfo) {
|
|
|
|
$this->appInfo->merge($settings);
|
|
|
|
} elseif ($settings instanceof Auth) {
|
|
|
|
$this->auth->merge($settings);
|
|
|
|
} elseif ($settings instanceof Connection) {
|
|
|
|
$this->connection->merge($settings);
|
|
|
|
} elseif ($settings instanceof Files) {
|
|
|
|
$this->files->merge($settings);
|
2024-05-20 17:42:04 +02:00
|
|
|
} elseif ($settings instanceof Metrics) {
|
|
|
|
$this->metrics->merge($settings);
|
2020-09-24 20:49:34 +02:00
|
|
|
} elseif ($settings instanceof Logger) {
|
|
|
|
$this->logger->merge($settings);
|
|
|
|
} elseif ($settings instanceof Peer) {
|
|
|
|
$this->peer->merge($settings);
|
|
|
|
} elseif ($settings instanceof RPC) {
|
|
|
|
$this->rpc->merge($settings);
|
|
|
|
} elseif ($settings instanceof SecretChats) {
|
|
|
|
$this->secretChats->merge($settings);
|
|
|
|
} elseif ($settings instanceof Serialization) {
|
|
|
|
$this->serialization->merge($settings);
|
|
|
|
} elseif ($settings instanceof TLSchema) {
|
|
|
|
$this->schema->merge($settings);
|
2020-09-26 17:11:41 +02:00
|
|
|
} elseif ($settings instanceof Ipc) {
|
|
|
|
$this->ipc->merge($settings);
|
2023-06-18 22:40:43 +02:00
|
|
|
} elseif ($settings instanceof Templates) {
|
|
|
|
$this->templates->merge($settings);
|
2020-11-29 20:02:50 +01:00
|
|
|
} elseif ($settings instanceof VoIP) {
|
|
|
|
$this->voip->merge($settings);
|
2020-09-24 23:25:54 +02:00
|
|
|
} elseif ($settings instanceof DatabaseAbstract) {
|
|
|
|
if (!$this->db instanceof $settings) {
|
|
|
|
$this->db = $settings;
|
|
|
|
} else {
|
|
|
|
$this->db->merge($settings);
|
|
|
|
}
|
2020-09-24 20:49:34 +02:00
|
|
|
}
|
2020-09-22 11:48:12 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
$this->appInfo->merge($settings->appInfo);
|
|
|
|
$this->auth->merge($settings->auth);
|
|
|
|
$this->connection->merge($settings->connection);
|
|
|
|
$this->files->merge($settings->files);
|
2024-05-20 17:42:04 +02:00
|
|
|
$this->metrics->merge($settings->metrics);
|
2020-09-22 11:48:12 +02:00
|
|
|
$this->logger->merge($settings->logger);
|
|
|
|
$this->peer->merge($settings->peer);
|
|
|
|
$this->rpc->merge($settings->rpc);
|
|
|
|
$this->secretChats->merge($settings->secretChats);
|
|
|
|
$this->serialization->merge($settings->serialization);
|
|
|
|
$this->schema->merge($settings->schema);
|
2020-09-26 17:11:41 +02:00
|
|
|
$this->ipc->merge($settings->ipc);
|
2023-06-18 22:40:43 +02:00
|
|
|
$this->templates->merge($settings->templates);
|
2020-11-29 20:02:50 +01:00
|
|
|
$this->voip->merge($settings->voip);
|
2020-09-22 11:48:12 +02:00
|
|
|
|
|
|
|
if (!$this->db instanceof $settings->db) {
|
|
|
|
$this->db = $settings->db;
|
|
|
|
} else {
|
|
|
|
$this->db->merge($settings->db);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get app information.
|
|
|
|
*/
|
|
|
|
public function getAppInfo(): AppInfo
|
|
|
|
{
|
|
|
|
return $this->appInfo;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set app information.
|
|
|
|
*
|
|
|
|
* @param AppInfo $appInfo App information.
|
|
|
|
*/
|
|
|
|
public function setAppInfo(AppInfo $appInfo): self
|
|
|
|
{
|
|
|
|
$this->appInfo = $appInfo;
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get cryptography settings.
|
|
|
|
*/
|
|
|
|
public function getAuth(): Auth
|
|
|
|
{
|
|
|
|
return $this->auth;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set cryptography settings.
|
|
|
|
*
|
|
|
|
* @param Auth $auth Cryptography settings.
|
|
|
|
*/
|
|
|
|
public function setAuth(Auth $auth): self
|
|
|
|
{
|
|
|
|
$this->auth = $auth;
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get connection settings.
|
|
|
|
*/
|
|
|
|
public function getConnection(): Connection
|
|
|
|
{
|
|
|
|
return $this->connection;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set connection settings.
|
|
|
|
*
|
|
|
|
* @param Connection $connection Connection settings.
|
|
|
|
*/
|
|
|
|
public function setConnection(Connection $connection): self
|
|
|
|
{
|
|
|
|
$this->connection = $connection;
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get file management settings.
|
|
|
|
*/
|
|
|
|
public function getFiles(): Files
|
|
|
|
{
|
|
|
|
return $this->files;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set file management settings.
|
|
|
|
*
|
|
|
|
* @param Files $files File management settings.
|
|
|
|
*/
|
|
|
|
public function setFiles(Files $files): self
|
|
|
|
{
|
|
|
|
$this->files = $files;
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2024-05-07 15:27:07 +02:00
|
|
|
/**
|
2024-05-20 17:42:04 +02:00
|
|
|
* Get metrics settings.
|
2024-05-07 15:27:07 +02:00
|
|
|
*/
|
2024-05-20 17:42:04 +02:00
|
|
|
public function getMetrics(): Metrics
|
2024-05-07 15:27:07 +02:00
|
|
|
{
|
2024-05-20 17:42:04 +02:00
|
|
|
return $this->metrics;
|
2024-05-07 15:27:07 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2024-05-20 17:42:04 +02:00
|
|
|
* Set metrics settings.
|
2024-05-07 15:27:07 +02:00
|
|
|
*
|
2024-05-20 17:42:04 +02:00
|
|
|
* @param Metrics $metrics File management settings.
|
2024-05-07 15:27:07 +02:00
|
|
|
*/
|
2024-05-20 17:42:04 +02:00
|
|
|
public function setMetrics(Metrics $metrics): self
|
2024-05-07 15:27:07 +02:00
|
|
|
{
|
2024-05-20 17:42:04 +02:00
|
|
|
$this->metrics = $metrics;
|
2024-05-07 15:27:07 +02:00
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2020-09-22 11:48:12 +02:00
|
|
|
/**
|
|
|
|
* Get logger settings.
|
|
|
|
*/
|
|
|
|
public function getLogger(): Logger
|
|
|
|
{
|
|
|
|
return $this->logger;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set logger settings.
|
|
|
|
*
|
|
|
|
* @param Logger $logger Logger settings.
|
|
|
|
*/
|
|
|
|
public function setLogger(Logger $logger): self
|
|
|
|
{
|
|
|
|
$this->logger = $logger;
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get peer database settings.
|
|
|
|
*/
|
|
|
|
public function getPeer(): Peer
|
|
|
|
{
|
|
|
|
return $this->peer;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set peer database settings.
|
|
|
|
*
|
|
|
|
* @param Peer $peer Peer database settings.
|
|
|
|
*/
|
|
|
|
public function setPeer(Peer $peer): self
|
|
|
|
{
|
|
|
|
$this->peer = $peer;
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get RPC settings.
|
|
|
|
*/
|
|
|
|
public function getRpc(): RPC
|
|
|
|
{
|
|
|
|
return $this->rpc;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set RPC settings.
|
|
|
|
*
|
|
|
|
* @param RPC $rpc RPC settings.
|
|
|
|
*/
|
|
|
|
public function setRpc(RPC $rpc): self
|
|
|
|
{
|
|
|
|
$this->rpc = $rpc;
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get secret chat settings.
|
|
|
|
*/
|
|
|
|
public function getSecretChats(): SecretChats
|
|
|
|
{
|
|
|
|
return $this->secretChats;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set secret chat settings.
|
|
|
|
*
|
|
|
|
* @param SecretChats $secretChats Secret chat settings.
|
|
|
|
*/
|
|
|
|
public function setSecretChats(SecretChats $secretChats): self
|
|
|
|
{
|
|
|
|
$this->secretChats = $secretChats;
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get serialization settings.
|
|
|
|
*/
|
|
|
|
public function getSerialization(): Serialization
|
|
|
|
{
|
|
|
|
return $this->serialization;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set serialization settings.
|
|
|
|
*
|
|
|
|
* @param Serialization $serialization Serialization settings.
|
|
|
|
*/
|
|
|
|
public function setSerialization(Serialization $serialization): self
|
|
|
|
{
|
|
|
|
$this->serialization = $serialization;
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get TL schema settings.
|
|
|
|
*/
|
|
|
|
public function getSchema(): TLSchema
|
|
|
|
{
|
|
|
|
return $this->schema;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set TL schema settings.
|
|
|
|
*
|
|
|
|
* @param TLSchema $schema TL schema settings.
|
|
|
|
*/
|
|
|
|
public function setSchema(TLSchema $schema): self
|
|
|
|
{
|
|
|
|
$this->schema = $schema;
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get database settings.
|
|
|
|
*/
|
|
|
|
public function getDb(): DatabaseAbstract
|
|
|
|
{
|
|
|
|
return $this->db;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set database settings.
|
|
|
|
*
|
|
|
|
* @param DatabaseAbstract $db DatabaseAbstract settings.
|
|
|
|
*/
|
|
|
|
public function setDb(DatabaseAbstract $db): self
|
|
|
|
{
|
|
|
|
$this->db = $db;
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
2020-09-26 17:11:41 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get IPC server settings.
|
|
|
|
*/
|
|
|
|
public function getIpc(): Ipc
|
|
|
|
{
|
|
|
|
return $this->ipc;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set IPC server settings.
|
|
|
|
*
|
|
|
|
* @param Ipc $ipc IPC server settings.
|
|
|
|
*/
|
|
|
|
public function setIpc(Ipc $ipc): self
|
|
|
|
{
|
|
|
|
$this->ipc = $ipc;
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function applyChanges(): SettingsAbstract
|
|
|
|
{
|
2023-10-01 20:05:04 +02:00
|
|
|
foreach (get_object_vars($this) as $setting) {
|
2020-09-26 21:57:06 +02:00
|
|
|
if ($setting instanceof SettingsAbstract) {
|
|
|
|
$setting->applyChanges();
|
|
|
|
}
|
2020-09-26 17:11:41 +02:00
|
|
|
}
|
|
|
|
return $this;
|
|
|
|
}
|
2020-09-26 21:57:06 +02:00
|
|
|
|
2023-06-18 22:40:43 +02:00
|
|
|
/**
|
|
|
|
* Get template settings.
|
|
|
|
*/
|
|
|
|
public function getTemplates(): Templates
|
|
|
|
{
|
|
|
|
return $this->templates;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set template settings.
|
|
|
|
*
|
|
|
|
* @param Templates $templates Template settings
|
|
|
|
*/
|
|
|
|
public function setTemplates(Templates $templates): self
|
|
|
|
{
|
|
|
|
$this->templates = $templates;
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2020-11-29 20:02:50 +01:00
|
|
|
/**
|
|
|
|
* Get voIP settings.
|
|
|
|
*/
|
|
|
|
public function getVoip(): VoIP
|
|
|
|
{
|
|
|
|
return $this->voip;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set voIP settings.
|
|
|
|
*
|
|
|
|
* @param VoIP $voip VoIP settings.
|
|
|
|
*/
|
|
|
|
public function setVoip(VoIP $voip): self
|
|
|
|
{
|
|
|
|
$this->voip = $voip;
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
2020-09-22 11:48:12 +02:00
|
|
|
}
|