1 /***************************************************************************
2 begin : Tue May 03 2005
3 copyright : (C) 2018 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
15 #include "globals_l.h"
16
17 #include <gwenhywfar/text.h>
18
19
20
AH_Control_ListUsers(AB_PROVIDER * pro,GWEN_DB_NODE * dbArgs,int argc,char ** argv)21 int AH_Control_ListUsers(AB_PROVIDER *pro,
22 GWEN_DB_NODE *dbArgs,
23 int argc,
24 char **argv)
25 {
26 GWEN_DB_NODE *db;
27 int rv;
28 int xml=0;
29 AB_USER_LIST *ul;
30 AB_USER *u;
31 int i=0;
32
33 const GWEN_ARGS args[]= {
34 {
35 0, /* flags */
36 GWEN_ArgsType_Int, /* type */
37 "xml", /* name */
38 0, /* minnum */
39 1, /* maxnum */
40 0, /* short option */
41 "xml", /* long option */
42 "Export as xml", /* short description */
43 0
44 },
45 {
46 GWEN_ARGS_FLAGS_HELP | GWEN_ARGS_FLAGS_LAST, /* flags */
47 GWEN_ArgsType_Int, /* type */
48 "help", /* name */
49 0, /* minnum */
50 0, /* maxnum */
51 "h", /* short option */
52 "help", /* long option */
53 "Show this help screen", /* short description */
54 "Show this help screen" /* long description */
55 }
56 };
57
58 db=GWEN_DB_GetGroup(dbArgs, GWEN_DB_FLAGS_DEFAULT, "local");
59 rv=GWEN_Args_Check(argc, argv, 1,
60 0 /*GWEN_ARGS_MODE_ALLOW_FREEPARAM*/,
61 args,
62 db);
63 if (rv==GWEN_ARGS_RESULT_ERROR) {
64 fprintf(stderr, "ERROR: Could not parse arguments\n");
65 return 1;
66 }
67 else if (rv==GWEN_ARGS_RESULT_HELP) {
68 GWEN_BUFFER *ubuf;
69
70 ubuf=GWEN_Buffer_new(0, 1024, 0, 1);
71 if (GWEN_Args_Usage(args, ubuf, GWEN_ArgsOutType_Txt)) {
72 fprintf(stderr, "ERROR: Could not create help string\n");
73 return 1;
74 }
75 fprintf(stdout, "%s\n", GWEN_Buffer_GetStart(ubuf));
76 GWEN_Buffer_free(ubuf);
77 return 0;
78 }
79
80 xml=GWEN_DB_VariableExists(db, "xml");
81
82 if (xml) {
83 fprintf(stdout, "<?xml version=\"1.0\"?>\n");
84 fprintf(stdout, "<users>\n");
85 }
86
87 ul=AB_User_List_new();
88 rv=AB_Provider_ReadUsers(pro, ul);
89 if (rv<0) {
90 if (rv==GWEN_ERROR_NOT_FOUND) {
91 DBG_ERROR(0, "No users found.");
92 }
93 else {
94 DBG_ERROR_ERR(0, rv);
95 }
96 AB_User_List_free(ul);
97 return 3;
98 }
99
100 u=AB_User_List_First(ul);
101 while (u) {
102 if (!xml) {
103 fprintf(stdout, "User %d: Bank: %s/%s User Id: %s Customer Id: %s Unique Id: %lu\n",
104 i++,
105 AB_User_GetCountry(u),
106 AB_User_GetBankCode(u),
107 AB_User_GetUserId(u),
108 AB_User_GetCustomerId(u),
109 (unsigned long int) AB_User_GetUniqueId(u));
110 }
111 else {
112 const char *name = AB_User_GetUserName(u);
113 fprintf(stdout, " <user>\n");
114 fprintf(stdout, " <userUniqueId>%lu</userUniqueId>\n", (unsigned long int) AB_User_GetUniqueId(u));
115 if (!name)
116 fprintf(stdout, " <UserName></UserName>\n");
117 else
118 fprintf(stdout, " <UserName><![CDATA[%s]]></UserName>\n", name);
119 fprintf(stdout, " <UserId>%s</UserId>\n", AB_User_GetUserId(u));
120 fprintf(stdout, " <CustomerId>%s</CustomerId>\n", AB_User_GetCustomerId(u));
121 fprintf(stdout, " <BankCode>%s</BankCode>\n", AB_User_GetBankCode(u));
122 fprintf(stdout, " <Country>%s</Country>\n", AB_User_GetCountry(u));
123 fprintf(stdout, " <LastSessionId>%d</LastSessionId>\n", AB_User_GetLastSessionId(u));
124 fprintf(stdout, " </user>\n\n");
125 }
126 u=AB_User_List_Next(u);
127 }
128 AB_User_List_free(ul);
129
130 if (xml) {
131 fprintf(stdout, "</users>\n");
132 }
133
134 return 0;
135 }
136
137
138
139
140