12#ifndef ROOT_TAuthenticate 
   13#define ROOT_TAuthenticate 
  126                 const char *user = 
"");
 
 
bool Bool_t
Boolean (0=false, 1=true) (bool)
 
int Int_t
Signed integer 4 bytes (int)
 
const char Option_t
Option string (const char)
 
#define ClassDefOverride(name, id)
 
std::string Message(const std::string &msg, const std::string &location)
 
R__EXTERN TVirtualMutex * gAuthenticateMutex
 
Int_t(* Krb5Auth_t)(TAuthenticate *auth, TString &user, TString &det, Int_t version)
 
Int_t(* SecureAuth_t)(TAuthenticate *auth, const char *user, const char *passwd, const char *remote, TString &det, Int_t version)
 
Int_t(* GlobusAuth_t)(TAuthenticate *auth, TString &user, TString &det)
 
Int_t(* CheckSecCtx_t)(const char *subj, TRootSecContext *ctx)
 
ROOT::Detail::TRangeCast< T, true > TRangeDynCast
TRangeDynCast is an adapter class that allows the typed iteration through a TCollection.
 
static void RemoveHostAuth(THostAuth *ha, Option_t *opt="")
Remove THostAuth instance from the list.
 
static Int_t SetRSAPublic(const char *rsapubexport, Int_t klen)
Store RSA public keys from export string rsaPubExport.
 
static TPluginHandler * fgPasswdDialog
 
void SetRSAKeyType(Int_t key)
 
static void SetGlobalSRPPwd(Bool_t srppwd)
Set global SRP passwd flag to be used for authentication to rootd.
 
static Bool_t fgPromptUser
 
TRootSecContext * fSecContext
 
TRootSecContext * GetSecContext() const
 
static void FileExpand(const char *fin, FILE *ftmp)
Expands include directives found in fexp files The expanded, temporary file, is pointed to by 'ftmp' ...
 
const char * GetProtocol() const
 
static const char * GetGlobalUser()
Static method returning the global user.
 
static void SetGlobalUser(const char *user)
Set global user name to be used for authentication to rootd.
 
static void SetPromptUser(Bool_t promptuser)
Set global PromptUser flag.
 
Int_t RfioAuth(TString &user)
RFIO authentication (no longer supported)
 
Int_t HasTimedOut() const
 
static void Show(Option_t *opt="S")
Print info about the authentication sector.
 
const char * GetSshUser(TString user) const
Method returning the user to be used for the ssh login (no longer supported)
 
void SetSecContext(TRootSecContext *ctx)
 
static const char * GetDefaultUser()
Static method returning the default user information.
 
static Bool_t GetPromptUser()
Static method returning the prompt user settings.
 
const char * GetRemoteHost() const
 
static Int_t SecureRecv(TSocket *Socket, Int_t dec, Int_t KeyType, char **Out)
Receive str from sock and decode it using key indicated by key type Return number of received bytes o...
 
static const char * GetKrb5Principal()
Static method returning the principal to be used to init Krb5 tickets.
 
TSocket * GetSocket() const
 
THostAuth * GetHostAuth() const
 
static GlobusAuth_t fgGlobusAuthHook
 
static void SetAuthReUse(Bool_t authreuse)
Set global AuthReUse flag.
 
static R__rsa_KEY_export * fgRSAPubExport
 
char * GetRandString(Int_t Opt, Int_t Len)
Allocates and fills a 0 terminated buffer of length len+1 with len random characters.
 
Int_t SshAuth(TString &user)
SSH client authentication code (no longer supported)
 
ESecurity GetSecurity() const
 
static char * PromptPasswd(const char *prompt="Password: ")
Static method to prompt for the user's passwd to be used for authentication to rootd.
 
static void SetDefaultUser(const char *defaultuser)
Set default user name.
 
static void SetGlobalPwHash(Bool_t pwhash)
Set global passwd hash flag to be used for authentication to rootd.
 
static void SetGlobalExpDate(TDatime expdate)
Set default expiring date for new validity contexts.
 
static Int_t GetRSAInit()
Static method returning the RSA initialization flag.
 
static void SetSecureAuthHook(SecureAuth_t func)
Set secure authorization function.
 
static Int_t GetClientProtocol()
Static method returning supported client protocol.
 
static Int_t ReadRootAuthrc()
Read authentication directives from $ROOTAUTHRC, $HOME/.rootauthrc or <Root_etc_dir>/system....
 
static Bool_t fgReadHomeAuthrc
 
static Int_t SecureSend(TSocket *Socket, Int_t enc, Int_t KeyType, const char *In)
Encode null terminated str using the session private key indicated by enc and sends it over the netwo...
 
Int_t GenRSAKeys()
Generate a valid pair of private/public RSA keys to protect for authentication token exchange.
 
