# Работа с контейнером данных OzCapsula в Web SDK

OzCapsula – это разработанный нами проприетарный формат, контейнер данных, обеспечивающий сквозную защиту и целостность информации в процессе передачи. Функциональность добавлена в версии 1.9.2. В режиме работы с контейнером данных SDK снимает видео на устройстве конечного пользователя, затем пакует медиафайлы вместе со всей нужной информацией в контейнер (`application/octet-stream`), после чего:

* отправляет данные напрямую в Oz API (`architecture`: `normal` для полной версии API или `lite` для Instant API), или
* отправляет данные на ваш бэкенд (`architecture`: `capture`).

Также необходим новый токен: `session_token`.

## **Конфигурация**

Ключевые параметры для использования контейнера

| **Параметр**             | **Значение**                 | **Описание**                                                                                     |
| ------------------------ | ---------------------------- | ------------------------------------------------------------------------------------------------ |
| use\_wasm\_container     | true                         | Включает функциональность контейнера данныз                                                      |
| architecture             | `normal` / `lite`/ `capture` | Определяет, как будут отправляться данные в  Oz API – через Web SDK или через ваш бэкенд         |
| api\_use\_session\_token | `api` / `client`             | Определяет, как будет получен session\_token – через Web SDK или запросом в API через ваш бэкенд |

## Session Token

#### `api_use_session_token: "client"`

При таких настройках session token получает ваш бэкенд перед открытием Web SDK.

**Шаги:**

1. Запросите session token у Oz API:

```bash
curl --location '{{host}}/api/authorize/session_token' \
  -H 'X-Forensic-Access-Token: <YOUR_TOKEN>'
```

2. В ответе придет краткосрочный `session_token`:

```bash
{
  "session_token": "eyJh..."
}
```

3. Передайте токен в плагин Web SDK:

```php
OzLiveness.open({
  session_token,
  // other open options
});
```

{% hint style="info" %}
Session token действителен в течение нескольких минут. Его необходимо запрашивать перед каждой съемкой видео.
{% endhint %}

#### `api_use_session_token: "api"`

При таких настройках SDK получает токен в Oz API автоматически, дополнительно ничего запрашивать или передавать не нужно.

## Описание процесса работы для разных архитектур

Процесс работы с контейнером зависит от типа архитектуры, который вы используете.

#### architecture: "normal"

В режиме `normal` Web SDK отправляет сгенерированный контейнер данный в Oz API автоматически. Дополнительно ничего загружать не нужно.

### **`architecture: "lite"`**

В режиме `lite` Web SDK отправляет сгенерированный контейнер данный в Oz API автоматически. Дополнительно ничего загружать не нужно.

### **`architecture: "capture"`**

В режиме `capture` **Web SDK только снимает видео и пакует все нужные данные** в контейнер, но **не отправляет** их в Oz API. За передачу данных из Web SDK в Oz API отвечает ваш бэкенд.&#x20;

**Процесс:**

1. Web SDK снимает видео и вызывает callback-функцию `on_capture_complete(result, container)`. Второй аргумент этой функции (`container`) представляет собой **Blob**-объект (`application/octet-stream`).
2. Вы отправляете этот объект на свой бэкенд.
3. Ваш бэкенд отправляет этот объект в Oz API запросом HTTPS POST.

**Пример запроса:**

```bash
curl -X POST \
  '{{host}}/api/folders' \
  -H 'Content-Type: application/octet-stream' \
  -H 'X-Forensic-Access-Token: <YOUR_TOKEN>' \
  --data-binary '@/path/to/container.dat'
```

Ответ будет таким же, как и при процессе без использования контейнера.

### Возможные ошибки <a href="#possible-errors" id="possible-errors"></a>

| **Ошибка**                                                                                                                              | **Описание**                                     |
| --------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------ |
| error\_wasm\_internal\_failure\_1                                                                                                       | Устройство или браузер не поддерживает WASM      |
| error\_wasm\_internal\_failure\_2                                                                                                       | На устройстве недостаточно памяти                |
| <ul><li>error\_wasm\_internal\_failure\_3</li><li>error\_wasm\_internal\_failure\_4</li><li>error\_wasm\_internal\_failure\_5</li></ul> | Контейнер создать не удалось. Попробуйте еще раз |
| error\_wasm\_internal\_failure\_1000                                                                                                    | Любая другая ошибка не из списка выше            |


---

# 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://doc.ozforensics.com/oz-knowledge-ru/rukovodstva/rukovodstvo-razrabotchika/sdk/websdk/rabota-s-konteinerom-dannykh-ozcapsula-v-web-sdk.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.
