[sr-dev] git:master: core: new core event executed when a non sip packet is received
Daniel-Constantin Mierla
miconda at gmail.com
Fri Jul 18 17:01:09 CEST 2014
Module: sip-router
Branch: master
Commit: ac0bd3790b40a4788cea83542b99fe9dd08116bf
URL: http://git.sip-router.org/cgi-bin/gitweb.cgi/sip-router/?a=commit;h=ac0bd3790b40a4788cea83542b99fe9dd08116bf
Author: Daniel-Constantin Mierla <miconda at gmail.com>
Committer: Daniel-Constantin Mierla <miconda at gmail.com>
Date: Fri Jul 18 16:01:29 2014 +0200
core: new core event executed when a non sip packet is received
- event type SREV_RCV_NOSIP
---
events.c | 13 +++++++++++++
events.h | 3 ++-
2 files changed, 15 insertions(+), 1 deletions(-)
diff --git a/events.c b/events.c
index a22af75..7b7625f 100644
--- a/events.c
+++ b/events.c
@@ -152,6 +152,11 @@ int sr_event_register_cb(int type, sr_event_cb_f f)
_sr_events_list.stun_in = f;
else return -1;
break;
+ case SREV_RCV_NOSIP:
+ if(_sr_events_list.rcv_nosip==0)
+ _sr_events_list.rcv_nosip = f;
+ else return -1;
+ break;
default:
return -1;
}
@@ -255,6 +260,12 @@ int sr_event_exec(int type, void *data)
ret = _sr_events_list.stun_in(data);
return ret;
} else return 1;
+ case SREV_RCV_NOSIP:
+ if(unlikely(_sr_events_list.rcv_nosip!=0))
+ {
+ ret = _sr_events_list.rcv_nosip(data);
+ return ret;
+ } else return 1;
default:
return -1;
}
@@ -288,6 +299,8 @@ int sr_event_enabled(int type)
return (_sr_events_list.tcp_ws_frame_out!=0)?1:0;
case SREV_STUN_IN:
return (_sr_events_list.stun_in!=0)?1:0;
+ case SREV_RCV_NOSIP:
+ return (_sr_events_list.rcv_nosip!=0)?1:0;
}
return 0;
}
diff --git a/events.h b/events.h
index f3cb4bc..df001a7 100644
--- a/events.h
+++ b/events.h
@@ -28,7 +28,7 @@
#define SREV_CORE_STATS 3
#define SREV_CFG_RUN_ACTION 4
#define SREV_PKG_UPDATE_STATS 5
-/* 6 - not used anymore */
+#define SREV_RCV_NOSIP 6
#define SREV_NET_DGRAM_IN 7
#define SREV_TCP_HTTP_100C 8
#define SREV_TCP_MSRP_FRAME 9
@@ -51,6 +51,7 @@ typedef struct sr_event_cb {
sr_event_cb_f tcp_ws_frame_in;
sr_event_cb_f tcp_ws_frame_out;
sr_event_cb_f stun_in;
+ sr_event_cb_f rcv_nosip;
} sr_event_cb_t;
void sr_event_cb_init(void);
More information about the sr-dev
mailing list