1 /* SPDX-License-Identifier: LGPL-2.1+ */
6 #include <sys/socket.h>
9 #include "alloc-util.h"
14 #include "socket-util.h"
15 #include "string-util.h"
18 static int send_on_socket(int fd
, const char *socket_name
, const void *packet
, size_t size
) {
19 union sockaddr_union sa
= {};
26 salen
= sockaddr_un_set_path(&sa
.un
, socket_name
);
28 return log_error_errno(salen
, "Specified socket path for AF_UNIX socket invalid, refusing: %s", socket_name
);
30 if (sendto(fd
, packet
, size
, MSG_NOSIGNAL
, &sa
.sa
, salen
) < 0)
31 return log_error_errno(errno
, "Failed to send: %m");
36 int main(int argc
, char *argv
[]) {
37 _cleanup_free_
char *packet
= NULL
;
38 _cleanup_close_
int fd
= -1;
42 log_set_target(LOG_TARGET_AUTO
);
43 log_parse_environment();
47 log_error("Wrong number of arguments.");
51 if (streq(argv
[1], "1")) {
52 _cleanup_string_free_erase_
char *line
= NULL
;
54 r
= read_line(stdin
, LONG_LINE_MAX
, &line
);
56 log_error_errno(r
, "Failed to read password: %m");
60 log_error("Got EOF while reading password.");
65 packet
= strjoin("+", line
);
71 length
= 1 + strlen(line
) + 1;
73 } else if (streq(argv
[1], "0")) {
83 log_error("Invalid first argument %s", argv
[1]);
88 fd
= socket(AF_UNIX
, SOCK_DGRAM
|SOCK_CLOEXEC
|SOCK_NONBLOCK
, 0);
90 r
= log_error_errno(errno
, "socket() failed: %m");
94 r
= send_on_socket(fd
, argv
[2], packet
, length
);
97 explicit_bzero_safe(packet
, length
);
99 return r
< 0 ? EXIT_FAILURE
: EXIT_SUCCESS
;