Wiki source code of Asterisk Extension Group Extensions
Last modified by ryanp on 2021/09/10 23:34
Show last authors
author | version | line-number | content |
---|---|---|---|
1 | {{layout}} | ||
2 | {{layout-section ac:type="two_right_sidebar"}} | ||
3 | {{layout-cell}} | ||
4 | {{warning}} | ||
5 | This page is currently being written. Although the information below is probably accurate, it may not be complete or may have errors. | ||
6 | {{/warning}} | ||
7 | |||
8 | {{info}} | ||
9 | The information on this page applies to **iSymphony 3.1+**. | ||
10 | {{/info}} | ||
11 | |||
12 | = (% style="color: rgb(0,0,0);" %)Description(%%) = | ||
13 | |||
14 | The Asterisk extension group extensions REST resource allows access to the extensions that are a part of an extension group. This resource allows adding and removing of extensions to and from an extension group. | ||
15 | |||
16 | |||
17 | {{/layout-cell}} | ||
18 | |||
19 | {{layout-cell}} | ||
20 | {{panel title="On this page:"}} | ||
21 | |||
22 | |||
23 | {{toc maxLevel="2" indent="1"/}} | ||
24 | {{/panel}} | ||
25 | {{/layout-cell}} | ||
26 | {{/layout-section}} | ||
27 | |||
28 | {{layout-section ac:type="single"}} | ||
29 | {{layout-cell}} | ||
30 | = (% style="color: rgb(0,0,0);" %)Root Resource Path(%%) = | ||
31 | |||
32 | {{code}} | ||
33 | communication_manager/rest/config/asterisk/{coreServerId}/extensionGroups/{extensionGroupId}/extensions | ||
34 | {{/code}} | ||
35 | |||
36 | = JSON Representation = | ||
37 | |||
38 | {{code}} | ||
39 | { | ||
40 | "id": "1584e59e-ce3c-4523-aa2d-af65c95fb29b", | ||
41 | "extension": "4224", | ||
42 | "displayName": "Sean", | ||
43 | "autoAnswer": false, | ||
44 | "peer": "SIP\/4224", | ||
45 | "altOriginationMethod": "", | ||
46 | "agentName": "Sean - Lappy", | ||
47 | "agentLocation": "Local\/4224@from-queue\/n", | ||
48 | "agentInterface": "SIP\/4224", | ||
49 | "agentPenalty": 0, | ||
50 | "agentPaused": false, | ||
51 | "originatingContextOverride": "", | ||
52 | "redirectingContextOverride": "", | ||
53 | "originateTimeoutOverride": 0, | ||
54 | "voiceMailContext": "default", | ||
55 | "voiceMailBox": "4224", | ||
56 | "permissionDisplayName": "Sean <4224>", | ||
57 | "permissionId": "1584e59e-ce3c-4523-aa2d-af65c95fb29b" | ||
58 | } | ||
59 | {{/code}} | ||
60 | |||
61 | |=((( | ||
62 | Property | ||
63 | )))|=((( | ||
64 | Type | ||
65 | )))|=((( | ||
66 | Description | ||
67 | ))) | ||
68 | |((( | ||
69 | {{{id}}} | ||
70 | )))|((( | ||
71 | String | ||
72 | )))|((( | ||
73 | Configuration id of the extension. | ||
74 | ))) | ||
75 | |(% colspan="1" %)(% colspan="1" %) | ||
76 | ((( | ||
77 | extension | ||
78 | )))|(% colspan="1" %)(% colspan="1" %) | ||
79 | ((( | ||
80 | String | ||
81 | )))|(% colspan="1" %)(% colspan="1" %) | ||
82 | ((( | ||
83 | The extension number. Used when dialing or transferring to the extensions. | ||
84 | ))) | ||
85 | |(% colspan="1" %)(% colspan="1" %) | ||
86 | ((( | ||
87 | {{{displayName}}} | ||
88 | )))|(% colspan="1" %)(% colspan="1" %) | ||
89 | ((( | ||
90 | String | ||
91 | )))|(% colspan="1" %)(% colspan="1" %) | ||
92 | ((( | ||
93 | The display name of the extension. | ||
94 | ))) | ||
95 | |(% colspan="1" %)(% colspan="1" %) | ||
96 | ((( | ||
97 | autoAnswer | ||
98 | )))|(% colspan="1" %)(% colspan="1" %) | ||
99 | ((( | ||
100 | Boolean | ||
101 | )))|(% colspan="1" %)(% colspan="1" %) | ||
102 | ((( | ||
103 | Flag specifying if auto answer SIP headers will be added for the initial call backs created by originations in the panel. | ||
104 | ))) | ||
105 | |(% colspan="1" %)(% colspan="1" %) | ||
106 | ((( | ||
107 | peer | ||
108 | )))|(% colspan="1" %)(% colspan="1" %) | ||
109 | ((( | ||
110 | String | ||
111 | )))|(% colspan="1" %)(% colspan="1" %) | ||
112 | ((( | ||
113 | The peer of the extension. Used to track call state on the extension. | ||
114 | ))) | ||
115 | |(% colspan="1" %)(% colspan="1" %) | ||
116 | ((( | ||
117 | {{{altOriginationMethod}}} | ||
118 | )))|(% colspan="1" %)(% colspan="1" %) | ||
119 | ((( | ||
120 | String | ||
121 | )))|(% colspan="1" %)(% colspan="1" %) | ||
122 | ((( | ||
123 | An alternative origination peer to use when making calls from this extension. This is very rarely set to a non blank value. | ||
124 | ))) | ||
125 | |(% colspan="1" %)(% colspan="1" %) | ||
126 | ((( | ||
127 | {{{agentName}}} | ||
128 | )))|(% colspan="1" %)(% colspan="1" %) | ||
129 | ((( | ||
130 | String | ||
131 | )))|(% colspan="1" %)(% colspan="1" %) | ||
132 | ((( | ||
133 | The display name for the extension when it is logged in as an agent in the queue. | ||
134 | ))) | ||
135 | |(% colspan="1" %)(% colspan="1" %) | ||
136 | ((( | ||
137 | {{{agentLocation}}} | ||
138 | )))|(% colspan="1" %)(% colspan="1" %) | ||
139 | ((( | ||
140 | String | ||
141 | )))|(% colspan="1" %)(% colspan="1" %) | ||
142 | ((( | ||
143 | The location of the extension used to identify the agent destination when this extension is logged into a queue. | ||
144 | ))) | ||
145 | |(% colspan="1" %)(% colspan="1" %) | ||
146 | ((( | ||
147 | {{{agentInterface}}} | ||
148 | )))|(% colspan="1" %)(% colspan="1" %) | ||
149 | ((( | ||
150 | String | ||
151 | )))|(% colspan="1" %)(% colspan="1" %) | ||
152 | ((( | ||
153 | The agent device that will be used to track agent state when this extension is logged into a queue. | ||
154 | ))) | ||
155 | |(% colspan="1" %)(% colspan="1" %) | ||
156 | ((( | ||
157 | {{{agentPenalty}}} | ||
158 | )))|(% colspan="1" %)(% colspan="1" %) | ||
159 | ((( | ||
160 | Integer | ||
161 | )))|(% colspan="1" %)(% colspan="1" %) | ||
162 | ((( | ||
163 | The default penalty that this extension will be given when it is logged into a queue, via the panel. | ||
164 | ))) | ||
165 | |(% colspan="1" %)(% colspan="1" %) | ||
166 | ((( | ||
167 | {{{agentPaused}}} | ||
168 | )))|(% colspan="1" %)(% colspan="1" %) | ||
169 | ((( | ||
170 | Boolean | ||
171 | )))|(% colspan="1" %)(% colspan="1" %) | ||
172 | ((( | ||
173 | Flag specifying if the agent will be automatically paused when they are logged into a queue, via the panel. | ||
174 | ))) | ||
175 | |(% colspan="1" %)(% colspan="1" %) | ||
176 | ((( | ||
177 | {{{originatingContextOverride}}} | ||
178 | )))|(% colspan="1" %)(% colspan="1" %) | ||
179 | ((( | ||
180 | String | ||
181 | )))|(% colspan="1" %)(% colspan="1" %) | ||
182 | ((( | ||
183 | An override to the global originating context set on the core server level. | ||
184 | ))) | ||
185 | |(% colspan="1" %)(% colspan="1" %) | ||
186 | ((( | ||
187 | (% style="line-height: 1.42857;" %)redirectingContextOverride | ||
188 | |||
189 | )))|(% colspan="1" %)(% colspan="1" %) | ||
190 | ((( | ||
191 | String | ||
192 | )))|(% colspan="1" %)(% colspan="1" %) | ||
193 | ((( | ||
194 | An override to the global redirecting context set on the core server level. | ||
195 | ))) | ||
196 | |(% colspan="1" %)(% colspan="1" %) | ||
197 | ((( | ||
198 | (% style="line-height: 1.42857;" %)originateTimeoutOverride | ||
199 | |||
200 | )))|(% colspan="1" %)(% colspan="1" %) | ||
201 | ((( | ||
202 | Integer | ||
203 | )))|(% colspan="1" %)(% colspan="1" %) | ||
204 | ((( | ||
205 | An override to the global origination timeout set on the core server level. | ||
206 | ))) | ||
207 | |(% colspan="1" %)(% colspan="1" %) | ||
208 | ((( | ||
209 | {{{voiceMailContext}}} | ||
210 | )))|(% colspan="1" %)(% colspan="1" %) | ||
211 | ((( | ||
212 | String | ||
213 | )))|(% colspan="1" %)(% colspan="1" %) | ||
214 | ((( | ||
215 | The context of the extension's voicemail box. | ||
216 | ))) | ||
217 | |(% colspan="1" %)(% colspan="1" %) | ||
218 | ((( | ||
219 | {{{voiceMailBox}}} | ||
220 | )))|(% colspan="1" %)(% colspan="1" %) | ||
221 | ((( | ||
222 | String | ||
223 | )))|(% colspan="1" %)(% colspan="1" %) | ||
224 | ((( | ||
225 | The name of the extension's voicemail box. | ||
226 | ))) | ||
227 | |(% colspan="1" %)(% colspan="1" %) | ||
228 | ((( | ||
229 | {{{permissionDisplayName}}} | ||
230 | )))|(% colspan="1" %)(% colspan="1" %) | ||
231 | ((( | ||
232 | String | ||
233 | )))|(% colspan="1" %)(% colspan="1" %) | ||
234 | ((( | ||
235 | Display name of the extension in the permission system. | ||
236 | ))) | ||
237 | |(% colspan="1" %)(% colspan="1" %) | ||
238 | ((( | ||
239 | {{{permissionId}}} | ||
240 | )))|(% colspan="1" %)(% colspan="1" %) | ||
241 | ((( | ||
242 | String | ||
243 | )))|(% colspan="1" %)(% colspan="1" %) | ||
244 | ((( | ||
245 | Permission id of the extension. | ||
246 | ))) | ||
247 | |||
248 | = Resource Paths = | ||
249 | |||
250 | |=(% colspan="2" %)(% colspan="2" %) | ||
251 | ((( | ||
252 | {{{communication_manager/rest/config/asterisk/{coreServerId}/extensionGroups/{extensionGroupId}/extensions}}} | ||
253 | ))) | ||
254 | |(% class="highlight-grey" data-highlight-colour="grey" %)(% class="highlight-grey" data-highlight-colour="grey" %) | ||
255 | ((( | ||
256 | **Description** | ||
257 | )))|((( | ||
258 | Accesses all the extensions that are part of the extension group. | ||
259 | ))) | ||
260 | |(% class="highlight-grey" data-highlight-colour="grey" %)(% class="highlight-grey" data-highlight-colour="grey" %) | ||
261 | ((( | ||
262 | **GET** | ||
263 | )))|((( | ||
264 | Gets all the configuration for all the extensions that are part of the extension group. | ||
265 | ))) | ||
266 | |(% class="highlight-grey" colspan="1" data-highlight-colour="grey" %)(% class="highlight-grey" colspan="1" data-highlight-colour="grey" %) | ||
267 | ((( | ||
268 | **POST | ||
269 | ** | ||
270 | )))|(% colspan="1" %)(% colspan="1" %) | ||
271 | ((( | ||
272 | Adds a extension to the extension group. | ||
273 | |||
274 | (% style="line-height: 1.42857;" %)**Errors:** | ||
275 | |||
276 | * 409 'The specified extension already exists in the extension group.': Returned if the extension is already a part of the extension group. | ||
277 | ))) | ||
278 | |(% colspan="2" %)(% colspan="2" %) | ||
279 | ((( | ||
280 | |||
281 | ))) | ||
282 | |=(% colspan="2" %)(% colspan="2" %) | ||
283 | ((( | ||
284 | {{{communication_manager/rest/config/asterisk/{coreServerId}/extensionsGroups/{extensionGroupId}/extensions/{extensionId}}}} | ||
285 | ))) | ||
286 | |(% class="highlight-grey" data-highlight-colour="grey" %)(% class="highlight-grey" data-highlight-colour="grey" %) | ||
287 | ((( | ||
288 | **Description** | ||
289 | )))|((( | ||
290 | Accesses the configuration of a specific extension in the extension group. | ||
291 | |||
292 | **Parameters:** | ||
293 | |||
294 | * extensionId: The configuration id of the extension. | ||
295 | ))) | ||
296 | |(% class="highlight-grey" data-highlight-colour="grey" %)(% class="highlight-grey" data-highlight-colour="grey" %) | ||
297 | ((( | ||
298 | **GET** | ||
299 | )))|((( | ||
300 | Gets the configuration of the specified extension in the extension group. | ||
301 | |||
302 | **Errors:** | ||
303 | |||
304 | * 404 'An extension with the given id does not exist': Returned if no extension exists in the extension group with the given id. | ||
305 | ))) | ||
306 | |(% class="highlight-grey" colspan="1" data-highlight-colour="grey" %)(% class="highlight-grey" colspan="1" data-highlight-colour="grey" %) | ||
307 | ((( | ||
308 | **DELETE** | ||
309 | )))|(% colspan="1" %)(% colspan="1" %) | ||
310 | ((( | ||
311 | Removes a specific extension from the extension group. | ||
312 | |||
313 | **Errors:** | ||
314 | |||
315 | * 404 'An extension with the given id does not exist': Returned if no extension exists in the extension group with the given id. | ||
316 | ))) | ||
317 | |||
318 | = Curl Examples = | ||
319 | |||
320 | === Get all extensions in an extension group === | ||
321 | |||
322 | {{code language="bash"}} | ||
323 | curl --user manager:manag3rpa55word -k -i -H "Accept: application/json" http://localhost:58080/communication_manager/rest/config/asterisk/ee828da8-5ee6-412d-82ac-1273f598659d/extensionGroup/56cf70a3-1ee0-4b09-8f40-297430eeeddf/extensions | ||
324 | {{/code}} | ||
325 | |||
326 | === Get the configuration for a specific extension in an extension group === | ||
327 | |||
328 | {{code language="bash"}} | ||
329 | curl --user manager:manag3rpa55word -k -i -H "Accept: application/json" http://localhost:58080/communication_manager/rest/config/asterisk/ee828da8-5ee6-412d-82ac-1273f598659d/extensionGroup/56cf70a3-1ee0-4b09-8f40-297430eeeddf/extensions/e05a9e3c-c306-4bba-abd7-4fe1034fe9f6 | ||
330 | {{/code}} | ||
331 | |||
332 | === Add an extension to an extension group === | ||
333 | |||
334 | {{code language="bash"}} | ||
335 | curl --user manager:manag3rpa55word -k -i -H "Content-Type: application/json" -H "Accept: application/json" -X POST -d '{"id":"1584e59e-ce3c-4523-aa2d-af65c95fb29b","extension":"4224","displayName":"Sean","autoAnswer":false,"peer":"SIP/4224","altOriginationMethod":"","agentName":"Sean","agentLocation":"Local/4224@from-queue/n","agentInterface":"SIP/4224","agentPenalty":0,"agentPaused":false,"originatingContextOverride":"","redirectingContextOverride":"","originateTimeoutOverride":0,"voiceMailContext":"default","voiceMailBox":"4224"}' http://localhost:58080/communication_manager/rest/config/asterisk/ee828da8-5ee6-412d-82ac-1273f598659d/extensionGroup/56cf70a3-1ee0-4b09-8f40-297430eeeddf/extensions | ||
336 | {{/code}} | ||
337 | |||
338 | === Remove an extension from an extension group === | ||
339 | |||
340 | {{code language="bash"}} | ||
341 | curl --user manager:manag3rpa55word -k -i -X DELETE http://localhost:58080/communication_manager/rest/config/asterisk/ee828da8-5ee6-412d-82ac-1273f598659d/extensionGroup/56cf70a3-1ee0-4b09-8f40-297430eeeddf/extensions/e05a9e3c-c306-4bba-abd7-4fe1034fe9f6 | ||
342 | {{/code}} | ||
343 | {{/layout-cell}} | ||
344 | {{/layout-section}} | ||
345 | {{/layout}} |