26
26
#include <sys/types.h>          /* ssize_t */
 
27
27
#include <sys/stat.h>           /* mkfifo(), S_IRUSR, S_IWUSR */
 
28
28
#include <iso646.h>             /* and */
 
29
 
#include <errno.h>              /* errno, EEXIST */
 
30
 
#include <stdio.h>              /* perror() */
 
 
29
#include <errno.h>              /* errno, EACCES, ENOTDIR, ELOOP,
 
 
30
                                   ENAMETOOLONG, ENOSPC, EROFS,
 
 
31
                                   ENOENT, EEXIST, EFAULT, EMFILE,
 
 
32
                                   ENFILE, ENOMEM, EBADF, EINVAL, EIO,
 
 
34
#include <error.h>              /* error() */
 
31
35
#include <stdlib.h>             /* EXIT_FAILURE, NULL, size_t, free(),
 
32
36
                                   realloc(), EXIT_SUCCESS */
 
33
37
#include <fcntl.h>              /* open(), O_RDONLY */
 
34
38
#include <unistd.h>             /* read(), close(), write(),
 
 
40
#include <sysexits.h>           /* EX_OSERR, EX_OSFILE,
 
 
41
                                   EX_UNAVAILABLE, EX_IOERR */
 
38
44
int main(__attribute__((unused))int argc,
 
 
44
50
  const char passfifo[] = "/lib/cryptsetup/passfifo";
 
45
 
  ret = (int)TEMP_FAILURE_RETRY(mkfifo(passfifo, S_IRUSR | S_IWUSR));
 
46
 
  if(ret == -1 and errno != EEXIST){
 
 
51
  ret = mkfifo(passfifo, S_IRUSR | S_IWUSR);
 
 
54
    error(0, errno, "mkfifo");
 
 
66
      return EX_UNAVAILABLE;    /* no "/lib/cryptsetup"? */
 
 
68
      break;                    /* not an error */
 
52
 
  int fifo_fd = (int)TEMP_FAILURE_RETRY(open(passfifo, O_RDONLY));
 
 
73
  int fifo_fd = open(passfifo, O_RDONLY);
 
 
76
    error(0, errno, "open");
 
 
81
      return EX_UNAVAILABLE;
 
58
94
  /* Read from FIFO */
 
 
65
101
      if(buf_len + blocksize > buf_allocated){
 
66
102
        char *tmp = realloc(buf, buf_allocated + blocksize);
 
 
104
          error(0, errno, "realloc");
 
73
109
        buf_allocated += blocksize;
 
75
 
      sret = TEMP_FAILURE_RETRY(read(fifo_fd, buf + buf_len,
 
76
 
                                     buf_allocated - buf_len));
 
 
111
      sret = read(fifo_fd, buf + buf_len, buf_allocated - buf_len);
 
 
116
        error(0, errno, "read");
 
 
126
          return EX_UNAVAILABLE;
 
82
129
      buf_len += (size_t)sret;
 
83
130
    } while(sret != 0);
 
87
 
  TEMP_FAILURE_RETRY(close(fifo_fd));
 
89
136
  /* Print password to stdout */
 
90
137
  size_t written = 0;
 
91
138
  while(written < buf_len){
 
92
 
    sret = TEMP_FAILURE_RETRY(write(STDOUT_FILENO, buf + written,
 
 
139
    sret = write(STDOUT_FILENO, buf + written, buf_len - written);
 
 
144
      error(0, errno, "write");
 
99
157
    written += (size_t)sret;
 
 
161
  ret = close(STDOUT_FILENO);
 
 
164
    error(0, errno, "close");
 
103
173
  return EXIT_SUCCESS;