summaryrefslogtreecommitdiff
path: root/orkaudio/audiocaptureplugins/voip/PacketHeaderDefs.h
diff options
context:
space:
mode:
authorGerald Begumisa <ben_g@users.sourceforge.net>2007-05-30 15:41:39 +0000
committerGerald Begumisa <ben_g@users.sourceforge.net>2007-05-30 15:41:39 +0000
commit87856bf5f56d2597209b7ed768f5096559e0587b (patch)
tree45defb5250e26cf766cf078ccfa7547febe70d26 /orkaudio/audiocaptureplugins/voip/PacketHeaderDefs.h
parenteff2a681b32a1947c44f80e6936e416a9c47c555 (diff)
Fix for correct Skinny on-hold handling. Now, only one recording is created when an endpoint goes on hold then returns.
git-svn-id: https://oreka.svn.sourceforge.net/svnroot/oreka/trunk@441 09dcff7a-b715-0410-9601-b79a96267cd0
Diffstat (limited to 'orkaudio/audiocaptureplugins/voip/PacketHeaderDefs.h')
-rw-r--r--orkaudio/audiocaptureplugins/voip/PacketHeaderDefs.h65
1 files changed, 65 insertions, 0 deletions
diff --git a/orkaudio/audiocaptureplugins/voip/PacketHeaderDefs.h b/orkaudio/audiocaptureplugins/voip/PacketHeaderDefs.h
index 9468c1f..982021c 100644
--- a/orkaudio/audiocaptureplugins/voip/PacketHeaderDefs.h
+++ b/orkaudio/audiocaptureplugins/voip/PacketHeaderDefs.h
@@ -185,6 +185,15 @@ typedef struct
bool SkinnyValidateOpenReceiveChannelAck(SkOpenReceiveChannelAckStruct *);
+typedef struct
+{
+ SkinnyHeaderStruct header;
+ unsigned long soft_key_event;
+ unsigned long line_instance;
+ unsigned long call_identifier;
+} SkSoftKeyEventMessageStruct;
+
+bool SkinnyValidateSoftKeyEvent(SkSoftKeyEventMessageStruct *);
#define SKINNY_CTRL_PORT 2000
#define SKINNY_MIN_MESSAGE_SIZE 12
@@ -198,6 +207,7 @@ bool SkinnyValidateOpenReceiveChannelAck(SkOpenReceiveChannelAckStruct *);
#define SKINNY_MSG_OPEN_RECEIVE_CHANNEL_ACK "OpenReceiveChannelAck"
#define SKINNY_MSG_LINE_STAT_MESSAGE "LineStatMessage"
#define SKINNY_MSG_CCM5_CALL_INFO_MESSAGE "Ccm5CallInfoMessage"
+#define SKINNY_MSG_SOFT_KEY_EVENT_MESSAGE "SoftKeyEventMessage"
#define SKINNY_CALL_TYPE_INBOUND 1
#define SKINNY_CALL_TYPE_OUTBOUND 2
@@ -212,11 +222,66 @@ typedef enum
SkLineStatMessage = 0x0092,
SkCloseReceiveChannel = 0x0106,
SkCcm5CallInfoMessage = 0x14A,
+ SkSoftKeyEventMessage = 0x0026,
SkUnkn = 0x0
} SkinnyMessageEnum;
int SkinnyMessageToEnum(CStdString& msg);
CStdString SkinnyMessageToString(int msgEnum);
+#define SKINNY_SOFTKEY_MAX_EVENT 18
+#define SKINNY_SOFTKEY_MIN_EVENT 1
+
+class SoftKeyEvent
+{
+public:
+#define SKINNY_SOFTKEY_REDIAL "Redial"
+#define SKINNY_SOFTKEY_NEWCALL "NewCall"
+#define SKINNY_SOFTKEY_HOLD "Hold"
+#define SKINNY_SOFTKEY_TRNSFER "Trnsfer"
+#define SKINNY_SOFTKEY_CFWDALL "CFwdAll"
+#define SKINNY_SOFTKEY_CFWDBUSY "CFwdBusy"
+#define SKINNY_SOFTKEY_CFWDNOANSWER "CFwdNoAnswer"
+#define SKINNY_SOFTKEY_BACKSPACE "BackSpace"
+#define SKINNY_SOFTKEY_ENDCALL "EndCall"
+#define SKINNY_SOFTKEY_RESUME "Resume"
+#define SKINNY_SOFTKEY_ANSWER "Answer"
+#define SKINNY_SOFTKEY_INFO "Info"
+#define SKINNY_SOFTKEY_CONFRN "Confrn"
+#define SKINNY_SOFTKEY_PARK "Park"
+#define SKINNY_SOFTKEY_JOIN "Join"
+#define SKINNY_SOFTKEY_MEETMECONFRN "MeetMeConfrn"
+#define SKINNY_SOFTKEY_CALLPICKUP "CallPickUp"
+#define SKINNY_SOFTKEY_GRPCALLPICKUP "GrpCallPickUp"
+#define SKINNY_SOFTKEY_UNKN "Unknown"
+
+ typedef enum {
+ SkSoftKeyRedial = 1,
+ SkSoftKeyNewCall = 2,
+ SkSoftKeyHold = 3,
+ SkSoftKeyTrnsfer = 4,
+ SkSoftKeyCFwdAll = 5,
+ SkSoftKeyCFwdBusy = 6,
+ SkSoftKeyCFwdNoAnswer = 7,
+ SkSoftKeyBackSpace = 8,
+ SkSoftKeyEndCall = 9,
+ SkSoftKeyResume = 10,
+ SkSoftKeyAnswer = 11,
+ SkSoftKeyInfo = 12,
+ SkSoftKeyConfrn = 13,
+ SkSoftKeyPark = 14,
+ SkSoftKeyJoin = 15,
+ SkSoftKeyMeetMeConfrn = 16,
+ SkSoftKeyCallPickUp = 17,
+ SkSoftKeyGrpCallPickUp = 18,
+ SkSoftKeyUnkn = 0
+ } SoftKeyEventEnum;
+
+ static int SoftKeyEventToEnum(CStdString& event);
+ static CStdString SoftKeyEventToString(int event);
+};
+
+
+//===================================================================
/*
* IAX2 Packet Headers
*/