gwenhywfar 5.14.1
gcttool/main.c
Go to the documentation of this file.
1/***************************************************************************
2 begin : Tue May 03 2005
3 copyright : (C) 2005-2010 by Martin Preuss
4 email : martin@libchipcard.de
5
6 ***************************************************************************
7 * Please see toplevel file COPYING for license details *
8 ***************************************************************************/
9
10#ifdef HAVE_CONFIG_H
11# include <config.h>
12#endif
13
14/*#define GCT_IS_EXPERIMENTAL
15#define DEBUG_GCT_TOOL */
16
17#include <gwenhywfar/debug.h>
18#include <gwenhywfar/pathmanager.h>
19#include <gwenhywfar/cgui.h>
20
21#include "funcs.h"
22#include "globals.h"
23
24#ifdef OS_WIN32
25# define DIRSEP "\\"
26#else
27# define DIRSEP "/"
28#endif
29
30#ifdef HAVE_I18N
31# include <libintl.h>
32# include <locale.h>
33#endif
34
35
36#ifdef HAVE_OPENSSL
37# include <gwenhywfar/gui_be.h>
38
39# include <openssl/err.h>
40# include <openssl/ssl.h>
41# include <openssl/des.h>
42#endif
43
44
45
46
47#ifdef HAVE_OPENSSL
48int getKeyDataFromTextOpenSSL(GWEN_UNUSED GWEN_GUI *gui,
49 const char *password,
50 unsigned char *buffer,
51 unsigned int bsize)
52{
53 DES_cblock left, right;
54 int i;
55
56 if (bsize!=16) {
57 DBG_ERROR(GWEN_LOGDOMAIN, "Buffer must be exact 16 bytes in length");
58 return -1;
59 }
60 DES_string_to_2keys(password, &left, &right);
61 for (i=0; i<8; i++)
62 *(buffer++)=left[i];
63 for (i=0; i<8; i++)
64 *(buffer++)=right[i];
65 return 0;
66}
67
68#endif
69
70
72 const char *tname)
73{
75 GWEN_PLUGIN *pl;
77
78 /* get crypt token */
80 if (pm==0) {
81 DBG_ERROR(0, "Plugin manager not found");
82 return NULL;
83 }
84
85 pl=GWEN_PluginManager_GetPlugin(pm, ttype);
86 if (pl==0) {
87 DBG_ERROR(0, "Plugin not found");
88
89 fprintf(stderr, "%s",
90 I18N("The plugin could not be found.\n"
91 "Please make sure that you have the following "
92 "packages installed (at least on Debian/Ubuntu):\n"
93 "- libchipcard-plugins-libgwenhywfar (for chipcards)\n"
94 "- libaqbanking-plugins-libgwenhywfar\n"));
95 return NULL;
96 }
97 DBG_INFO(0, "Plugin found");
98
100 if (ct==0) {
101 DBG_ERROR(0, "Could not create crypt token");
102 return NULL;
103 }
104
105 return ct;
106}
107
108
109
110int main(int argc, char **argv)
111{
112 GWEN_DB_NODE *db;
113 const char *cmd;
114 int rv;
115 int err;
116 GWEN_GUI *gui;
117 const GWEN_ARGS args[]= {
118 {
120 GWEN_ArgsType_Char, /* type */
121 "cfgfile", /* name */
122 0, /* minnum */
123 1, /* maxnum */
124 "C", /* short option */
125 "cfgfile", /* long option */
126 "Specify the configuration file", /* short description */
127 "Specify the configuration file" /* long description */
128 },
129 {
130 0, /* flags */
131 GWEN_ArgsType_Int, /* type */
132 "forcePin", /* name */
133 0, /* minnum */
134 1, /* maxnum */
135 0, /* short option */
136 "forcepin", /* long option */
137 "force pin entry", /* short description */
138 "force pin entry even if the error counter is not zero"
139 },
140 {
142 GWEN_ArgsType_Int, /* type */
143 "help", /* name */
144 0, /* minnum */
145 0, /* maxnum */
146 "h", /* short option */
147 "help", /* long option */
148 "Show this help screen", /* short description */
149 "Show this help screen" /* long description */
150 }
151 };
152 const GWEN_FUNCS funcs[]= {
153 GWEN_FE_DAH("create", createToken, I18N("This command creates a crypt token")),
154 GWEN_FE_DAH("showuser", showUser, I18N("Display user data stored on the token")),
155 GWEN_FE_DAH("showkey", showKey, I18N("Display key info stored on the token")),
156 GWEN_FE_DAH("genkey", genKey, I18N("Generate keys on crypt token")),
157 GWEN_FE_DAH("activateKey", activateKey, I18N("Activate keys on crypt token")),
158 GWEN_FE_DAH("update", updateToken, I18N("Update Crypt Token to newer version (e.g. OpenHBCI key files")),
159 GWEN_FE_DAH("setsignseq", setSignSeq, I18N("Set signature counter")),
160 GWEN_FE_DAH("changepin", changePin, I18N("Change pin of the crypt token")),
161 GWEN_FE_DA("setkey", setKey),
162 GWEN_FE_DA("hashTree", hashTree),
163 GWEN_FE_DA("checkTree", checkTree),
164 GWEN_FE_DAH("showpasswords", showPasswords, I18N("Display passwords store in a GWEN_PASSWD_STORE file")),
165 GWEN_FE_END(),
166 };
167 const GWEN_FUNCS *func;
168
169 err=GWEN_Init();
170 if (err) {
171 fprintf(stderr, "Could not initialize Gwenhywfar.\n");
172 return 2;
173 }
174
175 gui=GWEN_Gui_CGui_new();
176 GWEN_Gui_SetGui(gui);
177
178#ifdef HAVE_OPENSSL
179 /* for conversion purposes */
180 SSL_load_error_strings();
181 SSL_library_init();
182 GWEN_Gui_SetKeyDataFromTextOpenSslFn(gui, getKeyDataFromTextOpenSSL);
183#endif
184
185 GWEN_Logger_Open(GCT_LOGDOMAIN, "gct-tool", 0,
188
191
192#ifdef GCT_IS_EXPERIMENTAL
193 fprintf(stderr, "\n");
194 fprintf(stderr, "\n");
195 fprintf(stderr, "=================== WARNING ===================\n");
196 fprintf(stderr, "This tool is still EXPERIMENTAL !!!\n");
197 fprintf(stderr, "Please DON'T USE it with your daily key files !\n");
198 fprintf(stderr, "===============================================\n");
199 fprintf(stderr, "\n");
200 fprintf(stderr, "\n");
201#endif
202
203 db=GWEN_DB_Group_new("arguments");
204 rv=GWEN_Args_Check(argc, argv, 1,
207 args,
208 db);
209 if (rv==GWEN_ARGS_RESULT_ERROR) {
210 fprintf(stderr, "ERROR: Could not parse arguments main\n");
211 return -1;
212 }
213 else if (rv==GWEN_ARGS_RESULT_HELP) {
214 GWEN_BUFFER *ubuf;
215
216 ubuf=GWEN_Buffer_new(0, 1024, 0, 1);
218 I18N("Usage: "));
219 GWEN_Buffer_AppendString(ubuf, argv[0]);
221 I18N(" [GLOBAL OPTIONS] COMMAND "
222 "[LOCAL OPTIONS]\n"));
224 I18N("\nGlobal Options:\n"));
225 if (GWEN_Args_Usage(args, ubuf, GWEN_ArgsOutType_Txt)) {
226 fprintf(stderr, "ERROR: Could not create help string\n");
227 return 1;
228 }
229 fprintf(stderr, "%s\n", GWEN_Buffer_GetStart(ubuf));
230 GWEN_Buffer_free(ubuf);
231
232 fprintf(stderr, "%s\n", I18N("\nCommands:\n\n"));
234 return 0;
235 }
236 if (rv) {
237 argc-=rv-1;
238 argv+=rv-1;
239 }
240
241 cmd=GWEN_DB_GetCharValue(db, "params", 0, 0);
242 if (!cmd) {
243 fprintf(stderr, "ERROR: Command needed.\n");
244 return 1;
245 }
246
247 func=GWEN_Funcs_Find(funcs, cmd);
248 if (func!=NULL) {
249 rv=GWEN_Funcs_Call_DB_NODE_Args(func, db, argc, argv);
250 }
251 else {
252 fprintf(stderr, "ERROR: Unknown command \"%s\".\n", cmd);
253 rv=1;
254 }
255
256 err=GWEN_Fini();
257 if (err) {
258 fprintf(stderr,
259 "WARNING: Could not deinitialize Gwenhywfar.\n");
260 }
261
262 return rv;
263}
264
265
266
int activateKey(GWEN_DB_NODE *dbArgs, int argc, char **argv)
Definition activatekey.c:26
#define NULL
Definition binreloc.c:300
GWEN_BUFFER * GWEN_Buffer_new(char *buffer, uint32_t size, uint32_t used, int take)
Definition buffer.c:42
void GWEN_Buffer_free(GWEN_BUFFER *bf)
Definition buffer.c:89
int GWEN_Buffer_AppendString(GWEN_BUFFER *bf, const char *buffer)
Definition buffer.c:992
char * GWEN_Buffer_GetStart(const GWEN_BUFFER *bf)
Definition buffer.c:235
GWEN_GUI * GWEN_Gui_CGui_new(void)
Definition cgui.c:77
int changePin(GWEN_DB_NODE *dbArgs, int argc, char **argv)
Definition changepin.c:27
int checkTree(GWEN_DB_NODE *dbArgs, int argc, char **argv)
Definition checktree.c:29
struct GWEN_CRYPT_TOKEN GWEN_CRYPT_TOKEN
Definition ct.h:19
GWEN_CRYPT_TOKEN * GWEN_Crypt_Token_Plugin_CreateToken(GWEN_PLUGIN *pl, const char *name)
Definition ctplugin.c:146
#define GCT_LOGDOMAIN
Definition cttest.c:47
const char * GWEN_DB_GetCharValue(GWEN_DB_NODE *n, const char *path, int idx, const char *defVal)
Definition db.c:971
GWEN_DB_NODE * GWEN_DB_Group_new(const char *name)
Definition db.c:173
struct GWEN_DB_NODE GWEN_DB_NODE
Definition db.h:228
#define DBG_INFO(dbg_logger, format,...)
Definition debug.h:181
#define DBG_ERROR(dbg_logger, format,...)
Definition debug.h:97
#define I18N(m)
Definition error.c:42
void GWEN_Funcs_Usage_With_Help(const GWEN_FUNCS *funcs)
Definition funcs.c:82
const GWEN_FUNCS * GWEN_Funcs_Find(const GWEN_FUNCS *funcs, const char *name)
Definition funcs.c:95
int GWEN_Funcs_Call_DB_NODE_Args(const GWEN_FUNCS *func, GWEN_DB_NODE *node, int argc, char **argv)
Definition funcs.c:59
#define GWEN_FE_END
Definition funcs.h:71
#define GWEN_FE_DAH
Definition funcs.h:68
#define GWEN_FE_DA
Definition funcs.h:69
int createToken(GWEN_DB_NODE *dbArgs, int argc, char **argv)
int updateToken(GWEN_DB_NODE *dbArgs, int argc, char **argv)
Definition update.c:29
int showKey(GWEN_DB_NODE *dbArgs, int argc, char **argv)
Definition showkey.c:29
int setSignSeq(GWEN_DB_NODE *dbArgs, int argc, char **argv)
Definition setsignseq.c:29
int setKey(GWEN_DB_NODE *dbArgs, int argc, char **argv)
Definition setkey.c:29
int showUser(GWEN_DB_NODE *dbArgs, int argc, char **argv)
Definition showuser.c:27
int hashTree(GWEN_DB_NODE *dbArgs, int argc, char **argv)
Definition hashtree.c:27
int showPasswords(GWEN_DB_NODE *dbArgs, int argc, char **argv)
int main(int argc, char **argv)
GWEN_CRYPT_TOKEN * getCryptToken(const char *ttype, const char *tname)
int genKey(GWEN_DB_NODE *dbArgs, int argc, char **argv)
Definition genkey.c:26
struct GWEN_BUFFER GWEN_BUFFER
A dynamically resizeable text buffer.
Definition buffer.h:38
void GWEN_Gui_SetGui(GWEN_GUI *gui)
Definition gui.c:170
struct GWEN_GUI GWEN_GUI
Definition gui.h:176
GWENHYWFAR_API GWEN_GUI_KEYDATAFROMTEXT_OPENSSL_FN GWEN_Gui_SetKeyDataFromTextOpenSslFn(GWEN_GUI *gui, GWEN_GUI_KEYDATAFROMTEXT_OPENSSL_FN f)
int GWEN_Init(void)
Definition gwenhywfar.c:92
int GWEN_Fini(void)
Definition gwenhywfar.c:303
#define GWEN_UNUSED
int GWEN_Logger_Open(const char *logDomain, const char *ident, const char *file, GWEN_LOGGER_LOGTYPE logtype, GWEN_LOGGER_FACILITY facility)
Definition logger.c:281
void GWEN_Logger_SetLevel(const char *logDomain, GWEN_LOGGER_LEVEL l)
Definition logger.c:472
#define GWEN_LOGDOMAIN
Definition logger.h:32
@ GWEN_LoggerType_Console
Definition logger.h:41
@ GWEN_LoggerFacility_User
Definition logger.h:55
@ GWEN_LoggerLevel_Warning
Definition logger.h:66
GWEN_PLUGIN_MANAGER * GWEN_PluginManager_FindPluginManager(const char *s)
Definition plugin.c:545
GWEN_PLUGIN * GWEN_PluginManager_GetPlugin(GWEN_PLUGIN_MANAGER *pm, const char *s)
Definition plugin.c:522
struct GWEN_PLUGIN_MANAGER GWEN_PLUGIN_MANAGER
Definition plugin.h:37
struct GWEN_PLUGIN GWEN_PLUGIN
Definition plugin.h:36
int GWEN_Args_Check(int argc, char **argv, int startAt, uint32_t mode, const GWEN_ARGS *args, GWEN_DB_NODE *db)
int GWEN_Args_Usage(const GWEN_ARGS *args, GWEN_BUFFER *ubuf, GWEN_ARGS_OUTTYPE ot)
#define GWEN_ARGS_FLAGS_HAS_ARGUMENT
#define GWEN_ARGS_RESULT_ERROR
#define GWEN_ARGS_MODE_STOP_AT_FREEPARAM
#define GWEN_ARGS_MODE_ALLOW_FREEPARAM
#define GWEN_ARGS_FLAGS_HELP
#define GWEN_ARGS_FLAGS_LAST
@ GWEN_ArgsOutType_Txt
@ GWEN_ArgsType_Int
@ GWEN_ArgsType_Char
#define GWEN_ARGS_RESULT_HELP