gwenhywfar  4.99.8beta
showkey.c
Go to the documentation of this file.
1 /***************************************************************************
2  $RCSfile$
3  -------------------
4  cvs : $Id: create.c 892 2005-11-03 00:20:45Z aquamaniac $
5  begin : Tue May 03 2005
6  copyright : (C) 2005 by Martin Preuss
7  email : martin@libchipcard.de
8 
9  ***************************************************************************
10  * Please see toplevel file COPYING for license details *
11  ***************************************************************************/
12 
13 #ifdef HAVE_CONFIG_H
14 # include <config.h>
15 #endif
16 
17 #include "globals.h"
18 
19 #include <gwenhywfar/debug.h>
20 #include <gwenhywfar/ct.h>
21 #include <gwenhywfar/ctplugin.h>
22 #include <gwenhywfar/text.h>
23 
24 
25 
26 
27 
28 
29 int showKey(GWEN_DB_NODE *dbArgs, int argc, char **argv) {
30  GWEN_DB_NODE *db;
31  const char *ttype;
32  const char *tname;
33  GWEN_CRYPT_TOKEN *ct;
34  unsigned int keyId;
35  int shown=0;
36  int rv;
37  const GWEN_ARGS args[]={
38  {
39  GWEN_ARGS_FLAGS_HAS_ARGUMENT, /* flags */
40  GWEN_ArgsType_Int, /* type */
41  "keyId", /* name */
42  0, /* minnum */
43  1, /* maxnum */
44  "k", /* short option */
45  "key", /* long option */
46  "Key id (0 for any)", /* short description */
47  "Key id (0 for any)" /* long description */
48  },
49  {
50  GWEN_ARGS_FLAGS_HAS_ARGUMENT, /* flags */
51  GWEN_ArgsType_Char, /* type */
52  "tokenType", /* name */
53  1, /* minnum */
54  1, /* maxnum */
55  "t", /* short option */
56  "ttype", /* long option */
57  "Specify the crypt token type", /* short description */
58  "Specify the crypt token type" /* long description */
59  },
60  {
61  GWEN_ARGS_FLAGS_HAS_ARGUMENT, /* flags */
62  GWEN_ArgsType_Char, /* type */
63  "tokenName", /* name */
64  0, /* minnum */
65  1, /* maxnum */
66  "n", /* short option */
67  "tname", /* long option */
68  "Specify the crypt token name", /* short description */
69  "Specify the crypt token name" /* long description */
70  },
71  {
73  GWEN_ArgsType_Int, /* type */
74  "help", /* name */
75  0, /* minnum */
76  0, /* maxnum */
77  "h", /* short option */
78  "help", /* long option */
79  "Show this help screen", /* short description */
80  "Show this help screen" /* long description */
81  }
82  };
83 
84  db=GWEN_DB_GetGroup(dbArgs, GWEN_DB_FLAGS_DEFAULT, "local");
85  rv=GWEN_Args_Check(argc, argv, 1,
87  args,
88  db);
89  if (rv==GWEN_ARGS_RESULT_ERROR) {
90  fprintf(stderr, "ERROR: Could not parse arguments\n");
91  return 1;
92  }
93  else if (rv==GWEN_ARGS_RESULT_HELP) {
94  GWEN_BUFFER *ubuf;
95 
96  ubuf=GWEN_Buffer_new(0, 1024, 0, 1);
97  if (GWEN_Args_Usage(args, ubuf, GWEN_ArgsOutType_Txt)) {
98  fprintf(stderr, "ERROR: Could not create help string\n");
99  return 1;
100  }
101  fprintf(stderr, "%s\n", GWEN_Buffer_GetStart(ubuf));
102  GWEN_Buffer_free(ubuf);
103  return 0;
104  }
105 
106  keyId=GWEN_DB_GetIntValue(db, "keyId", 0, 0);
107 
108  ttype=GWEN_DB_GetCharValue(db, "tokenType", 0, 0);
109  assert(ttype);
110 
111  tname=GWEN_DB_GetCharValue(db, "tokenName", 0, 0);
112 
113  /* get crypt token */
114  ct=getCryptToken(ttype, tname);
115  if (ct==0)
116  return 3;
117 
118  if (GWEN_DB_GetIntValue(dbArgs, "forcePin", 0, 0))
120 
121  /* open crypt token for use */
122  rv=GWEN_Crypt_Token_Open(ct, 0, 0);
123  if (rv) {
124  DBG_ERROR(0, "Could not open token");
125  return 3;
126  }
127  else {
128  uint32_t keyIds[64];
129  uint32_t keyCount;
130  uint32_t i;
131 
132  keyCount=64;
133  rv=GWEN_Crypt_Token_GetKeyIdList(ct, keyIds, &keyCount, 0);
134  if (rv<0) {
135  DBG_ERROR(0, "Error filling key list");
136  GWEN_Crypt_Token_Close(ct, 0, 0);
137  return 3;
138  }
139  for (i=0; i<keyCount; i++) {
140  if (keyId==0 || keyId==keyIds[i]) {
141  const GWEN_CRYPT_TOKEN_KEYINFO *ki;
142  uint32_t flags;
143  const char *s;
144 
145  ki=GWEN_Crypt_Token_GetKeyInfo(ct, keyIds[i], 0xffffffff, 0);
146  if (ki) {
147  fprintf(stdout, "-------------------------------------------------\n");
148  fprintf(stdout, "Key %08x\n",
149  (unsigned int)GWEN_Crypt_Token_KeyInfo_GetId(ki));
150 
152  if (s)
153  fprintf(stdout, "Key Descr : %s\n", s);
154 
155  fprintf(stdout, "Crypt Algo : %s\n",
157  fprintf(stdout, "Key Size : %d\n", GWEN_Crypt_Token_KeyInfo_GetKeySize(ki));
158 
159  fprintf(stdout, "Key Flags :");
162  fprintf(stdout, " STATUS");
164  fprintf(stdout, " MODULUS");
166  fprintf(stdout, " EXPONENT");
168  fprintf(stdout, " KEYVERSION");
170  fprintf(stdout, " KEYNUMBER");
172  fprintf(stdout, " SIGNCOUNTER");
175  fprintf(stdout, " SIGN");
177  fprintf(stdout, " VERIFY");
179  fprintf(stdout, " ENCIPHER");
181  fprintf(stdout, " DECIPHER");
182  }
183  fprintf(stdout, "\n");
184 
185  if (flags & GWEN_CRYPT_TOKEN_KEYFLAGS_HASKEYNUMBER)
186  fprintf(stdout, "Key Number : %d\n", GWEN_Crypt_Token_KeyInfo_GetKeyNumber(ki));
187  if (flags & GWEN_CRYPT_TOKEN_KEYFLAGS_HASKEYVERSION)
188  fprintf(stdout, "Key Version: %d\n", GWEN_Crypt_Token_KeyInfo_GetKeyVersion(ki));
189  if (flags & GWEN_CRYPT_TOKEN_KEYFLAGS_HASSIGNCOUNTER)
190  fprintf(stdout, "Sign Cnt : %d\n", GWEN_Crypt_Token_KeyInfo_GetSignCounter(ki));
191  if (flags & GWEN_CRYPT_TOKEN_KEYFLAGS_HASMODULUS) {
192  GWEN_BUFFER *tbuf;
193  const uint8_t *p;
194  uint32_t len;
195  int nbits;
196 
197  tbuf=GWEN_Buffer_new(0, 256, 0, 1);
198  p=(const uint8_t*)GWEN_Crypt_Token_KeyInfo_GetModulusData(ki);
200 
201  nbits=len*8;
202  while(len && *p==0) {
203  p++;
204  len--;
205  nbits-=8;
206  }
207  if (len) {
208  int i;
209  uint8_t mask=0x80;
210  uint8_t b=*p;
211 
212  for (i=0; i<8; i++) {
213  if (b & mask)
214  break;
215  nbits--;
216  mask>>=1;
217  }
218  }
219 
220  fprintf(stdout, "Modulus : (%d bits)\n", nbits);
221 
222  while(len) {
223  uint32_t rl;
224 
225  rl=(len>16)?16:len;
226  GWEN_Text_ToHexBuffer((const char*)p, rl, tbuf, 2, ' ', 0);
227  fprintf(stdout, " %s\n", GWEN_Buffer_GetStart(tbuf));
228  GWEN_Buffer_Reset(tbuf);
229  p+=rl;
230  len-=rl;
231  }
232  GWEN_Buffer_free(tbuf);
233  }
234 
235  if (flags & GWEN_CRYPT_TOKEN_KEYFLAGS_HASEXPONENT) {
236  GWEN_BUFFER *tbuf;
237  const char *p;
238  uint32_t len;
239 
240  tbuf=GWEN_Buffer_new(0, 256, 0, 1);
241  fprintf(stdout, "Exponent : \n");
242  p=(const char*)GWEN_Crypt_Token_KeyInfo_GetExponentData(ki);
244  while(len) {
245  uint32_t rl;
246 
247  rl=(len>16)?16:len;
248  GWEN_Text_ToHexBuffer(p, rl, tbuf, 2, ' ', 0);
249  fprintf(stdout, " %s\n", GWEN_Buffer_GetStart(tbuf));
250  GWEN_Buffer_Reset(tbuf);
251  p+=rl;
252  len-=rl;
253  }
254  GWEN_Buffer_free(tbuf);
255  }
256 
257  shown++;
258  }
259  }
260  }
261  }
262 
263  /* close crypt token */
264  rv=GWEN_Crypt_Token_Close(ct, 0, 0);
265  if (rv) {
266  DBG_ERROR(0, "Could not close token");
267  return 3;
268  }
269 
270  if (!shown) {
271  if (keyId==0) {
272  DBG_ERROR(0, "No key found");
273  }
274  else {
275  DBG_ERROR(0, "Key %u not found", keyId);
276  }
277  return 1;
278  }
279 
280  return 0;
281 }
282 
283 
284 
#define GWEN_CRYPT_TOKEN_MODE_FORCE_PIN_ENTRY
Definition: ct.h:59
char * GWEN_Buffer_GetStart(const GWEN_BUFFER *bf)
Definition: buffer.c:223
struct GWEN_DB_NODE GWEN_DB_NODE
Definition: db.h:228
const uint8_t * GWEN_Crypt_Token_KeyInfo_GetModulusData(const GWEN_CRYPT_TOKEN_KEYINFO *st)
Definition: ct_keyinfo.c:786
uint32_t GWEN_Crypt_Token_KeyInfo_GetId(const GWEN_CRYPT_TOKEN_KEYINFO *p_struct)
Definition: ct_keyinfo.c:245
GWEN_CRYPT_TOKEN * getCryptToken(const char *ttype, const char *tname)
Definition: gcttool/main.c:69
#define GWEN_CRYPT_TOKEN_KEYFLAGS_HASMODULUS
Definition: ct_keyinfo.h:94
int GWEN_Crypt_Token_Close(GWEN_CRYPT_TOKEN *ct, int abandon, uint32_t gid)
Definition: ct.c:247
uint32_t GWEN_Crypt_Token_KeyInfo_GetSignCounter(const GWEN_CRYPT_TOKEN_KEYINFO *p_struct)
Definition: ct_keyinfo.c:287
#define GWEN_CRYPT_TOKEN_KEYFLAGS_CANSIGN
Definition: ct_keyinfo.h:102
#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
#define GWEN_CRYPT_TOKEN_KEYFLAGS_HASSIGNCOUNTER
Definition: ct_keyinfo.h:98
void GWEN_Buffer_Reset(GWEN_BUFFER *bf)
Definition: buffer.c:684
#define GWEN_ARGS_RESULT_HELP
Definition: src/base/args.h:58
uint32_t GWEN_Crypt_Token_KeyInfo_GetModulusLen(const GWEN_CRYPT_TOKEN_KEYINFO *st)
Definition: ct_keyinfo.c:792
int GWEN_Crypt_Token_GetKeyIdList(GWEN_CRYPT_TOKEN *ct, uint32_t *pIdList, uint32_t *pCount, uint32_t gid)
Definition: ct.c:281
#define GWEN_ARGS_RESULT_ERROR
Definition: src/base/args.h:57
int showKey(GWEN_DB_NODE *dbArgs, int argc, char **argv)
Definition: showkey.c:29
#define GWEN_CRYPT_TOKEN_KEYFLAGS_CANDECIPHER
Definition: ct_keyinfo.h:105
uint32_t GWEN_Crypt_Token_KeyInfo_GetKeyVersion(const GWEN_CRYPT_TOKEN_KEYINFO *p_struct)
Definition: ct_keyinfo.c:281
const char * GWEN_Crypt_CryptAlgoId_toString(GWEN_CRYPT_CRYPTALGOID a)
Definition: cryptalgo.c:52
int GWEN_Crypt_Token_KeyInfo_GetKeySize(const GWEN_CRYPT_TOKEN_KEYINFO *p_struct)
Definition: ct_keyinfo.c:263
const uint8_t * GWEN_Crypt_Token_KeyInfo_GetExponentData(const GWEN_CRYPT_TOKEN_KEYINFO *st)
Definition: ct_keyinfo.c:807
int GWEN_Args_Usage(const GWEN_ARGS *args, GWEN_BUFFER *ubuf, GWEN_ARGS_OUTTYPE ot)
#define GWEN_CRYPT_TOKEN_KEYFLAGS_CANVERIFY
Definition: ct_keyinfo.h:103
#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
uint32_t GWEN_Crypt_Token_KeyInfo_GetFlags(const GWEN_CRYPT_TOKEN_KEYINFO *p_struct)
Definition: ct_keyinfo.c:257
int GWEN_Crypt_Token_KeyInfo_GetCryptAlgoId(const GWEN_CRYPT_TOKEN_KEYINFO *p_struct)
Definition: ct_keyinfo.c:269
GWEN_DB_NODE * GWEN_DB_GetGroup(GWEN_DB_NODE *n, uint32_t flags, const char *path)
Definition: db.c:1260
void GWEN_Buffer_free(GWEN_BUFFER *bf)
Definition: buffer.c:83
#define GWEN_CRYPT_TOKEN_KEYFLAGS_HASEXPONENT
Definition: ct_keyinfo.h:95
struct GWEN_BUFFER GWEN_BUFFER
A dynamically resizeable text buffer.
Definition: buffer.h:41
struct GWEN_CRYPT_TOKEN GWEN_CRYPT_TOKEN
Definition: ct.h:19
#define GWEN_ARGS_FLAGS_LAST
Definition: src/base/args.h:51
int GWEN_Crypt_Token_Open(GWEN_CRYPT_TOKEN *ct, int admin, uint32_t gid)
Definition: ct.c:206
#define GWEN_CRYPT_TOKEN_KEYFLAGS_HASACTIONFLAGS
Definition: ct_keyinfo.h:96
const char * GWEN_Crypt_Token_KeyInfo_GetKeyDescr(const GWEN_CRYPT_TOKEN_KEYINFO *p_struct)
Definition: ct_keyinfo.c:251
#define GWEN_CRYPT_TOKEN_KEYFLAGS_HASKEYVERSION
Definition: ct_keyinfo.h:97
struct GWEN_CRYPT_TOKEN_KEYINFO GWEN_CRYPT_TOKEN_KEYINFO
Definition: ct_keyinfo.h:121
#define GWEN_CRYPT_TOKEN_KEYFLAGS_CANENCIPHER
Definition: ct_keyinfo.h:104
#define GWEN_CRYPT_TOKEN_KEYFLAGS_HASKEYNUMBER
Definition: ct_keyinfo.h:99
#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
#define GWEN_CRYPT_TOKEN_KEYFLAGS_HASSTATUS
Definition: ct_keyinfo.h:93
uint32_t GWEN_Crypt_Token_KeyInfo_GetExponentLen(const GWEN_CRYPT_TOKEN_KEYINFO *st)
Definition: ct_keyinfo.c:813
int GWEN_DB_GetIntValue(GWEN_DB_NODE *n, const char *path, int idx, int defVal)
Definition: db.c:1048
#define GWEN_ARGS_FLAGS_HAS_ARGUMENT
Definition: src/base/args.h:50
int GWEN_Text_ToHexBuffer(const char *src, unsigned l, GWEN_BUFFER *buf, unsigned int groupsize, char delimiter, int skipLeadingZeroes)
Definition: text.c:740
uint32_t GWEN_Crypt_Token_KeyInfo_GetKeyNumber(const GWEN_CRYPT_TOKEN_KEYINFO *p_struct)
Definition: ct_keyinfo.c:275
#define GWEN_DB_FLAGS_DEFAULT
Definition: db.h:168
void GWEN_Crypt_Token_AddModes(GWEN_CRYPT_TOKEN *ct, uint32_t f)
Definition: ct.c:188
const GWEN_CRYPT_TOKEN_KEYINFO * GWEN_Crypt_Token_GetKeyInfo(GWEN_CRYPT_TOKEN *ct, uint32_t id, uint32_t flags, uint32_t gid)
Definition: ct.c:299