diff options
author | Matthew Jordan <mjordan@digium.com> | 2014-07-18 21:48:46 +0000 |
---|---|---|
committer | Matthew Jordan <mjordan@digium.com> | 2014-07-18 21:48:46 +0000 |
commit | b299052e203807c9a2111eb2cd919246d7589cb3 (patch) | |
tree | ed02894e1620cc9d0113aa4449b168fa76f01186 /res/ari/resource_recordings.h | |
parent | eaf1225b40308f643272a7f7715c7b46aa075f83 (diff) |
ari: Add a copy operation for stored recordings
This patch adds a new operation for stored recordings, copy. It takes an
existing stored recording and makes a copy of it in the same directory
or a relative directory under the stored recording directory.
/ari/recordings/stored/{recordingName}/copy?destinationRecordingName={copy_name}
This is particularly useful for voicemail-esque applications, which may need to
copy or move recordings around a directory structure.
Review: https://reviewboard.asterisk.org/r/3768/
ASTERISK-24036 #close
Reported by: Sam Galarneau
Tested by: Sam Galarneau
........
Merged revisions 419021 from http://svn.asterisk.org/svn/asterisk/branches/12
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@419022 65c4cc65-6c06-0410-ace0-fbb531ad65f3
Diffstat (limited to 'res/ari/resource_recordings.h')
-rw-r--r-- | res/ari/resource_recordings.h | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/res/ari/resource_recordings.h b/res/ari/resource_recordings.h index 039cb168a..196122f44 100644 --- a/res/ari/resource_recordings.h +++ b/res/ari/resource_recordings.h @@ -76,6 +76,32 @@ struct ast_ari_recordings_delete_stored_args { * \param[out] response HTTP response */ void ast_ari_recordings_delete_stored(struct ast_variable *headers, struct ast_ari_recordings_delete_stored_args *args, struct ast_ari_response *response); +/*! Argument struct for ast_ari_recordings_copy_stored() */ +struct ast_ari_recordings_copy_stored_args { + /*! The name of the recording to copy */ + const char *recording_name; + /*! The destination name of the recording */ + const char *destination_recording_name; +}; +/*! + * \brief Body parsing function for /recordings/stored/{recordingName}/copy. + * \param body The JSON body from which to parse parameters. + * \param[out] args The args structure to parse into. + * \retval zero on success + * \retval non-zero on failure + */ +int ast_ari_recordings_copy_stored_parse_body( + struct ast_json *body, + struct ast_ari_recordings_copy_stored_args *args); + +/*! + * \brief Copy a stored recording. + * + * \param headers HTTP headers + * \param args Swagger parameters + * \param[out] response HTTP response + */ +void ast_ari_recordings_copy_stored(struct ast_variable *headers, struct ast_ari_recordings_copy_stored_args *args, struct ast_ari_response *response); /*! Argument struct for ast_ari_recordings_get_live() */ struct ast_ari_recordings_get_live_args { /*! The name of the recording */ |