Browse Source

core: added event callback field for tcp closed connection

Armen Babikyan 9 years ago
parent
commit
fa6465f92a
2 changed files with 15 additions and 0 deletions
  1. 13 0
      events.c
  2. 2 0
      events.h

+ 13 - 0
events.c

@@ -165,6 +165,11 @@ int sr_event_register_cb(int type, sr_event_cb_f f)
 					_sr_events_list.rcv_nosip = f;
 					_sr_events_list.rcv_nosip = f;
 				else return -1;
 				else return -1;
 			break;
 			break;
+		case SREV_TCP_CLOSED:
+				if(_sr_events_list.tcp_closed==0)
+					_sr_events_list.tcp_closed = f;
+				else return -1;
+			break;
 		default:
 		default:
 			return -1;
 			return -1;
 	}
 	}
@@ -284,6 +289,12 @@ int sr_event_exec(int type, void *data)
 					ret = _sr_events_list.rcv_nosip(data);
 					ret = _sr_events_list.rcv_nosip(data);
 					return ret;
 					return ret;
 				} else return 1;
 				} else return 1;
+		case SREV_TCP_CLOSED:
+				if(unlikely(_sr_events_list.tcp_closed!=0))
+				{
+					ret = _sr_events_list.tcp_closed(data);
+					return ret;
+				} else return 1;
 		default:
 		default:
 			return -1;
 			return -1;
 	}
 	}
@@ -319,6 +330,8 @@ int sr_event_enabled(int type)
 				return (_sr_events_list.stun_in!=0)?1:0;
 				return (_sr_events_list.stun_in!=0)?1:0;
 		case SREV_RCV_NOSIP:
 		case SREV_RCV_NOSIP:
 				return (_sr_events_list.rcv_nosip!=0)?1:0;
 				return (_sr_events_list.rcv_nosip!=0)?1:0;
+		case SREV_TCP_CLOSED:
+				return (_sr_events_list.tcp_closed!=0)?1:0;
 	}
 	}
 	return 0;
 	return 0;
 }
 }

+ 2 - 0
events.h

@@ -34,6 +34,7 @@
 #define SREV_TCP_WS_FRAME_IN		10
 #define SREV_TCP_WS_FRAME_IN		10
 #define SREV_TCP_WS_FRAME_OUT		11
 #define SREV_TCP_WS_FRAME_OUT		11
 #define SREV_STUN_IN			12
 #define SREV_STUN_IN			12
+#define SREV_TCP_CLOSED			13
 
 
 #define SREV_CB_LIST_SIZE	3
 #define SREV_CB_LIST_SIZE	3
 
 
@@ -52,6 +53,7 @@ typedef struct sr_event_cb {
 	sr_event_cb_f tcp_ws_frame_out;
 	sr_event_cb_f tcp_ws_frame_out;
 	sr_event_cb_f stun_in;
 	sr_event_cb_f stun_in;
 	sr_event_cb_f rcv_nosip;
 	sr_event_cb_f rcv_nosip;
+	sr_event_cb_f tcp_closed;
 } sr_event_cb_t;
 } sr_event_cb_t;
 
 
 void sr_event_cb_init(void);
 void sr_event_cb_init(void);