4 #ifndef DMLITE_CPP_AUTHN_H
5 #define DMLITE_CPP_AUTHN_H
7 #include "dmlite/common/config.h"
75 std::vector<GroupInfo>& g):
86 for (std::vector<GroupInfo>::iterator i =
groups.begin(); i !=
groups.end(); i++) {
87 if (r.length()) r.append(
",");
89 r.append(
SSTR( i->name <<
"(" << i->getLong(
"gid", -1) <<
"," << i->getLong(
"banned", 0) <<
")") );
129 virtual std::string
getImplId(
void)
const throw() = 0;
157 const boost::any& value) ;
160 virtual std::vector<GroupInfo>
getGroups(
void) ;
167 virtual void deleteGroup(
const std::string& groupName) ;
186 const boost::any& value) ;
189 virtual std::vector<UserInfo>
getUsers(
void) ;
196 virtual void deleteUser(
const std::string& userName) ;
205 virtual void getIdMap(
const std::string& userName,
206 const std::vector<std::string>& groupNames,
208 std::vector<GroupInfo>* groups) ;
232 #endif // DMLITE_CPP_AUTH_H
std::string remoteAddress
Definition: authn.h:26
virtual void updateUser(const UserInfo &user)
bool operator<(const UserInfo &) const
bool operator<(const SecurityCredentials &) const
bool operator==(const UserInfo &) const
std::string name
Definition: authn.h:49
std::vector< std::string > fqans
Definition: authn.h:34
virtual GroupInfo getGroup(const std::string &groupName)
virtual std::string getImplId(void) const =0
String ID of the user DB implementation.
static Authn * createAuthn(AuthnFactory *factory, PluginManager *pm)
Children of AuthnFactory are allowed to instantiate too (decorator)
bool operator!=(const SecurityContext &) const
bool operator<(const SecurityContext &) const
std::string oidc_audience
Definition: authn.h:30
virtual ~AuthnFactory()
Destructor.
bool operator!=(const SecurityCredentials &) const
SecurityContext()
Definition: authn.h:71
virtual void deleteGroup(const std::string &groupName)
Delete a group.
bool operator==(const SecurityCredentials &) const
Security context. To be created by the Authn.
Definition: authn.h:70
SecurityContext(const SecurityCredentials &c, const UserInfo &u, std::vector< GroupInfo > &g)
Definition: authn.h:73
std::string mech
Definition: authn.h:24
bool operator<(const GroupInfo &) const
CatalogInterface can only be instantiated through this class.
Definition: dmlite.h:42
bool operator>(const SecurityCredentials &) const
std::string oidc_scope
Definition: authn.h:32
bool operator!=(const UserInfo &) const
bool operator==(const SecurityContext &) const
bool operator>(const GroupInfo &) const
virtual UserInfo getUser(const std::string &userName)
bool operator!=(const GroupInfo &) const
bool operator>(const UserInfo &) const
std::string oidc_issuer
Definition: authn.h:31
AuthnFactory.
Definition: authn.h:213
void AuthNprocessing_append(const char *str)
Definition: authn.h:103
virtual UserInfo newUser(const std::string &userName)
std::vector< GroupInfo > groups
Definition: authn.h:81
Exceptions used by the API.
UserInfo user
Definition: authn.h:80
Helpful typedef for KeyValue containers.
Definition: extensible.h:20
Base class for factories.
Definition: base.h:48
virtual ~Authn()
Destructor.
std::string AuthNprocessing_msg
Definition: authn.h:100
bool operator==(const GroupInfo &) const
virtual void updateGroup(const GroupInfo &group)
SecurityCredentials credentials
Definition: authn.h:78
std::string clientName
Definition: authn.h:25
virtual void deleteUser(const std::string &userName)
Delete a user.
virtual std::vector< UserInfo > getUsers(void)
Get the user list.
Extensible types (hold metadata).
virtual std::vector< GroupInfo > getGroups(void)
Get the group list.
bool operator>(const SecurityContext &) const
std::string name
Definition: authn.h:60
virtual SecurityContext * createSecurityContext(void)
std::string sessionId
Definition: authn.h:27
long getLong(const std::string &key, long defaultValue=0) const
Gets an integer. May be able to perform some conversions.
Security credentials. To be filled by the front-end.
Definition: authn.h:23
const std::string prettystring()
Definition: authn.h:83
virtual GroupInfo newGroup(const std::string &groupName)
#define SSTR(message)
Definition: logger.h:51
virtual void getIdMap(const std::string &userName, const std::vector< std::string > &groupNames, UserInfo *user, std::vector< GroupInfo > *groups)