Compare a valid passphrase against "<?xml ". Skip the version string
[pwmd.git] / src / common.h
blob475ee3997ece875fa3ac41348466a3cbe34a3a4e
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 guint32 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 struct client_crypto_s {
157 gpointer iv;
158 gpointer key;
159 gpointer tkey;
160 gpointer tkey2;
161 gpointer inbuf;
162 goffset insize;
163 gpointer outbuf;
164 goffset outsize;
165 file_header_internal_t *fh;
166 gcry_cipher_hd_t gh;
169 /* These are flags that are set by a client via the OPTION command. */
170 #define OPT_ITERATIONS 0x1
171 #define OPT_PINENTRY 0x2
172 #define OPT_PINENTRY_TO 0x4
174 struct client_s {
175 assuan_context_t ctx;
176 #ifdef WITH_PINENTRY
177 struct pinentry_s *pinentry;
178 #endif
179 gpointer doc; /* xmlDocPtr */
180 gpointer xml_error;
181 gpointer xml;
182 gint len;
183 gint state;
184 gchar *filename;
185 guchar md5file[16];
186 gboolean new;
187 gboolean freed;
188 time_t mtime;
189 gboolean has_lock;
190 gboolean is_lock_cmd;
191 inquire_status_t inquire_status;
192 struct client_thread_s *thd;
193 struct client_crypto_s *crypto;
194 guchar opts;
197 gsize gcrykeysize, gcryblocksize;
198 GKeyFile *keyfileh;
199 gboolean log_syslog;
200 gint zlib_bufsize;
201 pth_mutex_t rcfile_mutex;
202 pth_mutex_t cn_mutex;
203 GSList *cn_thread_list;
205 void log_write(const gchar *fmt, ...);
206 gpg_error_t send_error(assuan_context_t ctx, gpg_error_t pwmd_errno);
207 gpg_error_t send_syserror(assuan_context_t ctx, int e);
208 gint open_file(const gchar *filename, struct stat *st);
209 gpg_error_t do_xml_encrypt(struct client_s *client, struct client_crypto_s *,
210 const gchar *filename);
211 gint get_key_file_integer(const gchar *section, const gchar *what);
212 gboolean get_key_file_boolean(const gchar *section, const gchar *what);
213 gchar *get_key_file_string(const gchar *section, const gchar *what);
214 gchar *expand_homedir(gchar *str);
215 void free_client(struct client_s *client);
216 void cleanup_crypto(struct client_crypto_s **);
217 struct client_crypto_s *init_client_crypto();
218 gpg_error_t do_assuan_command(assuan_context_t ctx,
219 void *(*cb)(void *data), void *data);
220 void close_file_header(file_header_internal_t *fh);
221 void cleanup_ev_cb(void *arg);
222 void cleanup_mutex_cb(void *arg);
223 void cleanup_fd_cb(void *arg);
224 void cleanup_unlink_cb(void *arg);
225 void cleanup_attr_cb(void *arg);
226 void cleanup_cancel_cb(void *arg);
228 #endif