1 /*-------------------------------------------------------------------------
4 * Copyright (c) 2016, Teodor Sigaev <teodor@sigaev.ru>
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
9 * 1. Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * 2. Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
15 * THIS SOFTWARE IS PROVIDED BY AUTHOR AND CONTRIBUTORS ``AS IS'' AND
16 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
17 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
18 * ARE DISCLAIMED. IN NO EVENT SHALL AUTHOR OR CONTRIBUTORS BE LIABLE
19 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
20 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
21 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
22 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
23 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
24 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26 *-------------------------------------------------------------------------
36 #include <hidapi/hidapi.h>
37 #include <sys/param.h>
41 static char* dbdir = NULL;
42 static int period = (150);
43 static char* pidfile = NULL;
44 static char* logfile = NULL;
45 static bool daemonize = false;
46 static char tfile[MAXPATHLEN],
49 static const double coefficient = 1.0;
51 static bool stopRequest = false;
59 usage(const char *errmsg) {
60 puts("trinketd - collecting info from AtomPro");
61 puts("Copyright (c) 2016, Teodor Sigaev <teodor@sigaev.ru>");
62 puts("trinketd [-d] [-l logfile] [-p pidfile] [-P period] [-D datadir]");
80 if (trinketOpen() != ERR_OK) {
81 fprintf(stderr, "trinketOpen fails\n");
86 while(42 && stopRequest == false) {
87 if (trinketGetCumDose(&curDose) != ERR_OK) {
88 fprintf(stderr, "trinketGetCumDose fails\n");
94 if (prevDose >= 0.0) {
95 double counts = curDose - prevDose;
96 double radlevel = coefficient * counts / (double)period;
98 bool successOpen = true;
101 if ((fh = fopen(tfile, "w")) == NULL) {
102 fprintf(stderr, "fopen fails\n");
108 fprintf(fh, "counts: %lld\n", (long long)counts);
109 fprintf(fh, "radlevel: %e\n", radlevel);
115 rename(tfile, ofile);
128 extern int opterr, optind;
131 main(int argn, char* argv[]) {
138 while((i=getopt(argn,argv,"dD:p:P:h")) != EOF) {
144 dbdir = strdup(optarg);
147 pidfile = strdup(optarg);
150 period = atoi(optarg);
158 if (opterr || optind != argn)
159 usage("argument err");
162 usage("Collecting period could not be zero nor negative");
164 if (daemonize && !dbdir)
165 usage("trinketd: it is useless to use -d without -D");
167 if (dbdir && strlen(dbdir) > MAXPATHLEN - 32)
168 usage("datadir is too long");
171 pidfd = open(pidfile, O_CREAT | O_WRONLY | O_TRUNC, 0666);
173 usage("could not write pidfile");
177 logfd = open(logfile, O_CREAT | O_WRONLY | O_APPEND, 0666);
179 usage("could not write logfile");
183 if (daemon(0, 0) == -1)
184 usage("could not daemonize");
190 snprintf(pid, sizeof(pid), "%lld", (long long)getpid());
191 if (write(pidfd, pid, strlen(pid)) != strlen(pid))
192 usage("could not write pid");
197 dup2(logfd, fileno(stderr));
201 if (hid_init() < 0) {
202 fprintf(stderr, "hid_init fails\n");
207 snprintf(tfile, MAXPATHLEN, "%s/trinket.tmp", dbdir);
208 snprintf(ofile, MAXPATHLEN, "%s/trinket.dat", dbdir);
211 memset(&sa, 0, sizeof(sa));
212 sigemptyset(&sa.sa_mask);
213 sa.sa_handler = sig_int;
214 sigaction(SIGINT, &sa, 0);
215 sigaction(SIGTERM, &sa, 0);
216 sigaction(SIGHUP, &sa, 0);