summaryrefslogtreecommitdiffabout
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--src/iiid.cc62
1 files changed, 30 insertions, 32 deletions
diff --git a/src/iiid.cc b/src/iiid.cc
index bd65001..29acd06 100644
--- a/src/iiid.cc
+++ b/src/iiid.cc
@@ -43,99 +43,97 @@ int main(int argc,char **argv) try {
43 " -V, --version display version information\n" 43 " -V, --version display version information\n"
44 " -L, --license show license\n" 44 " -L, --license show license\n"
45 " -p <port>, --port=<port> port to listen to\n" 45 " -p <port>, --port=<port> port to listen to\n"
46 " (you're not likely to ever need it)\n" 46 " (you're not likely to ever need it)\n"
47 " -d, --daemon run as daemon\n" 47 " -d, --daemon run as daemon\n"
48 << std::endl << std::endl; 48 << std::endl << std::endl;
49 exit(0); 49 exit(0);
50 break; 50 break;
51 case 'V': 51 case 'V':
52 std::cerr << VERSION << std::endl; 52 std::cerr << VERSION << std::endl;
53 exit(0); 53 exit(0);
54 break; 54 break;
55 case 'L': 55 case 'L':
56 extern const char *COPYING; 56 extern const char *COPYING;
57 std::cerr << COPYING << std::endl; 57 std::cerr << COPYING << std::endl;
58 exit(0); 58 exit(0);
59 break; 59 break;
60 case 'p': 60 case 'p':
61 port = 0xffff&strtol(optarg,0,0); 61 port = 0xffff&strtol(optarg,0,0);
62 if(errno) { 62 if(errno) {
63 std::cerr << "Failed to parse port number" << std::endl; 63 std::cerr << "Failed to parse port number" << std::endl;
64 exit(1); 64 exit(1);
65 } 65 }
66 break; 66 break;
67 case 'd': 67 case 'd':
68 daemon_mode = true; 68 daemon_mode = true;
69 break; 69 break;
70 default: 70 default:
71 std::cerr << "Huh?" << std::endl; 71 std::cerr << "Huh?" << std::endl;
72 exit(1); 72 exit(1);
73 break; 73 break;
74 } 74 }
75 } 75 }
76 76
77 const char *ident = rindex(*argv,'/'); 77 const char *ident = rindex(*argv,'/');
78 if(ident) 78 if(ident)
79 ++ident; 79 ++ident;
80 else 80 else
81 ident = *argv; 81 ident = *argv;
82 openlog(ident,LOG_PERROR|LOG_PID,LOG_DAEMON); 82 openlog(ident,LOG_PERROR|LOG_PID,LOG_DAEMON);
83 syslog(LOG_INFO,"Starting iii eye-fi manager on port %d", port); 83 syslog(LOG_INFO,"Starting iii eye-fi manager on port %d", port);
84 84
85 struct stat st; 85 struct stat st;
86 if(stat(EYEKIN_CONF_DIR,&st) || !S_ISDIR(st.st_mode)) 86 if(stat(EYEKIN_CONF_DIR,&st) || !S_ISDIR(st.st_mode))
87 syslog(LOG_WARNING,"configuration directory '%s' does not exist or is not a directory",EYEKIN_CONF_DIR); 87 syslog(LOG_WARNING,"configuration directory '%s' does not exist or is not a directory",EYEKIN_CONF_DIR);
88 glob_t g; int rg = glob(EYEKIN_CONF_DIR"/????????????.conf",GLOB_NOSORT,NULL,&g); 88 glob_t g; int rg = glob(EYEKIN_CONF_DIR"/????????????.conf",GLOB_NOSORT,NULL,&g);
89 if(rg || !g.gl_pathc) 89 if(rg || !g.gl_pathc)
90 syslog(LOG_WARNING,"I see nothing resembling a card config in '%s'",EYEKIN_CONF_DIR); 90 syslog(LOG_WARNING,"I see nothing resembling a card config in '%s'",EYEKIN_CONF_DIR);
91 else 91 else
92 globfree(&g); 92 globfree(&g);
93 93
94 if(daemon_mode){ 94 if(daemon_mode) {
95 pid_t pid, sid; 95 pid_t pid, sid;
96 96
97 /* Fork off the parent process */ 97 /* Fork off the parent process */
98 pid = fork(); 98 pid = fork();
99 if (pid < 0) { 99 if (pid < 0) {
100 exit(EXIT_FAILURE); 100 syslog(LOG_ERR, "Error forking the parent process");
101 } 101 exit(EXIT_FAILURE);
102 /* If we got a good PID, then 102 }
103 we can exit the parent process. */
104 if (pid > 0) {
105 exit(EXIT_SUCCESS);
106 }
107 103
108 /* Change the file mode mask */ 104 /* If we got a good PID, then we can exit the parent process. */
109 umask(0); 105 if (pid > 0) {
110 106 exit(EXIT_SUCCESS);
111 /* Create a new SID for the child process */ 107 }
112 sid = setsid(); 108
113 if (sid < 0) { 109 /* Create a new SID for the child process */
114 syslog(LOG_ERR, "Error creating a new SID for the child process"); 110 sid = setsid();
115 exit(EXIT_FAILURE); 111 if (sid < 0) {
116 } 112 syslog(LOG_ERR, "Error creating a new SID for the child process");
117 113 exit(EXIT_FAILURE);
118 /* Change the current working directory */ 114 }
119 if ((chdir("/")) < 0) {
120 syslog(LOG_ERR, "Error changing current working directory to /");
121 exit(EXIT_FAILURE);
122 }
123 115
124 /* Close out the standard file descriptors */ 116 /* Change the current working directory */
125 close(STDIN_FILENO); 117 if ((chdir("/")) < 0) {
126 close(STDOUT_FILENO); 118 syslog(LOG_ERR, "Error changing current working directory to /");
127 close(STDERR_FILENO); 119 exit(EXIT_FAILURE);
128 } 120 }
121
122 /* Close out the standard file descriptors */
123 close(STDIN_FILENO);
124 close(STDOUT_FILENO);
125 close(STDERR_FILENO);
126 }
129 127
130 eyefiworker().run(port); 128 eyefiworker().run(port);
131 129
132 closelog(); 130 closelog();
133 return 0; 131 return 0;
134} catch(const throwable_exit& e) { 132} catch(const throwable_exit& e) {
135 return e.rc; 133 return e.rc;
136} catch(const std::exception& e) { 134} catch(const std::exception& e) {
137 syslog(LOG_CRIT,"Exiting iii daemon, because of error condition"); 135 syslog(LOG_CRIT,"Exiting iii daemon, because of error condition");
138 syslog(LOG_CRIT,"Exception: %s",e.what()); 136 syslog(LOG_CRIT,"Exception: %s",e.what());
139 return 1; 137 return 1;
140} 138}
141 139