# Логирование в скриптах

# Пример вызова в скрипте через Imports и Namespace.action

<p class="callout success">Доступно с версии 2024.2</p>

### Вариант с использованием Imports:

```typescript
async function action(): Promise<void> {
    const message = `${Context.data.__item!.namespace}.${Context.data.__item!.code}.${Context.data.__item!.id}`;
    const details = JSON.stringify((<any>Context).json(), null, 2);
    Imports?.devtools?.action?.save_to_log?.call({message: message, details: details});
}
```

Нужно подключить зависимость и определить псевдоним, в данном примере это **devtools**:

[![image.png](https://kb.randmgroup.ru/uploads/images/gallery/2024-02/scaled-1680-/5iqtcCDwweto1iTd-image.png)](https://kb.randmgroup.ru/uploads/images/gallery/2024-02/5iqtcCDwweto1iTd-image.png)

# Пример вызова в скрипте

<p class="callout success">Логирование поддерживается как в клиентских, так и серверных скриптах.</p>

На текущий момент нами был обнаружен единственный способ для решения данной задачи. Он не является изящным, но "на безрыбье и рак щука". Отдельное спасибо за идею Раису.

Для того, чтобы в лог (приложение в разделе системных справочников) попала информация, в скрипте необходимо вызнать следующий код:

```typescript
const message = 'Сообщение из серверного скрипта';
const details = 'Проверка вызова логирования из серверного скрипта в ' + Date().toString();
await System.templater.generateText(Context, `{ExtText('82fe0bc6-0564-4b8a-a7d4-4c136cf8a949', 'logger', '${message}', '${details}')}`);
```

Результатом выполнения будет следующее:

[![image.png](https://kb.randmgroup.ru/uploads/images/gallery/2023-11/scaled-1680-/Tg40ofc0wQIBAUDy-image.png)](https://kb.randmgroup.ru/uploads/images/gallery/2023-11/Tg40ofc0wQIBAUDy-image.png)

[![image.png](https://kb.randmgroup.ru/uploads/images/gallery/2023-11/scaled-1680-/rV4bEQN5K9OuAnn8-image.png)](https://kb.randmgroup.ru/uploads/images/gallery/2023-11/rV4bEQN5K9OuAnn8-image.png)

# Логирование данных в обработчике событий

Для того, чтобы понять, какие данные приходят в обработчик событий в модуле, можно использовать следующий код:

```typescript
async function action(): Promise<void> {
    const message = 'Сообщение о записи входящего разговора';
    const details = JSON.stringify((<any>Context).json(), null, 2);
    await System.templater.generateText(Context, `{ExtText('82fe0bc6-0564-4b8a-a7d4-4c136cf8a949', 'logger', '${message}', ${details}')}`);
}
```

В результате, в логе будет следующая информация:

[![image.png](https://kb.randmgroup.ru/uploads/images/gallery/2024-02/scaled-1680-/YjXXTY7GvBiZ9ypm-image.png)](https://kb.randmgroup.ru/uploads/images/gallery/2024-02/YjXXTY7GvBiZ9ypm-image.png)

[![image.png](https://kb.randmgroup.ru/uploads/images/gallery/2024-02/scaled-1680-/KOlbE7SC2YLr45aT-image.png)](https://kb.randmgroup.ru/uploads/images/gallery/2024-02/KOlbE7SC2YLr45aT-image.png)