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 *-------------------------------------------------------------------------
35 #include <hidapi/hidapi.h>
36 #include <sys/param.h>
40 static char* dbdir = NULL;
41 static int period = (300); /* in seconds */
42 static char* pidfile = NULL;
43 static char* logfile = NULL;
44 static bool daemonize = false;
45 static bool workaround = false;
46 static char tfile[MAXPATHLEN],
49 static const double coefficient = (248e-6 / 2637.0);
52 usage(const char *errmsg) {
53 puts("trinketd - collecting info from AtomPro");
54 puts("Copyright (c) 2016, Teodor Sigaev <teodor@sigaev.ru>");
55 puts("trinketd [-d] [-l logfile] [-p pidfile] [-P period] [-D datadir] [-w]");
73 if (trinketOpen() != ERR_OK) {
74 fprintf(stderr, "trinketOpen fails\n");
83 if (trinketGetCumDose(&curDose) != ERR_OK) {
84 fprintf(stderr, "trinketGetCumDose fails\n");
90 if (prevDose >= 0.0) {
91 double counts = curDose - prevDose;
92 double radlevel = 1e6 * coefficient * counts * 3600.0 / (double)period;
94 bool successOpen = true;
97 if ((fh = fopen(tfile, "w")) == NULL) {
98 fprintf(stderr, "fopen fails\n");
104 fprintf(fh, "total: %lld\n", (long long)curDose);
105 fprintf(fh, "counts: %lld\n", (long long)counts);
106 fprintf(fh, "radlevel: %.02f\n", radlevel);
109 if (fh && fh != stdout) {
112 rename(tfile, ofile);
125 extern int opterr, optind;
128 main(int argn, char* argv[]) {
134 while((i=getopt(argn,argv,"dD:l:p:P:wh")) != EOF) {
140 dbdir = strdup(optarg);
143 logfile = strdup(optarg);
146 pidfile = strdup(optarg);
149 period = atoi(optarg);
160 if (opterr || optind != argn)
161 usage("argument err");
164 usage("Collecting period could not be zero nor negative");
166 if (daemonize && !dbdir)
167 usage("trinketd: it is useless to use -d without -D");
169 if (dbdir && strlen(dbdir) > MAXPATHLEN - 32)
170 usage("datadir is too long");
173 pidfd = open(pidfile, O_CREAT | O_WRONLY | O_TRUNC, 0666);
175 usage("could not write pidfile");
179 logfd = open(logfile, O_CREAT | O_WRONLY | O_APPEND, 0666);
181 usage("could not write logfile");
185 if (daemon(0, 0) == -1)
186 usage("could not daemonize");
192 snprintf(pid, sizeof(pid), "%lld", (long long)getpid());
193 if (write(pidfd, pid, strlen(pid)) != strlen(pid))
194 usage("could not write pid");
199 dup2(logfd, fileno(stderr));
203 if (hid_init() < 0) {
204 fprintf(stderr, "hid_init fails\n");
209 snprintf(tfile, MAXPATHLEN, "%s/trinket.tmp", dbdir);
210 snprintf(ofile, MAXPATHLEN, "%s/trinket.dat", dbdir);