Kannel: Open Source WAP and SMS gateway  svn-r5335
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 
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;
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 */
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  */
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 
110 
111 /*
112  * See files wtp_resp_machine-decl.h and for comments. We define one macro for
113  * every separate type.
114  */
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
Definition: wtp_resp.h:102
Octstr * sar_data
Definition: wtp_resp.h:74
struct WTPSARData WTPSARData
int csegm
Definition: wtp_resp.h:83
unsigned long mid
Definition: wtp_resp.h:116
int nsegm
Definition: wtp_resp.h:82
Octstr * data
Definition: wtp_resp.h:86
int sar_psn
Definition: wtp_resp.h:73
Definition: octstr.c:118
int tr
Definition: wtp_resp.h:85
int lsegm
Definition: wtp_resp.h:84
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.