Шаблоны моделей телефонов для autoprovision (ap_templates)

Обзор

Предоставляет доступ к файлам шаблонов для автопровижена.

Каталог располагается в категории автоматически синхронизирующихся каталогов :SYNC.

Во время работы сервиса autoprovision производится создание частной конфигурации на основании шаблона (по модели телефона или по бренду телефона). В этом каталоге производится размещение шаблонов. Поиск производится в следующем порядке: <Бренд Модель>.cfg, <бренд модель>.cfg, <Бренд>.cfg, <бренд>.cfg. Внутри шаблонов могут быть взаимные ссылки. Подстановка параметров в шаблон производится в глубину до тех пор, пока итог не обретет законченный формат конфигурации. Важно избегать циклов.

При каждом перезапуске роли ap в каталог копируются примеры конфигураций, если соответствующие файлы на момент отсутствуют в каталоге.

Запросы

HTTP verb Endpoint Описание

POST

/rest/v1/fs/targets/ap_templates

Заливка группы файлов

GET

/rest/v1/fs/targets/ap_templates

Получение списка файлов

GET

/rest/v1/fs/targets/ap_templates/<filename>

Скачивание файла

PUT

/rest/v1/fs/targets/ap_templates/<filename>

Перезаливка существующего файла

DELETE

/rest/v1/fs/targets/ap_templates/<filename>

Удаление файла

HEAD

/rest/v1/fs/targets/ap_templates/<filename>

Получение мета-информации о файле


Заливка группы файлов

Загрузка в коллекцию производится с помощью Content-Type: multipart/formdata.

В запросе может быть один или несколько файлов. Файлы размещаются под именами, указанными в заголовках Content-Disposition каждой части.

Если файл с указанным именем уже существует, то он не сохраняется и возвращает ошибку. В зависимости от Content-Type и наличия успешно размещенных файлов в запросе может быть возвращен неудачный HTTP-ответ, либо информация о неудаче в теле HTTP-ответа 200 OK.

Запрос

Пример запроса
POST /rest/v1/fs/targets/ap_templates HTTP/1.1
Content-Type: multipart/form-data; boundary=-----------boundary_69df8120352a996e

-----------boundary_69df8120352a996e
Content-Type: application/octet-stream
Content-Disposition: form-data; name="filename"; filename="Yealink SIP-T30P.cfg"
Content-Transfer-Encoding: binary

BINARY BODY OF 'Yealink SIP-T30P.cfg'
-----------boundary_69df8120352a996e--

Ответ

Пример ответа
[
  {
    "name": "index.html",
    "size": 60506,
    "status": "ok"
  }
]

Получение списка файлов

Запрос

Table 1. Параметры запроса
Имя Тип Описание

filter

object

Фильтр по значениям полей.

mask

str

Список полей для вывода. Доступные поля для выдачи: name, size, last_modified.

offset

int

Смещение в списке файлов, подлежащих выдаче.

limit

int

Максимальное количество файлов в списке.

order

array<object|str>

Порядок сортировки файлов в списке.

Пример запроса
GET /rest/v1/fs/targets/ap_templates HTTP/1.1

Ответ

Пример ответа
HTTP/1.1 200 OK
Content-Type: application/json; charset=utf-8

[
  {
    "name": "Yealink.cfg",
    "size": 2020,
    "last_modified": "2022-01-14 03:10:05"
  },
  {
    "name": "Yealink SIP-T46U.cfg",
    "size": 2381,
    "last_modified": "2022-01-14 03:27:55"
  }
]

Скачивание файла

Запрос

Table 2. Параметры запроса
Имя Тип Описание

attachment

bool

Тип выдачи. По умолчанию false.

true – выдаётся с заголовком Content-Disposition: attachment; filename=filename.ext либо Content-Disposition: attachment; filename*=UTF-8''%d1%84%d0%b0%d0%b9%d0%bb.ext, где файл.ext – имя файла в кодировке UTF-8 и URLencoded.

false – выдается без заголовка Content-Disposition.

Пример запроса
GET /rest/v1/fs/targets/ap_templates/Yealink SIP-T30P.cfg?attachment=true HTTP/1.1

Ответ

Пример ответа
HTTP/1.1 200 OK
Content-Type: application/octet-stream; charset=utf-8
Content-Disposition: attachment; filename*=UTF-8''Yealink%20SIP-T30P.wav

BINARY BODY OF 'Yealink SIP-T30P.cfg'

Перезаливка существующего файла

Производит замену файла.

Загрузка одного файла производится либо с помощью Content-Type: multipart/formdata, либо с произвольным Content-Type не являющимся мультипартом.

Если загрузка происходит с Content-Type: multipart/formdata, то будет сохранён только первый файл (первая часть имеющая поле filename в заголовке Content-Disposition), а само название файла будет проигнорировано.

Запрос

Пример запроса (octet-stream)
PUT /rest/v1/fs/targets/ap_templates/Yealink SIP-T30P.cfg HTTP/1.1
Content-Type: application/octet-stream

BINARY BODY OF 'Yealink SIP-T30P.cfg'
Пример запроса (multipart)
PUT /rest/v1/fs/targets/ap_templates/Yealink SIP-T30P.cfg HTTP/1.1
Content-Type: multipart/form-data; boundary=-----------boundary_69df8120352a996e

-----------boundary_69df8120352a996e
Content-Type: application/octet-stream
Content-Disposition: form-data; name="Yealink SIP-T30P.cfg"; filename="Yealink SIP-T30P.cfg"
Content-Transfer-Encoding: binary

BINARY BODY OF 'Yealink SIP-T30P.cfg'
-----------boundary_69df8120352a996e--

Ответ

Пример ответа
HTTP/1.1 204 No Content

Удаление файла

Запрос

Пример запроса
DELETE /rest/v1/fs/targets/ap_templates/Yealink SIP-T30P.cfg HTTP/1.1

Ответ

Пример ответа
HTTP/1.1 204 No Content

Получение мета-информации о файле

Возвращает мета-информацию о файле, содержащую в том числе размер в заголовке Content-Length.

Особенности

  • HTTP-ответ не содержит тела, несмотря на наличие заголовка Content-Length.

Запрос

Table 3. Параметры запроса
Имя Тип Описание

attachment

bool

Тип выдачи. По умолчанию false.

true – выдаётся с заголовком Content-Disposition: attachment; filename=filename.ext либо Content-Disposition: attachment; filename*=UTF-8''%d1%84%d0%b0%d0%b9%d0%bb.ext, где файл.ext – имя файла в кодировке UTF-8 и URLencoded.

false – выдается без заголовка Content-Disposition.

Пример запроса
HEAD /rest/v1/fs/targets/ap_templates/Yealink SIP-T30P.cfg?attachment=true HTTP/1.1

Ответ

Пример успешного ответа
HTTP/1.1 200 OK
Content-Type: application/octet-stream
Last-Modified: Fri, 14 Jan 2022 00:00:12 GMT 2022-01-14 00:10:05
Content-Disposition: attachment; filename=Yealink.cfg
Content-Length: 2020
Пример неуспешного ответа
HTTP/1.1 404 Not Found

См. также