В разделе приведены описания команд управления транками, работающими по протоколу SIP.

Примечание. В командах предусмотрен флаг --force. Его применение позволяет выполнить команду без дополнительного подтверждения, что бывает удобно, нпример, в скриптах автоматизации. Если флаг "--force" не указывать, то система выведет сообщение, например:

[block] Trunk eltex will be blocked
Continue: yes/no ?> 

Если ввести команду "yes", то команда будет выполнена . Если ввести команду "no", то нет.

apply

Команда используется для применения к транку профиля настроек.

Примечание. Параметры профиля применяются к транку разово. Если в профиле были изменения, то по необходимости нужно снова выполнить его применение к транку.

Путь команды:

/domain/<DOMAIN>/trunk/sip/apply

Синтаксис:

apply <GROUP> <IFACE> profile <PROFILE>

Параметры:

<GROUP> - название группы интерфейсов;
<TRUNK_INTERFACE> - логическое имя транка;
<PROFILE> - имя профиля настроек транков. Для применения доступны профили, которые соответствует локализованным спецификациям ISUP:

  • ISUP.ANSI;
  • ISUP.ETSI;
  • ISUP.RUS;
  • ISUP.TELCORDIA.

Профиль стандарта ISUP отличается от пользовательских профилей возможностью настраивать только определенные стандартом параметры.

Пример:

admin@[ds1@ecss1]:/$ domain/biysk.local/trunk/sip/apply smg.gr smg-4 profile ISUP.RUS 
Executed on the sip1@ecss2
profile 'ISUP.RUS' is applyed to trunk 'smg-4'.

[exec at: 17.03.2019 10:56:39, exec time: 116ms, nodes: sip1@ecss2]

block

Команда для блокировки определенного транка, всех транков одной группы.
Соответствующий интерфейс переводится в неактивное состояние.

Путь команды:

/domain/<DOMAIN>/trunk/sip/block

Синтаксис:

block <GROUP> <TRUNK_INTERFACE> [--force]

Параметры:

<GROUP> - имя группы, интерфейс/интерфейсы которой нужно заблокировать;
<TRUNK_INTERFACE> - имя блокируемого интерфейса, при указании символа "*" будут заблокированы все транки заданной группы;
[--force] - опционально, при указании данного флага блокировка транка/транков будет производиться без дополнительного вопроса.

Пример:

admin@[ds1@ecss1]:/$ domain/biysk.local/trunk/sip/block ssw.gr ems3
[block] Trunk ems3 will be blocked
continue: yes/no ?> yes
Executed on the sip1@ecss2
┌──────┬────┐
│ ems3 │ ok │
└──────┴────┘

[exec at: 17.03.2019 11:16:43, exec time: 3s 759ms, nodes: sip1@ecss2]

call-list

Команда просмотра списка активных вызовов через транк.

Путь команды:

/domain/<DOMAIN>/trunk/sip/call-list

Синтаксис:

сall-list [GROUP] [INTERFACE] [OPTIONS]

Параметры:

<GROUP> - название группы интерфейсов. Символ "*" указывается для экспорта всех групп интерфейсов;
<INTERFACE> - логическое имя транка;
OPTIONS:

  • <--complete> - установка данного флага позволяет отобразить все интерфейсы, на которые были приняты вызовы;
  • <--more T [sec|min|hour]> - установка данного флага позволяет отобразить все вызовы, длительность которых более установленного времени;
  • <--less T [sec|min|hour]> - установка данного флага позволяет отобразить все вызовы, длительность которых менее установленного времени.

Пример:

