LSSTApplications  20.0.0
LSSTDataManagementBasePackage
Static Public Member Functions | List of all members
lsst::daf::persistence::DbAuth Class Reference

Class for database authentication. More...

#include <DbAuth.h>

Static Public Member Functions

static void setPolicy (lsst::pex::policy::Policy::Ptr policy)
 Set the authenticator Policy. More...
 
static void resetPolicy ()
 Set the authenticator Policy back to null. More...
 
static bool available (std::string const &host, std::string const &port)
 Determine whether an authenticator string is available for database access. More...
 
static std::string authString (std::string const &host, std::string const &port)
 Get the authenticator string for a database. More...
 
static std::string username (std::string const &host, std::string const &port)
 Get the username to use to authenticate to a database. More...
 
static std::string password (std::string const &host, std::string const &port)
 Get the password to use to authenticate to a database. More...
 

Detailed Description

Class for database authentication.

Provides access to username and password to be used to authenticate to a database. Actual username and password come from a well-known environment variable or a well-known file or a file specified by Policy. The format for the authenticator string in any location is "username:password".

Definition at line 57 of file DbAuth.h.

Member Function Documentation

◆ authString()

std::string lsst::daf::persistence::DbAuth::authString ( std::string const &  host,
std::string const &  port 
)
static

Get the authenticator string for a database.

Parameters
[in]hostName of the host to connect to.
[in]portPort number to connect to (as string).
Returns
String with username:password

Definition at line 135 of file DbAuth.cc.

135  {
137  return result.first + ":" + result.second;
138 }

◆ available()

bool lsst::daf::persistence::DbAuth::available ( std::string const &  host,
std::string const &  port 
)
static

Determine whether an authenticator string is available for database access.

Parameters
[in]hostName of the host to connect to.
[in]portPort number to connect to (as string).
Returns
True if authenticator is available

Definition at line 120 of file DbAuth.cc.

120  {
121  try {
123  return true;
124  } catch (...) {
125  return false;
126  }
127  return false; // not reached
128 }

◆ password()

std::string lsst::daf::persistence::DbAuth::password ( std::string const &  host,
std::string const &  port 
)
static

Get the password to use to authenticate to a database.

Parameters
[in]hostName of the host to connect to.
[in]portPort number to connect to (as string).
Returns
Password string

Definition at line 155 of file DbAuth.cc.

155  {
157  return result.second;
158 }

◆ resetPolicy()

void lsst::daf::persistence::DbAuth::resetPolicy ( )
static

Set the authenticator Policy back to null.

Definition at line 112 of file DbAuth.cc.

112 { authPolicy = nullptr; }

◆ setPolicy()

void lsst::daf::persistence::DbAuth::setPolicy ( lsst::pex::policy::Policy::Ptr  policy)
static

Set the authenticator Policy.

Parameters
[in]policyPointer to a Policy

Definition at line 106 of file DbAuth.cc.

106  {
107  authPolicy = pexPolicy::Policy::Ptr(new pexPolicy::Policy(*policy, true));
108 }

◆ username()

std::string lsst::daf::persistence::DbAuth::username ( std::string const &  host,
std::string const &  port 
)
static

Get the username to use to authenticate to a database.

Parameters
[in]hostName of the host to connect to.
[in]portPort number to connect to (as string).
Returns
Username string

Definition at line 145 of file DbAuth.cc.

145  {
147  return result.first;
148 }

The documentation for this class was generated from the following files:
std::pair
std::search
T search(T... args)
lsst::pex::policy::Policy
a container for holding hierarchical configuration data in memory.
Definition: Policy.h:167
lsst::pex::policy::Policy::Ptr
std::shared_ptr< Policy > Ptr
Definition: Policy.h:169
result
py::object result
Definition: _schema.cc:429