freeswitch/libs/sipcc/include/config_api.h

121 lines
4.6 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 _CONFIG_API_H_
#define _CONFIG_API_H_
#include "cc_types.h"
/**
* configFetchReq
*
* This function tells the config manager to fetch the CTL file
* and then fetch the config from the CUCM. It is expected that
* this will result in processing of
* the config file after the config managers response is received.
*
* The response received for this request is asynchronous and
* should be handled via event provided by config manager.
* The CCAPI_Config_reponse api needs to be called for the
* handling of the response to the fetch request
*
*/
void configFetchReq(int device_handle);
/**
* configParserError
*
* Notify the config manager that the config file has an error
* and a new config file needs to be downloaded.
*
* The error could be XML format error or minimum config not being
* present in the config file. It is expected that
* this will result in processing of
* the config file after the config managers response is received.
*
*/
void configParserError(void);
/**
* When called this function should register with CUCM without prior device file download.
*/
void CCAPI_Start_response(int device_handle, const char *device_name, const char *sipUser, const char *sipPassword, const char *sipDomain);
/**
* Inform application that pSipcc stack has receive a NOTIFY message of event
* type "service-control" and action=apply-config. The arguments passed to this
* function contains the parameter values received in the message.
*
* @param config_version [in] latest version stamp of phone configuration.
* @param dial_plan_version [in] latest version stamp of the dial plan.
* @param fcp_version [in] latest version stamp of feature policy control.
* @param cucm_result [in] action taken by the cucm for the changes applied by the
* user to the phone configuration. cucm result could be
* @li "no_change" - the new phone configuration changes do not impact Unified CM,
* @li "config_applied" - The Unified CM Administration applied the
* configuration changes dynamically without requiring phone to re-register,
* @li "reregister_needed" - The Unified CM Administration applied the
* configuration changes and required the phone to re-register to make them
* effective.
* @param load_id [in] - firmware image name that phone should be running with
* @param inactive_load_id [in] - firmware image name that phone should be in inactive partition.
* @param load_server [in] - address of load server to download the firmware
* image load_id.
* @param log_server [in] - log server address where error report need to be
* sent. Error report, for example, could be related to image download failure
* or phone configuration file download failure.
* @param ppid [in] whether peer to peer upgrade is available
* @return void
*/
void configApplyConfigNotify(cc_string_t config_version,
cc_string_t dial_plan_version,
cc_string_t fcp_version,
cc_string_t cucm_result,
cc_string_t load_id,
cc_string_t inactive_load_id,
cc_string_t load_server,
cc_string_t log_server,
cc_boolean ppid);
/**
* dialPlanFetchReq
*
* This function tells the get file request service to fetch the latest dial
* plan from the CUCM.
*
* @param device_handle [in] handle of the device, the response is for
* @param dialPlanFileName [in] the name of dialplan file to retrieve
* @return cc_boolean indicating success/failure
*
*/
cc_boolean dialPlanFetchReq(int device_handle, char* dialPlanFileName);
/**
* fcpFetchReq
*
* This function tells the get file request service to fetch the latest fcp
* file from the CUCM.
*
* @param device_handle [in] handle of the device, the response is for
* @param dialPlanFileName [in] the name of fcp file to retrieve
* @return cc_boolean indicating success/failure
*
*/
cc_boolean fcpFetchReq(int device_handle, char* fcpFileName);
cc_boolean CCAPI_Config_set_server_address(const char *ip_address);
cc_boolean CCAPI_Config_set_transport_udp(const cc_boolean is_udp);
cc_boolean CCAPI_Config_set_local_voip_port(const int port);
cc_boolean CCAPI_Config_set_remote_voip_port(const int port);
int CCAPI_Config_get_local_voip_port();
int CCAPI_Config_get_remote_voip_port();
const char* CCAPI_Config_get_version();
cc_boolean CCAPI_Config_set_p2p_mode(const cc_boolean is_p2p);
cc_boolean CCAPI_Config_set_sdp_mode(const cc_boolean is_sdp);
cc_boolean CCAPI_Config_set_avp_mode(const cc_boolean is_rtpsavpf);
#endif /* _CONFIG_API_H_ */