Merge pull request #2804 from matt335672/update_comments
Update comments in smartcard code
This commit is contained in:
commit
fea7d80723
@ -18,6 +18,22 @@
|
||||
*
|
||||
*/
|
||||
|
||||
/**
|
||||
* @file sesman/chansrv/smartcard.c
|
||||
*
|
||||
* smartcard redirection support
|
||||
*
|
||||
* This file implements some of the PDUs detailed in [MS-RDPESC].
|
||||
*
|
||||
* The PDUs use DCE IDL structs. These are required to be re-interpreted
|
||||
* in DCE NDR (Netword Data Representation)
|
||||
*
|
||||
* For more information on this subject see DCE publication C706
|
||||
* "DCE 1.1: Remote Procedure Call" 1997. In particular:-
|
||||
* Section 4.2 : Describes the IDL
|
||||
* Section 14 : Describes the NDR
|
||||
*/
|
||||
|
||||
/*
|
||||
* smartcard redirection support
|
||||
*/
|
||||
@ -1085,13 +1101,51 @@ static void
|
||||
scard_send_ListReaders(IRP *irp, char *context, int context_bytes,
|
||||
char *groups, int cchReaders, int wide)
|
||||
{
|
||||
/* see [MS-RDPESC] 2.2.2.4 */
|
||||
/* see [MS-RDPESC] 2.2.2.4
|
||||
*
|
||||
* IDL:-
|
||||
*
|
||||
* typedef struct _REDIR_SCARDCONTEXT {
|
||||
* [range(0,16)] unsigned long cbContext;
|
||||
* [unique] [size_is(cbContext)] byte *pbContext;
|
||||
* } REDIR_SCARDCONTEXT;
|
||||
*
|
||||
* struct _ListReaders_Call {
|
||||
* REDIR_SCARDCONTEXT Context;
|
||||
* [range(0, 65536)] unsigned long cBytes;
|
||||
* [unique] [size_is(cBytes)] const byte *mszGroups;
|
||||
* long fmszReadersIsNULL;
|
||||
* unsigned long cchReaders;
|
||||
* } ListReaders_Call;
|
||||
*
|
||||
* Type summary:-
|
||||
*
|
||||
* Context.cbContext Unsigned 32-bit word
|
||||
* Context.pbContext Embedded full pointer to conformant array of bytes
|
||||
* cBytes Unsigned 32-bit word
|
||||
* mszGroups Embedded full pointer to conformant array of bytes
|
||||
* fmszReaders 32-bit word
|
||||
* cchReaders Unsigned 32-bit word
|
||||
*
|
||||
* NDL:-
|
||||
*
|
||||
* Offset Decription
|
||||
* 0 Context.cbContext
|
||||
* 4 Referent Identifier for pbContext
|
||||
* 8 cBytes
|
||||
* 12 Referent Identifier for mszGroups (or NULL)
|
||||
* 16 fmszReadersIsNULL
|
||||
* 20 cchReaders
|
||||
* 24 Conformant Array pointed to by pbContext
|
||||
* ?? Conformant Array pointed to by mszGroups
|
||||
*
|
||||
*/
|
||||
|
||||
SMARTCARD *sc;
|
||||
struct stream *s;
|
||||
int bytes;
|
||||
int bytes_groups;
|
||||
int val;
|
||||
int bytes_groups; // Length of NDR for groups + 2 terminators
|
||||
int val; // Referent Id for mszGroups (assume NULL)
|
||||
int index;
|
||||
int num_chars;
|
||||
tui32 ioctl;
|
||||
@ -1129,17 +1183,25 @@ scard_send_ListReaders(IRP *irp, char *context, int context_bytes,
|
||||
|
||||
s_push_layer(s, mcs_hdr, 4); /* bytes, set later */
|
||||
out_uint32_le(s, 0x00000000);
|
||||
// REDIR_SCARDCONTEXT Context;
|
||||
out_uint32_le(s, context_bytes);
|
||||
out_uint32_le(s, 0x00020000);
|
||||
// [range(0, 65536)] unsigned long cBytes;
|
||||
out_uint32_le(s, bytes_groups);
|
||||
// [unique] [size_is(cBytes)] const byte *mszGroups; (pointer)
|
||||
out_uint32_le(s, val);
|
||||
// long fmszReadersIsNULL;
|
||||
out_uint32_le(s, 0x00000000);
|
||||
// unsigned long cchReaders;
|
||||
out_uint32_le(s, cchReaders);
|
||||
|
||||
/* insert context */
|
||||
// At the end of the struct come the pointed-to structures
|
||||
|
||||
// Context field pbContext is a Uni-dimensional conformant array
|
||||
out_uint32_le(s, context_bytes);
|
||||
out_uint8a(s, context, context_bytes);
|
||||
|
||||
// mszGroups is also a Uni-dimensional conformant array of bytes
|
||||
if (bytes_groups > 0)
|
||||
{
|
||||
if (wide)
|
||||
@ -1215,8 +1277,69 @@ scard_send_GetStatusChange(IRP *irp, char *context, int context_bytes,
|
||||
int wide, tui32 timeout,
|
||||
tui32 num_readers, READER_STATE *rsa)
|
||||
{
|
||||
/* see [MS-RDPESC] 2.2.2.11 for ASCII */
|
||||
/* see [MS-RDPESC] 2.2.2.12 for Wide char */
|
||||
/* see [MS-RDPESC] 2.2.2.11 for ASCII
|
||||
* see [MS-RDPESC] 2.2.2.12 for Wide char
|
||||
*
|
||||
* Here is a breakdown of the Wide-char variant
|
||||
*
|
||||
* IDL:-
|
||||
*
|
||||
* typedef struct _REDIR_SCARDCONTEXT {
|
||||
* [range(0,16)] unsigned long cbContext;
|
||||
* [unique] [size_is(cbContext)] byte *pbContext;
|
||||
* } REDIR_SCARDCONTEXT;
|
||||
*
|
||||
* typedef struct _ReaderState_Common_Call {
|
||||
* unsigned long dwCurrentState;
|
||||
* unsigned long dwEventState;
|
||||
* [range(0,36)] unsigned long cbAtr;
|
||||
* byte rgbAtr[36];
|
||||
* } ReaderState_Common_Call;
|
||||
*
|
||||
* typedef struct _ReaderStateW {
|
||||
* [string] const wchar_t* szReader;
|
||||
* ReaderState_Common_Call Common;
|
||||
* } ReaderStateW;
|
||||
*
|
||||
* struct _GetStatusChangeW_Call {
|
||||
* REDIR_SCARDCONTEXT Context;
|
||||
* unsigned long dwTimeOut;
|
||||
* [range(0,11)] unsigned long cReaders;
|
||||
* [size_is(cReaders)] ReaderStateW* rgReaderStates;
|
||||
* } GetStatusChangeW_Call;
|
||||
*
|
||||
* Type summary:-
|
||||
*
|
||||
* Context.cbContext Unsigned 32-bit word
|
||||
* Context.pbContext Embedded full pointer to conformant array of bytes
|
||||
* dwTimeOut Unsigned 32-bit word
|
||||
* cReaders Unsigned 32-bit word
|
||||
* rgReaderStates
|
||||
* Embedded full pointer to array of rgReaderStates
|
||||
* rgReaderStates.szReader
|
||||
* Embedded full pointer to conformant and varying
|
||||
* string of [Windows] wchar_t
|
||||
* rgReaderStates.Common.dwCurrentState
|
||||
* Unsigned 32-bit word
|
||||
* rgReaderStates.Common.dwEventState
|
||||
* Unsigned 32-bit word
|
||||
* rgReaderStates.Common.cbAtr
|
||||
* Unsigned 32-bit word
|
||||
* rgReaderStates.Common.rgbAtr[36]
|
||||
* Uni-dimensional fixed array
|
||||
*
|
||||
* NDL:-
|
||||
* Offset Decription
|
||||
* 0 Context.cbContext
|
||||
* 4 Referent Identifier for pbContext
|
||||
* 8 dwTimeOut;
|
||||
* 12 cReaders;
|
||||
* 16 Referent Identifier for rgReaderStates
|
||||
* 20 Conformant Array pointed to by pbContext
|
||||
* ?? Conformant Array pointed to by rgReaderStates. Each element
|
||||
* of this array has a pointer to a string for the name
|
||||
* ?? String names pointed to in the above array.
|
||||
*/
|
||||
|
||||
SMARTCARD *sc;
|
||||
READER_STATE *rs;
|
||||
@ -1245,27 +1368,40 @@ scard_send_GetStatusChange(IRP *irp, char *context, int context_bytes,
|
||||
|
||||
s_push_layer(s, mcs_hdr, 4); /* bytes, set later */
|
||||
out_uint32_le(s, 0x00000000);
|
||||
// REDIR_SCARDCONTEXT Context;
|
||||
out_uint32_le(s, context_bytes);
|
||||
out_uint32_le(s, 0x00020000);
|
||||
|
||||
// unsigned long dwTimeOut;
|
||||
out_uint32_le(s, timeout);
|
||||
// [range(0,11)] unsigned long cReaders;
|
||||
out_uint32_le(s, num_readers);
|
||||
out_uint32_le(s, 0x00020004); /* ? */
|
||||
// [size_is(cReaders)] ReaderStateW* rgReaderStates;
|
||||
out_uint32_le(s, 0x00020004);
|
||||
|
||||
/* insert context */
|
||||
// At the end of the struct come the pointed-to structures
|
||||
|
||||
// Context field pbContext is a Uni-dimensional conformant array
|
||||
out_uint32_le(s, context_bytes);
|
||||
out_uint8a(s, context, context_bytes);
|
||||
|
||||
// rgReaderState is a Uni-dimensional conformant array
|
||||
out_uint32_le(s, num_readers);
|
||||
|
||||
/* insert card reader state */
|
||||
for (i = 0; i < num_readers; i++)
|
||||
{
|
||||
rs = &rsa[i];
|
||||
out_uint32_le(s, 0x00020008); /* ? */
|
||||
// [string] const wchar_t* szReader (wide)
|
||||
// [string] const char_t* szReader (ASCII)
|
||||
out_uint32_le(s, 0x00020008 + (i * 4));
|
||||
// unsigned long dwCurrentState;
|
||||
out_uint32_le(s, rs->current_state);
|
||||
// unsigned long dwEventState;
|
||||
out_uint32_le(s, rs->event_state);
|
||||
// [range(0,36)] unsigned long cbAtr;
|
||||
out_uint32_le(s, rs->atr_len);
|
||||
// byte rgbAtr[36];
|
||||
out_uint8p(s, rs->atr, 33);
|
||||
out_uint8s(s, 3);
|
||||
}
|
||||
@ -1342,8 +1478,53 @@ static void
|
||||
scard_send_Connect(IRP *irp, char *context, int context_bytes,
|
||||
int wide, READER_STATE *rs)
|
||||
{
|
||||
/* see [MS-RDPESC] 2.2.2.13 for ASCII */
|
||||
/* see [MS-RDPESC] 2.2.2.14 for Wide char */
|
||||
/* see [MS-RDPESC] 2.2.2.13 for ASCII
|
||||
* see [MS-RDPESC] 2.2.2.14 for Wide char
|
||||
*
|
||||
* Here is a breakdown of the Wide-char variant
|
||||
*
|
||||
* IDL:-
|
||||
*
|
||||
* typedef struct _REDIR_SCARDCONTEXT {
|
||||
* [range(0,16)] unsigned long cbContext;
|
||||
* [unique] [size_is(cbContext)] byte *pbContext;
|
||||
* } REDIR_SCARDCONTEXT;
|
||||
*
|
||||
* typedef struct _Connect_Common {
|
||||
* REDIR_SCARDCONTEXT Context;
|
||||
* unsigned long dwShareMode;
|
||||
* unsigned long dwPreferredProtocols;
|
||||
* } Connect_Common;
|
||||
*
|
||||
* typedef struct _ConnectW_Call {
|
||||
* [string] const wchar_t* szReader;
|
||||
* Connect_Common Common;
|
||||
* } ConnectW_Call;
|
||||
*
|
||||
* Type summary:-
|
||||
*
|
||||
* szReader Embedded full pointer to conformant and varying
|
||||
* string of [Windows] wchar_t
|
||||
* Common.Context.cbContext
|
||||
* Unsigned 32-bit word
|
||||
* Common.Context.pbContext
|
||||
* Embedded full pointer to conformant array of bytes
|
||||
* Common.dwShareMode Unsigned 32-bit word
|
||||
* Common.dwPreferredProtocols
|
||||
* Unsigned 32-bit word
|
||||
*
|
||||
* NDL:-
|
||||
*
|
||||
* Offset Decription
|
||||
* 0 Referent Identifier for szReader
|
||||
* 4 Context.cbContext
|
||||
* 8 Referent Identifier for pbContext
|
||||
* 12 dwShareMode
|
||||
* 16 dwPreferredProtocols
|
||||
* 20 Conformant Array pointed to by szReader
|
||||
* ?? Conformant Array pointed to by pbContext
|
||||
*
|
||||
*/
|
||||
|
||||
SMARTCARD *sc;
|
||||
struct stream *s;
|
||||
@ -1370,11 +1551,19 @@ scard_send_Connect(IRP *irp, char *context, int context_bytes,
|
||||
|
||||
s_push_layer(s, mcs_hdr, 4); /* bytes, set later */
|
||||
out_uint32_le(s, 0x00000000);
|
||||
// [string] const wchar_t* szReader;
|
||||
out_uint32_le(s, 0x00020000);
|
||||
|
||||
// REDIR_SCARDCONTEXT Context;
|
||||
out_uint32_le(s, context_bytes);
|
||||
out_uint32_le(s, 0x00020004);
|
||||
|
||||
// unsigned long dwShareMode;
|
||||
out_uint32_le(s, rs->dwShareMode);
|
||||
// unsigned long dwPreferredProtocols;
|
||||
out_uint32_le(s, rs->dwPreferredProtocols);
|
||||
|
||||
/* insert card reader name */
|
||||
num_chars = g_mbstowcs(w_reader_name, rs->reader_name, 99);
|
||||
out_uint32_le(s, num_chars + 2);
|
||||
out_uint32_le(s, 0x00000000);
|
||||
|
@ -18,9 +18,21 @@
|
||||
*/
|
||||
|
||||
/*
|
||||
* @file sesman/chansrv/smartcard_pcsc.c
|
||||
*
|
||||
* smartcard redirection support, PCSC daemon standin
|
||||
* this will act like pcsc daemon
|
||||
* pcsc lib and daemon write struct on unix domain socket for communication
|
||||
*
|
||||
* Currently this file implements some of the PDUs detailed in [MS-RDPESC].
|
||||
*
|
||||
* The PDUs use DCE IDL structs. These are required to be re-interpreted
|
||||
* in DCE NDR (Netword Data Representation)
|
||||
*
|
||||
* For more information on this subject see DCE publication C706
|
||||
* "DCE 1.1: Remote Procedure Call" 1997. In particular:-
|
||||
* Section 4.2 : Describes the IDL
|
||||
* Section 14 : Describes the NDR
|
||||
*/
|
||||
|
||||
#if defined(HAVE_CONFIG_H)
|
||||
@ -647,6 +659,31 @@ scard_function_list_readers_return(void *user_data,
|
||||
struct stream *in_s,
|
||||
int len, int status)
|
||||
{
|
||||
/* see [MS-RDPESC] 2.2.3.4
|
||||
*
|
||||
* IDL:-
|
||||
*
|
||||
* typedef struct _longAndMultiString_Return {
|
||||
* long ReturnCode;
|
||||
* [range(0,65536)] unsigned long cBytes;
|
||||
* [unique] [size_is(cBytes)] byte *msz;
|
||||
* } ListReaderGroups_Return, ListReaders_Return;
|
||||
*
|
||||
* Type summary:-
|
||||
*
|
||||
* ReturnCode 32-bit word
|
||||
* CBytes Unsigned 32-bit word
|
||||
* msz Embedded full pointer to conformant array of bytes
|
||||
*
|
||||
* NDR:-
|
||||
*
|
||||
* Offset Decription
|
||||
* 0 ReturnCode
|
||||
* 4 cBytes
|
||||
* 8 msz pointer Referent Identifier
|
||||
* 12 length of multistring in bytes
|
||||
* 16 Multistring data
|
||||
*/
|
||||
struct stream *out_s;
|
||||
int chr;
|
||||
int readers;
|
||||
@ -691,7 +728,11 @@ scard_function_list_readers_return(void *user_data,
|
||||
llen = 0;
|
||||
if (status == 0)
|
||||
{
|
||||
in_uint8s(in_s, 28);
|
||||
// Skip [C706] PDU Header
|
||||
in_uint8s(in_s, 16);
|
||||
// Move to length of multistring in bytes
|
||||
in_uint8s(in_s, 12);
|
||||
|
||||
in_uint32_le(in_s, len);
|
||||
llen = len;
|
||||
if (cchReaders > 0)
|
||||
@ -1397,6 +1438,33 @@ scard_function_status_return(void *user_data,
|
||||
struct stream *in_s,
|
||||
int len, int status)
|
||||
{
|
||||
/* see [MS-RDPESC] 2.2.3.10
|
||||
*
|
||||
* IDL:-
|
||||
*
|
||||
* typedef struct _Status_Return {
|
||||
* long ReturnCode;
|
||||
* unsigned long cBytes;
|
||||
* [unique] [size_is(cBytes)] byte *mszReaderNames;
|
||||
* unsigned long dwState;
|
||||
* unsigned long dwProtocol;
|
||||
* byte pbAtr[32];
|
||||
* [range(0,32)] unsigned long cbAtrLen;
|
||||
* } Status_Return;
|
||||
*
|
||||
* NDR:-
|
||||
*
|
||||
* Offset Decription
|
||||
* 0 ReturnCode
|
||||
* 4 cBytes
|
||||
* 8 Referent Identifier for mszReaderNames;
|
||||
* 12 dwState
|
||||
* 16 dwProtocol
|
||||
* 20 pbAtr
|
||||
* 52 cbAtrLen
|
||||
* 56 length of multistring in bytes (same as cBytes)
|
||||
* 60 Multistring data
|
||||
*/
|
||||
struct stream *out_s;
|
||||
int index;
|
||||
int bytes;
|
||||
@ -1442,9 +1510,10 @@ scard_function_status_return(void *user_data,
|
||||
lreader_name[0] = 0;
|
||||
if (status == 0)
|
||||
{
|
||||
in_uint8s(in_s, 20);
|
||||
in_uint8s(in_s, 16); // Skip [C706] PDU Header
|
||||
in_uint8s(in_s, 4); // ReturnCode
|
||||
in_uint32_le(in_s, dwReaderLen);
|
||||
in_uint8s(in_s, 4);
|
||||
in_uint8s(in_s, 4); // Referent Identifier
|
||||
in_uint32_le(in_s, dwState);
|
||||
dwState = g_ms2pc[dwState % 6];
|
||||
in_uint32_le(in_s, dwProtocol);
|
||||
@ -1747,6 +1816,7 @@ scard_process_msg(struct trans *con, struct stream *in_s, int command)
|
||||
break;
|
||||
|
||||
case 0x03: /* SCARD_LIST_READERS */
|
||||
/* This is only called from xrdp_pcsc.c */
|
||||
LOG_DEVEL(LOG_LEVEL_INFO, "scard_process_msg: SCARD_LIST_READERS");
|
||||
rv = scard_process_list_readers(con, in_s);
|
||||
break;
|
||||
|
Loading…
Reference in New Issue
Block a user