admin@[ds1@ecss1]:/$ domain/biysk.local/trunk/sip/call-list   
Executed on the sip1@ecss2
┌───────────────┬────────────────────────────────┬──────────┬──────────────────────────────────────────┬───────────────────────────────────────────────────────┐
│ Interface URI │           Direction            │  State   │                   Time                   │                    Additional info                    │
├───────────────┼────────────────────────────────┼──────────┼──────────────────────────────────────────┼───────────────────────────────────────────────────────┤
│ ems1          │ sip[245718] <- ssw[9639695494] │ outgoing │ Start: Sat, 16 Mar 2019 19:15:06         │ Node: sip1@ecss1, <61649.31655.8>                     │
│               │                                │          │ Last activity: Sun, 17 Mar 2019 11:14:40 │ CallRef: 847685256                                    │
│               │                                │          │                                          │ Call-ID: "BA:8c6f71e140668560:8c6f71e7addf886e"       │
│               │                                │          │                                          │ SessionID: <<"BA:8c6f71e140668560:8c6f71e7addf886e">> │
│               │                                │          │                                          │ Session handler: {amqp_io_8,<61649.31655.8>}          │
│ smg-4         │ sip[9639695494] -> ssw[245718] │ incoming │ Start: Sat, 16 Mar 2019 19:15:06         │ Node: sip1@ecss1, <61649.31609.8>                     │
│               │                                │          │ Last activity: Sun, 17 Mar 2019 11:14:40 │ CallRef: 847685256                                    │
│               │                                │          │                                          │ Call-ID: "1552-738506-319237"                         │
│               │                                │          │                                          │ SessionID: <<"8c6f71e140668560">>                     │
│               │                                │          │                                          │ Session handler: {amqp_io_16,<61649.31609.8>}         │
└───────────────┴────────────────────────────────┴──────────┴──────────────────────────────────────────┴───────────────────────────────────────────────────────┘
┌────────────┐
│ 2 sessions │
└────────────┘

[exec at: 17.03.2019 11:14:40, exec time: 226ms, nodes: sip1@ecss2]

check

Команда проверки доступности направления. Выполняется посредством отправки запроса OPTIONS.
Тест может выполняться для определенного транка или для всех транков группы либо кластера.

Путь команды:

/domain/<DOMAIN>/trunk/sip/check

Синтаксис:

check <GROUP> [<TRUNK_INTERFACE>] [timerF = <TIMEOUT>]

Параметры:

<GROUP> - название существующей группы интерфейсов. Символ "*" используется для указания всех групп транков;
<TRUNK_INTERFACE> - логическое имя транка. Символ "*" используется для указания всех интерфейсов группы.

Если ответ не получен (направление на данный транк не доступно), то выводится результат "timeout".

Примечание.
Если удаленный клиент не поддерживает запросы OPTIONS, и при этом не отвечает ответом 405, то результат будет таким же, хотя реально направление доступно для вызовов.
В таком случае периодический контроль доступности должен быть отключен (set options_control 0).

<TIMEOUT> - тайм-аут ожидания ответа, в пределах которого отправляются повторные запросы, если удаленная сторона не отвечает. Задается в миллисекундах. Для выключения контроля установите значение тайм-аута - 0.

Пример:

admin@[ds1@ecss1]:/$ domain/biysk.local/trunk/sip/check smg.gr smg-4 timerF = 5000
Executed on the sip1@ecss2
Intermediate (incomplete) result:
Process to <<"smg-4">> check is started: {<0.22114.0>,<0.22114.0>}
...
Executed on the sip1@ecss2
Intermediate (incomplete) result:
Try to send OPTIONS to <<"smg-4">> (timerF = 5000)
...
Executed on the sip1@ecss2
┌────────┬───────┬────────────┬────────────────────────────────────────────────────────────────────────────────┐
│ Group  │ Trunk │ Accessible │                                   Check info                                   │
├────────┼───────┼────────────┼────────────────────────────────────────────────────────────────────────────────┤
│ smg.gr │ smg-4 │ true       │ OPTIONS to <sip:192.168.2.8>: 200 OK, cseq: 200599 OPTIONS. Request by node: si│
│        │       │            │p1@ecss2                                                                        │
└────────┴───────┴────────────┴────────────────────────────────────────────────────────────────────────────────┘

[exec at: 17.03.2019 11:35:45, exec time: 392ms, nodes: sip1@ecss2]

clean

Команда устанавливает значения по умолчанию для параметров профиля транка.

Путь команды:

/domain/<DOMAIN>/trunk/sip/clean

Синтаксис:

clean --profile <PROFILE> <PARAMETER> [--force]

Параметры:

<PROFILE> - имя профиля;
<PARAMETER> - параметр, для которого устанавливается значение по умолчанию.

--force - выполнить команду без запроса подтверждения.

Пример:

admin@[ds1@ecss1]:/$ domain/biysk.local/trunk/sip/clean ssw.gr ems3 req100rel 
[clean] Set parameters to default value
continue: yes/no ?> yes
clean to 1 interfaces ...
[**********************************************************************] 5ms      
Executed on the sip1@ecss2
complete

