64 #define XrdSecPROTOIDENT "gsi"
65 #define XrdSecPROTOIDLEN sizeof(XrdSecPROTOIDENT)
66 #define XrdSecgsiVERSION 10400
67 #define XrdSecNOIPCHK 0x0001
68 #define XrdSecDEBUG 0x1000
69 #define XrdCryptoMax 10
71 #define kMAXBUFLEN 1024
74 #define XrdSecgsiVersDHsigned 10400
145 #define REL1(x) { if (x) delete x; }
146 #define REL2(x,y) { if (x) delete x; if (y) delete y; }
147 #define REL3(x,y,z) { if (x) delete x; if (y) delete y; if (z) delete z; }
149 #define SafeDelete(x) { if (x) {delete x ; x = 0;} }
150 #define SafeDelArray(x) { if (x) {delete [] x ; x = 0;} }
151 #define SafeFree(x) { if (x) {free(x) ; x = 0;} }
154 typedef char *(*XrdSecgsiGMAP_t)(
const char *, int);
251 char k[40]; snprintf(k, 40,
"%p", t);
258 char k[40]; snprintf(k, 40,
"%p", t);
285 const char *parms = 0);
299 int Sign(
const char *inbuf,
int inlen,
302 const char *sigbuf,
int siglen);
433 static int GetCA(
const char *cahash,
442 time_t timestamp,
String &cal);
457 const char *msg1,
const char *msg2 = 0,
458 const char *msg3 = 0);
462 const char *msg2 = 0,
const char *msg3 = 0);
466 const char *msg2 = 0,
const char *msg3 = 0);
int kXR_int32
Definition: XPtypes.hh:89
@ Hash_count
Definition: XrdOucHash.hh:54
kgsiHandshakeOpts
Definition: XrdSecProtocolgsi.hh:104
@ kOptsDelChn
Definition: XrdSecProtocolgsi.hh:110
@ kOptsSigReq
Definition: XrdSecProtocolgsi.hh:107
@ kOptsFwdPxy
Definition: XrdSecProtocolgsi.hh:106
@ kOptsPxCred
Definition: XrdSecProtocolgsi.hh:111
@ kOptsSrvReq
Definition: XrdSecProtocolgsi.hh:108
@ kOptsDlgPxy
Definition: XrdSecProtocolgsi.hh:105
@ kOptsPxFile
Definition: XrdSecProtocolgsi.hh:109
#define SafeDelete(x)
Definition: XrdSecProtocolgsi.hh:149
int(* XrdSecgsiAuthz_t)(XrdSecEntity &)
Definition: XrdSecProtocolgsi.hh:155
XrdCryptogsiX509Chain X509Chain
Definition: XrdSecProtocolgsi.hh:62
kgsiServerSteps
Definition: XrdSecProtocolgsi.hh:95
@ kXGS_cert
Definition: XrdSecProtocolgsi.hh:98
@ kXGS_none
Definition: XrdSecProtocolgsi.hh:96
@ kXGS_pxyreq
Definition: XrdSecProtocolgsi.hh:99
@ kXGS_init
Definition: XrdSecProtocolgsi.hh:97
@ kXGS_reserved
Definition: XrdSecProtocolgsi.hh:100
XrdSecgsiAuthz_t XrdSecgsiVOMS_t
Definition: XrdSecProtocolgsi.hh:159
int(* XrdSecgsiAuthzKey_t)(XrdSecEntity &, char **)
Definition: XrdSecProtocolgsi.hh:157
XrdOucString String
Definition: XrdSecProtocolgsi.hh:61
kgsiStatus
Definition: XrdSecProtocolgsi.hh:79
@ kgST_ok
Definition: XrdSecProtocolgsi.hh:81
@ kgST_error
Definition: XrdSecProtocolgsi.hh:80
@ kgST_more
Definition: XrdSecProtocolgsi.hh:82
int(* XrdSecgsiAuthzInit_t)(const char *)
Definition: XrdSecProtocolgsi.hh:156
char *(* XrdSecgsiGMAP_t)(const char *, int)
Definition: XrdSecProtocolgsi.hh:154
#define XrdCryptoMax
Definition: XrdSecProtocolgsi.hh:69
kgsiClientSteps
Definition: XrdSecProtocolgsi.hh:86
@ kXGC_sigpxy
Definition: XrdSecProtocolgsi.hh:90
@ kXGC_cert
Definition: XrdSecProtocolgsi.hh:89
@ kXGC_reserved
Definition: XrdSecProtocolgsi.hh:91
@ kXGC_none
Definition: XrdSecProtocolgsi.hh:87
@ kXGC_certreq
Definition: XrdSecProtocolgsi.hh:88
XrdSecgsiAuthzInit_t XrdSecgsiVOMSInit_t
Definition: XrdSecProtocolgsi.hh:160
kgsiErrors
Definition: XrdSecProtocolgsi.hh:115
@ kGSErrExportPuK
Definition: XrdSecProtocolgsi.hh:125
@ kGSErrBadRndmTag
Definition: XrdSecProtocolgsi.hh:127
@ kGSErrCreateBuffer
Definition: XrdSecProtocolgsi.hh:122
@ kGSErrNoCipher
Definition: XrdSecProtocolgsi.hh:129
@ kGSErrInit
Definition: XrdSecProtocolgsi.hh:140
@ kGSErrFinCipher
Definition: XrdSecProtocolgsi.hh:139
@ kGSErrParseBuffer
Definition: XrdSecProtocolgsi.hh:116
@ kGSErrGenCipher
Definition: XrdSecProtocolgsi.hh:124
@ kGSErrBadCreds
Definition: XrdSecProtocolgsi.hh:141
@ kGSErrUnmarshal
Definition: XrdSecProtocolgsi.hh:133
@ kGSErrRefCipher
Definition: XrdSecProtocolgsi.hh:136
@ kGSErrBadProtocol
Definition: XrdSecProtocolgsi.hh:119
@ kGSErrMarshal
Definition: XrdSecProtocolgsi.hh:132
@ kGSErrNoPublic
Definition: XrdSecProtocolgsi.hh:137
@ kGSErrSaveCreds
Definition: XrdSecProtocolgsi.hh:134
@ kGSErrSerialBuffer
Definition: XrdSecProtocolgsi.hh:123
@ kGSErrNoCreds
Definition: XrdSecProtocolgsi.hh:130
@ kGSErrDecodeBuffer
Definition: XrdSecProtocolgsi.hh:117
@ kGSErrLoadCrypto
Definition: XrdSecProtocolgsi.hh:118
@ kGSErrEncRndmTag
Definition: XrdSecProtocolgsi.hh:126
@ kGSErrDuplicateBucket
Definition: XrdSecProtocolgsi.hh:121
@ kGSErrBadOpt
Definition: XrdSecProtocolgsi.hh:131
@ kGSErrNoRndmTag
Definition: XrdSecProtocolgsi.hh:128
@ kGSErrAddBucket
Definition: XrdSecProtocolgsi.hh:138
@ kGSErrError
Definition: XrdSecProtocolgsi.hh:142
@ kGSErrCreateBucket
Definition: XrdSecProtocolgsi.hh:120
@ kGSErrNoBuffer
Definition: XrdSecProtocolgsi.hh:135
Definition: XrdSecProtocolgsi.hh:248
void Add(T *t)
Definition: XrdSecProtocolgsi.hh:250
XrdSysMutex mtx
Definition: XrdSecProtocolgsi.hh:264
void Del(T *t)
Definition: XrdSecProtocolgsi.hh:257
XrdOucHash< T > stack
Definition: XrdSecProtocolgsi.hh:265
Definition: XrdCryptoCipher.hh:48
Definition: XrdCryptoFactory.hh:122
Definition: XrdCryptoMsgDigest.hh:47
Definition: XrdCryptoRSA.hh:51
Definition: XrdCryptoX509Chain.hh:80
void Cleanup(bool keepCA=0)
Definition: XrdCryptoX509Crl.hh:49
Definition: XrdCryptoX509.hh:51
Definition: XrdCryptogsiX509Chain.hh:50
Definition: XrdNetAddrInfo.hh:54
Definition: XrdOucErrInfo.hh:99
Definition: XrdOucGMap.hh:49
Definition: XrdOucHash.hh:128
Definition: XrdOucString.hh:254
Definition: XrdOucTrace.hh:36
Definition: XrdSecEntity.hh:64
Definition: XrdSecInterface.hh:131
Definition: XrdSecProtocolgsi.hh:273
static GSIStack< XrdCryptoX509Chain > stackCA
Definition: XrdSecProtocolgsi.hh:375
int Authenticate(XrdSecCredentials *cred, XrdSecParameters **parms, XrdOucErrInfo *einfo=0)
bool useIV
Definition: XrdSecProtocolgsi.hh:403
int Verify(const char *inbuf, int inlen, const char *sigbuf, int siglen)
XrdSutBucket * bucketKey
Definition: XrdSecProtocolgsi.hh:396
static XrdSecgsiGMAP_t LoadGMAPFun(const char *plugin, const char *parms)
virtual ~XrdSecProtocolgsi()
Definition: XrdSecProtocolgsi.hh:286
static String SrvKey
Definition: XrdSecProtocolgsi.hh:321
XrdCryptoFactory * sessionCF
Definition: XrdSecProtocolgsi.hh:394
static String UsrCert
Definition: XrdSecProtocolgsi.hh:323
static XrdSecgsiAuthz_t LoadAuthzFun(const char *plugin, const char *parms, int &fmt)
XrdSecProtocolgsi(int opts, const char *hname, XrdNetAddrInfo &endPoint, const char *parms=0)
X509Chain * proxyChain
Definition: XrdSecProtocolgsi.hh:400
static int AuthzCertFmt
Definition: XrdSecProtocolgsi.hh:343
static XrdSecgsiVOMS_t VOMSFun
Definition: XrdSecProtocolgsi.hh:351
void FreeEntity(XrdSecEntity *in)
static int CRLDownload
Definition: XrdSecProtocolgsi.hh:330
static XrdSecgsiVOMS_t LoadVOMSFun(const char *plugin, const char *parms, int &fmt)
static char * Init(gsiOptions o, XrdOucErrInfo *erp)
static XrdSysLogger Logger
Definition: XrdSecProtocolgsi.hh:388
int ServerDoCertreq(XrdSutBuffer *br, XrdSutBuffer **bm, String &cmsg)
static bool VerifyCA(int opt, X509Chain *cca, XrdCryptoFactory *cf)
bool ServerCertNameOK(const char *subject, const char *hname, String &e)
static XrdSecgsiAuthzKey_t AuthzKey
Definition: XrdSecProtocolgsi.hh:342
int ParseServerInput(XrdSutBuffer *br, XrdSutBuffer **bm, String &cmsg)
static int PxyReqOpts
Definition: XrdSecProtocolgsi.hh:345
static String DefError
Definition: XrdSecProtocolgsi.hh:335
static XrdCryptoFactory * cryptF[XrdCryptoMax]
Definition: XrdSecProtocolgsi.hh:359
static String DefMD
Definition: XrdSecProtocolgsi.hh:334
static String PxyValid
Definition: XrdSecProtocolgsi.hh:325
static XrdOucGMap * servGMap
Definition: XrdSecProtocolgsi.hh:372
static String GetCApath(const char *cahash)
static String DefCRLext
Definition: XrdSecProtocolgsi.hh:319
static XrdOucTrace * EnableTracing()
static int GMAPCacheTimeOut
Definition: XrdSecProtocolgsi.hh:339
int ServerDoSigpxy(XrdSutBuffer *br, XrdSutBuffer **bm, String &cmsg)
static String UsrProxy
Definition: XrdSecProtocolgsi.hh:322
static int ncrypt
Definition: XrdSecProtocolgsi.hh:358
bool srvMode
Definition: XrdSecProtocolgsi.hh:401
int AddSerialized(char opt, kXR_int32 step, String ID, XrdSutBuffer *bls, XrdSutBuffer *buf, kXR_int32 type, XrdCryptoCipher *cip)
bool CheckTimeStamp(XrdSutBuffer *b, int skew, String &emsg)
static int VOMSAttrOpt
Definition: XrdSecProtocolgsi.hh:350
static int AuthzPxyWhat
Definition: XrdSecProtocolgsi.hh:346
int options
Definition: XrdSecProtocolgsi.hh:393
static int GetCA(const char *cahash, XrdCryptoFactory *cryptof, gsiHSVars *hs=0)
static int QueryProxy(bool checkcache, XrdSutCache *cache, const char *tag, XrdCryptoFactory *cf, time_t timestamp, ProxyIn_t *pi, ProxyOut_t *po)
int Decrypt(const char *inbuf, int inlen, XrdSecBuffer **outbuf)
static String cryptName[XrdCryptoMax]
Definition: XrdSecProtocolgsi.hh:361
XrdSecCredentials * ErrC(XrdOucErrInfo *einfo, XrdSutBuffer *b1, XrdSutBuffer *b2, XrdSutBuffer *b3, kXR_int32 ecode, const char *msg1=0, const char *msg2=0, const char *msg3=0)
static XrdSysMutex gsiContext
Definition: XrdSecProtocolgsi.hh:316
XrdNetAddrInfo epAddr
Definition: XrdSecProtocolgsi.hh:313
int Encrypt(const char *inbuf, int inlen, XrdSecBuffer **outbuf)
static XrdSutCacheEntry * GetSrvCertEnt(XrdSutCERef &gcref, XrdCryptoFactory *cf, time_t timestamp, String &cal)
static String GMAPFile
Definition: XrdSecProtocolgsi.hh:336
static int Debug
Definition: XrdSecProtocolgsi.hh:383
static bool HashCompatibility
Definition: XrdSecProtocolgsi.hh:354
static int AuthzCacheTimeOut
Definition: XrdSecProtocolgsi.hh:344
static int GMAPOpt
Definition: XrdSecProtocolgsi.hh:337
XrdCryptoRSA * sessionKver
Definition: XrdSecProtocolgsi.hh:399
static String UsrKey
Definition: XrdSecProtocolgsi.hh:324
static String CRLdir
Definition: XrdSecProtocolgsi.hh:318
XrdCryptoMsgDigest * sessionMD
Definition: XrdSecProtocolgsi.hh:397
int ClientDoCert(XrdSutBuffer *br, XrdSutBuffer **bm, String &cmsg)
int ClientDoPxyreq(XrdSutBuffer *br, XrdSutBuffer **bm, String &cmsg)
static String SrvAllowedNames
Definition: XrdSecProtocolgsi.hh:349
static GSIStack< XrdCryptoX509Crl > stackCRL
Definition: XrdSecProtocolgsi.hh:376
int ClientDoInit(XrdSutBuffer *br, XrdSutBuffer **bm, String &cmsg)
void Delete()
Delete the protocol object. DO NOT use C++ delete() on this object.
static int cryptID[XrdCryptoMax]
Definition: XrdSecProtocolgsi.hh:360
void CopyEntity(XrdSecEntity *in, XrdSecEntity *out, int *lout=0)
char * expectedHost
Definition: XrdSecProtocolgsi.hh:402
gsiHSVars * hs
Definition: XrdSecProtocolgsi.hh:406
static time_t lastGMAPCheck
Definition: XrdSecProtocolgsi.hh:379
static int DepLength
Definition: XrdSecProtocolgsi.hh:326
static bool TrustDNS
Definition: XrdSecProtocolgsi.hh:355
static String CAdir
Definition: XrdSecProtocolgsi.hh:317
static XrdSutCache cachePxy
Definition: XrdSecProtocolgsi.hh:367
static XrdSutCache cacheAuthzFun
Definition: XrdSecProtocolgsi.hh:369
static XrdSecgsiGMAP_t GMAPFun
Definition: XrdSecProtocolgsi.hh:340
static int AuthzAlways
Definition: XrdSecProtocolgsi.hh:348
XrdCryptoCipher * sessionKey
Definition: XrdSecProtocolgsi.hh:395
static bool GMAPuseDNname
Definition: XrdSecProtocolgsi.hh:338
XrdCryptoRSA * sessionKsig
Definition: XrdSecProtocolgsi.hh:398
static int VOMSCertFmt
Definition: XrdSecProtocolgsi.hh:352
static int AuthzPxyWhere
Definition: XrdSecProtocolgsi.hh:347
static XrdSutCache cacheCA
Definition: XrdSecProtocolgsi.hh:365
static XrdOucTrace * GSITrace
Definition: XrdSecProtocolgsi.hh:390
static XrdSysMutex mutexGMAP
Definition: XrdSecProtocolgsi.hh:380
static int CACheck
Definition: XrdSecProtocolgsi.hh:328
int getKey(char *kbuf=0, int klen=0)
static String SrvCert
Definition: XrdSecProtocolgsi.hh:320
static String DefCipher
Definition: XrdSecProtocolgsi.hh:333
static XrdSysError eDest
Definition: XrdSecProtocolgsi.hh:389
int ServerDoCert(XrdSutBuffer *br, XrdSutBuffer **bm, String &cmsg)
static bool Server
Definition: XrdSecProtocolgsi.hh:384
static String DefCrypto
Definition: XrdSecProtocolgsi.hh:332
static int MonInfoOpt
Definition: XrdSecProtocolgsi.hh:353
static void ErrF(XrdOucErrInfo *einfo, kXR_int32 ecode, const char *msg1, const char *msg2=0, const char *msg3=0)
static XrdCryptoCipher * refcip[XrdCryptoMax]
Definition: XrdSecProtocolgsi.hh:362
int ParseCrypto(String cryptlist)
static int DefBits
Definition: XrdSecProtocolgsi.hh:327
int ParseCAlist(String calist)
static int InitProxy(ProxyIn_t *pi, XrdCryptoFactory *cf, X509Chain *ch=0, XrdCryptoRSA **key=0)
static void QueryGMAP(XrdCryptoX509Chain *chain, int now, String &name)
int Sign(const char *inbuf, int inlen, XrdSecBuffer **outbuf)
static XrdSutCache cacheCert
Definition: XrdSecProtocolgsi.hh:366
int ErrS(String ID, XrdOucErrInfo *einfo, XrdSutBuffer *b1, XrdSutBuffer *b2, XrdSutBuffer *b3, kXR_int32 ecode, const char *msg1=0, const char *msg2=0, const char *msg3=0)
bool CheckRtag(XrdSutBuffer *bm, String &emsg)
static int CRLCheck
Definition: XrdSecProtocolgsi.hh:329
int setKey(char *kbuf, int klen)
int ParseClientInput(XrdSutBuffer *br, XrdSutBuffer **bm, String &emsg)
static XrdSutCache cacheGMAPFun
Definition: XrdSecProtocolgsi.hh:368
static XrdSecgsiAuthz_t AuthzFun
Definition: XrdSecProtocolgsi.hh:341
static XrdCryptoX509Crl * LoadCRL(XrdCryptoX509 *xca, const char *sjhash, XrdCryptoFactory *CF, int dwld, int &err)
static int VerifyCRL(XrdCryptoX509Crl *crl, XrdCryptoX509 *xca, XrdOucString crldir, XrdCryptoFactory *CF, int hashalg)
static int TimeSkew
Definition: XrdSecProtocolgsi.hh:385
XrdSecCredentials * getCredentials(XrdSecParameters *parm=0, XrdOucErrInfo *einfo=0)
static int CRLRefresh
Definition: XrdSecProtocolgsi.hh:331
Definition: XrdSutBucket.hh:44
Definition: XrdSutBuffer.hh:43
Definition: XrdSutCacheEntry.hh:100
Definition: XrdSutCacheEntry.hh:75
Definition: XrdSutCache.hh:49
Definition: XrdSutPFEntry.hh:78
Definition: XrdSysError.hh:90
Definition: XrdSysLogger.hh:53
Definition: XrdSysPthread.hh:166
void Lock()
Definition: XrdSysPthread.hh:222
void UnLock()
Definition: XrdSysPthread.hh:224
Definition: XrdSecProtocolgsi.hh:492
XrdSutPFEntry * Cref
Definition: XrdSecProtocolgsi.hh:502
bool RtagOK
Definition: XrdSecProtocolgsi.hh:507
bool Tty
Definition: XrdSecProtocolgsi.hh:508
String CryptoMod
Definition: XrdSecProtocolgsi.hh:496
bool HasPad
Definition: XrdSecProtocolgsi.hh:499
X509Chain * PxyChain
Definition: XrdSecProtocolgsi.hh:506
XrdCryptoX509Crl * Crl
Definition: XrdSecProtocolgsi.hh:505
XrdSutBuffer * Parms
Definition: XrdSecProtocolgsi.hh:512
int HashAlg
Definition: XrdSecProtocolgsi.hh:511
String ID
Definition: XrdSecProtocolgsi.hh:501
XrdSutBucket * Cbck
Definition: XrdSecProtocolgsi.hh:500
gsiHSVars()
Definition: XrdSecProtocolgsi.hh:514
void Dump(XrdSecProtocolgsi *p=0)
X509Chain * Chain
Definition: XrdSecProtocolgsi.hh:504
int Options
Definition: XrdSecProtocolgsi.hh:510
XrdSutPFEntry * Pent
Definition: XrdSecProtocolgsi.hh:503
~gsiHSVars()
Definition: XrdSecProtocolgsi.hh:520
time_t TimeStamp
Definition: XrdSecProtocolgsi.hh:495
int LastStep
Definition: XrdSecProtocolgsi.hh:509
int Iter
Definition: XrdSecProtocolgsi.hh:494
int RemVers
Definition: XrdSecProtocolgsi.hh:497
XrdCryptoCipher * Rcip
Definition: XrdSecProtocolgsi.hh:498
Definition: XrdSecProtocolgsi.hh:166
int authzto
Definition: XrdSecProtocolgsi.hh:194
char * authzfun
Definition: XrdSecProtocolgsi.hh:191
char mode
Definition: XrdSecProtocolgsi.hh:169
char * cert
Definition: XrdSecProtocolgsi.hh:174
int moninfo
Definition: XrdSecProtocolgsi.hh:206
char * valid
Definition: XrdSecProtocolgsi.hh:184
char * crldir
Definition: XrdSecProtocolgsi.hh:172
char * gmapfun
Definition: XrdSecProtocolgsi.hh:189
char * proxy
Definition: XrdSecProtocolgsi.hh:183
char * crlext
Definition: XrdSecProtocolgsi.hh:173
char * cipher
Definition: XrdSecProtocolgsi.hh:178
virtual ~gsiOptions()
Definition: XrdSecProtocolgsi.hh:222
char * vomsfunparms
Definition: XrdSecProtocolgsi.hh:205
char * key
Definition: XrdSecProtocolgsi.hh:176
int deplen
Definition: XrdSecProtocolgsi.hh:185
char * certdir
Definition: XrdSecProtocolgsi.hh:171
char * authzfunparms
Definition: XrdSecProtocolgsi.hh:192
char * srvnames
Definition: XrdSecProtocolgsi.hh:199
char * exppxy
Definition: XrdSecProtocolgsi.hh:200
int crl
Definition: XrdSecProtocolgsi.hh:180
int ogmap
Definition: XrdSecProtocolgsi.hh:195
int vomsat
Definition: XrdSecProtocolgsi.hh:203
bool trustdns
Definition: XrdSecProtocolgsi.hh:209
int authzcall
Definition: XrdSecProtocolgsi.hh:193
char * gridmap
Definition: XrdSecProtocolgsi.hh:187
char * md
Definition: XrdSecProtocolgsi.hh:179
int hashcomp
Definition: XrdSecProtocolgsi.hh:207
int authzpxy
Definition: XrdSecProtocolgsi.hh:201
short debug
Definition: XrdSecProtocolgsi.hh:168
gsiOptions()
Definition: XrdSecProtocolgsi.hh:211
int bits
Definition: XrdSecProtocolgsi.hh:186
int gmapto
Definition: XrdSecProtocolgsi.hh:188
char * vomsfun
Definition: XrdSecProtocolgsi.hh:204
void Print(XrdOucTrace *t)
char * clist
Definition: XrdSecProtocolgsi.hh:170
char * gmapfunparms
Definition: XrdSecProtocolgsi.hh:190
int sigpxy
Definition: XrdSecProtocolgsi.hh:198
int ca
Definition: XrdSecProtocolgsi.hh:181
int crlrefresh
Definition: XrdSecProtocolgsi.hh:182
int dlgpxy
Definition: XrdSecProtocolgsi.hh:196
Definition: XrdSecProtocolgsi.hh:237
int bits
Definition: XrdSecProtocolgsi.hh:244
const char * valid
Definition: XrdSecProtocolgsi.hh:242
const char * out
Definition: XrdSecProtocolgsi.hh:241
int deplen
Definition: XrdSecProtocolgsi.hh:243
const char * key
Definition: XrdSecProtocolgsi.hh:239
const char * certdir
Definition: XrdSecProtocolgsi.hh:240
const char * cert
Definition: XrdSecProtocolgsi.hh:238
Definition: XrdSecProtocolgsi.hh:230
XrdSutBucket * cbck
Definition: XrdSecProtocolgsi.hh:233
XrdCryptoRSA * ksig
Definition: XrdSecProtocolgsi.hh:232
X509Chain * chain
Definition: XrdSecProtocolgsi.hh:231
Generic structure to pass security information back and forth.
Definition: XrdSecInterface.hh:51