chiark / gitweb /
core: convert PID 1 to libsystemd-bus
[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_POST,
36         SOCKET_LISTENING,
37         SOCKET_RUNNING,
38         SOCKET_STOP_PRE,
39         SOCKET_STOP_PRE_SIGTERM,
40         SOCKET_STOP_PRE_SIGKILL,
41         SOCKET_STOP_POST,
42         SOCKET_FINAL_SIGTERM,
43         SOCKET_FINAL_SIGKILL,
44         SOCKET_FAILED,
45         _SOCKET_STATE_MAX,
46         _SOCKET_STATE_INVALID = -1
47 } SocketState;
48
49 typedef enum SocketExecCommand {
50         SOCKET_EXEC_START_PRE,
51         SOCKET_EXEC_START_POST,
52         SOCKET_EXEC_STOP_PRE,
53         SOCKET_EXEC_STOP_POST,
54         _SOCKET_EXEC_COMMAND_MAX,
55         _SOCKET_EXEC_COMMAND_INVALID = -1
56 } SocketExecCommand;
57
58 typedef enum SocketType {
59         SOCKET_SOCKET,
60         SOCKET_FIFO,
61         SOCKET_SPECIAL,
62         SOCKET_MQUEUE,
63         _SOCKET_FIFO_MAX,
64         _SOCKET_FIFO_INVALID = -1
65 } SocketType;
66
67 typedef enum SocketResult {
68         SOCKET_SUCCESS,
69         SOCKET_FAILURE_RESOURCES,
70         SOCKET_FAILURE_TIMEOUT,
71         SOCKET_FAILURE_EXIT_CODE,
72         SOCKET_FAILURE_SIGNAL,
73         SOCKET_FAILURE_CORE_DUMP,
74         SOCKET_FAILURE_SERVICE_FAILED_PERMANENT,
75         _SOCKET_RESULT_MAX,
76         _SOCKET_RESULT_INVALID = -1
77 } SocketResult;
78
79 typedef struct SocketPort {
80         Socket *socket;
81
82         SocketType type;
83         int fd;
84
85         SocketAddress address;
86         char *path;
87         sd_event_source *event_source;
88
89         LIST_FIELDS(struct SocketPort, port);
90 } SocketPort;
91
92 struct Socket {
93         Unit meta;
94
95         LIST_HEAD(SocketPort, ports);
96
97         unsigned n_accepted;
98         unsigned n_connections;
99         unsigned max_connections;
100
101         unsigned backlog;
102         usec_t timeout_usec;
103
104         ExecCommand* exec_command[_SOCKET_EXEC_COMMAND_MAX];
105         ExecContext exec_context;
106         KillContext kill_context;
107         CGroupContext cgroup_context;
108
109         /* For Accept=no sockets refers to the one service we'll
110         activate. For Accept=yes sockets is either NULL, or filled
111         when the next service we spawn. */
112         UnitRef service;
113
114         SocketState state, deserialized_state;
115
116         sd_event_source *timer_event_source;
117
118         ExecCommand* control_command;
119         SocketExecCommand control_command_id;
120         pid_t control_pid;
121
122         mode_t directory_mode;
123         mode_t socket_mode;
124
125         SocketResult result;
126
127         bool accept;
128
129         /* Socket options */
130         bool keep_alive;
131         bool free_bind;
132         bool transparent;
133         bool broadcast;
134         bool pass_cred;
135         bool pass_sec;
136
137         /* Only for INET6 sockets: issue IPV6_V6ONLY sockopt */
138         SocketAddressBindIPv6Only bind_ipv6_only;
139
140         int priority;
141         int mark;
142         size_t receive_buffer;
143         size_t send_buffer;
144         int ip_tos;
145         int ip_ttl;
146         size_t pipe_size;
147         char *bind_to_device;
148         char *tcp_congestion;
149         bool reuse_port;
150         long mq_maxmsg;
151         long mq_msgsize;
152
153         char *smack;
154         char *smack_ip_in;
155         char *smack_ip_out;
156 };
157
158 /* Called from the service code when collecting fds */
159 int socket_collect_fds(Socket *s, int **fds, unsigned *n_fds);
160
161 /* Called from the service code when a per-connection service ended */
162 void socket_connection_unref(Socket *s);
163
164 void socket_free_ports(Socket *s);
165
166 extern const UnitVTable socket_vtable;
167
168 const char* socket_state_to_string(SocketState i) _const_;
169 SocketState socket_state_from_string(const char *s) _pure_;
170
171 const char* socket_exec_command_to_string(SocketExecCommand i) _const_;
172 SocketExecCommand socket_exec_command_from_string(const char *s) _pure_;
173
174 const char* socket_result_to_string(SocketResult i) _const_;
175 SocketResult socket_result_from_string(const char *s) _pure_;
176
177 const char* socket_port_type_to_string(SocketPort *p) _pure_;