* ISO8859-* -> UTF_8
[olsrd.git] / lib / nameservice / src / nameservice_msg.h
1 /*
2  * Copyright (c) 2005, Bruno Randolf <bruno.randolf@4g-systems.biz>
3  * Copyright (c) 2004, Andreas T√łnnesen(andreto-at-olsr.org)
4  * All rights reserved.
5  *
6  * Redistribution and use in source and binary forms, with or without 
7  * modification, are permitted provided that the following conditions 
8  * are met:
9  *
10  * * Redistributions of source code must retain the above copyright notice, 
11  *   this list of conditions and the following disclaimer.
12  * * Redistributions in binary form must reproduce the above copyright notice, 
13  *   this list of conditions and the following disclaimer in the documentation 
14  *   and/or other materials provided with the distribution.
15  * * Neither the name of the UniK olsr daemon nor the names of its contributors 
16  *   may be used to endorse or promote products derived from this software 
17  *   without specific prior written permission.
18  *
19  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND 
20  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 
21  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 
22  * IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, 
23  * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 
24  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 
25  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY 
26  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE 
27  * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED 
28  * OF THE POSSIBILITY OF SUCH DAMAGE.
29  *
30  */
31
32 /* $Id: nameservice_msg.h,v 1.9 2007/11/29 18:09:10 bernd67 Exp $ */
33
34 /*
35  * Dynamic linked library for UniK OLSRd
36  */
37  
38 #ifndef _NAMESEVICE_MSG
39 #define _NAMESEVICE_MSG
40
41 /* type of the packet of name_entry */
42 typedef enum {
43         NAME_HOST = 0,
44         NAME_FORWARDER = 1,
45         NAME_SERVICE = 2,
46         NAME_LATLON = 3,
47 } NAME_TYPE;
48
49 /**
50  * the name, forwarder or service entry as found in a packet within a
51  * message
52  **/
53 struct name
54 {
55         olsr_u16_t              type;
56         olsr_u16_t              len;    // length of the name
57         // the ip of the hostname, or the ip of the dns-server
58         // ip is irrelevant for services
59         union olsr_ip_addr      ip;
60         /*
61          * name or service is written in plain text after this struct and padded to 4 byte
62          */
63 };
64
65
66 struct namemsg
67 {
68         olsr_u16_t version;    // version number of the nameservice plugin
69         olsr_u16_t nr_names;   // number of following packets including names, forwarders or services
70         /*
71          * at least one struct name following
72          */
73 };
74
75 #endif