[exec at: 17.03.2019 11:51:40, exec time: 3s 624ms, nodes: sip1@ecss2]

declare

Команда декларации транка SIP.
Декларация нового транка возможна только в существующем контексте маршрутизации.
Может быть выбрана существующая группа или задекларирована новая.
При декларации выполняется проверка на существование имени интерфейса (одинаковые имена запрещены, о чем будет сразу выдано предупреждение "trunk already exists") и связки IP:Порт:Слушающий_порт (в случае совпадения с существующим именем будет выдано предупреждение, декларация может быть выполнена, а в дальнейшем параметры могут быть изменены).
При успешной операции выполняется проверка доступности заданного направления посредством запроса OPTIONS (см. команду check).

Путь команды:

/domain/<DOMAIN>/trunk/sip/declare

Синтаксис:

declare <ROUTING_CONTEXT> <GROUP> <TRUNK_INTERFACE> <IP_SET>[--registration | <DEST_HOST> <DEST_PORT> <MODE> <LISTEN_PORT>]

Параметры:

<ROUTING_CONTEXT> - название существующего контекста маршрутизации;
<GROUP> - название группы интерфейсов (может быть задана существующая или новая группа);
<TRUNK_INTERFACE> - имя системного интерфейса, описывающего данное направление. Имя интерфейса является внутрисистемным идентификатором, участвующем в маршрутизации, отображении статистики и другое;
<IP_SET> - набор IP-адресов;
--registration - декларация динамического транка (с регистрацией);

Примечание:
При декларации динамического транка операторская регистрация должна выполнятся для пользователя <TRUNK_INTERFACE>@<GROUP>.
Параметры <DEST_HOST>, <DEST_PORT>, <MODE>, <LISTEN_PORT> не задаются.
Режим для динамических транков устанавливается sip-proxy, регистрация для транков с инкапсуляцией ISUP использоваться не должна.

<DEST_HOST> - хост, назначаемый для транка (IP-адрес или доменное имя);
<DEST_PORT> - порт, назначаемый для транка;
<MODE> - режим инкапсуляции ISUP:

  • sip-proxy - направление работает только по протоколу SIP (RFC 3261);
  • sip-t - направление работает по SIP с инкапсуляцией ISUP по протоколу SIP-T (RFC 3372);
  • sip-i - направление работает по SIP с инкапсуляцией ISUP по протоколу SIP-I (Q.1912-5);
  • sip-q - направление работает по SIP с инкапсуляцией QSIG по протоколу SIP-Q(Q.931).

Примечание.

Работа в режимах sip-t, sip-i в основном отличается при кодировании/декодировании инкапсулированного ISUP и при маппинге статусов ответов о завершении. В дальнейшем режим может быть изменен.

<LISTEN_PORT> - слушающий порт. На адаптере может быть открыто несколько слушающих портов.
Используя слушающие порты, можно детектировать запросы с разных транков одного удаленного хоста, которые имеют одинаковые IP-адрес и номер порта.
При выборе значения "default" слушающий порт, который принял входящий запрос, не будет учитываться при определении транка.

Пример:

admin@[ds1@ecss1]:/$ domain/biysk.local/trunk/sip/declare ctx_from_local sbc.gr brn.sbc ipset1 static 10.22.131.9 5068 sip-t 5076         
Executed on the sip1@ecss2
declared

[exec at: 17.03.2019 11:54:55, exec time: 158ms, nodes: sip1@ecss2]

info

Команда для просмотра информации о настройках параметров транка и профилей транка.
Дополнительное описание параметров интерфейсов (транков) приведено в Приложении Б. Набор параметров интерфейса SIP.

Путь команды:

/domain/<DOMAIN>/trunk/sip/info

Синтаксис:

info <GROUP> [<TRUNK_INTERFACE>] [--profile <PROFILE>]

Параметры:

<GROUP> - название существующей группы интерфейсов, символ "*" используется для указания всех групп транков;
<TRUNK_INTERFACE> - логическое имя транка, символ "*" используется для указания всех интерфейсов группы.
Для просмотра свойств группы имя интерфейса транка (символ "*") не указывается.
--profile - флаг используется для просмотра информации о конфигурации профилей транка;
<PROFILE> - имя профиля, символ "*" используется для указания всех профилей транков.

