# Мониторинг провайдеров на MikoPBX

При работе с поставщиками услуг связи периодически могут возникать проблемы. К примеру сервер поставщика не отвечает / не доступен. В рамках данной статьи будет предложен механизм оповещения на email системного администратора.

{% hint style="success" %}
Для работы оповещений потребуется настроить SMTP клиент. См. инструкции в разделе «[Почта и уведомления](broken://pages/tqyJLzMpdFJ2KU2vrQld)»
{% endhint %}

1. Создайте новое «[Приложение диалплан](/mikopbx/manual/modules/dialplan-applications.md)[а](/mikopbx/manual/modules/dialplan-applications.md)».

<figure><img src="/files/BiGqEHV32zVh9F4AUPzE" alt=""><figcaption><p>Создание нового приложения диалплана</p></figcaption></figure>

2. Укажите название - например, Provider Monitoring, короткий номер для приложения, к примеру 99, а так жу выберите «**Тип кода**» - «**PHP AGI Скрипт**»

<figure><img src="/files/B38Jw6gdkYk18FETI0ba" alt=""><figcaption><p>Параметры диалплана</p></figcaption></figure>

3. Перейдите во вкладку "Программный код":

<figure><img src="/files/9kDpg5SuOW8BelPuLLs9" alt=""><figcaption><p>Раздел "Программный код"</p></figcaption></figure>

4. Вставьте код:

```php
<?php
use MikoPBX\Common\Models\PbxSettings;
use MikoPBX\Common\Models\LanInterfaces;
use MikoPBX\Core\System\Notifications;
use MikoPBX\PBXCoreREST\Lib\SIPStackProcessor;

require_once 'Globals.php';

$result = SIPStackProcessor::callBack(['action' => 'getRegistry']);
$adminMail = null;
$localIP = '';
$message = '';
foreach ($result->data as $provider) {
    if ($provider['state'] !== 'OFF' && $provider['state'] !== 'REGISTERED') {
        if ($adminMail === null) {
            $adminMail = PbxSettings::getValueByKey('SystemNotificationsEmail');
            $interfaces = LanInterfaces::find("disabled='0'");
            foreach ($interfaces as $interface) {
                if (!empty($interface->ipaddr)) {
                    $localIP = $interface->ipaddr;
                    break;
                }
            }
        }
        $message .= "Provider state: {$provider['state']}<br>" . "Url (local): ']} <br><br>";
    }
}

if (!empty($message) && !empty($adminMail)) {
    $notify = new Notifications();
    try {
        $notify->sendMail($adminMail, 'Provider invalid state...', $message);
    } catch (\Throwable $e) {
    }
}
```

5. Сохраните изменения и скопируйте идентификатор приложения из адресной строки браузера, он имеет вид «**DIALPLAN-APP-9С060381**»

<figure><img src="/files/X0jAlaHKc0iZtyb1sHMl" alt=""><figcaption><p>Идентификатор приложения диалплана</p></figcaption></figure>

6. Перейдите в раздел **Система** → **Кастомизация системных файлов**, откройте для редактирования файл **/var/spool/cron/crontabs/root**

<figure><img src="/files/63T7t8ZVuyuXCJvUxevu" alt=""><figcaption><p>Необходимый файл для редактирования</p></figcaption></figure>

7. Выберите режим **«Добавлять в конец файла»**, внизу в черное поле для редактирования вставьте следующий код:

{% hint style="info" %}
Скорректируйте имя файла согласно вашему идентификатору приложения «**DIALPLAN-APP-9С060381**»
{% endhint %}

```
*/5 * * * * /usr/bin/php -f /var/lib/asterisk/agi-bin/DIALPLAN-APP-9С060381.php start > /dev/null 2> /dev/null 
```

Сохраните изменения.

<figure><img src="/files/aVLpbnzeM8g3FqsVxrus" alt=""><figcaption></figcaption></figure>

Готово!


---

# Agent Instructions: Querying This Documentation

If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://docs.mikopbx.com/mikopbx/faq/setup/monitoring-providers-on-mikopbx.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
