Archived
3
0
This repository has been archived on 2024-06-18. You can view files and clone it, but cannot push or open issues or pull requests.
libipc-old/remote/app/remoted.c

118 lines
2.9 KiB
C
Raw Normal View History

2017-08-23 20:57:44 +02:00
#include "../../core/communication.h"
2018-10-04 01:22:50 +02:00
#include "../../core/client.h"
2017-08-23 20:57:44 +02:00
#include "../../core/error.h"
2017-08-25 11:42:43 +02:00
#include "../lib/remoted.h"
2017-08-23 20:57:44 +02:00
#include <stdlib.h>
#include "../../core/logger.h"
2017-08-23 20:57:44 +02:00
#include <sys/socket.h>
#include <sys/un.h>
#include <unistd.h>
#include <signal.h>
#include <stdio.h>
2017-08-23 20:57:44 +02:00
// to quit them properly if a signal occurs
2018-10-04 00:30:47 +02:00
struct ipc_service srv;
2017-08-23 20:57:44 +02:00
void handle_signal (int signalnumber)
{
// the application will shut down, and remove the service unix socket
2018-10-04 01:22:50 +02:00
if (ipc_server_close (&srv) < 0) {
handle_error("ipc_server_close < 0");
2017-08-23 20:57:44 +02:00
}
log_info ("remoted received a signal %d\n", signalnumber);
2017-08-23 20:57:44 +02:00
exit (EXIT_SUCCESS);
}
void usage ()
{
fprintf (stderr, "remoted [-d <unix-socket-dir>] [-h]\n");
}
/* TODO: handle command line arguments */
// cmdline: remoted -d <unix-socket-dir>
void remoted_cmd_args (int argc, char **argv, char **env
, struct remoted_ctx *ctx)
{
(void) env;
(void) ctx;
int c;
while ( (c = getopt(argc, argv, "hd:")) != -1) {
switch (c) {
case 'd':
ctx->unix_socket_dir = malloc (strlen (optarg) +1);
strncpy (ctx->unix_socket_dir, optarg, strlen (optarg));
log_debug ("remoted unix socket dir: %s", ctx->unix_socket_dir);
break;
case '?':
case 'h':
usage ();
exit (EXIT_FAILURE);
default:
log_debug ("remoted getopt returned character code 0%o ??\n", c);
}
}
if (optind < argc) {
log_debug ("remoted non-option ARGV-elements:");
while (optind < argc)
log_debug ("\t%s", argv[optind++]);
}
}
/* TODO: handle authorizations */
int remoted_auth_conf (struct remoted_ctx *ctx)
2017-08-26 01:07:29 +02:00
{
(void) ctx;
return 0;
2017-08-26 01:07:29 +02:00
}
2017-08-23 20:57:44 +02:00
int main(int argc, char **argv, char **env)
2017-08-23 20:57:44 +02:00
{
struct remoted_ctx ctx;
memset (&ctx, 0, sizeof (struct remoted_ctx));
2018-10-04 00:30:47 +02:00
memset (&srv, 0, sizeof (struct ipc_service));
2017-08-23 20:57:44 +02:00
srv.index = 0;
srv.version = 0;
signal(SIGHUP, handle_signal);
signal(SIGINT, handle_signal);
signal(SIGQUIT, handle_signal);
remoted_cmd_args (argc, argv, env, &ctx);
log_info ("remoted started");
// load configuration
if (remoted_auth_conf (&ctx)) {
log_error ("remoted cannot load configuration");
}
else
log_info ("remoted configuration loaded");
2017-08-23 20:57:44 +02:00
2018-10-04 01:22:50 +02:00
if (ipc_server_init (argc, argv, env, &srv, REMOTED_SERVICE_NAME) < 0) {
2018-10-03 21:24:20 +02:00
handle_error("server_init < 0");
2017-08-23 20:57:44 +02:00
}
log_info ("remoted listening on %s", srv.spath);
2017-08-23 20:57:44 +02:00
// TODO: here comes pledge (openbsd)
2017-08-23 20:57:44 +02:00
// the service will loop until the end of time, a specific message, a signal
remoted_main_loop (&srv, &ctx);
2017-08-23 20:57:44 +02:00
2017-08-26 01:07:29 +02:00
// the application will shut down, and remove the service unix socket
2018-10-04 01:22:50 +02:00
if (ipc_server_close (&srv) < 0) {
2018-10-03 21:24:20 +02:00
handle_error("server_close < 0");
2017-08-23 20:57:44 +02:00
}
log_info ("remoted ended");
2017-08-23 20:57:44 +02:00
remoted_free_ctx (&ctx);
2017-08-23 20:57:44 +02:00
return EXIT_SUCCESS;
}