Kannel: Open Source WAP and SMS gateway
svn-r5336
wap_push_pap_mime.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
* wap_push_pap_mime.h: Header for a (gateway oriented) mime parser for pap
59
* module. This parser conforms proxy rules set in Push Message, chapter 7.
60
* (Headers are passed as they are)
61
*
62
* By Aarno Syvänen for Wapit Ltd
63
*/
64
65
#ifndef WAP_PUSH_PAP_MIME_H
66
#define WAP_PUSH_PAP_MIME_H
67
68
#include "
gwlib/gwlib.h
"
69
70
/*
71
* Implementation of the external function, PAP uses MIME type multipart/
72
* related to communicate a push message and related control information from
73
* pi to ppg. Mime_parse separates parts of message and in addition returns
74
* MIME-part-headers of the content entity. Preamble and epilogue of are dis-
75
* carded from control messages, but not from a multipart content entity.
76
* Multipart/related content type is defined in rfc 2046, chapters 5.1, 5.1.1,
77
* and 5.1.7. Grammar is capitulated in rfc 2046 appendix A and in rfc 822,
78
* appendix D. Functions called by mime_parse remove parsed parts from the mime
79
* content.
80
* Input: pointer to mime boundary and mime content
81
* Output: in all cases, pointer to pap control document and push data. If
82
* there is a capabilities document, pointer to this is returned, too. If there
83
* is none, pointer to NULL instead.
84
* In addition, return 1 if parsing was succesfull, 0 otherwise.
85
*/
86
87
int
mime_parse
(
Octstr
*
boundary
,
Octstr
*mime_content,
Octstr
**pap_content,
88
Octstr
**
push_data
,
List
**content_headers,
89
Octstr
**rdf_content);
90
91
#endif
gwlib.h
push_data
static char ** push_data
Definition:
test_ppg.c:96
boundary
static char * boundary
Definition:
test_ppg.c:97
mime_parse
int mime_parse(Octstr *boundary, Octstr *mime_content, Octstr **pap_content, Octstr **push_data, List **content_headers, Octstr **rdf_content)
Definition:
wap_push_pap_mime.c:131
Octstr
Definition:
octstr.c:118
List
Definition:
list.c:102
See file LICENSE for details about the license agreement for using, modifying, copying or deriving work from this software.