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