Bool_t CheckNetrc(TString &user, TString &passwd)
Try to get user name and passwd from the ~/.rootnetrc or ~/.netrc files.
 
static TString fgKrb5Principal
 
static const char * GetRSAPubExport(Int_t key=0)
Static method returning the RSA public keys.
 
static void InitRandom()
Initialize random machine using seed from /dev/urandom (or current time if /dev/urandom not available...
 
static R__rsa_KEY fgRSAPubKey
 
static Bool_t fgAuthReUse
 
static Bool_t GetGlobalPwHash()
Static method returning the global password hash flag.
 
static void SetKrb5AuthHook(Krb5Auth_t func)
Set kerberos5 authorization function.
 
static void SetGlobusAuthHook(GlobusAuth_t func)
Set Globus authorization function.
 
static void SetRSAInit(Int_t init=1)
Static method setting RSA initialization flag.
 
static void SetGlobalPasswd(const char *passwd)
Set global passwd to be used for authentication to rootd.
 
void SetEnvironment()
Set default authentication environment.
 
const char * GetUser() const
 
static Int_t SendRSAPublicKey(TSocket *Socket, Int_t key=0)
Receives server RSA Public key Sends local RSA public key encoded.
 
static TDatime fgLastAuthrc
 
static TList * fgAuthInfo
 
static TString fgAuthMeth[kMAXSEC]
 
void CatchTimeOut()
Called in connection with a timer timeout.
 
Int_t GetRSAKeyType() const
 
Bool_t GetUserPasswd(TString &user, TString &passwd, Bool_t &pwhash, Bool_t srppwd)
Try to get user name and passwd from several sources.
 
Bool_t Authenticate()
Authenticate to remote rootd server.
 
static R__rsa_KEY fgRSAPriKey
 
static TString fgRootAuthrc
 
Int_t AuthExists(TString User, Int_t method, const char *Options, Int_t *Message, Int_t *Rflag, CheckSecCtx_t funcheck)
Check if we have a valid established sec context in memory Retrieves relevant info and negotiates wit...
 
static TList * GetAuthInfo()
Static method returning the list with authentication details.
 
static GlobusAuth_t GetGlobusAuthHook()
Static method returning the globus authorization hook (no longer supported)
 
Int_t ClearAuth(TString &user, TString &passwd, Bool_t &pwhash)
UsrPwd client authentication code.
 
static void AuthError(const char *where, Int_t error)
Print error string depending on error code.
 
static Krb5Auth_t fgKrb5AuthHook
 
static char * GetDefaultDetails(Int_t method, Int_t opt, const char *user)
Determine default authentication details for method 'sec' and user 'usr'.
 
static void MergeHostAuthList(TList *Std, TList *New, Option_t *Opt="")
Tool for updating fgAuthInfo 'nin' contains list of last input information through (re)reading of a r...
 
static TString fgDefaultUser
 
static Int_t GetAuthMethodIdx(const char *meth)
Static method returning the method index (which can be used to find the method in GetAuthMethod()).
 
static Int_t DecodeRSAPublic(const char *rsapubexport, R__rsa_NUMBER &n, R__rsa_NUMBER &d, char **rsassl=nullptr)
Store RSA public keys from export string rsaPubExport.
 
static void SetTimeOut(Int_t to)
Set timeout (active if > 0)
 
static Bool_t fgUsrPwdCrypt
 
TAuthenticate(TSocket *sock, const char *remote, const char *proto, const char *user="")
Create authentication object.
 
static void RemoveSecContext(TRootSecContext *ctx)
Tool for removing SecContext ctx from THostAuth listed in fgAuthInfo.
 
static TDatime GetGlobalExpDate()
Static method returning default expiring date for new validity contexts.
 
static Bool_t GetGlobalSRPPwd()
Static method returning the global SRP password flag.
 
static SecureAuth_t fgSecAuthHook
 
static char * PromptUser(const char *remote)
Static method to prompt for the user name to be used for authentication to rootd.
 
static Bool_t CheckHost(const char *Host, const char *host)
Check if 'host' matches 'href': this means either equal or "containing" it, even with wild cards * in...
 
Int_t SshError(const char *errfile)
 
static void SetDefaultRSAKeyType(Int_t key)
Static method setting the default type of RSA key.
 
static const char * GetAuthMethod(Int_t idx)
Static method returning the method corresponding to idx.
 
static Bool_t GetAuthReUse()
Static method returning the authentication reuse settings.
 
static THostAuth * HasHostAuth(const char *host, const char *user, Option_t *opt="R")
Checks if a THostAuth with exact match for {host,user} exists in the fgAuthInfo list Returns pointer ...
 
This class stores the date and time with a precision of one second in an unsigned 32 bit word (950130...
 
Mother of all ROOT objects.
 
This class implements a mutex interface.