MODLANG-124
git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@14812 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
parent
e97fe49914
commit
4780a3d377
|
@ -55,7 +55,7 @@ class Session : public CoreSession {
|
||||||
virtual switch_status_t run_dtmf_callback(void *input, switch_input_type_t itype);
|
virtual switch_status_t run_dtmf_callback(void *input, switch_input_type_t itype);
|
||||||
void unsetInputCallback(void);
|
void unsetInputCallback(void);
|
||||||
void setInputCallback(char *cbfunc, char *funcargs = NULL);
|
void setInputCallback(char *cbfunc, char *funcargs = NULL);
|
||||||
void setHangupHook(char *func, char *arg);
|
void setHangupHook(char *func, char *arg = NULL);
|
||||||
bool ready();
|
bool ready();
|
||||||
int originate(CoreSession *a_leg_session, char *dest, int timeout);
|
int originate(CoreSession *a_leg_session, char *dest, int timeout);
|
||||||
|
|
||||||
|
|
|
@ -21,6 +21,7 @@ void mod_lua_conjure_session(lua_State * L, switch_core_session_t *session, cons
|
||||||
Session *result = new Session(session);
|
Session *result = new Session(session);
|
||||||
|
|
||||||
SWIG_NewPointerObj(L, result, SWIGTYPE_p_LUA__Session, destroy_me);
|
SWIG_NewPointerObj(L, result, SWIGTYPE_p_LUA__Session, destroy_me);
|
||||||
|
result->setLUA(L);
|
||||||
lua_setglobal(L, name);
|
lua_setglobal(L, name);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -7747,7 +7747,7 @@ static int _wrap_Session_setInputCallback(lua_State* L) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static int _wrap_Session_setHangupHook(lua_State* L) {
|
static int _wrap_Session_setHangupHook__SWIG_0(lua_State* L) {
|
||||||
int SWIG_arg = -1;
|
int SWIG_arg = -1;
|
||||||
LUA::Session *arg1 = (LUA::Session *) 0 ;
|
LUA::Session *arg1 = (LUA::Session *) 0 ;
|
||||||
char *arg2 = (char *) 0 ;
|
char *arg2 = (char *) 0 ;
|
||||||
|
@ -7777,6 +7777,89 @@ fail:
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static int _wrap_Session_setHangupHook__SWIG_1(lua_State* L) {
|
||||||
|
int SWIG_arg = -1;
|
||||||
|
LUA::Session *arg1 = (LUA::Session *) 0 ;
|
||||||
|
char *arg2 = (char *) 0 ;
|
||||||
|
|
||||||
|
SWIG_check_num_args("setHangupHook",2,2)
|
||||||
|
if(!SWIG_isptrtype(L,1)) SWIG_fail_arg("setHangupHook",1,"LUA::Session *");
|
||||||
|
if(!lua_isstring(L,2)) SWIG_fail_arg("setHangupHook",2,"char *");
|
||||||
|
|
||||||
|
if (!SWIG_IsOK(SWIG_ConvertPtr(L,1,(void**)&arg1,SWIGTYPE_p_LUA__Session,0))){
|
||||||
|
SWIG_fail_ptr("Session_setHangupHook",1,SWIGTYPE_p_LUA__Session);
|
||||||
|
}
|
||||||
|
|
||||||
|
arg2 = (char *)lua_tostring(L, 2);
|
||||||
|
(arg1)->setHangupHook(arg2);
|
||||||
|
SWIG_arg=0;
|
||||||
|
|
||||||
|
return SWIG_arg;
|
||||||
|
|
||||||
|
if(0) SWIG_fail;
|
||||||
|
|
||||||
|
fail:
|
||||||
|
lua_error(L);
|
||||||
|
return SWIG_arg;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static int _wrap_Session_setHangupHook(lua_State* L) {
|
||||||
|
int argc;
|
||||||
|
int argv[4]={
|
||||||
|
1,2,3,4
|
||||||
|
};
|
||||||
|
|
||||||
|
argc = lua_gettop(L);
|
||||||
|
if (argc == 2) {
|
||||||
|
int _v;
|
||||||
|
{
|
||||||
|
void *ptr;
|
||||||
|
if (SWIG_isptrtype(L,argv[0])==0 || SWIG_ConvertPtr(L,argv[0], (void **) &ptr, SWIGTYPE_p_LUA__Session, 0)) {
|
||||||
|
_v = 0;
|
||||||
|
} else {
|
||||||
|
_v = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (_v) {
|
||||||
|
{
|
||||||
|
_v = lua_isstring(L,argv[1]);
|
||||||
|
}
|
||||||
|
if (_v) {
|
||||||
|
return _wrap_Session_setHangupHook__SWIG_1(L);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (argc == 3) {
|
||||||
|
int _v;
|
||||||
|
{
|
||||||
|
void *ptr;
|
||||||
|
if (SWIG_isptrtype(L,argv[0])==0 || SWIG_ConvertPtr(L,argv[0], (void **) &ptr, SWIGTYPE_p_LUA__Session, 0)) {
|
||||||
|
_v = 0;
|
||||||
|
} else {
|
||||||
|
_v = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (_v) {
|
||||||
|
{
|
||||||
|
_v = lua_isstring(L,argv[1]);
|
||||||
|
}
|
||||||
|
if (_v) {
|
||||||
|
{
|
||||||
|
_v = lua_isstring(L,argv[2]);
|
||||||
|
}
|
||||||
|
if (_v) {
|
||||||
|
return _wrap_Session_setHangupHook__SWIG_0(L);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
lua_pushstring(L,"No matching function for overloaded 'Session_setHangupHook'");
|
||||||
|
lua_error(L);return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
static int _wrap_Session_ready(lua_State* L) {
|
static int _wrap_Session_ready(lua_State* L) {
|
||||||
int SWIG_arg = -1;
|
int SWIG_arg = -1;
|
||||||
LUA::Session *arg1 = (LUA::Session *) 0 ;
|
LUA::Session *arg1 = (LUA::Session *) 0 ;
|
||||||
|
|
|
@ -791,8 +791,6 @@ SWITCH_DECLARE(char *) CoreSession::playAndGetDigits(int min_digits,
|
||||||
sizeof(dtmf_buf),
|
sizeof(dtmf_buf),
|
||||||
digits_regex);
|
digits_regex);
|
||||||
|
|
||||||
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "playAndGetDigits dtmf_buf: %s\n", dtmf_buf);
|
|
||||||
|
|
||||||
end_allow_threads();
|
end_allow_threads();
|
||||||
return dtmf_buf;
|
return dtmf_buf;
|
||||||
}
|
}
|
||||||
|
@ -1146,7 +1144,6 @@ SWITCH_DECLARE(void) msleep(unsigned ms)
|
||||||
|
|
||||||
SWITCH_DECLARE(void) bridge(CoreSession &session_a, CoreSession &session_b)
|
SWITCH_DECLARE(void) bridge(CoreSession &session_a, CoreSession &session_b)
|
||||||
{
|
{
|
||||||
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session_a.session), SWITCH_LOG_DEBUG, "bridge called, session_a uuid: %s\n", session_a.get_uuid());
|
|
||||||
switch_input_callback_function_t dtmf_func = NULL;
|
switch_input_callback_function_t dtmf_func = NULL;
|
||||||
switch_input_args_t args;
|
switch_input_args_t args;
|
||||||
switch_channel_t *channel_a = NULL, *channel_b = NULL;
|
switch_channel_t *channel_a = NULL, *channel_b = NULL;
|
||||||
|
@ -1185,9 +1182,6 @@ SWITCH_DECLARE_NONSTD(switch_status_t) hanguphook(switch_core_session_t *session
|
||||||
CoreSession *coresession = NULL;
|
CoreSession *coresession = NULL;
|
||||||
switch_channel_state_t state = switch_channel_get_state(channel);
|
switch_channel_state_t state = switch_channel_get_state(channel);
|
||||||
|
|
||||||
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session_hungup), SWITCH_LOG_DEBUG, "hangup_hook called\n");
|
|
||||||
|
|
||||||
|
|
||||||
if ((coresession = (CoreSession *) switch_channel_get_private(channel, "CoreSession"))) {
|
if ((coresession = (CoreSession *) switch_channel_get_private(channel, "CoreSession"))) {
|
||||||
if (coresession->hook_state != state) {
|
if (coresession->hook_state != state) {
|
||||||
coresession->hook_state = state;
|
coresession->hook_state = state;
|
||||||
|
@ -1207,26 +1201,14 @@ SWITCH_DECLARE_NONSTD(switch_status_t) dtmf_callback(switch_core_session_t *sess
|
||||||
|
|
||||||
switch_channel_t *channel = switch_core_session_get_channel(session_cb);
|
switch_channel_t *channel = switch_core_session_get_channel(session_cb);
|
||||||
CoreSession *coresession = NULL;
|
CoreSession *coresession = NULL;
|
||||||
switch_status_t result;
|
|
||||||
|
|
||||||
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session_cb), SWITCH_LOG_INFO, "dtmf_callback called\n");
|
|
||||||
|
|
||||||
|
|
||||||
//coresession = (CoreSession *) buf;
|
|
||||||
coresession = (CoreSession *) switch_channel_get_private(channel, "CoreSession");
|
coresession = (CoreSession *) switch_channel_get_private(channel, "CoreSession");
|
||||||
|
|
||||||
if (!coresession) {
|
if (!coresession) {
|
||||||
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session_cb), SWITCH_LOG_ERROR, "Invalid CoreSession\n");
|
|
||||||
return SWITCH_STATUS_FALSE;
|
return SWITCH_STATUS_FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
result = coresession->run_dtmf_callback(input, itype);
|
return coresession->run_dtmf_callback(input, itype);
|
||||||
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session_cb), SWITCH_LOG_DEBUG, "process_callback_result returned\n");
|
|
||||||
if (result) {
|
|
||||||
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session_cb), SWITCH_LOG_DEBUG, "process_callback_result returned: %d\n", result);
|
|
||||||
}
|
|
||||||
return result;
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -1308,30 +1290,33 @@ SWITCH_DECLARE(switch_status_t) CoreSession::process_callback_result(char *resul
|
||||||
unsigned int pos = 0;
|
unsigned int pos = 0;
|
||||||
char *p;
|
char *p;
|
||||||
codec = switch_core_session_get_read_codec(session);
|
codec = switch_core_session_get_read_codec(session);
|
||||||
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "got codec\n");
|
|
||||||
if ((p = strchr(result, ':'))) {
|
if ((p = strchr(result, ':'))) {
|
||||||
p++;
|
p++;
|
||||||
if (*p == '+' || *p == '-') {
|
if (*p == '+' || *p == '-') {
|
||||||
int step;
|
int step;
|
||||||
|
int target;
|
||||||
if (!(step = atoi(p))) {
|
if (!(step = atoi(p))) {
|
||||||
step = 1000;
|
step = 1000;
|
||||||
}
|
}
|
||||||
if (step > 0) {
|
|
||||||
samps = step * (codec->implementation->samples_per_second / 1000);
|
samps = step * (codec->implementation->samples_per_second / 1000);
|
||||||
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "going to seek\n");
|
target = fhp->pos + samps;
|
||||||
switch_core_file_seek(fhp, &pos, samps, SEEK_CUR);
|
|
||||||
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "done seek\n");
|
if (target < 0) {
|
||||||
} else {
|
target = 0;
|
||||||
samps = step * (codec->implementation->samples_per_second / 1000);
|
|
||||||
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "going to seek\n");
|
|
||||||
switch_core_file_seek(fhp, &pos, fhp->pos - samps, SEEK_SET);
|
|
||||||
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "done seek\n");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "seek to position %d\n", target);
|
||||||
|
switch_core_file_seek(fhp, &pos, target, SEEK_SET);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
samps = atoi(p) * (codec->implementation->samples_per_second / 1000);
|
samps = atoi(p) * (codec->implementation->samples_per_second / 1000);
|
||||||
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "going to seek\n");
|
if (samps < 0) {
|
||||||
|
samps = 0;
|
||||||
|
}
|
||||||
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "seek to position %d\n", samps);
|
||||||
switch_core_file_seek(fhp, &pos, samps, SEEK_SET);
|
switch_core_file_seek(fhp, &pos, samps, SEEK_SET);
|
||||||
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "done seek\n");
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1340,11 +1325,9 @@ SWITCH_DECLARE(switch_status_t) CoreSession::process_callback_result(char *resul
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!strcmp(result, "true") || !strcmp(result, "undefined")) {
|
if (!strcmp(result, "true") || !strcmp(result, "undefined")) {
|
||||||
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "return success\n");
|
|
||||||
return SWITCH_STATUS_SUCCESS;
|
return SWITCH_STATUS_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "no callback result match for '%s', return false\n", result);
|
|
||||||
|
|
||||||
return SWITCH_STATUS_FALSE;
|
return SWITCH_STATUS_FALSE;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue