bzr branch
http://bzr.recompile.se/loggerhead/mandos/trunk
| 237.1.2
by Teddy Hogeborn Further steps towards a D-Bus server interface, plus minor syntax | 1 | /*  -*- coding: utf-8 -*- */
 | 
| 2 | /*
 | |
| 261
by Teddy Hogeborn * plugins.d/askpass-fifo.c: Fix name in header. | 3 |  * Askpass-FIFO - Read a password from a FIFO and output it
 | 
| 237.1.2
by Teddy Hogeborn Further steps towards a D-Bus server interface, plus minor syntax | 4 |  * 
 | 
| 466
by Teddy Hogeborn Update copyright year to "2011" wherever appropriate. | 5 |  * Copyright © 2008-2011 Teddy Hogeborn
 | 
| 6 |  * Copyright © 2008-2011 Björn Påhlsson
 | |
| 237.1.2
by Teddy Hogeborn Further steps towards a D-Bus server interface, plus minor syntax | 7 |  * 
 | 
| 8 |  * This program is free software: you can redistribute it and/or
 | |
| 9 |  * modify it under the terms of the GNU General Public License as
 | |
| 10 |  * published by the Free Software Foundation, either version 3 of the
 | |
| 11 |  * License, or (at your option) any later version.
 | |
| 12 |  * 
 | |
| 13 |  * This program is distributed in the hope that it will be useful, but
 | |
| 14 |  * WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
| 15 |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 | |
| 16 |  * General Public License for more details.
 | |
| 17 |  * 
 | |
| 18 |  * You should have received a copy of the GNU General Public License
 | |
| 19 |  * along with this program.  If not, see
 | |
| 20 |  * <http://www.gnu.org/licenses/>.
 | |
| 21 |  * 
 | |
| 363
by Teddy Hogeborn * plugin-runner.c: Minor stylistic changes. | 22 |  * Contact the authors at <mandos@fukt.bsnet.se>.
 | 
| 237.1.2
by Teddy Hogeborn Further steps towards a D-Bus server interface, plus minor syntax | 23 |  */
 | 
| 24 | ||
| 214
by Teddy Hogeborn * Makefile (PLUGINS): Added "plugins.d/askpass-fifo". | 25 | #define _GNU_SOURCE /* TEMP_FAILURE_RETRY() */ | 
| 26 | #include <sys/types.h> /* ssize_t */ | |
| 27 | #include <sys/stat.h> /* mkfifo(), S_IRUSR, S_IWUSR */ | |
| 28 | #include <iso646.h> /* and */ | |
| 390
by Teddy Hogeborn * plugins.d/askpass-fifo.c: Do close(STDOUT_FILENO) before exiting to | 29 | #include <errno.h> /* errno, EACCES, ENOTDIR, ELOOP, | 
| 30 | ENAMETOOLONG, ENOSPC, EROFS, | |
| 31 | ENOENT, EEXIST, EFAULT, EMFILE, | |
| 32 | ENFILE, ENOMEM, EBADF, EINVAL, EIO, | |
| 33 | EISDIR, EFBIG */ | |
| 24.1.155
by Björn Påhlsson mandos server: Added debuglevel that adjust at what level information | 34 | #include <error.h> /* error() */ | 
| 485
by Teddy Hogeborn Merge from Björn. | 35 | #include <stdio.h> /* fprintf(), vfprintf(), | 
| 36 | vasprintf() */ | |
| 355
by Teddy Hogeborn * mandos: White-space fixes only. | 37 | #include <stdlib.h> /* EXIT_FAILURE, NULL, size_t, free(), | 
| 214
by Teddy Hogeborn * Makefile (PLUGINS): Added "plugins.d/askpass-fifo". | 38 | realloc(), EXIT_SUCCESS */ | 
| 39 | #include <fcntl.h> /* open(), O_RDONLY */ | |
| 40 | #include <unistd.h> /* read(), close(), write(), | |
| 41 | STDOUT_FILENO */ | |
| 390
by Teddy Hogeborn * plugins.d/askpass-fifo.c: Do close(STDOUT_FILENO) before exiting to | 42 | #include <sysexits.h> /* EX_OSERR, EX_OSFILE, | 
| 43 | EX_UNAVAILABLE, EX_IOERR */ | |
| 24.1.174
by Björn Påhlsson * Makefile (CFLAGS): Added "-lrt" to include real time library. | 44 | #include <string.h> /* strerror() */ | 
| 45 | #include <stdarg.h> /* va_list, va_start(), ... */ | |
| 46 | ||
| 47 | ||
| 48 | /* Function to use when printing errors */
 | |
