/* * This file is part of the canserver project. * Copyright 2025 Edward V. Emelianov . * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ #include #include #include #include "clientserver.h" #include "globopts.h" void signals(int sig){ if(sig){ signal(sig, SIG_IGN); DBG("Get signal %d, quit.\n", sig); LOGERR("Exit with status %d", sig); }else LOGERR("Exit"); killsockets(); exit(sig); } int main(int argc, char **argv){ sl_init(); parseargs(argc, argv); if(!UserOpts.srvnode) ERRX("Point server node"); if(!UserOpts.cltnode) ERRX("Point serial client node"); sl_socktype_e type = (UserOpts.srvunix) ? SOCKT_UNIX : SOCKT_NET; sl_sock_t *srv = RunSrv(type, UserOpts.srvnode); if(!srv) ERRX("Server: can't create socket and/or run threads"); sl_sock_changemaxclients(srv, UserOpts.maxclients); DBG("Server done"); type = (UserOpts.cltunix) ? SOCKT_UNIX : SOCKT_NET; sl_sock_t *clt = RunClt(type, UserOpts.cltnode); if(!clt) ERRX("Serial client: can't connect to socket and/or run threads"); DBG("Client done"); sl_loglevel_e lvl = UserOpts.verbose + LOGLEVEL_ERR; if(lvl >= LOGLEVEL_AMOUNT) lvl = LOGLEVEL_AMOUNT - 1; if(UserOpts.logfile) OPENLOG(UserOpts.logfile, lvl, 1); LOGMSG("Started"); signal(SIGTERM, signals); signal(SIGINT, signals); signal(SIGQUIT, signals); signal(SIGTSTP, SIG_IGN); signal(SIGHUP, signals); while(srv && srv->connected && clt && clt->connected){ if(!srv->rthread){ WARNX("Server handlers thread is dead"); LOGERR("Server handlers thread is dead"); break; } } LOGMSG("End"); DBG("Close"); killsockets(); return 0; }