File: msg_start.xml

package info (click to toggle)
kamailio 5.6.3-2
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 68,332 kB
  • sloc: ansic: 744,091; xml: 196,848; cpp: 14,471; makefile: 8,859; sh: 8,814; sql: 7,844; yacc: 3,863; perl: 2,955; python: 2,710; java: 449; javascript: 269; php: 258; ruby: 225; cs: 40; awk: 27
file content (114 lines) | stat: -rw-r--r-- 3,081 bytes parent folder | download | duplicates (7)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE section PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN" 
   "http://www.oasis-open.org/docbook/xml/4.2/docbookx.dtd">

<section id="msg_start" xmlns:xi="http://www.w3.org/2001/XInclude">
    <sectioninfo>
	<revhistory>
	    <revision>
		<revnumber>$Revision$</revnumber>
		<date>$Date$</date>
	    </revision>
	</revhistory>
    </sectioninfo>

    <title>Structure <structname>msg_start</structname></title>
    <para>
	The structure represents the first line of a <acronym>SIP</acronym>
	request or response.
    </para>
    <para>
	The structure is defined in file <filename>parse_fline.h</filename>
	under <filename>parser</filename> subdirectory.
    </para>
    
    <para>
	<emphasis>Structure Declaration</emphasis>
	<programlisting>
struct msg_start {
    int type;                        /* Type of the Message - Request/Response */
    union {
        struct {
            str method;              /* Method string */
            str uri;                 /* Request URI */
            str version;             /* SIP version */
            int method_value;        /* Parsed method */
        } request;

        struct {
            str version;             /* SIP version */
            str status;              /* Reply status */
            str reason;              /* Reply reason phrase */
            unsigned int statuscode; /* Status code */
        } reply;
    }u;
};
	</programlisting>
    </para>
    <para>
	<emphasis>Description of Request Related Fields:</emphasis>
	<itemizedlist>
	    <listitem>
		<para>
		    <structfield>type</structfield> - Type of the message -
		    REQUEST or RESPONSE.
		</para>
	    </listitem>
	    <listitem>
		<para>
		    <structfield>method</structfield> - Name of method (same as
		    in the message).
		</para>
	    </listitem>
	    <listitem>
		<para>
		    <structfield>uri</structfield> - Request <acronym>URI</acronym>.
		</para>
	    </listitem>
	    <listitem>
		<para>
		    <structfield>version</structfield> - Version string.
		</para>
	    </listitem>
	    <listitem>
		<para>
		    <structfield>method_value</structfield> - Parsed
		    method. Field method which is of type <type>str</type> will
		    be converted to integer and stored here. This is good for
		    comparison, integer comparison is much faster then string
		    comparison.
		</para>
	    </listitem>
	</itemizedlist>
    </para>

    <para>
	<emphasis>Description of Response Related Fields:</emphasis>
	<itemizedlist>
	    <listitem>
		<para>
		    <structfield>version</structfield> - Version string.
		</para>
	    </listitem>
	    <listitem>
		<para>
		    <structfield>status</structfield> - Response status code as
		    string.
		</para>
	    </listitem>
	    <listitem>
		<para>
		    <structfield>reason</structfield> - Response reason string
		    as in the message.
		</para>
	    </listitem>
	    <listitem>
		<para>
		    <structfield>statuscode</structfield> - Response status
		    code converted to integer.
		</para>
	    </listitem>
	</itemizedlist>
    </para>
</section>