gwenhywfar  5.10.1
showuser.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 
22 
23 
24 
25 
26 
27 int showUser(GWEN_DB_NODE *dbArgs, int argc, char **argv)
28 {
29  GWEN_DB_NODE *db;
30  const char *ttype;
31  const char *tname;
32  GWEN_CRYPT_TOKEN *ct;
33  unsigned int cid;
34  int shown=0;
35  int rv;
36  const GWEN_ARGS args[]= {
37  {
38  GWEN_ARGS_FLAGS_HAS_ARGUMENT, /* flags */
39  GWEN_ArgsType_Int, /* type */
40  "contextId", /* name */
41  0, /* minnum */
42  1, /* maxnum */
43  "i", /* short option */
44  "id", /* long option */
45  "Context id (0 for any)", /* short description */
46  "Context id (0 for any)" /* long description */
47  },
48  {
49  GWEN_ARGS_FLAGS_HAS_ARGUMENT, /* flags */
50  GWEN_ArgsType_Char, /* type */
51  "tokenType", /* name */
52  1, /* minnum */
53  1, /* maxnum */
54  "t", /* short option */
55  "ttype", /* long option */
56  "Specify the crypt token type", /* short description */
57  "Specify the crypt token type" /* long description */
58  },
59  {
60  GWEN_ARGS_FLAGS_HAS_ARGUMENT, /* flags */
61  GWEN_ArgsType_Char, /* type */
62  "tokenName", /* name */
63  0, /* minnum */
64  1, /* maxnum */
65  "n", /* short option */
66  "tname", /* long option */
67  "Specify the crypt token name", /* short description */
68  "Specify the crypt token name" /* long description */
69  },
70  {
72  GWEN_ArgsType_Int, /* type */
73  "help", /* name */
74  0, /* minnum */
75  0, /* maxnum */
76  "h", /* short option */
77  "help", /* long option */
78  "Show this help screen", /* short description */
79  "Show this help screen" /* long description */
80  }
81  };
82 
83  db=GWEN_DB_GetGroup(dbArgs, GWEN_DB_FLAGS_DEFAULT, "local");
84  rv=GWEN_Args_Check(argc, argv, 1,
86  args,
87  db);
88  if (rv==GWEN_ARGS_RESULT_ERROR) {
89  fprintf(stderr, "ERROR: Could not parse arguments\n");
90  return 1;
91  }
92  else if (rv==GWEN_ARGS_RESULT_HELP) {
93  GWEN_BUFFER *ubuf;
94 
95  ubuf=GWEN_Buffer_new(0, 1024, 0, 1);
96  if (GWEN_Args_Usage(args, ubuf, GWEN_ArgsOutType_Txt)) {
97  fprintf(stderr, "ERROR: Could not create help string\n");
98  return 1;
99  }
100  fprintf(stderr, "%s\n", GWEN_Buffer_GetStart(ubuf));
101  GWEN_Buffer_free(ubuf);
102  return 0;
103  }
104 
105  cid=GWEN_DB_GetIntValue(db, "contextId", 0, 0);
106 
107  ttype=GWEN_DB_GetCharValue(db, "tokenType", 0, 0);
108  assert(ttype);
109 
110  tname=GWEN_DB_GetCharValue(db, "tokenName", 0, 0);
111 
112  /* get crypt token */
113  ct=getCryptToken(ttype, tname);
114  if (ct==0)
115  return 3;
116 
117  if (GWEN_DB_GetIntValue(dbArgs, "forcePin", 0, 0))
119 
120  /* open crypt token for use */
121  rv=GWEN_Crypt_Token_Open(ct, 0, 0);
122  if (rv) {
123  DBG_ERROR(0, "Could not open token");
124  return 3;
125  }
126  else {
127  uint32_t ctxIds[32];
128  uint32_t ctxCount;
129  uint32_t i;
130 
131  ctxCount=32;
132  rv=GWEN_Crypt_Token_GetContextIdList(ct, ctxIds, &ctxCount, 0);
133  if (rv<0) {
134  DBG_ERROR(0, "Error filling context list");
135  GWEN_Crypt_Token_Close(ct, 0, 0);
136  return 3;
137  }
138  for (i=0; i<ctxCount; i++) {
139  if (cid==0 || cid==ctxIds[i]) {
140  const GWEN_CRYPT_TOKEN_CONTEXT *ctx;
141  const char *s;
142  uint32_t kid;
143 
144  ctx=GWEN_Crypt_Token_GetContext(ct, ctxIds[i], 0);
145  if (ctx) {
146  fprintf(stdout, "-------------------------------------------------\n");
147  fprintf(stdout, "Context %u\n",
148  (unsigned int)GWEN_Crypt_Token_Context_GetId(ctx));
150  if (s)
151  fprintf(stdout, "Service : %s\n", s);
153  if (s)
154  fprintf(stdout, "User Id : %s\n", s);
156  if (s)
157  fprintf(stdout, "Customer Id : %s\n", s);
159  if (s)
160  fprintf(stdout, "User Name : %s\n", s);
162  if (s)
163  fprintf(stdout, "Peer Id : %s\n", s);
165  if (s)
166  fprintf(stdout, "Peer Name : %s\n", s);
168  if (s)
169  fprintf(stdout, "Address : %s\n", s);
170  fprintf(stdout, "Port : %d\n", GWEN_Crypt_Token_Context_GetPort(ctx));
172  if (s)
173  fprintf(stdout, "System Id : %s\n", s);
175  if (kid!=0)
176  fprintf(stdout, "Sign Key Id : %d\n", kid);
178  if (kid!=0)
179  fprintf(stdout, "Verify Key Id : %d\n", kid);
181  if (kid!=0)
182  fprintf(stdout, "Encipher Key Id: %d\n", kid);
184  if (kid!=0)
185  fprintf(stdout, "Decipher Key Id: %d\n", kid);
186 
187  shown++;
188  }
189  else {
190  fprintf(stderr, "Context %d not found (%d)\n", i, ctxIds[i]);
191  }
192  }
193  }
194  }
195 
196  /* close crypt token */
197  rv=GWEN_Crypt_Token_Close(ct, 0, 0);
198  if (rv) {
199  DBG_ERROR(0, "Could not close token");
200  return 3;
201  }
202 
203  if (!shown) {
204  if (cid==0) {
205  DBG_ERROR(0, "No context found");
206  }
207  else {
208  DBG_ERROR(0, "Context %u not found", cid);
209  }
210  return 1;
211  }
212 
213  return 0;
214 
215 }
216 
217 
218 
const char * GWEN_Crypt_Token_Context_GetServiceId(const GWEN_CRYPT_TOKEN_CONTEXT *p_struct)
Definition: ct_context.c:599
#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
uint32_t GWEN_Crypt_Token_Context_GetSignKeyId(const GWEN_CRYPT_TOKEN_CONTEXT *p_struct)
Definition: ct_context.c:491
const char * GWEN_Crypt_Token_Context_GetUserId(const GWEN_CRYPT_TOKEN_CONTEXT *p_struct)
Definition: ct_context.c:605
const char * GWEN_Crypt_Token_Context_GetUserName(const GWEN_CRYPT_TOKEN_CONTEXT *p_struct)
Definition: ct_context.c:617
GWEN_CRYPT_TOKEN * getCryptToken(const char *ttype, const char *tname)
Definition: gcttool/main.c:71
const char * GWEN_Crypt_Token_Context_GetAddress(const GWEN_CRYPT_TOKEN_CONTEXT *p_struct)
Definition: ct_context.c:635
uint32_t GWEN_Crypt_Token_Context_GetEncipherKeyId(const GWEN_CRYPT_TOKEN_CONTEXT *p_struct)
Definition: ct_context.c:515
uint32_t GWEN_Crypt_Token_Context_GetVerifyKeyId(const GWEN_CRYPT_TOKEN_CONTEXT *p_struct)
Definition: ct_context.c:509
int GWEN_Crypt_Token_Close(GWEN_CRYPT_TOKEN *ct, int abandon, uint32_t gid)
Definition: ct.c:265
int GWEN_Crypt_Token_Context_GetPort(const GWEN_CRYPT_TOKEN_CONTEXT *p_struct)
Definition: ct_context.c:641
const char * GWEN_Crypt_Token_Context_GetSystemId(const GWEN_CRYPT_TOKEN_CONTEXT *p_struct)
Definition: ct_context.c:647
uint32_t GWEN_Crypt_Token_Context_GetId(const GWEN_CRYPT_TOKEN_CONTEXT *p_struct)
Definition: ct_context.c:485
#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_ARGS_RESULT_HELP
Definition: src/base/args.h:58
#define GWEN_ARGS_RESULT_ERROR
Definition: src/base/args.h:57
int showUser(GWEN_DB_NODE *dbArgs, int argc, char **argv)
Definition: showuser.c:27
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
const char * GWEN_Crypt_Token_Context_GetPeerId(const GWEN_CRYPT_TOKEN_CONTEXT *p_struct)
Definition: ct_context.c:623
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
const GWEN_CRYPT_TOKEN_CONTEXT * GWEN_Crypt_Token_GetContext(GWEN_CRYPT_TOKEN *ct, uint32_t id, uint32_t gid)
Definition: ct.c:379
struct GWEN_CRYPT_TOKEN_CONTEXT GWEN_CRYPT_TOKEN_CONTEXT
Definition: ct_context.h:221
uint32_t GWEN_Crypt_Token_Context_GetDecipherKeyId(const GWEN_CRYPT_TOKEN_CONTEXT *p_struct)
Definition: ct_context.c:521
#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
const char * GWEN_Crypt_Token_Context_GetPeerName(const GWEN_CRYPT_TOKEN_CONTEXT *p_struct)
Definition: ct_context.c:629
int GWEN_DB_GetIntValue(GWEN_DB_NODE *n, const char *path, int idx, int defVal)
Definition: db.c:1163
const char * GWEN_Crypt_Token_Context_GetCustomerId(const GWEN_CRYPT_TOKEN_CONTEXT *p_struct)
Definition: ct_context.c:611
int GWEN_Crypt_Token_GetContextIdList(GWEN_CRYPT_TOKEN *ct, uint32_t *pIdList, uint32_t *pCount, uint32_t gid)
Definition: ct.c:360
#define GWEN_ARGS_FLAGS_HAS_ARGUMENT
Definition: src/base/args.h:50
#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