source: ogServer-Git/src/main.c @ d6789f1

Last change on this file since d6789f1 was 37e91b2, checked in by OpenGnSys Support Team <soporte-og@…>, 4 years ago

#971 rename sources folder to src

Use the same folder as in ogClient.

  • Property mode set to 100644
File size: 2.0 KB
RevLine 
[48de515]1/*
2 * Copyright (C) 2020 Soleta Networks <info@soleta.eu>
3 *
4 * This program is free software: you can redistribute it and/or modify it under
5 * the terms of the GNU Affero General Public License as published by the
6 * Free Software Foundation, version 3.
7 */
8
9#include "ogAdmServer.h"
10#include "dbi.h"
11#include "utils.h"
12#include "list.h"
13#include "rest.h"
14#include "client.h"
15#include "json.h"
16#include "schedule.h"
17#include "core.h"
[866b6c5]18#include "cfg.h"
[48de515]19#include <syslog.h>
20
[96090fd]21#define OG_SERVER_CFG_JSON      "/opt/opengnsys/cfg/ogserver.json"
[866b6c5]22
[48de515]23int main(int argc, char *argv[])
24{
25        struct ev_io ev_io_server_rest, ev_io_agent_rest;
[866b6c5]26        struct og_server_cfg cfg = {};
[48de515]27        int i;
28
29        og_loop = ev_default_loop(0);
30
31        if (signal(SIGPIPE, SIG_IGN) == SIG_ERR)
32                exit(EXIT_FAILURE);
33
[1a406b2]34        openlog("ogserver", LOG_PID, LOG_DAEMON);
[48de515]35
36        if (!validacionParametros(argc, argv, 1)) // Valida parámetros de ejecución
37                exit(EXIT_FAILURE);
38
[96090fd]39        if (parse_json_config(OG_SERVER_CFG_JSON, &cfg) < 0) {
40                syslog(LOG_INFO, "Falling back to legacy configuration file at %s\n",
41                       szPathFileCfg);
42                if (!tomaConfiguracion(szPathFileCfg))
[866b6c5]43                        exit(EXIT_FAILURE);
[96090fd]44        } else {
[866b6c5]45                from_json_to_legacy(&cfg);
[48de515]46        }
47
48        for (i = 0; i < MAXIMOS_CLIENTES; i++) {
49                tbsockets[i].ip[0] = '\0';
50                tbsockets[i].cli = NULL;
51        }
52
53        socket_rest = og_socket_server_init("8888");
[f6f1f18]54        if (socket_rest < 0) {
55                syslog(LOG_ERR, "Cannot open REST API server socket\n");
[48de515]56                exit(EXIT_FAILURE);
[f6f1f18]57        }
[48de515]58
59        ev_io_init(&ev_io_server_rest, og_server_accept_cb, socket_rest, EV_READ);
60        ev_io_start(og_loop, &ev_io_server_rest);
61
62        socket_agent_rest = og_socket_server_init("8889");
[f6f1f18]63        if (socket_agent_rest < 0) {
64                syslog(LOG_ERR, "Cannot open ogClient server socket\n");
[48de515]65                exit(EXIT_FAILURE);
[f6f1f18]66        }
[48de515]67
68        ev_io_init(&ev_io_agent_rest, og_server_accept_cb, socket_agent_rest, EV_READ);
69        ev_io_start(og_loop, &ev_io_agent_rest);
70
[f6f1f18]71        if (og_dbi_schedule_get() < 0) {
72                syslog(LOG_ERR, "Cannot connect to database\n");
[48de515]73                exit(EXIT_FAILURE);
[f6f1f18]74        }
[48de515]75
76        og_schedule_next(og_loop);
77
78        syslog(LOG_INFO, "Waiting for connections\n");
79
80        while (1)
81                ev_loop(og_loop, 0);
82
83        exit(EXIT_SUCCESS);
84}
Note: See TracBrowser for help on using the repository browser.