Skip to content

Commit

Permalink
secgsi: add option to save delegated proxies as credentials
Browse files Browse the repository at this point in the history
  • Loading branch information
abh3 authored and gganis committed Jun 19, 2018
1 parent eeded7e commit 5ad04a3
Show file tree
Hide file tree
Showing 2 changed files with 31 additions and 7 deletions.
35 changes: 29 additions & 6 deletions src/XrdSecgsi/XrdSecProtocolgsi.cc
Expand Up @@ -835,13 +835,18 @@ char *XrdSecProtocolgsi::Init(gsiOptions opt, XrdOucErrInfo *erp)
//
// Template for the created proxy files
if ((PxyReqOpts & kOptsPxFile)) {
String TmpProxy = gUsrPxyDef;
if (opt.exppxy) TmpProxy = opt.exppxy;
if (XrdSutExpand(TmpProxy) == 0) {
UsrProxy = TmpProxy;
if (opt.exppxy && !strcmp(opt.exppxy, "=creds")) {
PxyReqOpts &= ~kOptsPxFile;
PxyReqOpts |= kOptsPxCred;
} else {
UsrProxy = gUsrPxyDef;
UsrProxy += "u<uid>";
String TmpProxy = gUsrPxyDef;
if (opt.exppxy) TmpProxy = opt.exppxy;
if (XrdSutExpand(TmpProxy) == 0) {
UsrProxy = TmpProxy;
} else {
UsrProxy = gUsrPxyDef;
UsrProxy += "u<uid>";
}
}
DEBUG("Template for exported proxy files: "<<UsrProxy);
}
Expand Down Expand Up @@ -3742,6 +3747,24 @@ int XrdSecProtocolgsi::ServerDoSigpxy(XrdSutBuffer *br, XrdSutBuffer **bm,
// Notify
if (QTRACE(Authen)) { proxyChain->Dump(); }

// Check if the proxy chain is to become the actual credentials
//
if ((PxyReqOpts & kOptsPxCred)) {
XrdCryptoX509ExportChain_t c2mem =
(sessionCF) ? sessionCF->X509ExportChain() : 0;
if (!c2mem) {
cmsg = "chain exporter not found; proxy chain not exported";
return 0;
}
XrdOucString spxy;
XrdSutBucket *bpxy = (*c2mem)(proxyChain, true);
bpxy->ToString(spxy);
SafeFree(Entity.creds);
Entity.creds = strdup(spxy.c_str());
Entity.credslen = spxy.length();
return 0;
}

//
// Extract user login name, if any
String user;
Expand Down
3 changes: 2 additions & 1 deletion src/XrdSecgsi/XrdSecProtocolgsi.hh
Expand Up @@ -103,7 +103,8 @@ enum kgsiHandshakeOpts {
kOptsSigReq = 4, // 0x0004: Accept to sign delegated proxy
kOptsSrvReq = 8, // 0x0008: Server request for delegated proxy
kOptsPxFile = 16, // 0x0010: Save delegated proxies in file
kOptsDelChn = 32 // 0x0020: Delete chain
kOptsDelChn = 32, // 0x0020: Delete chain
kOptsPxCred = 64 // 0x0040: Save delegated proxies as credentials
};

// Error codes
Expand Down

0 comments on commit 5ad04a3

Please sign in to comment.