xrootd
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
Classes | Public Member Functions | Static Public Member Functions | Private Member Functions | Static Private Member Functions | Private Attributes | Static Private Attributes | Friends | List of all members
XrdSecProtocolsss Class Reference

#include <XrdSecProtocolsss.hh>

Inheritance diagram for XrdSecProtocolsss:
Inheritance graph
[legend]
Collaboration diagram for XrdSecProtocolsss:
Collaboration graph
[legend]

Classes

struct  Crypto
 

Public Member Functions

int Authenticate (XrdSecCredentials *cred, XrdSecParameters **parms, XrdOucErrInfo *einfo=0)
 
void Delete ()
 Delete the protocol object. DO NOT use C++ delete() on this object. More...
 
XrdSecCredentialsgetCredentials (XrdSecParameters *parms=0, XrdOucErrInfo *einfo=0)
 
int Init_Client (XrdOucErrInfo *erp, const char *Parms)
 
int Init_Server (XrdOucErrInfo *erp, const char *Parms)
 
 XrdSecProtocolsss (const char *hname, XrdNetAddrInfo &endPoint)
 
- Public Member Functions inherited from XrdSecProtocol
virtual int Encrypt (const char *inbuff, int inlen, XrdSecBuffer **outbuff)
 
virtual int Decrypt (const char *inbuff, int inlen, XrdSecBuffer **outbuff)
 
virtual int Sign (const char *inbuff, int inlen, XrdSecBuffer **outbuff)
 
virtual int Verify (const char *inbuff, int inlen, const char *sigbuff, int siglen)
 
virtual int getKey (char *buff=0, int size=0)
 
virtual int setKey (char *buff, int size)
 
virtual bool needTLS ()
 Check if this protocol requires TLS to properly function. More...
 
 XrdSecProtocol (const char *pName)
 Constructor. More...
 

Static Public Member Functions

static int eMsg (const char *epn, int rc, const char *txt1, const char *txt2=0, const char *txt3=0, const char *txt4=0)
 
static int Fatal (XrdOucErrInfo *erP, const char *epn, int rc, const char *etxt)
 
static char * Load_Client (XrdOucErrInfo *erp, const char *Parms)
 
static char * Load_Server (XrdOucErrInfo *erp, const char *Parms)
 

Private Member Functions

 ~XrdSecProtocolsss ()
 
int Decode (XrdOucErrInfo *error, XrdSecsssKT::ktEnt &decKey, char *iBuff, XrdSecsssRR_DataHdr *rrDHdr, int iSize)
 
XrdSecCredentialsEncode (XrdOucErrInfo *error, XrdSecsssKT::ktEnt &encKey, XrdSecsssRR_Hdr *rrHdr, XrdSecsssRR_DataHdr *rrDHdr, int dLen)
 
int getCred (XrdOucErrInfo *, XrdSecsssRR_DataHdr *&, const char *, const char *)
 
int getCred (XrdOucErrInfo *, XrdSecsssRR_DataHdr *&, const char *, const char *, XrdSecParameters *)
 
char * getLID (char *buff, int blen)
 
int myClock ()
 
char * setID (char *id, char **idP)
 
void setIP (XrdNetAddrInfo &endPoint)
 

Static Private Member Functions

static XrdCryptoLiteLoad_Crypto (XrdOucErrInfo *erp, const char *eN)
 
static XrdCryptoLiteLoad_Crypto (XrdOucErrInfo *erp, const char eT)
 

Private Attributes

char * urName
 
char urIP [48]
 
char urIQ [48]
 
XrdNetAddrInfoepAddr
 
XrdSecsssKTkeyTab
 
XrdCryptoLiteCrypto
 
char * idBuff
 
int dataOpts
 
char Sequence
 
bool v2EndPnt
 

Static Private Attributes

static struct Crypto CryptoTab []
 
static int deltaTime
 
static bool isMutual
 
static bool isMapped
 
static bool ktFixed
 
static XrdSecsssKTktObject
 
static XrdCryptoLiteCryptObj
 
static XrdSecsssIDidMap
 
static char * aProts
 
static XrdSecsssEntstaticID
 

Friends

class XrdSecProtocolDummy
 

Additional Inherited Members

- Public Attributes inherited from XrdSecProtocol
XrdSecEntity Entity
 
- Protected Member Functions inherited from XrdSecProtocol
virtual ~XrdSecProtocol ()
 Destructor (prevents use of direct delete). More...
 

Constructor & Destructor Documentation

XrdSecProtocolsss::XrdSecProtocolsss ( const char *  hname,
XrdNetAddrInfo endPoint 
)
inline

References setIP(), and urName.

XrdSecProtocolsss::~XrdSecProtocolsss ( )
inlineprivate

Member Function Documentation

int XrdSecProtocolsss::Authenticate ( XrdSecCredentials cred,
XrdSecParameters **  parms,
XrdOucErrInfo einfo = 0 
)
virtual

Authenticate a client.

