Fixed OPEN and SAVE to use the "key_file" if specified. If set and an
[pwmd.git] / src / common.h
blob72a43e519d02154f78aac69df1b9c4e91eddffa9
1 /* vim:tw=78:ts=8:sw=4:set ft=c: */
2 /*
3 Copyright (C) 2006-2008 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>
26 #include "status.h"
28 #define _ASSUAN_ONLY_GPG_ERRORS 1
29 #include <assuan.h>
31 #ifdef ENABLE_NLS
32 #ifdef HAVE_LOCALE_H
33 #include <locale.h>
34 #endif
35 #endif
37 #include "gettext.h"
38 #define N_(msgid) gettext(msgid)
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_event_t ev;
86 pinentry_cmd_t which;
87 gchar *filename;
88 assuan_context_t ctx;
89 pinentry_finalize_cb cb;
90 pid_t pid;
91 pid_t pin_pid;
92 gint fd;
93 pinentry_status_t status;
94 gchar *title;
95 gchar *desc;
96 gchar *prompt;
97 gchar *ttyname;
98 gchar *ttytype;
99 gchar *display;
100 gchar *path;
101 gint timeout;
102 gboolean has_lock;
103 gint enable;
104 membuf_t data;
105 int (*inquire_cb)(void *data, const char *line);
106 void *inquire_data;
108 #endif
110 typedef struct {
111 guint iter;
112 guchar iv[16]; /* FIXME: is this portable? */
113 guint flags;
114 gushort version;
115 guint data;
116 guchar data2[256];
117 } file_header_t;
119 typedef struct {
120 gint iter;
121 guchar iv[16]; /* FIXME: is this portable? */
122 } file_header_v1_t;
124 typedef struct {
125 gboolean v1;
126 gint fd;
127 struct stat st;
128 gpointer doc;
129 gsize len;
131 union {
132 file_header_v1_t fh1;
133 file_header_t fh2;
135 } file_header_internal_t;
137 struct client_thread_s {
138 pth_t tid;
139 gint fd;
140 pth_msgport_t msg;
141 pth_t msg_tid;
142 pth_event_t msg_ev;
143 gchar *msg_name;
144 struct client_s *cl;
145 #ifdef WITH_GNUTLS
146 gboolean remote;
147 struct tls_s *tls;
148 #endif
151 struct client_s {
152 assuan_context_t ctx;
153 #ifdef WITH_PINENTRY
154 struct pinentry_s *pinentry;
155 #endif
156 gpointer doc; /* xmlDocPtr */
157 gpointer xml_error;
158 gpointer xml;
159 gint len;
160 gint state;
161 gcry_cipher_hd_t gh;
162 gchar *filename;
163 guchar md5file[16];
164 gboolean new;
165 gboolean freed;
166 time_t mtime;
167 gboolean has_lock;
168 gboolean is_lock_cmd;
169 inquire_status_t inquire_status;
170 struct client_thread_s *thd;
173 gsize gcrykeysize, gcryblocksize;
174 GKeyFile *keyfileh;
175 gboolean log_syslog;
176 gint zlib_bufsize;
178 void log_write(const gchar *fmt, ...);
179 gpg_error_t send_error(assuan_context_t ctx, gpg_error_t pwmd_errno);
180 gpg_error_t send_syserror(assuan_context_t ctx, int e);
181 gint open_file(const gchar *filename, struct stat *st);
182 gpg_error_t do_xml_encrypt(struct client_s *client, gcry_cipher_hd_t gh,
183 const gchar *filename, gpointer data, size_t insize, guchar *shakey,
184 guint iter);
185 gint get_key_file_integer(const gchar *section, const gchar *what);
186 gboolean get_key_file_boolean(const gchar *section, const gchar *what);
187 gchar *get_key_file_string(const gchar *section, const gchar *what);
188 gchar *expand_homedir(gchar *str);
189 void free_client(struct client_s *client);
190 gpg_error_t send_status(assuan_context_t ctx, status_msg_t which);
191 gchar *parse_keyfile(const gchar *filename, gboolean cmdline);
193 #endif