Если в профиле безопасности (/system/security/profile/) параметр show_password_at_cli = off, то в выводе пароль скрывается, и вместо него показываются ********.  В режиме on_request пароль показывается автоматически

Пример:

Свойства определенного транка:

admin@mycelium1@ecss1:/$ domain/biysk.local/trunk/sip/info ssw.gr ems2 
Executed on the sip1@ecss1
┌────────┬──────┬───────────┬────────────┬────────────┬────────────────────────────────────────────────────────────────────────┐
│ Group  │ Uri  │ Is active │ Is blocked │ Is dynamic │                               Parameters                               │
├────────┼──────┼───────────┼────────────┼────────────┼────────────────────────────────────────────────────────────────────────┤
│ ssw.gr │ ems2 │ true      │ false      │ false      │ declared by admin at 13.03.2020 15:00:46                               │
│        │      │           │            │            │                                                                        │
│        │      │           │            │            │  remote-end-point             = 192.168.2.12:5072                      │
│        │      │           │            │            │  local-end-point              = ipset1:5072                            │
│        │      │           │            │            │  mode                         = sip-proxy                              │
│        │      │           │            │            │  connect time                 = 16.06.2020 09:35:56                    │
│        │      │           │            │            │  uptime                       = 2d 1h 46m                              │
│        │      │           │            │            │  disconnections number        = 0                                      │
│        │      │           │            │            │  - - - - - - - - - - - - - -  = - - - - - - - - - - - - - -            │
│        │      │           │            │            │  alarm_enable                 = false                                  │
│        │      │           │            │            │  category_to_sip              = default                                │
│        │      │           │            │            │  cdpn-transformation          = none                                   │
│        │      │           │            │            │  channel-contact-map          = []                                     │
│        │      │           │            │            │  content_encoding             = none                                   │
│        │      │           │            │            │  disable-remote-port-control  = false                                  │
│        │      │           │            │            │  display-name-encoding        = default                                │
│        │      │           │            │            │  dtmf-duration                = 100                                    │
│        │      │           │            │            │  dtmf-relay                   = false                                  │
│        │      │           │            │            │  history-info                 = false                                  │
│        │      │           │            │            │  inc-authentication           = true                                   │
│        │      │           │            │            │  inc-authentication_type      = user                                   │
│        │      │           │            │            │  inc-login                    = none                                   │
│        │      │           │            │            │  inc-password                 = ********                               │
│        │      │           │            │            │  invite-transaction-timeout   = 32000                                  │
│        │      │           │            │            │  maddr                        = none                                   │
│        │      │           │            │            │  my_from                      = biysk.local                            │
│        │      │           │            │            │  options_control              = disable                                │
│        │      │           │            │            │  original-cdpn-to             = true                                   │
│        │      │           │            │            │  out-login                    = none                                   │
│        │      │           │            │            │  out-password                 = ********                               │
│        │      │           │            │            │  out-registration             = disable                                │
│        │      │           │            │            │  referred-by-as-cgpn          = false                                  │
│        │      │           │            │            │  remote-client                = default                                │
│        │      │           │            │            │  remote-ctr-indication        = rpi                                    │
│        │      │           │            │            │  remote-network-type          = local                                  │
│        │      │           │            │            │  req100rel                    = false                                  │
│        │      │           │            │            │  rfc-4028-control             = force                                  │
│        │      │           │            │            │  routing.context              = ctx_from_local                         │
│        │      │           │            │            │  sip-domain                   = 192.168.2.12 (use-address)             │
│        │      │           │            │            │  sip-modifications            =                                        │
│        │      │           │            │            │  sip-transit                  =                                        │
│        │      │           │            │            │  sip_transport                = udp_only                               │
│        │      │           │            │            │  symbol_hash_as_is            = false                                  │
│        │      │           │            │            │  tel-uri-in-diversion         = false                                  │
│        │      │           │            │            │  trunk (trunk name)           = biysk.local.ssw.gr.trunk.autoname      │
│        │      │           │            │            │  user-name                    = ems2                                   │
└────────┴──────┴───────────┴────────────┴────────────┴────────────────────────────────────────────────────────────────────────┘

[exec at: 18.06.2020 11:22:06, exec time: 25ms, nodes: sip1@ecss1]

Просмотр конфигурации профилей транков:

admin@[ds1@ecss1]:/$ domain/biysk.local/trunk/sip/info --profile *
Executed on the sip1@ecss2
┌───────────┬───────────────────────────┐
│  Profile  │        Parameters         │
├───────────┼───────────────────────────┤
│ ISUP.ETSI │ network-node-id = 0       │
│           │ network-id = 0            │
│           │ use-global-callref = true │
│           │ country-code = 250        │
│ ISUP.RUS  │ isup_r_ccl_send = true    │
└───────────┴───────────────────────────┘

[exec at: 17.03.2019 11:58:12, exec time: 100ms, nodes: sip1@ecss2]

remove

Команда для удаления определенного транка, всех транков одной группы или профиля транка.

Путь команды:

/domain/<DOMAIN>/trunk/sip/remove

Синтаксис:

remove <GROUP> <TRUNK_INTERFACE>|--profile <PROFILE> [--force]

Параметры:

<GROUP> - название существующей группы интерфейсов;
<TRUNK_INTERFACE> - имя интерфейса, который нужно удалить. Символ "*" используется для указания всех интерфейсов группы. При удалении всех интерфейсов группы также удаляется сама группа.

<PROFILE> - имя профиля, символ "*" используется для указания всех профилей транков.

  • --profile - флаг используется для удаления профиля транка;
  • --force - опционально, при указании данного флага удаление транка/транков будет производиться без дополнительного вопроса.

Пример:

Удаление транка:

admin@[ds1@ecss1]:/$ domain/biysk.local/trunk/sip/remove sbc.gr brn.sbc --force 
Executed on the sip1@ecss1

[exec at: 17.03.2019 12:01:30, exec time: 108ms, nodes: sip1@ecss1]

set

Данной командой выполняется настройка параметров группы транков.

Путь команды:

domain/<DOMAIN>/trunk/sip/set

Синтаксис:

set <GROUP> <TRUNK_INTERFACE> <PARAMETER> <VALUE> | --profile <PROFILE>

Параметры:

<GROUP> - название существующей группы интерфейса. Символ "*" используется для указания всех групп транков;
<TRUNK_INTERFACE> - имя интерфейса. Символ "*" используется для указания всех интерфейсов группы;
<PARAMETER> - название параметра, список параметров приведен в Приложении Б. Набор параметров интерфейса SIP.
<VALUE> - значение параметра.

--profile - флаг используется для создания/настройки профиля транков;
<PROFILE> - имя профиля.

Пароли проверяются на соответствие требованиям, установленным в профиле безопасности (/system/security/profile/), параметр restrictions.

Примеры:

Установка адреса:
admin@[ds1@ecss1]:/$ domain/biysk.local/trunk/sip/set ssw.gr ems3 remote-end-point 192.168.2.15 5088 
complete

[exec at: 17.03.2019 11:45:17, exec time: 117ms, nodes: sip1@ecss1]

Установка контекста маршрутизации:

admin@[ds1@ecss1]:/$ domain/biysk.local/trunk/sip/set sbc.gr nsk_sbc routing.context ctx_from_local 
change context for 1 users ...
[**********************************************************************] 3ms      
complete

[exec at: 17.03.2019 11:39:20, exec time: 108ms, nodes: sip1@ecss1]

unblock

Команда для разблокировки определенного транка, всех транков одной группы.
Соответствующий интерфейс переводится в активное состояние.

Путь команды:

/domain/<DOMAIN>/trunk/sip/unblock

Синтаксис:

unblock <GROUP> <TRUNK_INTERFACE>[--force]

Параметры:

<GROUP> - имя группы, интерфейс/интерфейсы которой нужно разблокировать;
<TRUNK_INTERFACE> - имя интерфейса, символ "*" используется для указания всех интерфейсов группы;
[--force] - опционально, при указании данного флага разблокировка транка/транков будет производиться без дополнительного вопроса.

Пример:

admin@[ds1@ecss1]:/$ domain/biysk.local/trunk/sip/unblock ssw.gr * --force 
Executed on the sip1@ecss2
┌──────┬────┐
│ bsk1 │ ok │
│ bsk2 │ ok │
│ ems1 │ ok │
│ ems2 │ ok │
│ ems3 │ ok │
└──────┴────┘

[exec at: 17.03.2019 11:41:42, exec time: 125ms, nodes: sip1@ecss2]