freeswitch/libs/sipcc/include/ccapi_call.h

247 lines
8.1 KiB
C

/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
#ifndef _CCAPI_CALL_H_
#define _CCAPI_CALL_H_
#include "ccapi_types.h"
/**
* Get reference to call info
* @param [in] handle - call handle
* @return cc_call_info_snap_t
* NOTE: The info returned by this method must be released using CCAPI_Call_releaseCallInfo()
*/
cc_callinfo_ref_t CCAPI_Call_getCallInfo(cc_call_handle_t handle);
/**
* Release the resources held by this call info snapshot
* @param [in] ref - refrence to the call info to be freed
* @return void
*/
void CCAPI_Call_releaseCallInfo(cc_callinfo_ref_t ref);
/**
* Retain the call info reference
* @param [in] ref - reference to the call info to be retained
* @return void
* NOTE: Application that has retained callInfo must call CCAPI_Call_releaseCallInfo()
* to free memory associated with this Info.
*/
void CCAPI_Call_retainCallInfo(cc_callinfo_ref_t ref);
/**
* get the line associated with this call
* @param [in] handle - call handle
* @return cc_lineid_t
*/
cc_lineid_t CCAPI_Call_getLine(cc_call_handle_t call_handle);
/**
* Originate call - API to go offhook and dial specified digits on a given call
* @param [in] handle - call handle
* @param [in] video_pref - video direction desired on call
* @param [in] digits - digits to be dialed. can be empty then this API simply goes offhook
* @return SUCCESS or FAILURE
*/
cc_return_t CCAPI_Call_originateCall(cc_call_handle_t handle, cc_sdp_direction_t video_pref, cc_string_t digits);
cc_return_t CCAPI_CreateOffer(cc_call_handle_t handle, const cc_media_constraints_t *constraints);
cc_return_t CCAPI_CreateAnswer(cc_call_handle_t handle, const cc_media_constraints_t *constraints);
cc_return_t CCAPI_SetLocalDescription(cc_call_handle_t handle, cc_jsep_action_t action, cc_string_t sdp);
cc_return_t CCAPI_SetRemoteDescription(cc_call_handle_t handle, cc_jsep_action_t action, cc_string_t sdp);
cc_return_t CCAPI_SetPeerConnection(cc_call_handle_t handle, cc_peerconnection_t pc);
cc_return_t CCAPI_AddStream(cc_call_handle_t handle, cc_media_stream_id_t stream_id, cc_media_track_id_t track_id, cc_media_type_t media_type);
cc_return_t CCAPI_RemoveStream(cc_call_handle_t handle, cc_media_stream_id_t stream_id, cc_media_track_id_t track_id, cc_media_type_t media_type);
cc_return_t CCAPI_AddICECandidate(cc_call_handle_t handle, cc_string_t candidate, cc_string_t mid, cc_level_t level);
/**
* Send digits on the call - can be invoked either to dial additional digits or send DTMF
* @param [in] handle - call handle
* @param [in] digit - digit to be dialed
* @return SUCCESS or FAILURE
*/
cc_return_t CCAPI_Call_sendDigit(cc_call_handle_t handle, cc_digit_t digit);
/**
* Send Backspace - Delete last digit dialed.
* @param [in] handle - call handle
* @return SUCCESS or FAILURE
*/
cc_return_t CCAPI_Call_backspace(cc_call_handle_t handle);
/**
* Answer Call
* @param [in] handle - call handle
* @param [in] video_pref - video direction desired on call
* @return SUCCESS or FAILURE
*/
cc_return_t CCAPI_Call_answerCall(cc_call_handle_t handle, cc_sdp_direction_t video_pref);
/**
* Redial
* @param [in] handle - call handle
* @param [in] video_pref - video direction desired on call
* @return SUCCESS or FAILURE
*/
cc_return_t CCAPI_Call_redial(cc_call_handle_t handle, cc_sdp_direction_t video_pref);
/**
* Initiate Call Forward All
* @param [in] handle - call handle
* @return SUCCESS or FAILURE
*/
cc_return_t CCAPI_Call_initiateCallForwardAll(cc_call_handle_t handle);
/**
* Hold
* @param [in] handle - call handle
* @param [in] reason - hold reason
* @return SUCCESS or FAILURE
*/
cc_return_t CCAPI_Call_hold(cc_call_handle_t handle, cc_hold_reason_t reason);
/**
* Resume
* @param [in] handle - call handle
* @param [in] video_pref - video direction desired on call
* @return SUCCESS or FAILURE
*/
cc_return_t CCAPI_Call_resume(cc_call_handle_t handle, cc_sdp_direction_t video_pref) ;
/**
* end Consult leg - used to end consult leg when the user picks active calls list for xfer/conf
* @param [in] handle - call handle
* @return SUCCESS or FAILURE
*/
cc_return_t CCAPI_Call_endConsultativeCall(cc_call_handle_t handle);
/**
* end Call
* @param [in] handle - call handle
* @return SUCCESS or FAILURE
*/
cc_return_t CCAPI_Call_endCall(cc_call_handle_t handle);
/**
* Initiate a conference
* @param [in] handle - call handle
* @param [in] video_pref - video direction desired on consult call
* @return SUCCESS or FAILURE
*/
cc_return_t CCAPI_Call_conferenceStart(cc_call_handle_t handle, cc_sdp_direction_t video_pref);
/**
* complete conference
* @param [in] handle - call handle
* @param [in] phandle - call handle of the other leg
* @param [in] video_pref - video direction desired on consult call
* @return SUCCESS or FAILURE
*/
cc_return_t CCAPI_Call_conferenceComplete(cc_call_handle_t handle, cc_call_handle_t phandle,
cc_sdp_direction_t video_pref);
/**
* start transfer
* @param [in] handle - call handle
* @param [in] video_pref - video direction desired on consult call
* @return SUCCESS or FAILURE
*/
cc_return_t CCAPI_Call_transferStart(cc_call_handle_t handle, cc_sdp_direction_t video_pref);
/**
* complete transfer
* @param [in] handle - call handle
* @param [in] phandle - call handle of the other leg
* @param [in] video_pref - video direction desired on consult call
* @return SUCCESS or FAILURE
*/
cc_return_t CCAPI_Call_transferComplete(cc_call_handle_t handle, cc_call_handle_t phandle,
cc_sdp_direction_t video_pref);
/**
* cancel conference or transfer
* @param [in] handle - call handle
* @return SUCCESS or FAILURE
*/
cc_return_t CCAPI_Call_cancelTransferOrConferenceFeature(cc_call_handle_t handle);
/**
* direct Transfer
* @param [in] handle - call handle
* @param [in] target - call handle for transfer target call
* @return SUCCESS or FAILURE
*/
cc_return_t CCAPI_Call_directTransfer(cc_call_handle_t handle, cc_call_handle_t target);
/**
* Join Across line
* @param [in] handle - call handle
* @param [in] target - join target
* @return SUCCESS or FAILURE
*/
cc_return_t CCAPI_Call_joinAcrossLine(cc_call_handle_t handle, cc_call_handle_t target);
/**
* BLF Call Pickup
* @param [in] handle - call handle
* @param [in] video_pref - video direction preference
* @param [in] speed - speedDial Number
* @return SUCCESS or FAILURE
*/
cc_return_t CCAPI_Call_blfCallPickup(cc_call_handle_t handle, cc_sdp_direction_t video_pref, cc_string_t speed);
/**
* Select a call
* @param [in] handle - call handle
* @return SUCCESS or FAILURE
*/
cc_return_t CCAPI_Call_select(cc_call_handle_t handle);
/**
* Update Video Media Cap for the call
* @param [in] handle - call handle
* @param [in] video_pref - video direction desired on call
* @return SUCCESS or FAILURE
*/
cc_return_t CCAPI_Call_updateVideoMediaCap(cc_call_handle_t handle, cc_sdp_direction_t video_pref);
/**
* send INFO method for the call
* @param [in] handle - call handle
* @param [in] infopackage - Info-Package header value
* @param [in] infotype - Content-Type header val
* @param [in] infobody - Body of the INFO message
* @return SUCCESS or FAILURE
*/
cc_return_t CCAPI_Call_sendInfo(cc_call_handle_t handle, cc_string_t infopackage, cc_string_t infotype, cc_string_t infobody);
/**
* API to mute/unmute audio
* @param [in] val - TRUE=> mute FALSE => unmute
* @return SUCCESS or FAILURE
* NOTE: The mute state is persisted within the stack and shall be remembered across hold/resume.
* This API doesn't perform the mute operation but simply caches the mute state of the session.
*/
cc_return_t CCAPI_Call_setAudioMute(cc_call_handle_t handle, cc_boolean val);
/**
* API to mute/unmute Video
* @param [in] val - TRUE=> mute FALSE => unmute
* @return SUCCESS or FAILURE
* NOTE: The mute state is persisted within the stack and shall be remembered across hold/resume
* This API doesn't perform the mute operation but simply caches the mute state of the session.
*/
cc_return_t CCAPI_Call_setVideoMute(cc_call_handle_t handle, cc_boolean val);
#endif // _CCAPI_CALL_H_