gwenhywfar  5.10.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
48 int 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 
71 GWEN_CRYPT_TOKEN *getCryptToken(const char *ttype,
72  const char *tname)
73 {
75  GWEN_PLUGIN *pl;
76  GWEN_CRYPT_TOKEN *ct;
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 
110 int 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  {
119  GWEN_ARGS_FLAGS_HAS_ARGUMENT, /* flags */
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 
struct GWEN_PLUGIN_MANAGER GWEN_PLUGIN_MANAGER
Definition: plugin.h:40
char * GWEN_Buffer_GetStart(const GWEN_BUFFER *bf)
Definition: buffer.c:235
#define I18N(m)
Definition: error.c:42
int setSignSeq(GWEN_DB_NODE *dbArgs, int argc, char **argv)
Definition: setsignseq.c:29
#define GCT_LOGDOMAIN
Definition: cttest.c:47
GWENHYWFAR_API GWEN_GUI_KEYDATAFROMTEXT_OPENSSL_FN GWEN_Gui_SetKeyDataFromTextOpenSslFn(GWEN_GUI *gui, GWEN_GUI_KEYDATAFROMTEXT_OPENSSL_FN f)
Definition: gui_virtual.c:325
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:627
#define NULL
Definition: binreloc.c:300
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:529
#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:146
#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:42
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:548
#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
#define GWEN_FE_END
Definition: funcs.h:71
#define GWEN_FE_DA
Definition: funcs.h:69
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:971
void GWEN_Buffer_free(GWEN_BUFFER *bf)
Definition: buffer.c:89
struct GWEN_BUFFER GWEN_BUFFER
A dynamically resizeable text buffer.
Definition: buffer.h:38
int GWEN_Fini(void)
Definition: gwenhywfar.c:303
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:225
int GWEN_Funcs_Call_DB_NODE_Args(const GWEN_FUNCS *func, GWEN_DB_NODE *node, int argc, char **argv)
Definition: funcs.c:59
const GWEN_FUNCS * GWEN_Funcs_Find(const GWEN_FUNCS *funcs, const char *name)
Definition: funcs.c:95
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:110
#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:71
#define DBG_INFO(dbg_logger, format, args...)
Definition: debug.h:181
struct GWEN_GUI GWEN_GUI
Definition: gui.h:176
GWEN_DB_NODE * GWEN_DB_Group_new(const char *name)
Definition: db.c:173
void GWEN_Funcs_Usage_With_Help(const GWEN_FUNCS *funcs)
Definition: funcs.c:82
void GWEN_Gui_SetGui(GWEN_GUI *gui)
Definition: gui.c:170
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
#define GWEN_UNUSED
int GWEN_Buffer_AppendString(GWEN_BUFFER *bf, const char *buffer)
Definition: buffer.c:989
#define GWEN_FE_DAH
Definition: funcs.h:68