1C-Bitrix 25.700.0
Загрузка...
Поиск...
Не найдено
provideroffline.php
См. документацию.
1<?php
2namespace Bitrix\Rest\Event;
3
4use Bitrix\Main\Application;
5use Bitrix\Main\Loader;
6use Bitrix\Pull;
7use Bitrix\Rest\EventOfflineTable;
8use Bitrix\Main\EventManager;
9use Bitrix\Rest\Tools\Diagnostics\Event\Logger;
10use Bitrix\Rest\Tools\Diagnostics\Event\LogType;
11use Bitrix\Rest\Tools\Diagnostics\LoggerManager;
12
14{
18 protected static $instance = null;
19
20 private array $eventList = [];
21 private bool $isFinaliseInit = false;
22
23 public static function instance(): ProviderOffline
24 {
25 if (static::$instance === null)
26 {
27 static::$instance = new static();
28 }
29
30 return static::$instance;
31 }
32
33 public function send(array $eventList)
34 {
35 $this->eventList = array_merge($this->eventList, $eventList);
36 $this->registerFinalize();
37 }
38
42 public function registerFinalize(): void
43 {
44 if (!$this->isFinaliseInit)
45 {
46 $this->isFinaliseInit = true;
47 $application = Application::getInstance();
48 $application->addBackgroundJob(
49 job: [__CLASS__, 'runFinalize'],
50 priority: $application::JOB_PRIORITY_LOW
51 );
52 }
53 }
54
58 public static function runFinalize(): void
59 {
60 $instance = static::instance();
61 $instance->finalize();
62 }
63
67 public function finalize(): void
68 {
69 $serverAuthData = $this->getServerAuthData();
70
71 $offlineEventsCount = [];
72 $offlineEventsApp = [];
73
74 foreach ($this->eventList as $item)
75 {
76 $application = $item['APPLICATION'];
77 $handler = $item['HANDLER'];
78
79 if (
80 $serverAuthData['client_id'] !== $application['CLIENT_ID']
81 || $serverAuthData['auth_connector'] !== $handler['CONNECTOR_ID']
82 )
83 {
84 if (!isset($offlineEventsCount[$application['CLIENT_ID']]))
85 {
86 $offlineEventsCount[$application['CLIENT_ID']] = [];
87 }
88
89 if (!isset($offlineEventsCount[$application['CLIENT_ID']][$handler['CONNECTOR_ID']]))
90 {
91 $offlineEventsCount[$application['CLIENT_ID']][$handler['CONNECTOR_ID']] = 0;
92 }
93
95 [
96 'APP_ID' => $application['ID'],
97 'EVENT_NAME' => $handler['EVENT_NAME'],
98 'EVENT_DATA' => $item['DATA'],
99 'EVENT_ADDITIONAL' => $item['AUTH'],
100 'CONNECTOR_ID' => $handler['CONNECTOR_ID'],
101 ]
102 );
103
104 $offlineEventsCount[$application['CLIENT_ID']][$handler['CONNECTOR_ID']]++;
105 $offlineEventsApp[$application['ID']] = true;
106 }
107 else
108 {
109 LoggerManager::getInstance()->getLogger()?->info(
110 "\n{delimiter}\n"
111 . "{date} - {host}\n{delimiter}\n"
112 . "Event skipped because initializer is current application. \n"
113 . "auth: {serverAuthData}"
114 . "app: {application}\n", [
115 'serverAuthData' => $serverAuthData,
116 'application' => $application,
117 'MESSAGE' => LogType::OFFLINE_EVENT_SKIPPED->value,
118 ]);
119 }
120 }
121
122 if (!empty($offlineEventsCount))
123 {
124 $this->notifyApplications($offlineEventsCount);
125 }
126
127 if (!empty($offlineEventsApp))
128 {
129 $this->sendOfflineEvent(array_keys($offlineEventsApp));
130 }
131
132 $this->eventList = [];
133 $this->isFinaliseInit = false;
134 }
135
136 protected function getServerAuthData()
137 {
138 $server = \CRestServer::instance();
139 $serverAuthData = array('auth_connector' => '', 'client_id' => '');
140 if($server !== null)
141 {
142 $serverAuthData = $server->getAuthData();
143 if(!isset($serverAuthData['auth_connector']))
144 {
145 $serverAuthData['auth_connector'] = '';
146 }
147
148 $serverAuthData['client_id'] = $server->getClientId();
149 }
150
151 return $serverAuthData;
152 }
153
154 protected function sendOfflineEvent(array $appList)
155 {
156 foreach (EventManager::getInstance()->findEventHandlers(
157 "rest",
158 "onAfterOfflineEventCall"
159 ) as $event)
160 {
161 ExecuteModuleEventEx($event, [['APP_LIST' => $appList]]);
162 }
163 }
164
166 {
167 foreach($counters as $clientId => $connectorCounters)
168 {
169 if(is_array($connectorCounters) && !empty($connectorCounters))
170 {
171 $this->notifyApplication($clientId, $connectorCounters);
172 }
173 }
174 }
175
176 protected function notifyApplication($clientId, array $connectorCounters)
177 {
178 if(Loader::includeModule('pull'))
179 {
180 $eventParam = array();
181
182 foreach($connectorCounters as $connectorId => $count)
183 {
184 $eventParam[] = array(
185 'connector_id' => $connectorId,
186 'count' => $count
187 );
188 }
189
190 Pull\Event::add(Pull\Event::SHARED_CHANNEL, array(
191 'module_id' => 'rest',
192 'command' => 'event_offline',
193 'params' => $eventParam,
194 ), $clientId);
195 }
196 }
197}
$count
Определения admin_tab.php:4
static add($recipient, array $parameters, $channelType=\CPullChannel::TYPE_PRIVATE)
Определения event.php:22
notifyApplication($clientId, array $connectorCounters)
Определения provideroffline.php:176
sendOfflineEvent(array $appList)
Определения provideroffline.php:154
notifyApplications(array $counters)
Определения provideroffline.php:165
send(array $eventList)
Определения provideroffline.php:33
static callEvent($fields)
Определения eventoffline.php:122
</td ></tr ></table ></td ></tr >< tr >< td class="bx-popup-label bx-width30"><?=GetMessage("PAGE_NEW_TAGS")?> array( $site)
Определения file_new.php:804
$application
Определения bitrix.php:23
ExecuteModuleEventEx($arEvent, $arParams=[])
Определения tools.php:5214
$event
Определения prolog_after.php:141
$counters
Определения options.php:100
$clientId
Определения seo_client.php:18