| 485
by Teddy Hogeborn Merge from Björn. | 49 | void error_plus(int status, int errnum, const char *formatstring, | 
| 50 | ...){ | |
| 24.1.174
by Björn Påhlsson * Makefile (CFLAGS): Added "-lrt" to include real time library. | 51 | va_list ap; | 
| 52 | char *text; | |
| 53 | int ret; | |
| 54 |   
 | |
| 55 | va_start(ap, formatstring); | |
| 56 | ret = vasprintf(&text, formatstring, ap); | |
| 57 | if (ret == -1){ | |
| 485
by Teddy Hogeborn Merge from Björn. | 58 | fprintf(stderr, "Mandos plugin %s: ", | 
| 59 | program_invocation_short_name); | |
| 24.1.174
by Björn Påhlsson * Makefile (CFLAGS): Added "-lrt" to include real time library. | 60 | vfprintf(stderr, formatstring, ap); | 
| 61 | fprintf(stderr, ": "); | |
| 62 | fprintf(stderr, "%s\n", strerror(errnum)); | |
| 63 | error(status, errno, "vasprintf while printing error"); | |
| 64 | return; | |
| 65 | } | |
| 66 | fprintf(stderr, "Mandos plugin "); | |
| 67 | error(status, errnum, "%s", text); | |
| 68 | free(text); | |
| 69 | }
 | |
