version 1.9, 2022/03/18 20:54:01 |
version 1.20, 2022/04/03 09:14:25 |
|
|
|
|
#include <stdio.h> |
#include <stdio.h> |
#include <stdlib.h> |
#include <stdlib.h> |
#include <unistd.h> |
|
#include <string.h> |
#include <string.h> |
#include <syslog.h> |
#include <syslog.h> |
|
#include <unistd.h> |
|
|
#include "blind.h" |
#include "blind.h" |
#include "config.h" |
#include "config.h" |
#include "log.h" |
#include "log.h" |
|
|
static void usage(void); |
static void usage(void); |
|
|
int daemonize = 1; |
struct blind *bl; |
int verbose = 0; |
|
struct blind *bl; |
|
|
|
static void |
static void |
usage(void) |
usage(void) |
|
|
main(int argc, char *argv[]) |
main(int argc, char *argv[]) |
{ |
{ |
int ch; |
int ch; |
|
int verbose = 0; |
int no_action = 0; |
int no_action = 0; |
|
int daemonize = 1; |
const char *config = BL_CONF; |
const char *config = BL_CONF; |
|
|
while ((ch = getopt(argc, argv, "dhnvf:")) != -1) { |
while ((ch = getopt(argc, argv, "dhnvf:")) != -1) { |
Line 62 main(int argc, char *argv[]) |
|
Line 62 main(int argc, char *argv[]) |
|
config = optarg; |
config = optarg; |
break; |
break; |
case 'v': |
case 'v': |
verbose = 1; |
verbose = BL_OPT_VERBOSE; |
break; |
break; |
default: |
default: |
usage(); |
usage(); |
Line 74 main(int argc, char *argv[]) |
|
Line 74 main(int argc, char *argv[]) |
|
if (argc || *argv) |
if (argc || *argv) |
usage(); |
usage(); |
|
|
log_initialize(daemonize, LOG_DAEMON); |
log_init(daemonize, LOG_DAEMON); |
log_setverbose(verbose); |
log_info("%s %s", BL_TEXT, BL_VERS); |
log_info("%s %s starting", BL_TEXT, BL_VERS); |
|
log_debug("verbose mode"); |
|
|
|
if ((bl = config_init()) == NULL) |
if ((bl = config_init()) == NULL) |
log_fatal("config default"); |
log_fatal("initialization failed"); |
|
|
if (strlcpy(bl->bl_conf, config, PATH_MAX)>= PATH_MAX) |
if (verbose) { |
log_fatal("config file exceeds PATH_MAX"); |
bl->bl_opt |= verbose; |
|
log_set(verbose); |
// conf file |
log_debug("verbose mode on"); |
|
} |
|
|
// parse config |
if (strlcpy(bl->bl_conf, config, PATH_MAX) >= PATH_MAX) |
|
log_fatal("file name exceeds PATH_MAX"); |
log_debug("conf=%s", bl->bl_conf); |
|
log_debug("sock=%s", bl->bl_sock); |
if (config_load(bl)) |
log_debug("ttl=%d", bl->bl_ttl); |
log_fatal("config %s", bl->bl_conf); |
|
|
// TAILQ_INIT(&offline_queue) |
log_debug("conf=%s", bl->bl_conf); |
|
log_debug("sock=%s", bl->bl_sock); |
|
log_debug(" ttl=%d", bl->bl_ttl); |
|
log_debug(" opt=%d", bl->bl_opt); |
|
|
|
// to be continued |
|
|
|
free(bl); |
|
|
exit(0); |
exit(0); |
} |
} |