1 |
/************************************/ |
2 |
/* Smart Card support for RDesktop. */ |
3 |
/* Copyright (C) by Alexi Volkov */ |
4 |
/* e-mail: alexi@myrealbox.com */ |
5 |
/* ICQ: 264679502 */ |
6 |
/************************************/ |
7 |
|
8 |
#include <pthread.h> |
9 |
#include <pcsclite.h> |
10 |
#include "proto.h" |
11 |
|
12 |
/*************************************************************************/ |
13 |
/* these are the additional types needed to split out 64-vs-32-bit APIs */ |
14 |
/* */ |
15 |
|
16 |
/* The point of all of this is to avoid patching the existing smartcard |
17 |
* infrastructure (PC/SC Lite, libmusclecard+libmusclepkcs11 or CoolKey, any |
18 |
* other apps linking against any of these) because the need for patches |
19 |
* spreads without limit. The alternative is to patch the heck out of rdesktop, |
20 |
* which is already being done anyway. |
21 |
* |
22 |
* - jared.jennings@eglin.af.mil, 2 Aug 2006 |
23 |
*/ |
24 |
|
25 |
#include <stdint.h> |
26 |
|
27 |
/* A DWORD when dealing with the smartcard stuff. Could be 32 bits or 64. */ |
28 |
typedef DWORD MYPCSC_DWORD; |
29 |
/* A DWORD when talking to the server. Must be exactly 32 bits all the time.*/ |
30 |
typedef uint32_t SERVER_DWORD; |
31 |
|
32 |
typedef SCARDCONTEXT MYPCSC_SCARDCONTEXT; |
33 |
typedef SCARDHANDLE MYPCSC_SCARDHANDLE; |
34 |
typedef uint32_t SERVER_SCARDCONTEXT; |
35 |
typedef uint32_t SERVER_SCARDHANDLE; |
36 |
|
37 |
typedef SCARD_READERSTATE_A MYPCSC_SCARD_READERSTATE_A; |
38 |
typedef LPSCARD_READERSTATE_A MYPCSC_LPSCARD_READERSTATE_A; |
39 |
|
40 |
typedef struct |
41 |
{ |
42 |
const char *szReader; |
43 |
void *pvUserData; |
44 |
SERVER_DWORD dwCurrentState; |
45 |
SERVER_DWORD dwEventState; |
46 |
SERVER_DWORD cbAtr; |
47 |
unsigned char rgbAtr[MAX_ATR_SIZE]; |
48 |
} |
49 |
SERVER_SCARD_READERSTATE_A; |
50 |
|
51 |
typedef SERVER_SCARD_READERSTATE_A *SERVER_LPSCARD_READERSTATE_A; |
52 |
|
53 |
#define SERVER_SCARDSTATESIZE (sizeof(SERVER_SCARD_READERSTATE_A) - sizeof(const char *) - sizeof(void *)) |
54 |
#define MYPCSC_SCARDSTATESIZE (sizeof(MYPCSC_SCARD_READERSTATE_A) - sizeof(const char *) - sizeof(void *)) |
55 |
|
56 |
typedef struct _SERVER_SCARD_IO_REQUEST |
57 |
{ |
58 |
SERVER_DWORD dwProtocol; /* Protocol identifier */ |
59 |
SERVER_DWORD cbPciLength; /* Protocol Control Inf Length */ |
60 |
} |
61 |
SERVER_SCARD_IO_REQUEST, *SERVER_LPSCARD_IO_REQUEST; |
62 |
|
63 |
typedef SCARD_IO_REQUEST MYPCSC_SCARD_IO_REQUEST; |
64 |
typedef LPSCARD_IO_REQUEST MYPCSC_LPSCARD_IO_REQUEST; |
65 |
|
66 |
|
67 |
/* */ |
68 |
/* */ |
69 |
/*************************************************************************/ |
70 |
|
71 |
|
72 |
#define SC_TRUE 1 |
73 |
#define SC_FALSE 0 |
74 |
|
75 |
#define SC_ESTABLISH_CONTEXT 0x00090014 /* EstablishContext */ |
76 |
#define SC_RELEASE_CONTEXT 0x00090018 /* ReleaseContext */ |
77 |
#define SC_IS_VALID_CONTEXT 0x0009001C /* IsValidContext */ |
78 |
#define SC_LIST_READER_GROUPS 0x00090020 /* ListReaderGroups */ |
79 |
#define SC_LIST_READERS 0x00090028 /* ListReadersA */ |
80 |
#define SC_INTRODUCE_READER_GROUP 0x00090050 /* IntroduceReaderGroup */ |
81 |
#define SC_FORGET_READER_GROUP 0x00090058 /* ForgetReader */ |
82 |
#define SC_INTRODUCE_READER 0x00090060 /* IntroduceReader */ |
83 |
#define SC_FORGET_READER 0x00090068 /* IntroduceReader */ |
84 |
#define SC_ADD_READER_TO_GROUP 0x00090070 /* AddReaderToGroup */ |
85 |
#define SC_REMOVE_READER_FROM_GROUP 0x00090078 /* RemoveReaderFromGroup */ |
86 |
#define SC_CONNECT 0x000900AC /* ConnectA */ |
87 |
#define SC_RECONNECT 0x000900B4 /* Reconnect */ |
88 |
#define SC_DISCONNECT 0x000900B8 /* Disconnect */ |
89 |
#define SC_GET_STATUS_CHANGE 0x000900A0 /* GetStatusChangeA */ |
90 |
#define SC_CANCEL 0x000900A8 /* Cancel */ |
91 |
#define SC_BEGIN_TRANSACTION 0x000900BC /* BeginTransaction */ |
92 |
#define SC_END_TRANSACTION 0x000900C0 /* EndTransaction */ |
93 |
#define SC_STATE 0x000900C4 /* State */ |
94 |
#define SC_STATUS 0x000900C8 /* StatusA */ |
95 |
#define SC_TRANSMIT 0x000900D0 /* Transmit */ |
96 |
#define SC_CONTROL 0x000900D4 /* Control */ |
97 |
#define SC_GETATTRIB 0x000900D8 /* GetAttrib */ |
98 |
#define SC_SETATTRIB 0x000900DC /* SetAttrib */ |
99 |
#define SC_ACCESS_STARTED_EVENT 0x000900E0 /* SCardAccessStartedEvent */ |
100 |
#define SC_LOCATE_CARDS_BY_ATR 0x000900E8 /* LocateCardsByATR */ |
101 |
|
102 |
/* #define INPUT_LINKED 0x00020000 */ |
103 |
#define INPUT_LINKED 0xFFFFFFFF |
104 |
|
105 |
#define SC_THREAD_FUNCTION(f) void *(*f)(void *) |
106 |
|
107 |
extern RDPDR_DEVICE g_rdpdr_device[]; |
108 |
|
109 |
typedef struct _MEM_HANDLE |
110 |
{ |
111 |
struct _MEM_HANDLE *prevHandle; |
112 |
struct _MEM_HANDLE *nextHandle; |
113 |
int dataSize; |
114 |
} MEM_HANDLE, *PMEM_HANDLE; |
115 |
|
116 |
typedef struct _SCARD_ATRMASK_L |
117 |
{ |
118 |
unsigned int cbAtr; |
119 |
unsigned char rgbAtr[36]; |
120 |
unsigned char rgbMask[36]; |
121 |
} SCARD_ATRMASK_L, *PSCARD_ATRMASK_L, *LPSCARD_ATRMASK_L; |
122 |
|
123 |
typedef struct _TSCNameMapRec |
124 |
{ |
125 |
char alias[128]; |
126 |
char name[128]; |
127 |
char vendor[128]; |
128 |
} TSCNameMapRec, *PSCNameMapRec; |
129 |
|
130 |
typedef struct _TSCHCardRec |
131 |
{ |
132 |
DWORD hCard; |
133 |
char *vendor; |
134 |
struct _TSCHCardRec *next; |
135 |
struct _TSCHCardRec *prev; |
136 |
} TSCHCardRec, *PSCHCardRec; |
137 |
|
138 |
typedef struct _TSCThreadData |
139 |
{ |
140 |
uint32 device; |
141 |
uint32 id; |
142 |
NTHANDLE handle; |
143 |
uint32 request; |
144 |
STREAM in; |
145 |
STREAM out; |
146 |
PMEM_HANDLE memHandle; |
147 |
struct _TSCThreadData *next; |
148 |
} TSCThreadData, *PSCThreadData; |
149 |
|
150 |
typedef struct _TThreadListElement |
151 |
{ |
152 |
pthread_t thread; |
153 |
pthread_mutex_t busy; |
154 |
pthread_mutex_t nodata; |
155 |
PSCThreadData data; |
156 |
struct _TThreadListElement *next; |
157 |
} TThreadListElement, *PThreadListElement; |
158 |
|
159 |
int scard_enum_devices(uint32 * id, char *optarg); |