Kannel: Open Source WAP and SMS gateway
svn-r5336
wtp_resp.h
Go to the documentation of this file.
1
/* ====================================================================
2
* The Kannel Software License, Version 1.0
3
*
4
* Copyright (c) 2001-2018 Kannel Group
5
* Copyright (c) 1998-2001 WapIT Ltd.
6
* All rights reserved.
7
*
8
* Redistribution and use in source and binary forms, with or without
9
* modification, are permitted provided that the following conditions
10
* are met:
11
*
12
* 1. Redistributions of source code must retain the above copyright
13
* notice, this list of conditions and the following disclaimer.
14
*
15
* 2. Redistributions in binary form must reproduce the above copyright
16
* notice, this list of conditions and the following disclaimer in
17
* the documentation and/or other materials provided with the
18
* distribution.
19
*
20
* 3. The end-user documentation included with the redistribution,
21
* if any, must include the following acknowledgment:
22
* "This product includes software developed by the
23
* Kannel Group (http://www.kannel.org/)."
24
* Alternately, this acknowledgment may appear in the software itself,
25
* if and wherever such third-party acknowledgments normally appear.
26
*
27
* 4. The names "Kannel" and "Kannel Group" must not be used to
28
* endorse or promote products derived from this software without
29
* prior written permission. For written permission, please
30
* contact org@kannel.org.
31
*
32
* 5. Products derived from this software may not be called "Kannel",
33
* nor may "Kannel" appear in their name, without prior written
34
* permission of the Kannel Group.
35
*
36
* THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
37
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
38
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
39
* DISCLAIMED. IN NO EVENT SHALL THE KANNEL GROUP OR ITS CONTRIBUTORS
40
* BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,
41
* OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
42
* OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
43
* BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
44
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
45
* OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
46
* EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
47
* ====================================================================
48
*
49
* This software consists of voluntary contributions made by many
50
* individuals on behalf of the Kannel Group. For more information on
51
* the Kannel Group, please see <http://www.kannel.org/>.
52
*
53
* Portions of this software are based upon software originally written at
54
* WapIT Ltd., Helsinki, Finland for the Kannel project.
55
*/
56
57
/*
58
* WTP responder header
59
*
60
* Aarno Syvänen for Wapit Ltd
61
*/
62
63
#ifndef WTP_RESPONDER_H
64
#define WTP_RESPONDER_H
65
66
typedef
struct
WTPRespMachine
WTPRespMachine
;
67
68
#include "
gwlib/gwlib.h
"
69
#include "
wap_events.h
"
70
#include "
timers.h
"
71
72
typedef
struct
sar_info_t
{
73
int
sar_psn
;
74
Octstr
*
sar_data
;
75
}
sar_info_t
;
76
77
78
/*
79
* Structure to keep SAR data during transmission
80
*/
81
typedef
struct
WTPSARData
{
82
int
nsegm
;
/* number of the last segment, i.e. total number - 1 */
83
int
csegm
;
/* last segment confirmed by recipient */
84
int
lsegm
;
/* last sent segment */
85
int
tr
;
/* if current psn is gtr or ttr */
86
Octstr
*
data
;
87
}
WTPSARData
;
88
89
/*
90
* Maximum segment size. (Nokia WAP GW uses the size of 576,
91
* but mobiles use 1,5K size).
92
*/
93
#define SAR_SEGM_SIZE 1400
94
#define SAR_GROUP_LEN 3
95
96
97
/*
98
* Responder machine states and responder WTP machine.
99
* See file wtp_resp_state-decl.h for comments. Note that we must define macro
100
* ROW to produce an empty string.
101
*/
102
enum
resp_states
{
103
#define STATE_NAME(state) state,
104
#define ROW(state, event, condition, action, next_state)
105
#include "
wtp_resp_states.def
"
106
resp_states_count
107
};
108
109
typedef
enum
resp_states
resp_states
;
110
111
/*
112
* See files wtp_resp_machine-decl.h and for comments. We define one macro for
113
* every separate type.
114
*/
115
struct
WTPRespMachine
{
116
unsigned
long
mid
;
117
#define INTEGER(name) int name;
118
#define TIMER(name) Timer *name;
119
#define ADDRTUPLE(name) WAPAddrTuple *name;
120
#define ENUM(name) resp_states name;
121
#define EVENT(name) WAPEvent *name;
122
#define LIST(name) List *name;
123
#define SARDATA(name) WTPSARData *name;
124
#define MACHINE(field) field
125
#include "
wtp_resp_machine.def
"
126
};
127
128
#endif
resp_states
resp_states
Definition:
wtp_resp.h:102
gwlib.h
WTPRespMachine
Definition:
wtp_resp.h:115
sar_info_t::sar_data
Octstr * sar_data
Definition:
wtp_resp.h:74
WTPSARData
struct WTPSARData WTPSARData
WTPSARData::csegm
int csegm
Definition:
wtp_resp.h:83
WTPRespMachine::mid
unsigned long mid
Definition:
wtp_resp.h:116
WTPSARData::nsegm
int nsegm
Definition:
wtp_resp.h:82
WTPSARData::data
Octstr * data
Definition:
wtp_resp.h:86
wtp_resp_states.def
sar_info_t::sar_psn
int sar_psn
Definition:
wtp_resp.h:73
timers.h
Octstr
Definition:
octstr.c:118
WTPSARData::tr
int tr
Definition:
wtp_resp.h:85
wtp_resp_machine.def
sar_info_t
Definition:
wtp_resp.h:72
WTPSARData::lsegm
int lsegm
Definition:
wtp_resp.h:84
wap_events.h
WTPSARData
Definition:
wtp_resp.h:81
sar_info_t
struct sar_info_t sar_info_t
See file LICENSE for details about the license agreement for using, modifying, copying or deriving work from this software.