kosmosafive/kosmos.linemessage
最新稳定版本:2.0.1
Composer 安装命令:
composer require kosmosafive/kosmos.linemessage
包简介
Kosmos: Мультиканальный транспорт для отправки оповещений
README 文档
README
Введение
Отправка сообщений получателю предполагает возможность поставки через один или несколько каналов связи. Механизм поставки при этом должен быть скрыт.
Идея решения состоит в том, чтобы, опираясь на некоторую конфигурацию и бизнес-логику, сформировать коллекцию каналов связи, по которым потенциально можно отправить сообщение. Также формируется максимально возможный контекст – массив данных, который включает как обязательные поля для обработки канала связи (например, email получателя для отправки email), так и используемые в возможных шаблонах.
Полученные данные принимает отправитель и возвращает коллекцию результатов, из которой можно получить как общий результат, так и точечный по каждому каналу связи.
Потенциальное логирование модулем не предусмотрено. Предполагается логирование в вызывающей конструкции и\или на инфраструктурном слое.
Установка
- Установить модуль
Установка через composer
В composer.json (пример для директории local) проекта добавьте
{
"require": {
"wikimedia/composer-merge-plugin": "dev-master"
},
"config": {
"allow-plugins": {
"wikimedia/composer-merge-plugin": true
}
},
"extra": {
"merge-plugin": {
"require": [
"../bitrix/composer-bx.json",
"modules/*/composer.json"
],
"recurse": true,
"replace": true,
"ignore-duplicates": false,
"merge-dev": true,
"merge-extra": false,
"merge-extra-deep": false,
"merge-scripts": false
},
"installer-paths": {
"modules/{$name}/": [
"type:bitrix-d7-module"
]
}
}
}
Использование
Отправка сообщений по каналам связи
use Bitrix\Main\Loader; use Kosmos\LineMessage\Line; use Kosmos\LineMessage\Sender; Loader::requireModule('kosmos.linemessage'); $someTemplateLine = new Line\Email('SOME_TEMPLATE'); $anotherTemplateLine = new Line\Email('ANOTHER_TEMPLATE'); $lineCollection = new Line\Collection( $someTemplateLine, $anotherTemplateLine ); $oneMoreTemplateLine = new Line\Email('ONE_MORE_TEMPLATE', true); $lineCollection->add($oneMoreTemplateLine); $context = ['EMAIL' => 'test@email.com']; $lineResultCollection = (new Sender($lines, $context))->send();
Работа с LineResultCollection
$lineResultCollection->isSuccess(); // true, если все сообщения были отправлены $lineResultCollection->isHandled(); // true, если все каналы обработаны $lineResultCollection->getSuccessCollection(); // коллекция отправленных $lineResultCollection->getFailureCollection(); // коллекция неотправленных $lineResultCollection->getHandledCollection(); // коллекция обработанных $lineResultCollection->getUnhandledCollection(); // коллекция необработанных
Получить результат для конкретного Line
$someTemplateLineResult = $lineResultCollection->findByLine($someTemplateLine);
Работа с LineResult
$someTemplateLineResult->isSuccess(); // true, если сообщение было отправлено $someTemplateLineResult->isHandled(); // true, если канал обработан
Каналы связи
Конструктор
- eventName – название события
- immediately – (опционально) немедленная отправка
Контекст
- EMAIL – email получателя
- LID – (опционально) идентификатор сайта
Добавление собственного канала связи
Необходимо реализовать интерфейс Kosmos\LineMessage\Line\LineInterface. Можно наследовать базовый класс Kosmos\LineMessage\Line\Line.
统计信息
- 总下载量: 6
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: Apache-2.0
- 更新时间: 2024-08-16