Version 2.1.
[pwmd.git] / src / common.h
blob2d704c3187f1768fe62a46906a7d86cd4b3e4247
1 /* vim:tw=78:ts=8:sw=4:set ft=c: */
2 /*
3 Copyright (C) 2006-2009 Ben Kibbey <bjk@luxsci.net>
5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2 of the License, or
8 (at your option) any later version.
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details.
15 You should have received a copy of the GNU General Public License
16 along with this program; if not, write to the Free Software
17 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02110-1301 USA
19 #ifndef COMMON_H
20 #define COMMON_H
22 #include <sys/types.h>
23 #include <sys/stat.h>
24 #include <pth.h>
25 #include <gcrypt.h>
27 #define _ASSUAN_ONLY_GPG_ERRORS 1
28 #include <assuan.h>
30 #ifdef ENABLE_NLS
31 #ifdef HAVE_LOCALE_H
32 #include <locale.h>
33 #endif
34 #endif
36 #include "gettext.h"
37 #define N_(msgid) gettext(msgid)
38 #include "status.h"
40 enum {
41 STATE_CONNECTED,
42 STATE_OPEN
45 typedef enum {
46 INQUIRE_INIT,
47 INQUIRE_BUSY,
48 INQUIRE_DONE
49 } inquire_status_t;
51 typedef enum {
52 PINENTRY_OPEN,
53 PINENTRY_SAVE
54 } pinentry_cmd_t;
56 #ifdef WITH_PINENTRY
57 typedef struct {
58 size_t len;
59 void *buf;
60 } membuf_t;
62 typedef enum {
63 PINENTRY_NONE,
64 PINENTRY_INIT,
65 PINENTRY_PID,
66 PINENTRY_RUNNING,
67 PINENTRY_TIMEOUT
68 } pinentry_status_t;
70 typedef struct {
71 gint fd;
72 gpg_error_t error;
73 pinentry_status_t status;
74 union {
75 gchar key[ASSUAN_LINELENGTH];
76 pid_t pid;
77 } what;
78 } pinentry_key_s;
80 typedef gpg_error_t (*pinentry_finalize_cb)(assuan_context_t, guchar *, gboolean);
82 struct pinentry_s {
83 pth_t tid;
84 pth_mutex_t status_mutex;
85 pth_mutex_t cond_mutex;
86 pth_cond_t cond;
87 pinentry_cmd_t which;
88 gchar *filename;
89 assuan_context_t ctx;
90 pinentry_finalize_cb cb;
91 pid_t pid;
92 pid_t pin_pid;
93 gint fd;
94 pinentry_status_t status;
95 gchar *name;
96 gchar *title;
97 gchar *desc;
98 gchar *prompt;
99 gchar *ttyname;
100 gchar *ttytype;
101 gchar *display;
102 gchar *path;
103 gchar *lcctype;
104 gchar *lcmessages;
105 gint timeout;
106 gboolean has_lock;
107 gint enable;
108 membuf_t data;
109 assuan_error_t (*inquire_cb)(void *data, const char *line);
110 void *inquire_data;
112 #endif
114 typedef struct {
115 guint8 magic[5];
116 guint16 version;
117 guint64 iter;
118 guint64 flags;
119 guint8 iv[16];
120 } file_header_t;
122 typedef struct {
123 gint iter;
124 guint8 iv[16];
125 } file_header_v1_t;
127 typedef struct {
128 gboolean v1;
129 gint fd;
130 struct stat st;
131 gpointer doc;
132 goffset len;
134 union {
135 file_header_v1_t fh1;
136 file_header_t fh2;
137 } ver;
138 } file_header_internal_t;
140 struct client_thread_s {
141 pth_t tid;
142 pth_msgport_t mp;
143 pth_t msg_tid;
144 pth_mutex_t mp_mutex;
145 gint fd;
146 struct client_s *cl;
149 struct assuan_cmd_s {
150 assuan_context_t ctx;
151 const gchar *line;
152 gint line_len;
153 const gchar *line2;
156 /* For use with .flags in the data file header. */
157 #define PWMD_CIPHER_OFFSET (1)
158 #define PWMD_CIPHER(n) (PWMD_CIPHER_OFFSET << n)
159 #define PWMD_CIPHER_AES128 PWMD_CIPHER(0)
160 #define PWMD_CIPHER_AES192 PWMD_CIPHER(1)
161 #define PWMD_CIPHER_AES256 PWMD_CIPHER(2)
162 #define PWMD_CIPHER_SERPENT128 PWMD_CIPHER(3)
163 #define PWMD_CIPHER_SERPENT192 PWMD_CIPHER(4)
164 #define PWMD_CIPHER_SERPENT256 PWMD_CIPHER(5)
165 #define PWMD_CIPHER_CAMELLIA128 PWMD_CIPHER(6)
166 #define PWMD_CIPHER_CAMELLIA192 PWMD_CIPHER(7)
167 #define PWMD_CIPHER_CAMELLIA256 PWMD_CIPHER(8)
168 #define PWMD_CIPHER_3DES PWMD_CIPHER(9)
169 #define PWMD_CIPHER_CAST5 PWMD_CIPHER(10)
170 #define PWMD_CIPHER_BLOWFISH PWMD_CIPHER(11)
171 #define PWMD_CIPHER_TWOFISH PWMD_CIPHER(12)
172 #define PWMD_CIPHER_TWOFISH128 PWMD_CIPHER(13)
174 #define PWMD_FLAG_OFFSET (1<<15)
175 #define PWMD_FLAG(n) (PWMD_FLAG_OFFSET << n)
177 struct client_crypto_s {
178 gpointer iv;
179 gpointer key;
180 gpointer tkey;
181 gpointer tkey2;
182 gpointer inbuf;
183 goffset insize;
184 gpointer outbuf;
185 goffset outsize;
186 file_header_internal_t *fh;
187 gcry_cipher_hd_t gh;
188 gsize blocksize;
189 gsize keysize;
192 /* These are flags that are set by a client via the OPTION command. */
193 #define OPT_ITERATIONS 0x1
194 #define OPT_PINENTRY 0x2
195 #define OPT_PINENTRY_TO 0x4
197 struct client_s {
198 assuan_context_t ctx;
199 #ifdef WITH_PINENTRY
200 struct pinentry_s *pinentry;
201 #endif
202 gpointer doc; /* xmlDocPtr */
203 gpointer xml_error;
204 gpointer xml;
205 gint len;
206 gint state;
207 gchar *filename;
208 guchar md5file[16];
209 gboolean new;
210 gboolean freed;
211 time_t mtime;
212 gboolean has_lock;
213 gboolean is_lock_cmd;
214 inquire_status_t inquire_status;
215 struct client_thread_s *thd;
216 struct client_crypto_s *crypto;
217 guchar opts;
218 gpg_error_t last_rc;
221 GKeyFile *keyfileh;
222 gboolean log_syslog;
223 gint zlib_bufsize;
224 pth_mutex_t rcfile_mutex;
225 pth_mutex_t cn_mutex;
226 GSList *cn_thread_list;
228 #define log_write0 log_write
230 #define log_write1(...) { \
231 if (get_key_file_integer("global", "log_level") >= 1) \
232 log_write(__VA_ARGS__); \
235 #define log_write2(...) { \
236 if (get_key_file_integer("global", "log_level") >= 2) \
237 log_write(__VA_ARGS__); \
240 void log_write(const gchar *fmt, ...);
241 gpg_error_t send_error(assuan_context_t ctx, gpg_error_t pwmd_errno);
242 gpg_error_t send_syserror(assuan_context_t ctx, int e);
243 gint open_file(const gchar *filename, struct stat *st);
244 gpg_error_t do_xml_encrypt(struct client_s *client, struct client_crypto_s *,
245 const gchar *filename);
246 gint get_key_file_integer(const gchar *section, const gchar *what);
247 gdouble get_key_file_double(const gchar *section, const gchar *what);
248 gboolean get_key_file_boolean(const gchar *section, const gchar *what);
249 gchar *get_key_file_string(const gchar *section, const gchar *what);
250 gchar *expand_homedir(gchar *str);
251 void free_client(struct client_s *client);
252 void cleanup_crypto(struct client_crypto_s **);
253 struct client_crypto_s *init_client_crypto();
254 gpg_error_t init_client_crypto2(const char *filename,
255 struct client_crypto_s *crypto);
256 gpg_error_t do_assuan_command(assuan_context_t ctx,
257 void *(*cb)(void *data), void *data);
258 void close_file_header(file_header_internal_t *fh);
259 void cleanup_ev_cb(void *arg);
260 void cleanup_mutex_cb(void *arg);
261 void cleanup_fd_cb(void *arg);
262 void cleanup_unlink_cb(void *arg);
263 void cleanup_attr_cb(void *arg);
264 void cleanup_cancel_cb(void *arg);
265 guint pwmd_cipher_str_to_cipher(const gchar *str);
267 #endif