| 214
by Teddy Hogeborn * Makefile (PLUGINS): Added "plugins.d/askpass-fifo". | 70 | |
| 71 | int main(__attribute__((unused))int argc, | |
| 72 | __attribute__((unused))char **argv){ | |
| 73 | int ret = 0; | |
| 74 | ssize_t sret; | |
| 75 |   
 | |
| 76 | /* Create FIFO */ | |
| 77 | const char passfifo[] = "/lib/cryptsetup/passfifo"; | |
| 369
by Teddy Hogeborn * init.d-mandos (Required-Start, Required-Stop): Bug fix: Added | 78 | ret = mkfifo(passfifo, S_IRUSR | S_IWUSR); | 
| 390
by Teddy Hogeborn * plugins.d/askpass-fifo.c: Do close(STDOUT_FILENO) before exiting to | 79 | if(ret == -1){ | 
| 80 | int e = errno; | |
| 81 | switch(e){ | |
| 82 | case EACCES: | |
| 83 | case ENOTDIR: | |
| 84 | case ELOOP: | |
| 24.1.174
by Björn Påhlsson * Makefile (CFLAGS): Added "-lrt" to include real time library. | 85 | error_plus(EX_OSFILE, errno, "mkfifo"); | 
| 390
by Teddy Hogeborn * plugins.d/askpass-fifo.c: Do close(STDOUT_FILENO) before exiting to | 86 | case ENAMETOOLONG: | 
| 87 | case ENOSPC: | |
| 88 | case EROFS: | |
| 89 | default: | |
| 24.1.174
by Björn Påhlsson * Makefile (CFLAGS): Added "-lrt" to include real time library. | 90 | error_plus(EX_OSERR, errno, "mkfifo"); | 
| 390
by Teddy Hogeborn * plugins.d/askpass-fifo.c: Do close(STDOUT_FILENO) before exiting to | 91 | case ENOENT: | 
| 479
by Teddy Hogeborn * plugins.d/askpass-fifo.c (main): Don't print message if FIFO exists. | 92 | /* no "/lib/cryptsetup"? */ | 
| 24.1.174
by Björn Påhlsson * Makefile (CFLAGS): Added "-lrt" to include real time library. | 93 | error_plus(EX_UNAVAILABLE, errno, "mkfifo"); | 
| 390
by Teddy Hogeborn * plugins.d/askpass-fifo.c: Do close(STDOUT_FILENO) before exiting to | 94 | case EEXIST: | 
| 95 | break; /* not an error */ | |
| 96 | } | |
| 214
by Teddy Hogeborn * Makefile (PLUGINS): Added "plugins.d/askpass-fifo". | 97 | } | 
| 98 |   
 | |
| 99 | /* Open FIFO */ | |
| 369
by Teddy Hogeborn * init.d-mandos (Required-Start, Required-Stop): Bug fix: Added | 100 | int fifo_fd = open(passfifo, O_RDONLY); | 
| 214
by Teddy Hogeborn * Makefile (PLUGINS): Added "plugins.d/askpass-fifo". | 101 | if(fifo_fd == -1){ | 
| 390
by Teddy Hogeborn * plugins.d/askpass-fifo.c: Do close(STDOUT_FILENO) before exiting to | 102 | int e = errno; | 
| 24.1.174
by Björn Påhlsson * Makefile (CFLAGS): Added "-lrt" to include real time library. | 103 | error_plus(0, errno, "open"); | 
| 390
by Teddy Hogeborn * plugins.d/askpass-fifo.c: Do close(STDOUT_FILENO) before exiting to | 104 | switch(e){ | 
| 105 | case EACCES: | |
| 106 | case ENOENT: | |
| 107 | case EFAULT: | |
| 108 | return EX_UNAVAILABLE; | |
| 109 | case ENAMETOOLONG: | |
| 110 | case EMFILE: | |
| 111 | case ENFILE: | |
| 112 | case ENOMEM: | |
| 113 | default: | |
| 114 | return EX_OSERR; | |
| 115 | case ENOTDIR: | |
| 116 | case ELOOP: | |
| 117 | return EX_OSFILE; | |
| 118 | } | |
| 214
by Teddy Hogeborn * Makefile (PLUGINS): Added "plugins.d/askpass-fifo". | 119 | } | 
| 120 |   
 | |
| 121 | /* Read from FIFO */ | |
| 122 | char *buf = NULL; | |
| 123 | size_t buf_len = 0; | |
| 124 | { | |
| 125 | size_t buf_allocated = 0; | |
| 126 | const size_t blocksize = 1024; | |
| 363
by Teddy Hogeborn * plugin-runner.c: Minor stylistic changes. | 127 | do { | 
| 214
by Teddy Hogeborn * Makefile (PLUGINS): Added "plugins.d/askpass-fifo". | 128 | if(buf_len + blocksize > buf_allocated){ | 
| 129 | char *tmp = realloc(buf, buf_allocated + blocksize); | |
| 130 | if(tmp == NULL){ | |
| 24.1.174
by Björn Påhlsson * Makefile (CFLAGS): Added "-lrt" to include real time library. | 131 | error_plus(0, errno, "realloc"); | 
| 214
by Teddy Hogeborn * Makefile (PLUGINS): Added "plugins.d/askpass-fifo". | 132 | free(buf); | 
| 390
by Teddy Hogeborn * plugins.d/askpass-fifo.c: Do close(STDOUT_FILENO) before exiting to | 133 | return EX_OSERR; | 
| 214
by Teddy Hogeborn * Makefile (PLUGINS): Added "plugins.d/askpass-fifo". | 134 | } | 
| 135 | buf = tmp; | |
| 136 | buf_allocated += blocksize; | |
| 137 | } | |
| 369
by Teddy Hogeborn * init.d-mandos (Required-Start, Required-Stop): Bug fix: Added | 138 | sret = read(fifo_fd, buf + buf_len, buf_allocated - buf_len); | 
| 214
by Teddy Hogeborn * Makefile (PLUGINS): Added "plugins.d/askpass-fifo". | 139 | if(sret == -1){ | 
| 390
by Teddy Hogeborn * plugins.d/askpass-fifo.c: Do close(STDOUT_FILENO) before exiting to | 140 | int e = errno; | 
| 141 | free(buf); | |
| 142 | errno = e; | |
| 24.1.174
by Björn Påhlsson * Makefile (CFLAGS): Added "-lrt" to include real time library. | 143 | error_plus(0, errno, "read"); | 
| 390
by Teddy Hogeborn * plugins.d/askpass-fifo.c: Do close(STDOUT_FILENO) before exiting to | 144 | switch(e){ | 
| 145 | case EBADF: | |
| 146 | case EFAULT: | |
| 147 | case EINVAL: | |
| 148 | default: | |
| 149 | return EX_OSERR; | |
| 150 | case EIO: | |
| 151 | return EX_IOERR; | |
| 152 | case EISDIR: | |
| 153 | return EX_UNAVAILABLE; | |
| 154 | } | |
| 214
by Teddy Hogeborn * Makefile (PLUGINS): Added "plugins.d/askpass-fifo". | 155 | } | 
| 156 | buf_len += (size_t)sret; | |
| 363
by Teddy Hogeborn * plugin-runner.c: Minor stylistic changes. | 157 | } while(sret != 0); | 
| 214
by Teddy Hogeborn * Makefile (PLUGINS): Added "plugins.d/askpass-fifo". | 158 | } | 
| 159 |   
 | |
| 160 | /* Close FIFO */ | |
| 369
by Teddy Hogeborn * init.d-mandos (Required-Start, Required-Stop): Bug fix: Added | 161 | close(fifo_fd); | 
| 214
by Teddy Hogeborn * Makefile (PLUGINS): Added "plugins.d/askpass-fifo". | 162 |   
 | 
| 163 | /* Print password to stdout */ | |
| 164 | size_t written = 0; | |
| 165 | while(written < buf_len){ | |
| 369
by Teddy Hogeborn * init.d-mandos (Required-Start, Required-Stop): Bug fix: Added | 166 | sret = write(STDOUT_FILENO, buf + written, buf_len - written); | 
| 214
by Teddy Hogeborn * Makefile (PLUGINS): Added "plugins.d/askpass-fifo". | 167 | if(sret == -1){ | 
| 390
by Teddy Hogeborn * plugins.d/askpass-fifo.c: Do close(STDOUT_FILENO) before exiting to | 168 | int e = errno; | 
| 169 | free(buf); | |
| 170 | errno = e; | |
| 24.1.174
by Björn Påhlsson * Makefile (CFLAGS): Added "-lrt" to include real time library. | 171 | error_plus(0, errno, "write"); | 
| 390
by Teddy Hogeborn * plugins.d/askpass-fifo.c: Do close(STDOUT_FILENO) before exiting to | 172 | switch(e){ | 
| 173 | case EBADF: | |
| 174 | case EFAULT: | |
| 175 | case EINVAL: | |
| 176 | return EX_OSFILE; | |
| 177 | case EFBIG: | |
| 178 | case EIO: | |
| 179 | case ENOSPC: | |
| 180 | default: | |
| 181 | return EX_IOERR; | |
| 182 | } | |
| 214
by Teddy Hogeborn * Makefile (PLUGINS): Added "plugins.d/askpass-fifo". | 183 | } | 
| 184 | written += (size_t)sret; | |
| 185 | } | |
| 186 | free(buf); | |
| 187 |   
 | |
| 390
by Teddy Hogeborn * plugins.d/askpass-fifo.c: Do close(STDOUT_FILENO) before exiting to | 188 | ret = close(STDOUT_FILENO); | 
| 189 | if(ret == -1){ | |
| 190 | int e = errno; | |
| 24.1.174
by Björn Påhlsson * Makefile (CFLAGS): Added "-lrt" to include real time library. | 191 | error_plus(0, errno, "close"); | 
| 390
by Teddy Hogeborn * plugins.d/askpass-fifo.c: Do close(STDOUT_FILENO) before exiting to | 192 | switch(e){ | 
| 193 | case EBADF: | |
| 194 | return EX_OSFILE; | |
| 195 | case EIO: | |
| 196 | default: | |
| 197 | return EX_IOERR; | |
| 198 | } | |
| 199 | } | |
| 214
by Teddy Hogeborn * Makefile (PLUGINS): Added "plugins.d/askpass-fifo". | 200 | return EXIT_SUCCESS; | 
| 201 | }
 |