gwenhywfar 5.14.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
29int setKey(GWEN_DB_NODE *dbArgs, int argc, char **argv)
30{
31 GWEN_DB_NODE *db;
32 const char *ttype;
33 const char *tname;
35 unsigned int keyId;
36 int seq;
37 int keyNum;
38 int keyVer;
39 int rv;
40 const GWEN_ARGS args[]= {
41 {
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 {
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 {
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 {
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 {
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 {
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
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
char * GWEN_Buffer_GetStart(const GWEN_BUFFER *bf)
Definition buffer.c:235
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
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
int GWEN_Crypt_Token_Open(GWEN_CRYPT_TOKEN *ct, int admin, uint32_t gid)
Definition ct.c:222
int GWEN_Crypt_Token_Close(GWEN_CRYPT_TOKEN *ct, int abandon, uint32_t gid)
Definition ct.c:265
void GWEN_Crypt_Token_AddModes(GWEN_CRYPT_TOKEN *ct, uint32_t f)
Definition ct.c:202
#define GWEN_CRYPT_TOKEN_MODE_FORCE_PIN_ENTRY
Definition ct.h:59
struct GWEN_CRYPT_TOKEN GWEN_CRYPT_TOKEN
Definition ct.h:19
GWEN_CRYPT_TOKEN_KEYINFO * GWEN_Crypt_Token_KeyInfo_dup(const GWEN_CRYPT_TOKEN_KEYINFO *p_src)
Definition ct_keyinfo.c:109
void GWEN_Crypt_Token_KeyInfo_free(GWEN_CRYPT_TOKEN_KEYINFO *p_struct)
Definition ct_keyinfo.c:78
void GWEN_Crypt_Token_KeyInfo_SetKeyVersion(GWEN_CRYPT_TOKEN_KEYINFO *p_struct, uint32_t p_src)
Definition ct_keyinfo.c:365
void GWEN_Crypt_Token_KeyInfo_SetSignCounter(GWEN_CRYPT_TOKEN_KEYINFO *p_struct, uint32_t p_src)
Definition ct_keyinfo.c:371
void GWEN_Crypt_Token_KeyInfo_SetKeyNumber(GWEN_CRYPT_TOKEN_KEYINFO *p_struct, uint32_t p_src)
Definition ct_keyinfo.c:359
void GWEN_Crypt_Token_KeyInfo_AddFlags(GWEN_CRYPT_TOKEN_KEYINFO *p_struct, uint32_t p_src)
Definition ct_keyinfo.c:335
#define GWEN_CRYPT_TOKEN_KEYFLAGS_HASKEYNUMBER
Definition ct_keyinfo.h:105
#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_HASSIGNCOUNTER
Definition ct_keyinfo.h:104
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
int GWEN_DB_GetIntValue(GWEN_DB_NODE *n, const char *path, int idx, int defVal)
Definition db.c:1163
#define GWEN_DB_FLAGS_DEFAULT
Definition db.h:168
struct GWEN_DB_NODE GWEN_DB_NODE
Definition db.h:228
#define DBG_ERROR(dbg_logger, format,...)
Definition debug.h:97
GWEN_CRYPT_TOKEN * getCryptToken(const char *ttype, const char *tname)
struct GWEN_BUFFER GWEN_BUFFER
A dynamically resizeable text buffer.
Definition buffer.h:38
#define GWEN_LOGDOMAIN
Definition logger.h:32
int setKey(GWEN_DB_NODE *dbArgs, int argc, char **argv)
Definition setkey.c:29
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_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