res_stasis_recording: Add a "target_uri" field to recording events.
[asterisk/asterisk.git] / rest-api / api-docs / bridges.json
index ec7cdae..b259ca8 100644 (file)
@@ -2,7 +2,7 @@
        "_copyright": "Copyright (C) 2012 - 2013, Digium, Inc.",
        "_author": "David M. Lee, II <dlee@digium.com>",
        "_svn_revision": "$Revision$",
-       "apiVersion": "0.0.1",
+       "apiVersion": "1.1.0",
        "swaggerVersion": "1.1",
        "basePath": "http://localhost:8088/stasis",
        "resourcePath": "/api-docs/bridges.{format}",
                        "operations": [
                                {
                                        "httpMethod": "GET",
-                                       "summary": "List active bridges.",
-                                       "nickname": "getBridges",
+                                       "summary": "List all active bridges in Asterisk.",
+                                       "nickname": "list",
                                        "responseClass": "List[Bridge]"
                                },
                                {
                                        "httpMethod": "POST",
                                        "summary": "Create a new bridge.",
                                        "notes": "This bridge persists until it has been shut down, or Asterisk has been shut down.",
-                                       "nickname": "newBridge",
+                                       "nickname": "create",
                                        "responseClass": "Bridge",
                                        "parameters": [
                                                {
                                                                        "holding"
                                                                ]
                                                        }
+                                               },
+                                               {
+                                                       "name": "name",
+                                                       "description": "Name to give to the bridge being created.",
+                                                       "paramType": "query",
+                                                       "required": false,
+                                                       "allowMultiple": false,
+                                                       "dataType": "string"
                                                }
                                        ]
                                }
@@ -50,7 +58,7 @@
                                {
                                        "httpMethod": "GET",
                                        "summary": "Get bridge details.",
-                                       "nickname": "getBridge",
+                                       "nickname": "get",
                                        "responseClass": "Bridge",
                                        "parameters": [
                                                {
@@ -73,7 +81,7 @@
                                        "httpMethod": "DELETE",
                                        "summary": "Shut down a bridge.",
                                        "notes": "If any channels are in this bridge, they will be removed and resume whatever they were doing beforehand.",
-                                       "nickname": "deleteBridge",
+                                       "nickname": "destroy",
                                        "responseClass": "void",
                                        "parameters": [
                                                {
                                {
                                        "httpMethod": "POST",
                                        "summary": "Add a channel to a bridge.",
-                                       "nickname": "addChannelToBridge",
+                                       "nickname": "addChannel",
                                        "responseClass": "void",
                                        "parameters": [
                                                {
                                                },
                                                {
                                                        "code": 409,
-                                                       "reason": "Bridge not in Stasis application"
+                                                       "reason": "Bridge not in Stasis application; Channel currently recording"
                                                },
                                                {
                                                        "code": 422,
                                {
                                        "httpMethod": "POST",
                                        "summary": "Remove a channel from a bridge.",
-                                       "nickname": "removeChannelFromBridge",
+                                       "nickname": "removeChannel",
                                        "responseClass": "void",
                                        "parameters": [
                                                {
                                {
                                        "httpMethod": "POST",
                                        "summary": "Play music on hold to a bridge or change the MOH class that is playing.",
-                                       "nickname": "mohStartBridge",
+                                       "nickname": "startMoh",
                                        "responseClass": "void",
                                        "parameters": [
                                                {
                                                        "reason": "Bridge not in Stasis application"
                                                }
                                        ]
-                               }
-                       ]
-               },
-               {
-                       "path": "/bridges/{bridgeId}/moh",
-                       "description": "Stop music on hold for a bridge",
-                       "operations": [
+                               },
                                {
                                        "httpMethod": "DELETE",
                                        "summary": "Stop playing music on hold to a bridge.",
-                                       "notes": "This will only stop music on hold being played via bridges/{bridgeId}/mohStart.",
-                                       "nickname": "mohStopBridge",
+                                       "notes": "This will only stop music on hold being played via POST bridges/{bridgeId}/moh.",
+                                       "nickname": "stopMoh",
                                        "responseClass": "void",
                                        "parameters": [
                                                {
                                        "httpMethod": "POST",
                                        "summary": "Start playback of media on a bridge.",
                                        "notes": "The media URI may be any of a number of URI's. Currently sound: and recording: URI's are supported. This operation creates a playback resource that can be used to control the playback of media (pause, rewind, fast forward, etc.)",
-                                       "nickname": "playOnBridge",
+                                       "nickname": "play",
                                        "responseClass": "Playback",
                                        "parameters": [
                                                {
                                        "httpMethod": "POST",
                                        "summary": "Start a recording.",
                                        "notes": "This records the mixed audio from all channels participating in this bridge.",
-                                       "nickname": "recordBridge",
+                                       "nickname": "record",
                                        "responseClass": "LiveRecording",
                                        "parameters": [
                                                {
                                                        }
                                                }
                                        ],
-                                       "errorResponses": [
+                    "errorResponses": [
+                        {
+                            "code": 400,
+                            "reason": "Invalid parameters"
+                        },
+                        {
+                            "code": 404,
+                            "reason": "Bridge not found"
+                        },
+                        {
+                            "code": 409,
+                            "reason": "Bridge is not in a Stasis application; A recording with the same name already exists on the system and can not be overwritten because it is in progress or ifExists=fail"
+                        },
                                                {
-                                                       "code": 400,
-                                                       "reason": "Recording name invalid"
-                                               },
-                                               {
-                                                       "code": 404,
-                                                       "reason": "Bridge not found"
-                                               },
-                                               {
-                                                       "code": 409,
-                                                       "reason": "Bridge not in Stasis application; Recording already in progress"
+                                                       "code": 422,
+                                                       "reason": "The format specified is unknown on this system"
                                                }
-                                       ]
+                    ]
                                }
                        ]
                }
                                        "description": "Bridging class",
                                        "required": true
                                },
+                               "creator": {
+                                       "type": "string",
+                                       "description": "Entity that created the bridge",
+                                       "required": true
+                               },
+                               "name": {
+                                       "type": "string",
+                                       "description": "Name the creator gave the bridge",
+                                       "required": true
+                               },
                                "channels": {
                                        "type": "List[string]",
                                        "description": "Ids of channels participating in this bridge",