summaryrefslogtreecommitdiffabout
path: root/src
authorMichael Krelin <hacker@klever.net>2012-01-20 22:40:10 (UTC)
committer Michael Krelin <hacker@klever.net>2012-01-20 22:40:10 (UTC)
commit8035dab48b39f1b0bb9e7aba5ce69fbf59259406 (patch) (unidiff)
treeaca1c9d7cf86d1194cca595c9e84bb0e374fdc07 /src
parent55df23325d4305ea547331e64ca660ba906dc0e6 (diff)
downloadiii-8035dab48b39f1b0bb9e7aba5ce69fbf59259406.zip
iii-8035dab48b39f1b0bb9e7aba5ce69fbf59259406.tar.gz
iii-8035dab48b39f1b0bb9e7aba5ce69fbf59259406.tar.bz2
more startup sanity checks
Signed-off-by: Michael Krelin <hacker@klever.net>
Diffstat (limited to 'src') (more/less context) (ignore whitespace changes)
-rw-r--r--src/iiid.cc11
1 files changed, 11 insertions, 0 deletions
diff --git a/src/iiid.cc b/src/iiid.cc
index c026050..d655fe3 100644
--- a/src/iiid.cc
+++ b/src/iiid.cc
@@ -1,10 +1,12 @@
1#include <syslog.h> 1#include <syslog.h>
2#include <getopt.h> 2#include <getopt.h>
3#include <sys/stat.h>
4#include <glob.h>
3#include <iostream> 5#include <iostream>
4#include <cassert> 6#include <cassert>
5#include <stdexcept> 7#include <stdexcept>
6#include "eyetil.h" 8#include "eyetil.h"
7#include "eyefiworker.h" 9#include "eyefiworker.h"
8 10
9#include "config.h" 11#include "config.h"
10 12
@@ -69,16 +71,25 @@ int main(int argc,char **argv) try {
69 const char *ident = rindex(*argv,'/'); 71 const char *ident = rindex(*argv,'/');
70 if(ident) 72 if(ident)
71 ++ident; 73 ++ident;
72 else 74 else
73 ident = *argv; 75 ident = *argv;
74 openlog(ident,LOG_PERROR|LOG_PID,LOG_DAEMON); 76 openlog(ident,LOG_PERROR|LOG_PID,LOG_DAEMON);
75 syslog(LOG_INFO,"Starting iii eye-fi manager"); 77 syslog(LOG_INFO,"Starting iii eye-fi manager");
76 78
79 struct stat st;
80 if(stat(EYEKIN_CONF_DIR,&st) || !S_ISDIR(st.st_mode))
81 syslog(LOG_WARNING,"configuration directory '%s' does not exist or is not a directory",EYEKIN_CONF_DIR);
82 glob_t g; int rg = glob(EYEKIN_CONF_DIR"/????????????.conf",GLOB_NOSORT,NULL,&g);
83 if(rg || !g.gl_pathc)
84 syslog(LOG_WARNING,"I see nothing resembling a card config in '%s'",EYEKIN_CONF_DIR);
85 else
86 globfree(&g);
87
77 eyefiworker().run(port); 88 eyefiworker().run(port);
78 89
79 closelog(); 90 closelog();
80 return 0; 91 return 0;
81} catch(std::exception& e) { 92} catch(std::exception& e) {
82 syslog(LOG_CRIT,"Exiting iii daemon, because of error condition"); 93 syslog(LOG_CRIT,"Exiting iii daemon, because of error condition");
83 syslog(LOG_CRIT,"Exception: %s",e.what()); 94 syslog(LOG_CRIT,"Exception: %s",e.what());
84 return 1; 95 return 1;