Parameters
credCredentials supplied by the client.
parmsPlace where the address of additional authentication data is to be placed for another autrhentication handshake.
einfoThe error information object where error messages should be placed. The messages are returned to the client. Should einfo be null, messages should be written to stderr.
Returns
> 0 -> parms present (more authentication needed) = 0 -> Entity present (authentication suceeded) < 0 -> einfo present (error has occurred)

Implements XrdSecProtocol.

int XrdSecProtocolsss::Decode ( XrdOucErrInfo error,
XrdSecsssKT::ktEnt decKey,
char *  iBuff,
XrdSecsssRR_DataHdr rrDHdr,
int  iSize 
)
private
void XrdSecProtocolsss::Delete ( )
virtual

Delete the protocol object. DO NOT use C++ delete() on this object.

Implements XrdSecProtocol.

static int XrdSecProtocolsss::eMsg ( const char *  epn,
int  rc,
const char *  txt1,
const char *  txt2 = 0,
const char *  txt3 = 0,
const char *  txt4 = 0 
)
static
XrdSecCredentials* XrdSecProtocolsss::Encode ( XrdOucErrInfo error,
XrdSecsssKT::ktEnt encKey,
XrdSecsssRR_Hdr rrHdr,
XrdSecsssRR_DataHdr rrDHdr,
int  dLen 
)
private
static int XrdSecProtocolsss::Fatal ( XrdOucErrInfo erP,
const char *  epn,
int  rc,
const char *  etxt 
)
static
int XrdSecProtocolsss::getCred ( XrdOucErrInfo ,
XrdSecsssRR_DataHdr *&  ,
const char *  ,
const char *   
)
private
int XrdSecProtocolsss::getCred ( XrdOucErrInfo ,
XrdSecsssRR_DataHdr *&  ,
const char *  ,
const char *  ,
XrdSecParameters  
)
private
XrdSecCredentials* XrdSecProtocolsss::getCredentials ( XrdSecParameters parm = 0,
XrdOucErrInfo einfo = 0 
)
virtual

Generate client credentials to be used in the authentication process.

Parameters
parmPointer to the information returned by the server either in the initial login response or the authmore response.
einfoThe error information object where error messages should be placed. The messages are returned to the client. Should einfo be null, messages should be written to stderr.
Returns
Success: Pointer to credentials to sent to the server. The caller is responsible for deleting the object. Failure: Null pointer with einfo, if supplied, containing the reason for the failure.

Implements XrdSecProtocol.

char* XrdSecProtocolsss::getLID ( char *  buff,
int  blen 
)
private
int XrdSecProtocolsss::Init_Client ( XrdOucErrInfo erp,
const char *  Parms 
)
int XrdSecProtocolsss::Init_Server ( XrdOucErrInfo erp,
const char *  Parms 
)
static char* XrdSecProtocolsss::Load_Client ( XrdOucErrInfo erp,
const char *  Parms 
)
static
static XrdCryptoLite* XrdSecProtocolsss::Load_Crypto ( XrdOucErrInfo erp,
const char *  eN 
)
staticprivate
static XrdCryptoLite* XrdSecProtocolsss::Load_Crypto ( XrdOucErrInfo erp,
const char  eT 
)
staticprivate
static char* XrdSecProtocolsss::Load_Server ( XrdOucErrInfo erp,
const char *  Parms 
)
static
int XrdSecProtocolsss::myClock ( )
private
char* XrdSecProtocolsss::setID ( char *  id,
char **  idP 
)
private
void XrdSecProtocolsss::setIP ( XrdNetAddrInfo endPoint)
private

Referenced by XrdSecProtocolsss().

Friends And Related Function Documentation

friend class XrdSecProtocolDummy
friend

Member Data Documentation

char* XrdSecProtocolsss::aProts
staticprivate
XrdCryptoLite* XrdSecProtocolsss::CryptObj
staticprivate
struct Crypto XrdSecProtocolsss::CryptoTab[]
staticprivate
int XrdSecProtocolsss::dataOpts
private
int XrdSecProtocolsss::deltaTime
staticprivate
XrdNetAddrInfo* XrdSecProtocolsss::epAddr
private
char* XrdSecProtocolsss::idBuff
private
XrdSecsssID* XrdSecProtocolsss::idMap
staticprivate
bool XrdSecProtocolsss::isMapped
staticprivate
bool XrdSecProtocolsss::isMutual
staticprivate
XrdSecsssKT* XrdSecProtocolsss::keyTab
private
bool XrdSecProtocolsss::ktFixed
staticprivate
XrdSecsssKT* XrdSecProtocolsss::ktObject
staticprivate
char XrdSecProtocolsss::Sequence
private
XrdSecsssEnt* XrdSecProtocolsss::staticID
staticprivate
char XrdSecProtocolsss::urIP[48]
private
char XrdSecProtocolsss::urIQ[48]
private
char* XrdSecProtocolsss::urName
private

Referenced by XrdSecProtocolsss().

bool XrdSecProtocolsss::v2EndPnt
private

The documentation for this class was generated from the following file: