version 1.2, 2022/03/15 22:05:18 |
version 1.11, 2022/03/19 07:42:12 |
|
|
#include <stdio.h> |
#include <stdio.h> |
#include <stdlib.h> |
#include <stdlib.h> |
#include <unistd.h> |
#include <unistd.h> |
|
#include <string.h> |
|
#include <syslog.h> |
|
|
#include "blind.h" |
#include "blind.h" |
|
#include "config.h" |
|
#include "log.h" |
|
|
static void usage(void); |
static void usage(void); |
|
|
int daemonize = 1; |
int daemonize = 1; |
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 action = 1; |
int verbose = 0; |
const char *config = CONFIG; |
int no_action = 0; |
|
const char *config = BL_CONF; |
|
|
while ((ch = getopt(argc, argv, "dhnvf:")) != -1) { |
while ((ch = getopt(argc, argv, "dhnvf:")) != -1) { |
switch (ch) { |
switch (ch) { |
Line 47 main(int argc, char *argv[]) |
|
Line 52 main(int argc, char *argv[]) |
|
daemonize = 0; |
daemonize = 0; |
break; |
break; |
case 'h': |
case 'h': |
/* have to change it in next commit */ |
fprintf(stderr, BL_TEXT " " BL_VERS "\n"); |
fprintf(stderr, "version: " BLIND_TXT " " BLIND_VER "\n"); |
|
usage(); |
usage(); |
break; |
break; |
case 'n': |
case 'n': |
action = 0; |
no_action = 1; |
break; |
break; |
case 'f': |
case 'f': |
config = optarg; |
config = optarg; |
break; |
break; |
case 'v': |
case 'v': |
verbose = 1; |
verbose = BL_OPT_VERBOSE; |
break; |
break; |
default: |
default: |
usage(); |
usage(); |
Line 69 main(int argc, char *argv[]) |
|
Line 73 main(int argc, char *argv[]) |
|
|
|
if (argc || *argv) |
if (argc || *argv) |
usage(); |
usage(); |
|
|
|
log_init(daemonize, LOG_DAEMON); |
|
log_info("%s %s starting", BL_TEXT, BL_VERS); |
|
|
|
if ((bl = config_init()) == NULL) |
|
log_fatal("default values init failed"); |
|
|
|
if (strlcpy(bl->bl_conf, config, PATH_MAX)>= PATH_MAX) |
|
log_fatal("config file name exceeds PATH_MAX"); |
|
|
|
bl->bl_opt |= verbose; |
|
log_setv(verbose); |
|
log_debug("verbose mode on"); |
|
|
|
// conf file |
|
|
|
// parse config |
|
|
|
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); |
|
log_debug(" flg=%d", bl->bl_flg); |
|
|
|
// TAILQ_INIT(&offline_queue) |
|
|
exit(0); |
exit(0); |
} |
} |