]> git.ipfire.org Git - thirdparty/systemd.git/blame - src/core/socket.h
ci: re-enable uefi secure boot
[thirdparty/systemd.git] / src / core / socket.h
CommitLineData
db9ecf05 1/* SPDX-License-Identifier: LGPL-2.1-or-later */
c2f1db8f 2#pragma once
5cb5a6ff 3
836e4e7e
DDM
4#include "cgroup.h"
5#include "core-forward.h"
6#include "execute.h"
7#include "list.h"
43a19142 8#include "pidref.h"
71d35b6b 9#include "socket-util.h"
57b7a260 10#include "unit.h"
5cb5a6ff 11
5cb5a6ff
LP
12typedef enum SocketExecCommand {
13 SOCKET_EXEC_START_PRE,
3900e5fd 14 SOCKET_EXEC_START_CHOWN,
5cb5a6ff
LP
15 SOCKET_EXEC_START_POST,
16 SOCKET_EXEC_STOP_PRE,
17 SOCKET_EXEC_STOP_POST,
e537352b 18 _SOCKET_EXEC_COMMAND_MAX,
2d93c20e 19 _SOCKET_EXEC_COMMAND_INVALID = -EINVAL,
5cb5a6ff
LP
20} SocketExecCommand;
21
542563ba
LP
22typedef enum SocketType {
23 SOCKET_SOCKET,
e537352b 24 SOCKET_FIFO,
b0a3f2bc 25 SOCKET_SPECIAL,
916abb21 26 SOCKET_MQUEUE,
60252446 27 SOCKET_USB_FUNCTION,
038ed5a4 28 _SOCKET_TYPE_MAX,
2d93c20e 29 _SOCKET_TYPE_INVALID = -EINVAL,
542563ba
LP
30} SocketType;
31
cfc4eb4c
LP
32typedef enum SocketResult {
33 SOCKET_SUCCESS,
34 SOCKET_FAILURE_RESOURCES,
35 SOCKET_FAILURE_TIMEOUT,
36 SOCKET_FAILURE_EXIT_CODE,
37 SOCKET_FAILURE_SIGNAL,
38 SOCKET_FAILURE_CORE_DUMP,
07299350 39 SOCKET_FAILURE_START_LIMIT_HIT,
8b26cdbd 40 SOCKET_FAILURE_TRIGGER_LIMIT_HIT,
6bf0f408 41 SOCKET_FAILURE_SERVICE_START_LIMIT_HIT,
cfc4eb4c 42 _SOCKET_RESULT_MAX,
2d93c20e 43 _SOCKET_RESULT_INVALID = -EINVAL,
cfc4eb4c
LP
44} SocketResult;
45
01f78473 46typedef struct SocketPort {
718db961
LP
47 Socket *socket;
48
542563ba 49 SocketType type;
9d58f1db 50 int fd;
15087cdb 51 int *auxiliary_fds;
da6053d0 52 size_t n_auxiliary_fds;
542563ba
LP
53
54 SocketAddress address;
55 char *path;
718db961 56 sd_event_source *event_source;
542563ba 57
01f78473
LP
58 LIST_FIELDS(struct SocketPort, port);
59} SocketPort;
542563ba 60
9b191525
LP
61typedef enum SocketTimestamping {
62 SOCKET_TIMESTAMPING_OFF,
63 SOCKET_TIMESTAMPING_US, /* SO_TIMESTAMP */
64 SOCKET_TIMESTAMPING_NS, /* SO_TIMESTAMPNS */
65 _SOCKET_TIMESTAMPING_MAX,
2d93c20e 66 _SOCKET_TIMESTAMPING_INVALID = -EINVAL,
9b191525
LP
67} SocketTimestamping;
68
1b4ab5a2
MY
69typedef enum SocketDeferTrigger {
70 SOCKET_DEFER_NO,
71 SOCKET_DEFER_YES,
72 SOCKET_DEFER_PATIENT,
73 _SOCKET_DEFER_MAX,
74 _SOCKET_DEFER_INVALID = -EINVAL,
75} SocketDeferTrigger;
76
836e4e7e 77typedef struct Socket {
ac155bb8 78 Unit meta;
5cb5a6ff 79
542563ba
LP
80 LIST_HEAD(SocketPort, ports);
81
9a73653c 82 Set *peers_by_address;
9d565427 83
7fab9d01
LP
84 unsigned n_accepted;
85 unsigned n_connections;
a98f7575 86 unsigned n_refused;
7fab9d01 87 unsigned max_connections;
9d565427 88 unsigned max_connections_per_source;
7fab9d01 89
542563ba 90 unsigned backlog;
209e9dcd 91 unsigned keep_alive_cnt;
034c6ed7 92 usec_t timeout_usec;
209e9dcd
SS
93 usec_t keep_alive_time;
94 usec_t keep_alive_interval;
cc567c9b 95 usec_t defer_accept;
034c6ed7 96
b36ab0d4 97 ExecCommand *exec_command[_SOCKET_EXEC_COMMAND_MAX];
5cb5a6ff 98 ExecContext exec_context;
4819ff03 99 KillContext kill_context;
4ad49000 100 CGroupContext cgroup_context;
29206d46 101
28135da3 102 ExecRuntime *exec_runtime;
9cc54544 103 CGroupRuntime *cgroup_runtime;
5cb5a6ff 104
b15bdda8 105 /* For Accept=no sockets refers to the one service we'll
f2f725e5
ZJS
106 * activate. For Accept=yes sockets is either NULL, or filled
107 * to refer to the next service we spawn. */
57020a3a 108 UnitRef service;
034c6ed7 109
a16e1123 110 SocketState state, deserialized_state;
034c6ed7 111
718db961 112 sd_event_source *timer_event_source;
7fab9d01 113
b36ab0d4 114 ExecCommand *control_command;
a16e1123 115 SocketExecCommand control_command_id;
43a19142 116 PidRef control_pid;
5cb5a6ff 117
b36ab0d4
MY
118 bool pass_fds_to_exec;
119
7fab9d01
LP
120 mode_t directory_mode;
121 mode_t socket_mode;
4f2d528d 122
cfc4eb4c 123 SocketResult result;
c968d76a 124 SocketResult clean_result;
7fab9d01 125
811ba7a0
LP
126 char **symlinks;
127
7fab9d01 128 bool accept;
bd1fe7c7 129 bool remove_on_stop;
55301ec0 130 bool writable;
3e5f04bf 131 bool flush_pending;
4fd5948e 132
74bb646e
SS
133 int socket_protocol;
134
4fd5948e
LP
135 /* Socket options */
136 bool keep_alive;
4427c3f4 137 bool no_delay;
7fab9d01 138 bool free_bind;
6b6d2dee 139 bool transparent;
ec6370a2 140 bool broadcast;
d68af586 141 bool pass_cred;
35462aa1 142 bool pass_pidfd;
54ecda32 143 bool pass_sec;
a3d19f5d 144 bool pass_pktinfo;
5c12797f 145 bool pass_rights;
9b191525 146 SocketTimestamping timestamping;
68667801
ZJS
147
148 /* Only for INET6 sockets: issue IPV6_V6ONLY sockopt */
149 SocketAddressBindIPv6Only bind_ipv6_only;
150
4fd5948e 151 int priority;
7fab9d01 152 int mark;
4fd5948e
LP
153 size_t receive_buffer;
154 size_t send_buffer;
155 int ip_tos;
156 int ip_ttl;
157 size_t pipe_size;
4fd5948e 158 char *bind_to_device;
cebf8b20 159 char *tcp_congestion;
718db961 160 bool reuse_port;
916abb21
LP
161 long mq_maxmsg;
162 long mq_msgsize;
57020a3a 163
0eb59ccf
AK
164 char *smack;
165 char *smack_ip_in;
166 char *smack_ip_out;
3900e5fd 167
16115b0a
MS
168 bool selinux_context_from_net;
169
3900e5fd 170 char *user, *group;
5ad096b3 171
8dd4c05b 172 char *fdname;
8b26cdbd
LP
173
174 RateLimit trigger_limit;
14702b9c 175 RateLimit poll_limit;
1b4ab5a2
MY
176
177 usec_t defer_trigger_max_usec;
178 SocketDeferTrigger defer_trigger;
836e4e7e 179} Socket;
5cb5a6ff 180
9d565427
SS
181SocketPeer *socket_peer_ref(SocketPeer *p);
182SocketPeer *socket_peer_unref(SocketPeer *p);
3ebcd323 183int socket_acquire_peer(Socket *s, int fd, SocketPeer **p);
9d565427
SS
184
185DEFINE_TRIVIAL_CLEANUP_FUNC(SocketPeer*, socket_peer_unref);
186
44d8db9e 187/* Called from the service code when collecting fds */
54668cb9 188int socket_collect_fds(Socket *s, int **ret);
44d8db9e 189
6cf6bbc2
LP
190/* Called from the service code when a per-connection service ended */
191void socket_connection_unref(Socket *s);
192
2fbdfe0b 193SocketPort* socket_port_free(SocketPort *p);
f8b21a08
FS
194DEFINE_TRIVIAL_CLEANUP_FUNC(SocketPort*, socket_port_free);
195
74051b9b
LP
196void socket_free_ports(Socket *s);
197
e49b2110
DDM
198int socket_port_to_address(const SocketPort *s, char **ret);
199
934ef6a5 200int socket_load_service_unit(Socket *s, int cfd, Unit **ret);
8dd4c05b 201
daa78907 202const char* socket_fdname(Socket *s);
8dd4c05b 203
87f0e418 204extern const UnitVTable socket_vtable;
5cb5a6ff 205
44a6b1b6
ZJS
206const char* socket_exec_command_to_string(SocketExecCommand i) _const_;
207SocketExecCommand socket_exec_command_from_string(const char *s) _pure_;
a16e1123 208
44a6b1b6
ZJS
209const char* socket_result_to_string(SocketResult i) _const_;
210SocketResult socket_result_from_string(const char *s) _pure_;
67419600 211
44a6b1b6 212const char* socket_port_type_to_string(SocketPort *p) _pure_;
038ed5a4 213SocketType socket_port_type_from_string(const char *p) _pure_;
57b7a260 214
9b191525
LP
215const char* socket_timestamping_to_string(SocketTimestamping p) _const_;
216SocketTimestamping socket_timestamping_from_string(const char *p) _pure_;
217SocketTimestamping socket_timestamping_from_string_harder(const char *p) _pure_;
218
1b4ab5a2
MY
219const char* socket_defer_trigger_to_string(SocketDeferTrigger i) _const_;
220SocketDeferTrigger socket_defer_trigger_from_string(const char *s) _pure_;
221
57b7a260 222DEFINE_CAST(SOCKET, Socket);