]> git.ipfire.org Git - thirdparty/systemd.git/blame - src/socket.h
man: Clarify man page with respect to automatic fstab dependencies
[thirdparty/systemd.git] / src / socket.h
CommitLineData
03467c88 1/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
5cb5a6ff
LP
2
3#ifndef foosockethfoo
4#define foosockethfoo
5
a7334b09
LP
6/***
7 This file is part of systemd.
8
9 Copyright 2010 Lennart Poettering
10
11 systemd is free software; you can redistribute it and/or modify it
12 under the terms of the GNU General Public License as published by
13 the Free Software Foundation; either version 2 of the License, or
14 (at your option) any later version.
15
16 systemd is distributed in the hope that it will be useful, but
17 WITHOUT ANY WARRANTY; without even the implied warranty of
18 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
19 General Public License for more details.
20
21 You should have received a copy of the GNU General Public License
22 along with systemd; If not, see <http://www.gnu.org/licenses/>.
23***/
24
5cb5a6ff
LP
25typedef struct Socket Socket;
26
acbb0225 27#include "manager.h"
87f0e418 28#include "unit.h"
542563ba 29#include "socket-util.h"
6e2ef85b 30#include "mount.h"
57020a3a 31#include "service.h"
5cb5a6ff
LP
32
33typedef enum SocketState {
34 SOCKET_DEAD,
35 SOCKET_START_PRE,
36 SOCKET_START_POST,
37 SOCKET_LISTENING,
38 SOCKET_RUNNING,
39 SOCKET_STOP_PRE,
034c6ed7
LP
40 SOCKET_STOP_PRE_SIGTERM,
41 SOCKET_STOP_PRE_SIGKILL,
5cb5a6ff 42 SOCKET_STOP_POST,
80876c20
LP
43 SOCKET_FINAL_SIGTERM,
44 SOCKET_FINAL_SIGKILL,
fdf20a31 45 SOCKET_FAILED,
e537352b
LP
46 _SOCKET_STATE_MAX,
47 _SOCKET_STATE_INVALID = -1
5cb5a6ff
LP
48} SocketState;
49
50typedef enum SocketExecCommand {
51 SOCKET_EXEC_START_PRE,
52 SOCKET_EXEC_START_POST,
53 SOCKET_EXEC_STOP_PRE,
54 SOCKET_EXEC_STOP_POST,
e537352b
LP
55 _SOCKET_EXEC_COMMAND_MAX,
56 _SOCKET_EXEC_COMMAND_INVALID = -1
5cb5a6ff
LP
57} SocketExecCommand;
58
542563ba
LP
59typedef enum SocketType {
60 SOCKET_SOCKET,
e537352b 61 SOCKET_FIFO,
b0a3f2bc 62 SOCKET_SPECIAL,
916abb21 63 SOCKET_MQUEUE,
e537352b
LP
64 _SOCKET_FIFO_MAX,
65 _SOCKET_FIFO_INVALID = -1
542563ba
LP
66} SocketType;
67
cfc4eb4c
LP
68typedef enum SocketResult {
69 SOCKET_SUCCESS,
70 SOCKET_FAILURE_RESOURCES,
71 SOCKET_FAILURE_TIMEOUT,
72 SOCKET_FAILURE_EXIT_CODE,
73 SOCKET_FAILURE_SIGNAL,
74 SOCKET_FAILURE_CORE_DUMP,
75 _SOCKET_RESULT_MAX,
76 _SOCKET_RESULT_INVALID = -1
77} SocketResult;
78
01f78473 79typedef struct SocketPort {
542563ba 80 SocketType type;
9d58f1db 81 int fd;
542563ba
LP
82
83 SocketAddress address;
84 char *path;
acbb0225 85 Watch fd_watch;
542563ba 86
01f78473
LP
87 LIST_FIELDS(struct SocketPort, port);
88} SocketPort;
542563ba 89
5cb5a6ff 90struct Socket {
ac155bb8 91 Unit meta;
5cb5a6ff 92
542563ba
LP
93 LIST_HEAD(SocketPort, ports);
94
7fab9d01
LP
95 unsigned n_accepted;
96 unsigned n_connections;
97 unsigned max_connections;
98
542563ba 99 unsigned backlog;
034c6ed7
LP
100 usec_t timeout_usec;
101
e537352b 102 ExecCommand* exec_command[_SOCKET_EXEC_COMMAND_MAX];
5cb5a6ff
LP
103 ExecContext exec_context;
104
b15bdda8
LP
105 /* For Accept=no sockets refers to the one service we'll
106 activate. For Accept=yes sockets is either NULL, or filled
107 when the next service we spawn. */
57020a3a 108 UnitRef service;
034c6ed7 109
a16e1123 110 SocketState state, deserialized_state;
034c6ed7 111
7fab9d01
LP
112 Watch timer_watch;
113
034c6ed7 114 ExecCommand* control_command;
a16e1123 115 SocketExecCommand control_command_id;
5cb5a6ff
LP
116 pid_t control_pid;
117
7fab9d01
LP
118 mode_t directory_mode;
119 mode_t socket_mode;
4f2d528d 120
cfc4eb4c 121 SocketResult result;
7fab9d01
LP
122
123 bool accept;
4fd5948e
LP
124
125 /* Socket options */
126 bool keep_alive;
7fab9d01 127 bool free_bind;
6b6d2dee 128 bool transparent;
ec6370a2 129 bool broadcast;
d68af586 130 bool pass_cred;
4fd5948e 131 int priority;
7fab9d01 132 int mark;
4fd5948e
LP
133 size_t receive_buffer;
134 size_t send_buffer;
135 int ip_tos;
136 int ip_ttl;
137 size_t pipe_size;
4fd5948e 138 char *bind_to_device;
cebf8b20 139 char *tcp_congestion;
916abb21
LP
140 long mq_maxmsg;
141 long mq_msgsize;
57020a3a
LP
142
143 /* Only for INET6 sockets: issue IPV6_V6ONLY sockopt */
144 SocketAddressBindIPv6Only bind_ipv6_only;
5cb5a6ff
LP
145};
146
44d8db9e
LP
147/* Called from the service code when collecting fds */
148int socket_collect_fds(Socket *s, int **fds, unsigned *n_fds);
149
ceee3d82
LP
150/* Called from the service when it shut down */
151void socket_notify_service_dead(Socket *s);
152
6e2ef85b
LP
153/* Called from the mount code figure out if a mount is a dependency of
154 * any of the sockets of this socket */
155int socket_add_one_mount_link(Socket *s, Mount *m);
156
6cf6bbc2
LP
157/* Called from the service code when a per-connection service ended */
158void socket_connection_unref(Socket *s);
159
87f0e418 160extern const UnitVTable socket_vtable;
5cb5a6ff 161
a16e1123
LP
162const char* socket_state_to_string(SocketState i);
163SocketState socket_state_from_string(const char *s);
164
165const char* socket_exec_command_to_string(SocketExecCommand i);
166SocketExecCommand socket_exec_command_from_string(const char *s);
167
cfc4eb4c
LP
168const char* socket_result_to_string(SocketResult i);
169SocketResult socket_result_from_string(const char *s);
170
5cb5a6ff 171#endif