gwenhywfar  4.99.8beta
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 "globals.h"
22 
23 #ifdef OS_WIN32
24 # define DIRSEP "\\"
25 #else
26 # define DIRSEP "/"
27 #endif
28 
29 #ifdef HAVE_I18N
30 # include <libintl.h>
31 # include <locale.h>
32 #endif
33 
34 
35 #ifdef HAVE_OPENSSL
36 # include <gwenhywfar/gui_be.h>
37 
38 # include <openssl/err.h>
39 # include <openssl/ssl.h>
40 # include <openssl/des.h>
41 #endif
42 
43 
44 
45 
46 #ifdef HAVE_OPENSSL
47 int getKeyDataFromTextOpenSSL(GWEN_GUI *gui,
48  const char *password,
49  unsigned char *buffer,
50  unsigned int bsize) {
51  DES_cblock left, right;
52  int i;
53 
54  if (bsize!=16) {
55  DBG_ERROR(GWEN_LOGDOMAIN, "Buffer must be exact 16 bytes in length");
56  return -1;
57  }
58  DES_string_to_2keys(password, &left, &right);
59  for (i=0; i<8; i++)
60  *(buffer++)=left[i];
61  for (i=0; i<8; i++)
62  *(buffer++)=right[i];
63  return 0;
64 }
65 
66 #endif
67 
68 
69 GWEN_CRYPT_TOKEN *getCryptToken(const char *ttype,
70  const char *tname) {
72  GWEN_PLUGIN *pl;
73  GWEN_CRYPT_TOKEN *ct;
74 
75  /* get crypt token */
77  if (pm==0) {
78  DBG_ERROR(0, "Plugin manager not found");
79  return NULL;
80  }
81 
82  pl=GWEN_PluginManager_GetPlugin(pm, ttype);
83  if (pl==0) {
84  DBG_ERROR(0, "Plugin not found");
85 
86  fprintf(stderr, "%s",
87  I18N("The plugin could not be found.\n"
88  "Please make sure that you have the following "
89  "packages installed (at least on Debian/Ubuntu):\n"
90  "- libchipcard-plugins-libgwenhywfar (for chipcards)\n"
91  "- libaqbanking-plugins-libgwenhywfar\n"));
92  return NULL;
93  }
94  DBG_INFO(0, "Plugin found");
95 
97  if (ct==0) {
98  DBG_ERROR(0, "Could not create crypt token");
99  return NULL;
100  }
101 
102  return ct;
103 }
104 
105 
106 
107 int main(int argc, char **argv) {
108  GWEN_DB_NODE *db;
109  const char *cmd;
110  int rv;
111  int err;
112  GWEN_GUI *gui;
113  const GWEN_ARGS args[]={
114  {
115  GWEN_ARGS_FLAGS_HAS_ARGUMENT, /* flags */
116  GWEN_ArgsType_Char, /* type */
117  "cfgfile", /* name */
118  0, /* minnum */
119  1, /* maxnum */
120  "C", /* short option */
121  "cfgfile", /* long option */
122  "Specify the configuration file", /* short description */
123  "Specify the configuration file" /* long description */
124  },
125  {
126  0, /* flags */
127  GWEN_ArgsType_Int, /* type */
128  "forcePin", /* name */
129  0, /* minnum */
130  1, /* maxnum */
131  0, /* short option */
132  "forcepin", /* long option */
133  "force pin entry", /* short description */
134  "force pin entry even if the error counter is not zero"
135  },
136  {
138  GWEN_ArgsType_Int, /* type */
139  "help", /* name */
140  0, /* minnum */
141  0, /* maxnum */
142  "h", /* short option */
143  "help", /* long option */
144  "Show this help screen", /* short description */
145  "Show this help screen" /* long description */
146  }
147  };
148 
149  err=GWEN_Init();
150  if (err) {
151  fprintf(stderr, "Could not initialize Gwenhywfar.\n");
152  return 2;
153  }
154 
155  gui=GWEN_Gui_CGui_new();
156  GWEN_Gui_SetGui(gui);
157 
158 #ifdef HAVE_OPENSSL
159  /* for conversion purposes */
160  SSL_load_error_strings();
161  SSL_library_init();
162  GWEN_Gui_SetKeyDataFromTextOpenSslFn(gui, getKeyDataFromTextOpenSSL);
163 #endif
164 
165  GWEN_Logger_Open(GCT_LOGDOMAIN, "gct-tool", 0,
168 
171 
172 #ifdef GCT_IS_EXPERIMENTAL
173  fprintf(stderr, "\n");
174  fprintf(stderr, "\n");
175  fprintf(stderr, "=================== WARNING ===================\n");
176  fprintf(stderr, "This tool is still EXPERIMENTAL !!!\n");
177  fprintf(stderr, "Please DON'T USE it with your daily key files !\n");
178  fprintf(stderr, "===============================================\n");
179  fprintf(stderr, "\n");
180  fprintf(stderr, "\n");
181 #endif
182 
183  db=GWEN_DB_Group_new("arguments");
184  rv=GWEN_Args_Check(argc, argv, 1,
187  args,
188  db);
189  if (rv==GWEN_ARGS_RESULT_ERROR) {
190  fprintf(stderr, "ERROR: Could not parse arguments main\n");
191  return -1;
192  }
193  else if (rv==GWEN_ARGS_RESULT_HELP) {
194  GWEN_BUFFER *ubuf;
195 
196  ubuf=GWEN_Buffer_new(0, 1024, 0, 1);
198  I18N("Usage: "));
199  GWEN_Buffer_AppendString(ubuf, argv[0]);
201  I18N(" [GLOBAL OPTIONS] COMMAND "
202  "[LOCAL OPTIONS]\n"));
204  I18N("\nGlobal Options:\n"));
205  if (GWEN_Args_Usage(args, ubuf, GWEN_ArgsOutType_Txt)) {
206  fprintf(stderr, "ERROR: Could not create help string\n");
207  return 1;
208  }
210  I18N("\nCommands:\n\n"));
212  I18N(" create:\n"
213  " This command creates a crypt token"
214  "\n\n"));
216  I18N(" showuser:\n"
217  " Display user data stored on the "
218  "token\n\n"));
220  I18N(" showkey:\n"
221  " Display key info stored on the "
222  "token\n\n"));
224  I18N(" update:\n"
225  " Update Crypt Token to newer version (e.g. OpenHBCI key"
226  "files)\n\n"));
228  I18N(" showpasswords:\n"
229  " Display passwords store in a GWEN_PASSWD_STORE file\n\n"));
230 
231  fprintf(stderr, "%s\n", GWEN_Buffer_GetStart(ubuf));
232  GWEN_Buffer_free(ubuf);
233  return 0;
234  }
235  if (rv) {
236  argc-=rv-1;
237  argv+=rv-1;
238  }
239 
240  cmd=GWEN_DB_GetCharValue(db, "params", 0, 0);
241  if (!cmd) {
242  fprintf(stderr, "ERROR: Command needed.\n");
243  return 1;
244  }
245 
246  if (strcasecmp(cmd, "create")==0) {
247  rv=createToken(db, argc, argv);
248  }
249  else if (strcasecmp(cmd, "showuser")==0) {
250  rv=showUser(db, argc, argv);
251  }
252  else if (strcasecmp(cmd, "showkey")==0) {
253  rv=showKey(db, argc, argv);
254  }
255  else if (strcasecmp(cmd, "genkey")==0) {
256  rv=genKey(db, argc, argv);
257  }
258  else if (strcasecmp(cmd, "activatekey")==0) {
259  rv=activateKey(db, argc, argv);
260  }
261  else if (strcasecmp(cmd, "update")==0) {
262  rv=updateToken(db, argc, argv);
263  }
264  else if (strcasecmp(cmd, "setsignseq")==0) {
265  rv=setSignSeq(db, argc, argv);
266  }
267  else if (strcasecmp(cmd, "changepin")==0) {
268  rv=changePin(db, argc, argv);
269  }
270  else if (strcasecmp(cmd, "setkey")==0) {
271  rv=setKey(db, argc, argv);
272  }
273  else if (strcasecmp(cmd, "hashTree")==0) {
274  rv=hashTree(db, argc, argv);
275  }
276  else if (strcasecmp(cmd, "checkTree")==0) {
277  rv=checkTree(db, argc, argv);
278  }
279  else if (strcasecmp(cmd, "showpasswords")==0) {
280  rv=showPasswords(db, argc, argv);
281  }
282  else {
283  fprintf(stderr, "ERROR: Unknown command \"%s\".\n", cmd);
284  rv=1;
285  }
286 
287  err=GWEN_Fini();
288  if (err) {
289  fprintf(stderr,
290  "WARNING: Could not deinitialize Gwenhywfar.\n");
291  }
292 
293  return rv;
294 }
295 
296 
297 
struct GWEN_PLUGIN_MANAGER GWEN_PLUGIN_MANAGER
Definition: plugin.h:40
char * GWEN_Buffer_GetStart(const GWEN_BUFFER *bf)
Definition: buffer.c:223
#define I18N(m)
Definition: error.c:42
int setSignSeq(GWEN_DB_NODE *dbArgs, int argc, char **argv)
Definition: setsignseq.c:29
#define GCT_LOGDOMAIN
struct GWEN_DB_NODE GWEN_DB_NODE
Definition: db.h:228
struct GWEN_PLUGIN GWEN_PLUGIN
Definition: plugin.h:39
void GWEN_Logger_SetLevel(const char *logDomain, GWEN_LOGGER_LEVEL l)
Definition: logger.c:604
#define NULL
Definition: binreloc.c:290
GWEN_GUI_KEYDATAFROMTEXT_OPENSSL_FN GWEN_Gui_SetKeyDataFromTextOpenSslFn(GWEN_GUI *gui, GWEN_GUI_KEYDATAFROMTEXT_OPENSSL_FN f)
Definition: gui.c:646
int updateToken(GWEN_DB_NODE *dbArgs, int argc, char **argv)
Definition: update.c:29
GWEN_PLUGIN * GWEN_PluginManager_GetPlugin(GWEN_PLUGIN_MANAGER *pm, const char *s)
Definition: plugin.c:501
#define GWEN_LOGDOMAIN
Definition: logger.h:35
int showKey(GWEN_DB_NODE *dbArgs, int argc, char **argv)
Definition: showkey.c:29
GWEN_CRYPT_TOKEN * GWEN_Crypt_Token_Plugin_CreateToken(GWEN_PLUGIN *pl, const char *name)
Definition: ctplugin.c:138
#define GWEN_ARGS_FLAGS_HELP
Definition: src/base/args.h:52
GWEN_BUFFER * GWEN_Buffer_new(char *buffer, uint32_t size, uint32_t used, int take)
Definition: buffer.c:38
int hashTree(GWEN_DB_NODE *dbArgs, int argc, char **argv)
Definition: hashtree.c:27
GWEN_PLUGIN_MANAGER * GWEN_PluginManager_FindPluginManager(const char *s)
Definition: plugin.c:519
#define GWEN_ARGS_RESULT_HELP
Definition: src/base/args.h:58
#define GWEN_ARGS_RESULT_ERROR
Definition: src/base/args.h:57
int activateKey(GWEN_DB_NODE *dbArgs, int argc, char **argv)
Definition: activatekey.c:26
#define GWEN_ARGS_MODE_STOP_AT_FREEPARAM
Definition: src/base/args.h:55
int showUser(GWEN_DB_NODE *dbArgs, int argc, char **argv)
Definition: showuser.c:27
int setKey(GWEN_DB_NODE *dbArgs, int argc, char **argv)
Definition: setkey.c:29
int GWEN_Args_Usage(const GWEN_ARGS *args, GWEN_BUFFER *ubuf, GWEN_ARGS_OUTTYPE ot)
#define GWEN_ARGS_MODE_ALLOW_FREEPARAM
Definition: src/base/args.h:54
const char * GWEN_DB_GetCharValue(GWEN_DB_NODE *n, const char *path, int idx, const char *defVal)
Definition: db.c:897
void GWEN_Buffer_free(GWEN_BUFFER *bf)
Definition: buffer.c:83
struct GWEN_BUFFER GWEN_BUFFER
A dynamically resizeable text buffer.
Definition: buffer.h:41
int GWEN_Fini(void)
Definition: gwenhywfar.c:301
struct GWEN_CRYPT_TOKEN GWEN_CRYPT_TOKEN
Definition: ct.h:19
#define GWEN_ARGS_FLAGS_LAST
Definition: src/base/args.h:51
int GWEN_Logger_Open(const char *logDomain, const char *ident, const char *file, GWEN_LOGGER_LOGTYPE logtype, GWEN_LOGGER_FACILITY facility)
Definition: logger.c:212
int changePin(GWEN_DB_NODE *dbArgs, int argc, char **argv)
Definition: changepin.c:27
int genKey(GWEN_DB_NODE *dbArgs, int argc, char **argv)
Definition: genkey.c:26
int main(int argc, char **argv)
Definition: gcttool/main.c:107
#define DBG_ERROR(dbg_logger, format, args...)
Definition: debug.h:97
int GWEN_Args_Check(int argc, char **argv, int startAt, uint32_t mode, const GWEN_ARGS *args, GWEN_DB_NODE *db)
Definition: src/base/args.c:45
int checkTree(GWEN_DB_NODE *dbArgs, int argc, char **argv)
Definition: checktree.c:29
int createToken(GWEN_DB_NODE *dbArgs, int argc, char **argv)
GWEN_CRYPT_TOKEN * getCryptToken(const char *ttype, const char *tname)
Definition: gcttool/main.c:69
#define DBG_INFO(dbg_logger, format, args...)
Definition: debug.h:164
struct GWEN_GUI GWEN_GUI
Definition: gui.h:176
GWEN_DB_NODE * GWEN_DB_Group_new(const char *name)
Definition: db.c:131
void GWEN_Gui_SetGui(GWEN_GUI *gui)
Definition: gui.c:152
int showPasswords(GWEN_DB_NODE *dbArgs, int argc, char **argv)
Definition: showpasswords.c:30
int GWEN_Init(void)
Definition: gwenhywfar.c:92
GWEN_GUI * GWEN_Gui_CGui_new(void)
Definition: cgui.c:74
#define GWEN_ARGS_FLAGS_HAS_ARGUMENT
Definition: src/base/args.h:50
int GWEN_Buffer_AppendString(GWEN_BUFFER *bf, const char *buffer)
Definition: buffer.c:1014