gwenhywfar  5.10.1
setkey.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 setKey(GWEN_DB_NODE *dbArgs, int argc, char **argv)
30 {
31  GWEN_DB_NODE *db;
32  const char *ttype;
33  const char *tname;
34  GWEN_CRYPT_TOKEN *ct;
35  unsigned int keyId;
36  int seq;
37  int keyNum;
38  int keyVer;
39  int rv;
40  const GWEN_ARGS args[]= {
41  {
42  GWEN_ARGS_FLAGS_HAS_ARGUMENT, /* flags */
43  GWEN_ArgsType_Int, /* type */
44  "keyId", /* name */
45  1, /* minnum */
46  1, /* maxnum */
47  "k", /* short option */
48  "key", /* long option */
49  "Key id (0 for any)", /* short description */
50  "Key id (0 for any)" /* long description */
51  },
52  {
53  GWEN_ARGS_FLAGS_HAS_ARGUMENT, /* flags */
54  GWEN_ArgsType_Int, /* type */
55  "keyNum", /* name */
56  0, /* minnum */
57  1, /* maxnum */
58  0, /* short option */
59  "keynum", /* long option */
60  "Key number", /* short description */
61  "Key number" /* long description */
62  },
63  {
64  GWEN_ARGS_FLAGS_HAS_ARGUMENT, /* flags */
65  GWEN_ArgsType_Int, /* type */
66  "keyVer", /* name */
67  0, /* minnum */
68  1, /* maxnum */
69  0, /* short option */
70  "keyver", /* long option */
71  "Key version", /* short description */
72  "Key version" /* long description */
73  },
74  {
75  GWEN_ARGS_FLAGS_HAS_ARGUMENT, /* flags */
76  GWEN_ArgsType_Int, /* type */
77  "seq", /* name */
78  0, /* minnum */
79  1, /* maxnum */
80  "s", /* short option */
81  "seq", /* long option */
82  "New sequence counter value", /* short description */
83  "New sequence counter value" /* long description */
84  },
85  {
86  GWEN_ARGS_FLAGS_HAS_ARGUMENT, /* flags */
87  GWEN_ArgsType_Char, /* type */
88  "tokenType", /* name */
89  1, /* minnum */
90  1, /* maxnum */
91  "t", /* short option */
92  "ttype", /* long option */
93  "Specify the crypt token type", /* short description */
94  "Specify the crypt token type" /* long description */
95  },
96  {
97  GWEN_ARGS_FLAGS_HAS_ARGUMENT, /* flags */
98  GWEN_ArgsType_Char, /* type */
99  "tokenName", /* name */
100  0, /* minnum */
101  1, /* maxnum */
102  "n", /* short option */
103  "tname", /* long option */
104  "Specify the crypt token name", /* short description */
105  "Specify the crypt token name" /* long description */
106  },
107  {
109  GWEN_ArgsType_Int, /* type */
110  "help", /* name */
111  0, /* minnum */
112  0, /* maxnum */
113  "h", /* short option */
114  "help", /* long option */
115  "Show this help screen", /* short description */
116  "Show this help screen" /* long description */
117  }
118  };
119 
120  db=GWEN_DB_GetGroup(dbArgs, GWEN_DB_FLAGS_DEFAULT, "local");
121  rv=GWEN_Args_Check(argc, argv, 1,
123  args,
124  db);
125  if (rv==GWEN_ARGS_RESULT_ERROR) {
126  fprintf(stderr, "ERROR: Could not parse arguments\n");
127  return 1;
128  }
129  else if (rv==GWEN_ARGS_RESULT_HELP) {
130  GWEN_BUFFER *ubuf;
131 
132  ubuf=GWEN_Buffer_new(0, 1024, 0, 1);
133  if (GWEN_Args_Usage(args, ubuf, GWEN_ArgsOutType_Txt)) {
134  fprintf(stderr, "ERROR: Could not create help string\n");
135  return 1;
136  }
137  fprintf(stderr, "%s\n", GWEN_Buffer_GetStart(ubuf));
138  GWEN_Buffer_free(ubuf);
139  return 0;
140  }
141 
142  keyId=GWEN_DB_GetIntValue(db, "keyId", 0, 0);
143  seq=GWEN_DB_GetIntValue(db, "seq", 0, -1);
144  keyNum=GWEN_DB_GetIntValue(db, "keyNum", 0, -1);
145  keyVer=GWEN_DB_GetIntValue(db, "keyVer", 0, -1);
146 
147  ttype=GWEN_DB_GetCharValue(db, "tokenType", 0, 0);
148  assert(ttype);
149 
150  tname=GWEN_DB_GetCharValue(db, "tokenName", 0, 0);
151 
152  /* get crypt token */
153  ct=getCryptToken(ttype, tname);
154  if (ct==0)
155  return 3;
156 
157  if (GWEN_DB_GetIntValue(dbArgs, "forcePin", 0, 0))
159 
160  /* open crypt token for use */
161  rv=GWEN_Crypt_Token_Open(ct, 0, 0);
162  if (rv) {
163  DBG_ERROR(0, "Could not open token");
164  return 3;
165  }
166  else {
167  const GWEN_CRYPT_TOKEN_KEYINFO *ki;
168 
169  ki=GWEN_Crypt_Token_GetKeyInfo(ct, keyId,
171  0);
172  if (ki) {
174 
176  if (seq!=-1) {
178  fprintf(stderr, "Setting signature counter\n");
179  }
180 
181  if (keyNum!=-1) {
182  fprintf(stderr, "Setting key number\n");
186  }
187 
188  if (keyVer!=-1) {
189  fprintf(stderr, "Setting key version\n");
193  }
194 
195  /* store key info */
196  rv=GWEN_Crypt_Token_SetKeyInfo(ct, keyId, nki, 0);
198  if (rv) {
199  DBG_ERROR(GWEN_LOGDOMAIN, "Unable to set modify key information (%d)", rv);
200  return 4;
201  }
202  }
203  }
204 
205  /* close crypt token */
206  rv=GWEN_Crypt_Token_Close(ct, 0, 0);
207  if (rv) {
208  DBG_ERROR(0, "Could not close token");
209  return 3;
210  }
211 
212  return 0;
213 }
214 
215 
216 
#define GWEN_CRYPT_TOKEN_MODE_FORCE_PIN_ENTRY
Definition: ct.h:59
char * GWEN_Buffer_GetStart(const GWEN_BUFFER *bf)
Definition: buffer.c:235
struct GWEN_DB_NODE GWEN_DB_NODE
Definition: db.h:228
void GWEN_Crypt_Token_KeyInfo_free(GWEN_CRYPT_TOKEN_KEYINFO *p_struct)
Definition: ct_keyinfo.c:78
GWEN_CRYPT_TOKEN * getCryptToken(const char *ttype, const char *tname)
Definition: gcttool/main.c:71
int GWEN_Crypt_Token_Close(GWEN_CRYPT_TOKEN *ct, int abandon, uint32_t gid)
Definition: ct.c:265
int GWEN_Crypt_Token_SetKeyInfo(GWEN_CRYPT_TOKEN *ct, uint32_t id, const GWEN_CRYPT_TOKEN_KEYINFO *ki, uint32_t gid)
Definition: ct.c:341
#define GWEN_LOGDOMAIN
Definition: logger.h:35
#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
#define GWEN_CRYPT_TOKEN_KEYFLAGS_HASSIGNCOUNTER
Definition: ct_keyinfo.h:104
#define GWEN_ARGS_RESULT_HELP
Definition: src/base/args.h:58
GWEN_CRYPT_TOKEN_KEYINFO * GWEN_Crypt_Token_KeyInfo_dup(const GWEN_CRYPT_TOKEN_KEYINFO *p_src)
Definition: ct_keyinfo.c:109
#define GWEN_ARGS_RESULT_ERROR
Definition: src/base/args.h:57
void GWEN_Crypt_Token_KeyInfo_SetKeyVersion(GWEN_CRYPT_TOKEN_KEYINFO *p_struct, uint32_t p_src)
Definition: ct_keyinfo.c:365
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
GWEN_DB_NODE * GWEN_DB_GetGroup(GWEN_DB_NODE *n, uint32_t flags, const char *path)
Definition: db.c:1381
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
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:222
#define GWEN_CRYPT_TOKEN_KEYFLAGS_HASKEYVERSION
Definition: ct_keyinfo.h:103
struct GWEN_CRYPT_TOKEN_KEYINFO GWEN_CRYPT_TOKEN_KEYINFO
Definition: ct_keyinfo.h:127
#define GWEN_CRYPT_TOKEN_KEYFLAGS_HASKEYNUMBER
Definition: ct_keyinfo.h:105
#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
void GWEN_Crypt_Token_KeyInfo_SetKeyNumber(GWEN_CRYPT_TOKEN_KEYINFO *p_struct, uint32_t p_src)
Definition: ct_keyinfo.c:359
int GWEN_DB_GetIntValue(GWEN_DB_NODE *n, const char *path, int idx, int defVal)
Definition: db.c:1163
int setKey(GWEN_DB_NODE *dbArgs, int argc, char **argv)
Definition: setkey.c:29
void GWEN_Crypt_Token_KeyInfo_SetSignCounter(GWEN_CRYPT_TOKEN_KEYINFO *p_struct, uint32_t p_src)
Definition: ct_keyinfo.c:371
#define GWEN_ARGS_FLAGS_HAS_ARGUMENT
Definition: src/base/args.h:50
void GWEN_Crypt_Token_KeyInfo_AddFlags(GWEN_CRYPT_TOKEN_KEYINFO *p_struct, uint32_t p_src)
Definition: ct_keyinfo.c:335
#define GWEN_DB_FLAGS_DEFAULT
Definition: db.h:168
void GWEN_Crypt_Token_AddModes(GWEN_CRYPT_TOKEN *ct, uint32_t f)
Definition: ct.c:202
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:320