* Dump a git blame of each file in rest-api/api-docs.
* Get the commit for each "resourcePath" and "httpMethod" entry.
* Find the tags for each commit (same as other processes).
* Insert a "since" array after each "resourcePath" and "httpMethod" entry.
        "swaggerVersion": "1.1",
        "basePath": "http://localhost:8088/ari",
        "resourcePath": "/api-docs/applications.{format}",
+       "since": [
+               "13.0.0"
+       ],
        "apis": [
                {
                        "path": "/applications",
                        "operations": [
                                {
                                        "httpMethod": "GET",
+                                       "since": [
+                                               "13.0.0"
+                                       ],
                                        "summary": "List all applications.",
                                        "nickname": "list",
                                        "responseClass": "List[Application]"
                        "operations": [
                                {
                                        "httpMethod": "GET",
+                                       "since": [
+                                               "13.0.0"
+                                       ],
                                        "summary": "Get details of an application.",
                                        "nickname": "get",
                                        "responseClass": "Application",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "13.0.0"
+                                       ],
                                        "summary": "Subscribe an application to a event source.",
                                        "notes": "Returns the state of the application after the subscriptions have changed",
                                        "nickname": "subscribe",
                                },
                                {
                                        "httpMethod": "DELETE",
+                                       "since": [
+                                               "13.0.0"
+                                       ],
                                        "summary": "Unsubscribe an application from an event source.",
                                        "notes": "Returns the state of the application after the subscriptions have changed",
                                        "nickname": "unsubscribe",
                        "operations": [
                                {
                                        "httpMethod": "PUT",
+                                       "since": [
+                                               "13.26.0",
+                                               "16.3.0"
+                                       ],
                                        "summary": "Filter application events types.",
                                        "notes": "Allowed and/or disallowed event type filtering can be done. The body (parameter) should specify a JSON key/value object that describes the type of event filtering needed. One, or both of the following keys can be designated:<br /><br />\"allowed\" - Specifies an allowed list of event types<br />\"disallowed\" - Specifies a disallowed list of event types<br /><br />Further, each of those key's value should be a JSON array that holds zero, or more JSON key/value objects. Each of these objects must contain the following key with an associated value:<br /><br />\"type\" - The type name of the event to filter<br /><br />The value must be the string name (case sensitive) of the event type that needs filtering. For example:<br /><br />{ \"allowed\": [ { \"type\": \"StasisStart\" }, { \"type\": \"StasisEnd\" } ] }<br /><br />As this specifies only an allowed list, then only those two event type messages are sent to the application. No other event messages are sent.<br /><br />The following rules apply:<br /><br />* If the body is empty, both the allowed and disallowed filters are set empty.<br />* If both list types are given then both are set to their respective values (note, specifying an empty array for a given type sets that type to empty).<br />* If only one list type is given then only that type is set. The other type is not updated.<br />* An empty \"allowed\" list means all events are allowed.<br />* An empty \"disallowed\" list means no events are disallowed.<br />* Disallowed events take precedence over allowed events if the event type is specified in both lists.",
                                        "nickname": "filter",
 
        "swaggerVersion": "1.1",
        "basePath": "http://localhost:8088/ari",
        "resourcePath": "/api-docs/asterisk.{format}",
+       "since": [
+               "12.0.0"
+       ],
        "apis": [
                {
                        "path": "/asterisk/config/dynamic/{configClass}/{objectType}/{id}",
                        "operations": [
                                {
                                        "httpMethod": "GET",
+                                       "since": [
+                                               "13.5.0"
+                                       ],
                                        "summary": "Retrieve a dynamic configuration object.",
                                        "nickname": "getObject",
                                        "responseClass": "List[ConfigTuple]",
                                },
                                {
                                        "httpMethod": "PUT",
+                                       "since": [
+                                               "13.5.0"
+                                       ],
                                        "summary": "Create or update a dynamic configuration object.",
                                        "nickname": "updateObject",
                                        "responseClass": "List[ConfigTuple]",
                                },
                                {
                                        "httpMethod": "DELETE",
+                                       "since": [
+                                               "13.5.0"
+                                       ],
                                        "summary": "Delete a dynamic configuration object.",
                                        "nickname": "deleteObject",
                                        "responseClass": "void",
                        "operations": [
                                {
                                        "httpMethod": "GET",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Gets Asterisk system information.",
                                        "nickname": "getInfo",
                                        "responseClass": "AsteriskInfo",
                        "operations": [
                                {
                                        "httpMethod": "GET",
+                                       "since": [
+                                               "13.25.0",
+                                               "16.2.0"
+                                       ],
                                        "summary": "Response pong message.",
                                        "nickname": "ping",
                                        "responseClass": "AsteriskPing"
                        "operations": [
                                {
                                        "httpMethod": "GET",
+                                       "since": [
+                                               "13.5.0"
+                                       ],
                                        "summary": "List Asterisk modules.",
                                        "nickname": "listModules",
                                        "responseClass": "List[Module]"
                        "operations": [
                                {
                                        "httpMethod": "GET",
+                                       "since": [
+                                               "13.5.0"
+                                       ],
                                        "summary": "Get Asterisk module information.",
                                        "nickname": "getModule",
                                        "responseClass": "Module",
                                },
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "13.5.0"
+                                       ],
                                        "summary": "Load an Asterisk module.",
                                        "nickname": "loadModule",
                                        "responseClass": "void",
                                },
                                {
                                        "httpMethod": "DELETE",
+                                       "since": [
+                                               "13.5.0"
+                                       ],
                                        "summary": "Unload an Asterisk module.",
                                        "nickname": "unloadModule",
                                        "responseClass": "void",
                                },
                                {
                                        "httpMethod": "PUT",
+                                       "since": [
+                                               "13.5.0"
+                                       ],
                                        "summary": "Reload an Asterisk module.",
                                        "nickname": "reloadModule",
                                        "responseClass": "void",
                        "operations": [
                                {
                                        "httpMethod": "GET",
+                                       "since": [
+                                               "13.6.0"
+                                       ],
                                        "summary": "Gets Asterisk log channel information.",
                                        "nickname": "listLogChannels",
                                        "responseClass": "List[LogChannel]"
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "13.6.0"
+                                       ],
                                        "summary": "Adds a log channel.",
                                        "nickname": "addLog",
                                        "responseClass": "void",
                                },
                                {
                                        "httpMethod": "DELETE",
+                                       "since": [
+                                               "13.6.0"
+                                       ],
                                        "summary": "Deletes a log channel.",
                                        "nickname": "deleteLog",
                                        "responseClass": "void",
                        "operations": [
                                {
                                        "httpMethod": "PUT",
+                                       "since": [
+                                               "13.6.0"
+                                       ],
                                        "summary": "Rotates a log channel.",
                                        "nickname": "rotateLog",
                                        "responseClass": "void",
                        "operations": [
                                {
                                        "httpMethod": "GET",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Get the value of a global variable.",
                                        "nickname": "getGlobalVar",
                                        "responseClass": "Variable",
                                },
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Set the value of a global variable.",
                                        "nickname": "setGlobalVar",
                                        "responseClass": "void",
 
        "swaggerVersion": "1.1",
        "basePath": "http://localhost:8088/ari",
        "resourcePath": "/api-docs/bridges.{format}",
+       "since": [
+               "12.0.0"
+       ],
        "requiresModules": [
                "res_stasis_recording",
                "res_stasis_playback"
                        "operations": [
                                {
                                        "httpMethod": "GET",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "List all active bridges in Asterisk.",
                                        "nickname": "list",
                                        "responseClass": "List[Bridge]"
                                },
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Create a new bridge.",
                                        "notes": "This bridge persists until it has been shut down, or Asterisk has been shut down.",
                                        "nickname": "create",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "12.2.0"
+                                       ],
                                        "summary": "Create a new bridge or updates an existing one.",
                                        "notes": "This bridge persists until it has been shut down, or Asterisk has been shut down.",
                                        "nickname": "createWithId",
                                },
                                {
                                        "httpMethod": "GET",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Get bridge details.",
                                        "nickname": "get",
                                        "responseClass": "Bridge",
                                },
                                {
                                        "httpMethod": "DELETE",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "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": "destroy",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Add a channel to a bridge.",
                                        "nickname": "addChannel",
                                        "responseClass": "void",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Remove a channel from a bridge.",
                                        "nickname": "removeChannel",
                                        "responseClass": "void",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "13.13.0",
+                                               "14.2.0"
+                                       ],
                                        "summary": "Set a channel as the video source in a multi-party mixing bridge. This operation has no effect on bridges with two or fewer participants.",
                                        "nickname": "setVideoSource",
                                        "responseClass": "void",
                        "operations": [
                                {
                                        "httpMethod": "DELETE",
+                                       "since": [
+                                               "13.13.0",
+                                               "14.2.0"
+                                       ],
                                        "summary": "Removes any explicit video source in a multi-party mixing bridge. This operation has no effect on bridges with two or fewer participants. When no explicit video source is set, talk detection will be used to determine the active video stream.",
                                        "nickname": "clearVideoSource",
                                        "responseClass": "void",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Play music on hold to a bridge or change the MOH class that is playing.",
                                        "nickname": "startMoh",
                                        "responseClass": "void",
                                },
                                {
                                        "httpMethod": "DELETE",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Stop playing music on hold to a bridge.",
                                        "notes": "This will only stop music on hold being played via POST bridges/{bridgeId}/moh.",
                                        "nickname": "stopMoh",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Start playback of media on a bridge.",
                                        "notes": "The media URI may be any of a number of URI's. Currently sound:, recording:, number:, digits:, characters:, and tone: 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": "play",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "12.3.0"
+                                       ],
                                        "summary": "Start playback of media on a bridge.",
                                        "notes": "The media URI may be any of a number of URI's. Currently sound:, recording:, number:, digits:, characters:, and tone: 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": "playWithId",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Start a recording.",
                                        "notes": "This records the mixed audio from all channels participating in this bridge.",
                                        "nickname": "record",
 
        "swaggerVersion": "1.1",
        "basePath": "http://localhost:8088/ari",
        "resourcePath": "/api-docs/channels.{format}",
+       "since": [
+               "12.0.0"
+       ],
        "requiresModules": [
                "res_stasis_answer",
                "res_stasis_playback",
                        "operations": [
                                {
                                        "httpMethod": "GET",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "List all active channels in Asterisk.",
                                        "nickname": "list",
                                        "responseClass": "List[Channel]"
                                },
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Create a new channel (originate).",
                                        "notes": "The new channel is created immediately and a snapshot of it returned. If a Stasis application is provided it will be automatically subscribed to the originated channel for further events and updates.",
                                        "nickname": "originate",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "14.0.0"
+                                       ],
                                        "summary": "Create channel.",
                                        "nickname": "create",
                                        "responseClass": "Channel",
                        "operations": [
                                {
                                        "httpMethod": "GET",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Channel details.",
                                        "nickname": "get",
                                        "responseClass": "Channel",
                                },
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "12.2.0"
+                                       ],
                                        "summary": "Create a new channel (originate with id).",
                                        "notes": "The new channel is created immediately and a snapshot of it returned. If a Stasis application is provided it will be automatically subscribed to the originated channel for further events and updates.",
                                        "nickname": "originateWithId",
                                },
                                {
                                        "httpMethod": "DELETE",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Delete (i.e. hangup) a channel.",
                                        "nickname": "hangup",
                                        "responseClass": "void",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Exit application; continue execution in the dialplan.",
                                        "nickname": "continueInDialplan",
                                        "responseClass": "void",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "13.26.0",
+                                               "16.3.0"
+                                       ],
                                        "summary": "Move the channel from one Stasis application to another.",
                                        "nickname": "move",
                                        "responseClass": "void",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "13.3.0"
+                                       ],
                                        "summary": "Redirect the channel to a different location.",
                                        "nickname": "redirect",
                                        "responseClass": "void",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Answer a channel.",
                                        "nickname": "answer",
                                        "responseClass": "void",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Indicate ringing to a channel.",
                                        "nickname": "ring",
                                        "responseClass": "void",
                                },
                                {
                                        "httpMethod": "DELETE",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Stop ringing indication on a channel if locally generated.",
                                        "nickname": "ringStop",
                                        "responseClass": "void",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Send provided DTMF to a given channel.",
                                        "nickname": "sendDTMF",
                                        "responseClass": "void",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Mute a channel.",
                                        "nickname": "mute",
                                        "responseClass": "void",
                                },
                                {
                                        "httpMethod": "DELETE",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Unmute a channel.",
                                        "nickname": "unmute",
                                        "responseClass": "void",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Hold a channel.",
                                        "nickname": "hold",
                                        "responseClass": "void",
                                },
                                {
                                        "httpMethod": "DELETE",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Remove a channel from hold.",
                                        "nickname": "unhold",
                                        "responseClass": "void",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Play music on hold to a channel.",
                                        "notes": "Using media operations such as /play on a channel playing MOH in this manner will suspend MOH without resuming automatically. If continuing music on hold is desired, the stasis application must reinitiate music on hold.",
                                        "nickname": "startMoh",
                                },
                                {
                                        "httpMethod": "DELETE",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Stop playing music on hold to a channel.",
                                        "nickname": "stopMoh",
                                        "responseClass": "void",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Play silence to a channel.",
                                        "notes": "Using media operations such as /play on a channel playing silence in this manner will suspend silence without resuming automatically.",
                                        "nickname": "startSilence",
                                },
                                {
                                        "httpMethod": "DELETE",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Stop playing silence to a channel.",
                                        "nickname": "stopSilence",
                                        "responseClass": "void",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Start playback of media.",
                                        "notes": "The media URI may be any of a number of URI's. Currently sound:, recording:, number:, digits:, characters:, and tone: 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": "play",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "12.2.0"
+                                       ],
                                        "summary": "Start playback of media and specify the playbackId.",
                                        "notes": "The media URI may be any of a number of URI's. Currently sound:, recording:, number:, digits:, characters:, and tone: 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": "playWithId",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Start a recording.",
                                        "notes": "Record audio from a channel. Note that this will not capture audio sent to the channel. The bridge itself has a record feature if that's what you want.",
                                        "nickname": "record",
                        "operations": [
                                {
                                        "httpMethod": "GET",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Get the value of a channel variable or function.",
                                        "nickname": "getChannelVar",
                                        "responseClass": "Variable",
                                },
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Set the value of a channel variable or function.",
                                        "nickname": "setChannelVar",
                                        "responseClass": "void",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Start snooping.",
                                        "notes": "Snoop (spy/whisper) on a specific channel.",
                                        "nickname": "snoopChannel",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "12.2.0"
+                                       ],
                                        "summary": "Start snooping.",
                                        "notes": "Snoop (spy/whisper) on a specific channel.",
                                        "nickname": "snoopChannelWithId",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "14.0.0"
+                                       ],
                                        "summary": "Dial a created channel.",
                                        "nickname": "dial",
                                        "responseClass": "void",
                        "operations": [
                                {
                                        "httpMethod": "GET",
+                                       "since": [
+                                               "13.27.0",
+                                               "16.4.0"
+                                       ],
                                        "summary": "RTP stats on a channel.",
                                        "nickname": "rtpstatistics",
                                        "responseClass": "RTPstat",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "16.6.0",
+                                               "17.1.0"
+                                       ],
                                        "summary": "Start an External Media session.",
                                        "notes": "Create a channel to an External Media source/sink.",
                                        "nickname": "externalMedia",
 
        "swaggerVersion": "1.1",
        "basePath": "http://localhost:8088/ari",
        "resourcePath": "/api-docs/deviceStates.{format}",
+       "since": [
+               "12.0.0"
+       ],
        "requiresModules": [
                "res_stasis_device_state"
        ],
                        "operations": [
                                {
                                        "httpMethod": "GET",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "List all ARI controlled device states.",
                                        "nickname": "list",
                                        "responseClass": "List[DeviceState]"
                        "operations": [
                                {
                                        "httpMethod": "GET",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Retrieve the current state of a device.",
                                        "nickname": "get",
                                        "responseClass": "DeviceState",
                                },
                                {
                                        "httpMethod": "PUT",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Change the state of a device controlled by ARI. (Note - implicitly creates the device state).",
                                        "nickname": "update",
                                        "responseClass": "void",
                                },
                                {
                                        "httpMethod": "DELETE",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Destroy a device-state controlled by ARI.",
                                        "nickname": "delete",
                                        "responseClass": "void",
 
        "swaggerVersion": "1.1",
        "basePath": "http://localhost:8088/ari",
        "resourcePath": "/api-docs/endpoints.{format}",
+       "since": [
+               "12.0.0"
+       ],
        "apis": [
                {
                        "path": "/endpoints",
                        "operations": [
                                {
                                        "httpMethod": "GET",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "List all endpoints.",
                                        "nickname": "list",
                                        "responseClass": "List[Endpoint]"
                        "operations": [
                                {
                                        "httpMethod": "PUT",
+                                       "since": [
+                                               "13.0.0"
+                                       ],
                                        "summary": "Send a message to some technology URI or endpoint.",
                                        "nickname": "sendMessage",
                                        "responseClass": "void",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "18.20.0",
+                                               "20.5.0"
+                                       ],
                                        "summary": "Refer an endpoint or technology URI to some technology URI or endpoint.",
                                        "nickname": "refer",
                                        "responseClass": "void",
                        "operations": [
                                {
                                        "httpMethod": "GET",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "List available endoints for a given endpoint technology.",
                                        "nickname": "listByTech",
                                        "responseClass": "List[Endpoint]",
                        "operations": [
                                {
                                        "httpMethod": "GET",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Details for an endpoint.",
                                        "nickname": "get",
                                        "responseClass": "Endpoint",
                        "operations": [
                                {
                                        "httpMethod": "PUT",
+                                       "since": [
+                                               "13.0.0"
+                                       ],
                                        "summary": "Send a message to some endpoint in a technology.",
                                        "nickname": "sendMessageToEndpoint",
                                        "responseClass": "void",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "18.20.0",
+                                               "20.5.0"
+                                       ],
                                        "summary": "Refer an endpoint or technology URI to some technology URI or endpoint.",
                                        "nickname": "referToEndpoint",
                                        "responseClass": "void",
 
        "swaggerVersion": "1.2",
        "basePath": "http://localhost:8088/ari",
        "resourcePath": "/api-docs/events.{format}",
+       "since": [
+               "12.0.0"
+       ],
        "requiresModules": [
                "res_http_websocket"
        ],
                        "operations": [
                                {
                                        "httpMethod": "GET",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "upgrade": "websocket",
                                        "websocketProtocol": "ari",
                                        "summary": "WebSocket connection for events.",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "12.3.0"
+                                       ],
                                        "summary": "Generate a user event.",
                                        "nickname": "userEvent",
                                        "responseClass": "void",
 
        "swaggerVersion": "1.1",
        "basePath": "http://localhost:8088/ari",
        "resourcePath": "/api-docs/mailboxes.{format}",
+       "since": [
+               "12.1.0"
+       ],
        "requiresModules": [
                "res_stasis_mailbox"
        ],
                        "operations": [
                                {
                                        "httpMethod": "GET",
+                                       "since": [
+                                               "12.1.0"
+                                       ],
                                        "summary": "List all mailboxes.",
                                        "nickname": "list",
                                        "responseClass": "List[Mailbox]"
                        "operations": [
                                {
                                        "httpMethod": "GET",
+                                       "since": [
+                                               "12.1.0"
+                                       ],
                                        "summary": "Retrieve the current state of a mailbox.",
                                        "nickname": "get",
                                        "responseClass": "Mailbox",
                                },
                                {
                                        "httpMethod": "PUT",
+                                       "since": [
+                                               "12.1.0"
+                                       ],
                                        "summary": "Change the state of a mailbox. (Note - implicitly creates the mailbox).",
                                        "nickname": "update",
                                        "responseClass": "void",
                                },
                                {
                                        "httpMethod": "DELETE",
+                                       "since": [
+                                               "12.1.0"
+                                       ],
                                        "summary": "Destroy a mailbox.",
                                        "nickname": "delete",
                                        "responseClass": "void",
 
        "swaggerVersion": "1.1",
        "basePath": "http://localhost:8088/ari",
        "resourcePath": "/api-docs/playbacks.{format}",
+       "since": [
+               "12.0.0"
+       ],
        "requiresModules": [
                "res_stasis_playback"
        ],
                        "operations": [
                                {
                                        "httpMethod": "GET",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Get a playback's details.",
                                        "nickname": "get",
                                        "responseClass": "Playback",
                                },
                                {
                                        "httpMethod": "DELETE",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Stop a playback.",
                                        "nickname": "stop",
                                        "responseClass": "void",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Control a playback.",
                                        "nickname": "control",
                                        "responseClass": "void",
 
        "swaggerVersion": "1.1",
        "basePath": "http://localhost:8088/ari",
        "resourcePath": "/api-docs/recordings.{format}",
+       "since": [
+               "12.0.0"
+       ],
        "requiresModules": [
                "res_stasis_recording"
        ],
                        "operations": [
                                {
                                        "httpMethod": "GET",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "List recordings that are complete.",
                                        "nickname": "listStored",
                                        "responseClass": "List[StoredRecording]"
                        "operations": [
                                {
                                        "httpMethod": "GET",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Get a stored recording's details.",
                                        "nickname": "getStored",
                                        "responseClass": "StoredRecording",
                                },
                                {
                                        "httpMethod": "DELETE",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Delete a stored recording.",
                                        "nickname": "deleteStored",
                                        "responseClass": "void",
                        "operations": [
                                {
                                        "httpMethod": "GET",
+                                       "since": [
+                                               "14.0.0"
+                                       ],
                                        "summary": "Get the file associated with the stored recording.",
                                        "nickname": "getStoredFile",
                                        "responseClass": "binary",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "12.5.0"
+                                       ],
                                        "summary": "Copy a stored recording.",
                                        "nickname": "copyStored",
                                        "responseClass": "StoredRecording",
                        "operations": [
                                {
                                        "httpMethod": "GET",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "List live recordings.",
                                        "nickname": "getLive",
                                        "responseClass": "LiveRecording",
                                },
                                {
                                        "httpMethod": "DELETE",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Stop a live recording and discard it.",
                                        "nickname": "cancel",
                                        "responseClass": "void",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Stop a live recording and store it.",
                                        "nickname": "stop",
                                        "responseClass": "void",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Pause a live recording.",
                                        "notes": "Pausing a recording suspends silence detection, which will be restarted when the recording is unpaused. Paused time is not included in the accounting for maxDurationSeconds.",
                                        "nickname": "pause",
                                },
                                {
                                        "httpMethod": "DELETE",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Unpause a live recording.",
                                        "nickname": "unpause",
                                        "responseClass": "void",
                        "operations": [
                                {
                                        "httpMethod": "POST",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Mute a live recording.",
                                        "notes": "Muting a recording suspends silence detection, which will be restarted when the recording is unmuted.",
                                        "nickname": "mute",
                                },
                                {
                                        "httpMethod": "DELETE",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Unmute a live recording.",
                                        "nickname": "unmute",
                                        "responseClass": "void",
 
        "swaggerVersion": "1.1",
        "basePath": "http://localhost:8088/ari",
        "resourcePath": "/api-docs/sounds.{format}",
+       "since": [
+               "12.0.0"
+       ],
        "apis": [
                {
                        "path": "/sounds",
                        "operations": [
                                {
                                        "httpMethod": "GET",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "List all sounds.",
                                        "nickname": "list",
                                        "responseClass": "List[Sound]",
                        "operations": [
                                {
                                        "httpMethod": "GET",
+                                       "since": [
+                                               "12.0.0"
+                                       ],
                                        "summary": "Get a sound's details.",
                                        "nickname": "get",
                                        "responseClass": "Sound",