chiark / gitweb /
6c0084c477b6fbe34d7988fc46690243edd60164
[elogind.git] / src / core / socket.h
1 /*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
2
3 #pragma once
4
5 /***
6   This file is part of systemd.
7
8   Copyright 2010 Lennart Poettering
9
10   systemd is free software; you can redistribute it and/or modify it
11   under the terms of the GNU Lesser General Public License as published by
12   the Free Software Foundation; either version 2.1 of the License, or
13   (at your option) any later version.
14
15   systemd is distributed in the hope that it will be useful, but
16   WITHOUT ANY WARRANTY; without even the implied warranty of
17   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
18   Lesser General Public License for more details.
19
20   You should have received a copy of the GNU Lesser General Public License
21   along with systemd; If not, see <http://www.gnu.org/licenses/>.
22 ***/
23
24 typedef struct Socket Socket;
25
26 #include "manager.h"
27 #include "unit.h"
28 #include "socket-util.h"
29 #include "mount.h"
30 #include "service.h"
31
32 typedef enum SocketState {
33         SOCKET_DEAD,
34         SOCKET_START_PRE,
35         SOCKET_START_CHOWN,
36         SOCKET_START_POST,
37         SOCKET_LISTENING,
38         SOCKET_RUNNING,
39         SOCKET_STOP_PRE,
40         SOCKET_STOP_PRE_SIGTERM,
41         SOCKET_STOP_PRE_SIGKILL,
42         SOCKET_STOP_POST,
43         SOCKET_FINAL_SIGTERM,
44         SOCKET_FINAL_SIGKILL,
45         SOCKET_FAILED,
46         _SOCKET_STATE_MAX,
47         _SOCKET_STATE_INVALID = -1
48 } SocketState;
49
50 typedef enum SocketExecCommand {
51         SOCKET_EXEC_START_PRE,
52         SOCKET_EXEC_START_CHOWN,
53         SOCKET_EXEC_START_POST,
54         SOCKET_EXEC_STOP_PRE,
55         SOCKET_EXEC_STOP_POST,
56         _SOCKET_EXEC_COMMAND_MAX,
57         _SOCKET_EXEC_COMMAND_INVALID = -1
58 } SocketExecCommand;
59
60 typedef enum SocketType {
61         SOCKET_SOCKET,
62         SOCKET_FIFO,
63         SOCKET_SPECIAL,
64         SOCKET_MQUEUE,
65         _SOCKET_FIFO_MAX,
66         _SOCKET_FIFO_INVALID = -1
67 } SocketType;
68
69 typedef enum SocketResult {
70         SOCKET_SUCCESS,
71         SOCKET_FAILURE_RESOURCES,
72         SOCKET_FAILURE_TIMEOUT,
73         SOCKET_FAILURE_EXIT_CODE,
74         SOCKET_FAILURE_SIGNAL,
75         SOCKET_FAILURE_CORE_DUMP,
76         SOCKET_FAILURE_SERVICE_FAILED_PERMANENT,
77         _SOCKET_RESULT_MAX,
78         _SOCKET_RESULT_INVALID = -1
79 } SocketResult;
80
81 typedef struct SocketPort {
82         Socket *socket;
83
84         SocketType type;
85         int fd;
86
87         SocketAddress address;
88         char *path;
89         sd_event_source *event_source;
90
91         LIST_FIELDS(struct SocketPort, port);
92 } SocketPort;
93
94 struct Socket {
95         Unit meta;
96
97         LIST_HEAD(SocketPort, ports);
98
99         unsigned n_accepted;
100         unsigned n_connections;
101         unsigned max_connections;
102
103         unsigned backlog;
104         usec_t timeout_usec;
105
106         ExecCommand* exec_command[_SOCKET_EXEC_COMMAND_MAX];
107         ExecContext exec_context;
108         KillContext kill_context;
109         CGroupContext cgroup_context;
110         ExecRuntime *exec_runtime;
111
112         /* For Accept=no sockets refers to the one service we'll
113         activate. For Accept=yes sockets is either NULL, or filled
114         when the next service we spawn. */
115         UnitRef service;
116
117         SocketState state, deserialized_state;
118
119         sd_event_source *timer_event_source;
120
121         ExecCommand* control_command;
122         SocketExecCommand control_command_id;
123         pid_t control_pid;
124
125         mode_t directory_mode;
126         mode_t socket_mode;
127
128         SocketResult result;
129
130         char **symlinks;
131
132         bool accept;
133         bool remove_on_stop;
134
135         /* Socket options */
136         bool keep_alive;
137         bool no_delay;
138         bool fast_open;
139         bool free_bind;
140         bool transparent;
141         bool broadcast;
142         bool pass_cred;
143         bool pass_sec;
144
145         /* Only for INET6 sockets: issue IPV6_V6ONLY sockopt */
146         SocketAddressBindIPv6Only bind_ipv6_only;
147
148         int priority;
149         int mark;
150         size_t receive_buffer;
151         size_t send_buffer;
152         int ip_tos;
153         int ip_ttl;
154         size_t pipe_size;
155         char *bind_to_device;
156         char *tcp_congestion;
157         bool reuse_port;
158         long mq_maxmsg;
159         long mq_msgsize;
160
161         char *smack;
162         char *smack_ip_in;
163         char *smack_ip_out;
164
165         char *user, *group;
166 };
167
168 /* Called from the service code when collecting fds */
169 int socket_collect_fds(Socket *s, int **fds, unsigned *n_fds);
170
171 /* Called from the service code when a per-connection service ended */
172 void socket_connection_unref(Socket *s);
173
174 void socket_free_ports(Socket *s);
175
176 extern const UnitVTable socket_vtable;
177
178 const char* socket_state_to_string(SocketState i) _const_;
179 SocketState socket_state_from_string(const char *s) _pure_;
180
181 const char* socket_exec_command_to_string(SocketExecCommand i) _const_;
182 SocketExecCommand socket_exec_command_from_string(const char *s) _pure_;
183
184 const char* socket_result_to_string(SocketResult i) _const_;
185 SocketResult socket_result_from_string(const char *s) _pure_;
186
187 const char* socket_port_type_to_string(SocketPort *p) _pure_;
188
189 int socket_instantiate_service(Socket *s);