mirror of
https://github.com/asterisk/asterisk.git
synced 2025-09-04 11:58:52 +00:00
ARI recordings: Issue HTTP failures for recording requests with file conflicts
If a file already exists in the recordings directory with the same name as what we would record, issue a 422 instead of relying on the internal failure and issuing success. (closes issue ASTERISK-22623) Reported by: Joshua Colp Review: https://reviewboard.asterisk.org/r/2922/ ........ Merged revisions 401973 from http://svn.asterisk.org/svn/asterisk/branches/12 git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@401999 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
@@ -454,20 +454,20 @@
|
||||
}
|
||||
}
|
||||
],
|
||||
"errorResponses": [
|
||||
{
|
||||
"code": 400,
|
||||
"reason": "Recording name invalid"
|
||||
},
|
||||
{
|
||||
"code": 404,
|
||||
"reason": "Bridge not found"
|
||||
},
|
||||
{
|
||||
"code": 409,
|
||||
"reason": "Bridge not in Stasis application; Recording already in progress"
|
||||
}
|
||||
]
|
||||
"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"
|
||||
}
|
||||
]
|
||||
}
|
||||
]
|
||||
}
|
||||
|
@@ -720,7 +720,7 @@
|
||||
},
|
||||
{
|
||||
"code": 409,
|
||||
"reason": "Channel is not in a Stasis application; the channel is currently bridged with other channels; A recording with the same name is currently in progress."
|
||||
"reason": "Channel is not in a Stasis application; the channel is currently bridged with other hcannels; A recording with the same name already exists on the system and can not be overwritten because it is in progress or ifExists=fail"
|
||||
}
|
||||
]
|
||||
}
|
||||
|
@@ -120,6 +120,47 @@
|
||||
}
|
||||
}
|
||||
},
|
||||
"RecordingStarted": {
|
||||
"id": "RecordingStarted",
|
||||
"extends": "Event",
|
||||
"description": "Event showing the start of a recording operation.",
|
||||
"properties": {
|
||||
"recording": {
|
||||
"type": "LiveRecording",
|
||||
"description": "Recording control object",
|
||||
"required": true
|
||||
}
|
||||
}
|
||||
},
|
||||
"RecordingFinished": {
|
||||
"id": "RecordingFinished",
|
||||
"extends": "Event",
|
||||
"description": "Event showing the completion of a recording operation.",
|
||||
"properties": {
|
||||
"recording": {
|
||||
"type": "LiveRecording",
|
||||
"description": "Recording control object",
|
||||
"required": true
|
||||
}
|
||||
}
|
||||
},
|
||||
"RecordingFailed": {
|
||||
"id": "RecordingFailed",
|
||||
"extends": "Event",
|
||||
"description": "Event showing failure of a recording operation.",
|
||||
"properties": {
|
||||
"recording": {
|
||||
"type": "LiveRecording",
|
||||
"description": "Recording control object",
|
||||
"required": true
|
||||
},
|
||||
"cause": {
|
||||
"type": "string",
|
||||
"description": "Cause for the recording failure",
|
||||
"required": true
|
||||
}
|
||||
}
|
||||
},
|
||||
"ApplicationReplaced": {
|
||||
"id": "ApplicationReplaced",
|
||||
"description": "Notification that another WebSocket has taken over for an application.\n\nAn application may only be subscribed to by a single WebSocket at a time. If multiple WebSockets attempt to subscribe to the same application, the newer WebSocket wins, and the older one receives this event.",
|
||||
|
@@ -309,9 +309,11 @@
|
||||
"valueType": "LIST",
|
||||
"values": [
|
||||
"queued",
|
||||
"playing",
|
||||
"recording",
|
||||
"paused",
|
||||
"done"
|
||||
"done",
|
||||
"failed",
|
||||
"canceled"
|
||||
]
|
||||
}
|
||||
},
|
||||
|
Reference in New Issue
Block a user