blob: 6c59ce10af9647697fa27fedc2a212ca8a8a87ce [file] [log] [blame]
Willy Tarreaudd815982007-10-16 12:25:14 +02001/*
2 include/types/protocols.h
3 This file defines the structures used by generic network protocols.
4
5 Copyright (C) 2000-2007 Willy Tarreau - w@1wt.eu
6
7 This library is free software; you can redistribute it and/or
8 modify it under the terms of the GNU Lesser General Public
9 License as published by the Free Software Foundation, version 2.1
10 exclusively.
11
12 This library is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 Lesser General Public License for more details.
16
17 You should have received a copy of the GNU Lesser General Public
18 License along with this library; if not, write to the Free Software
19 Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20*/
21
22#ifndef _TYPES_PROTOCOLS_H
23#define _TYPES_PROTOCOLS_H
24
25#include <sys/types.h>
26#include <sys/socket.h>
Willy Tarreaue6ad2b12007-10-18 12:45:54 +020027#include <sys/stat.h>
28#include <sys/un.h>
Willy Tarreaudd815982007-10-16 12:25:14 +020029
30#include <common/config.h>
31#include <common/mini-clist.h>
32
33/* max length of a protcol name, including trailing zero */
34#define PROTO_NAME_LEN 16
35
Willy Tarreaudd815982007-10-16 12:25:14 +020036/* listener state */
37#define LI_NEW 0 /* not initialized yet */
Willy Tarreaudabf2e22007-10-28 21:59:24 +010038#define LI_INIT 1 /* all parameters filled in, but not assigned yet */
39#define LI_ASSIGNED 2 /* assigned to the protocol, but not listening yet */
40#define LI_LISTEN 3 /* started, listening but not enabled */
41#define LI_READY 4 /* started, listening and enabled */
42#define LI_FULL 5 /* reached its connection limit */
43
44/* Listener transitions
45 * calloc() set() add_listener() bind()
46 * -------> NEW ----> INIT ----------> ASSIGNED -----> LISTEN
47 * <------- <---- <---------- <-----
48 * free() bzero() del_listener() unbind()
49 *
50 * The file descriptor is valid only during these three states :
51 *
52 * disable()
53 * LISTEN <------------ READY
54 * A| ------------> |A
55 * || !max & enable() ||
56 * || ||
57 * || max ||
58 * || max & enable() V| !max
59 * |+---------------> FULL
60 * +-----------------
61 * disable()
62 *
63 */
Willy Tarreaudd815982007-10-16 12:25:14 +020064
Willy Tarreau6fb42e02007-10-28 17:02:33 +010065/* listener socket options */
66#define LI_O_NONE 0x0000
67#define LI_O_NOLINGER 0x0001 /* disable linger on this socket */
68
Willy Tarreaudd815982007-10-16 12:25:14 +020069/* The listener will be directly referenced by the fdtab[] which holds its
70 * socket. The listener provides the protocol-specific accept() function to
71 * the fdtab.
72 */
73struct listener {
74 int fd; /* the listen socket */
Willy Tarreaudabf2e22007-10-28 21:59:24 +010075 int state; /* state: NEW, INIT, ASSIGNED, LISTEN, READY, FULL */
Willy Tarreau6fb42e02007-10-28 17:02:33 +010076 int options; /* socket options : LI_O_* */
Willy Tarreaudd815982007-10-16 12:25:14 +020077 struct sockaddr_storage addr; /* the address we listen to */
78 struct protocol *proto; /* protocol this listener belongs to */
79 int nbconn; /* current number of connections on this listener */
80 int maxconn; /* maximum connections allowed on this listener */
81 struct listener *next; /* next address for the same proxy, or NULL */
82 struct list proto_list; /* list in the protocol header */
83 int (*accept)(int fd); /* accept() function passed to fdtab[] */
84 void (*handler)(struct task *t, struct timeval *next); /* protocol handler */
85 struct timeval *timeout; /* pointer to client-side timeout */
86 void *private; /* any private data which may be used by accept() */
Willy Tarreaue6ad2b12007-10-18 12:45:54 +020087 union { /* protocol-dependant access restrictions */
88 struct { /* UNIX socket permissions */
89 uid_t uid; /* -1 to leave unchanged */
90 gid_t gid; /* -1 to leave unchanged */
91 mode_t mode; /* 0 to leave unchanged */
92 } ux;
93 } perm;
Willy Tarreaudd815982007-10-16 12:25:14 +020094};
95
96/* This structure contains all information needed to easily handle a protocol.
97 * Its primary goal is to ease listeners maintenance. Specifically, the
98 * bind_all() primitive must be used before any fork(), and the enable_all()
99 * primitive must be called after the fork() to enable all fds. Last, the
100 * unbind_all() primitive closes all listeners.
101 */
102struct protocol {
103 char name[PROTO_NAME_LEN]; /* protocol name, zero-terminated */
104 int sock_domain; /* socket domain, as passed to socket() */
105 int sock_type; /* socket type, as passed to socket() */
106 int sock_prot; /* socket protocol, as passed to socket() */
107 sa_family_t sock_family; /* socket family, for sockaddr */
Willy Tarreau106bf272007-10-28 12:09:45 +0100108 socklen_t sock_addrlen; /* socket address length, used by bind() */
109 int l3_addrlen; /* layer3 address length, used by hashes */
Willy Tarreaudd815982007-10-16 12:25:14 +0200110 int (*read)(int fd); /* generic read function */
111 int (*write)(int fd); /* generic write function */
112 int (*bind_all)(struct protocol *proto); /* bind all unbound listeners */
113 int (*unbind_all)(struct protocol *proto); /* unbind all bound listeners */
114 int (*enable_all)(struct protocol *proto); /* enable all bound listeners */
Willy Tarreaudabf2e22007-10-28 21:59:24 +0100115 int (*disable_all)(struct protocol *proto); /* disable all bound listeners */
Willy Tarreaudd815982007-10-16 12:25:14 +0200116 struct list listeners; /* list of listeners using this protocol */
117 int nb_listeners; /* number of listeners */
118 struct list list; /* list of registered protocols */
119};
120
121#endif /* _TYPES_PROTOCOLS_H */
122
123/*
124 * Local variables:
125 * c-indent-level: 8
126 * c-basic-offset: 8
127 * End:
128 */