Add notifications section (#159)
This commit is contained in:
parent
e973d605f4
commit
5b91648590
@ -44,6 +44,7 @@ class ApiVersion5 extends AbstractLoader
|
|||||||
use V5\Delivery;
|
use V5\Delivery;
|
||||||
use V5\Files;
|
use V5\Files;
|
||||||
use V5\Module;
|
use V5\Module;
|
||||||
|
use V5\Notifications;
|
||||||
use V5\Orders;
|
use V5\Orders;
|
||||||
use V5\Packs;
|
use V5\Packs;
|
||||||
use V5\References;
|
use V5\References;
|
||||||
|
47
lib/RetailCrm/Methods/V5/Notifications.php
Normal file
47
lib/RetailCrm/Methods/V5/Notifications.php
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace RetailCrm\Methods\V5;
|
||||||
|
|
||||||
|
use RetailCrm\Response\ApiResponse;
|
||||||
|
|
||||||
|
trait Notifications
|
||||||
|
{
|
||||||
|
protected static $allowedTypes = ['api.info', 'api.error'];
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return ApiResponse
|
||||||
|
*/
|
||||||
|
public function sendNotification(array $notification)
|
||||||
|
{
|
||||||
|
if (empty($notification['type']) || !in_array($notification['type'], self::$allowedTypes, true)) {
|
||||||
|
throw new \InvalidArgumentException(
|
||||||
|
'Parameter `type` must be not empty & must be equal one of these values: api.info|api.error'
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (empty($notification['message'])) {
|
||||||
|
throw new \InvalidArgumentException(
|
||||||
|
'Parameter `message` should not be blank'
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (empty($notification['userGroups']) && empty($notification['userIds'])) {
|
||||||
|
throw new \InvalidArgumentException(
|
||||||
|
'One of the parameters must be filled: `userGroups` or `userIds`'
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!empty($notification['userGroups']) && !empty($notification['userIds'])) {
|
||||||
|
throw new \InvalidArgumentException(
|
||||||
|
'Only one of the two fields must be set: `userIds`, `userGroups`'
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/** @noinspection PhpUndefinedMethodInspection */
|
||||||
|
return $this->client->makeRequest(
|
||||||
|
"/notifications/send",
|
||||||
|
"POST",
|
||||||
|
['notification' => \json_encode($notification, JSON_UNESCAPED_SLASHES)]
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,106 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace RetailCrm\Tests\Methods\Version5;
|
||||||
|
|
||||||
|
use RetailCrm\Test\TestCase;
|
||||||
|
|
||||||
|
class ApiClientNotificationsTest extends TestCase
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @dataProvider notificationsProvider
|
||||||
|
*
|
||||||
|
* @group notifications_v5
|
||||||
|
*
|
||||||
|
* @param callable $getNotification
|
||||||
|
* @param string|null $exceptionClass
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function testSendNotification(callable $getNotification, $exceptionClass)
|
||||||
|
{
|
||||||
|
$client = static::getApiClient();
|
||||||
|
if (!empty($exceptionClass)) {
|
||||||
|
$this->expectException($exceptionClass);
|
||||||
|
}
|
||||||
|
$response = $client->request->sendNotification($getNotification());
|
||||||
|
if (empty($exceptionClass)) {
|
||||||
|
static::assertTrue(in_array($response->getStatusCode(), [200, 201]));
|
||||||
|
static::assertTrue($response->isSuccessful());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array[]
|
||||||
|
*/
|
||||||
|
public function notificationsProvider()
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'error_type' => [
|
||||||
|
static function () {
|
||||||
|
$notification = self::getErrorNotification();
|
||||||
|
$notification['type'] = 'another';
|
||||||
|
|
||||||
|
return $notification;
|
||||||
|
},
|
||||||
|
'InvalidArgumentException',
|
||||||
|
],
|
||||||
|
'error_message' => [
|
||||||
|
static function () {
|
||||||
|
$notification = self::getErrorNotification();
|
||||||
|
$notification['message'] = [];
|
||||||
|
|
||||||
|
return $notification;
|
||||||
|
},
|
||||||
|
'InvalidArgumentException',
|
||||||
|
],
|
||||||
|
'error_users_empty' => [
|
||||||
|
static function () {
|
||||||
|
$notification = self::getErrorNotification();
|
||||||
|
$notification['userGroups'] = [];
|
||||||
|
$notification['userIds'] = [];
|
||||||
|
|
||||||
|
return $notification;
|
||||||
|
},
|
||||||
|
'InvalidArgumentException',
|
||||||
|
],
|
||||||
|
'error_users_filled' => [
|
||||||
|
static function () {
|
||||||
|
return self::getErrorNotification();;
|
||||||
|
},
|
||||||
|
'InvalidArgumentException',
|
||||||
|
],
|
||||||
|
'success_group' => [
|
||||||
|
static function () {
|
||||||
|
$notification = self::getErrorNotification();
|
||||||
|
unset($notification['userIds']);
|
||||||
|
|
||||||
|
return $notification;
|
||||||
|
},
|
||||||
|
null,
|
||||||
|
],
|
||||||
|
'success_ids' => [
|
||||||
|
static function () {
|
||||||
|
$notification = self::getErrorNotification();
|
||||||
|
unset($notification['userGroups']);
|
||||||
|
|
||||||
|
return $notification;
|
||||||
|
},
|
||||||
|
null,
|
||||||
|
],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
protected static function getErrorNotification()
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'type' => 'api.error',
|
||||||
|
'userIds' => [1],
|
||||||
|
'userGroups' => ['superadmins'],
|
||||||
|
'message' => '<a href="/admin/integration/moysklad2/edit">[Модуль МойСклад]</a>
|
||||||
|
Возникли проблемы при проверке доступов входа. Введен неверный логин/пароль, проверьте корректность введенных данных.',
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user