24 #ifndef UTILS_DOMETALKER_H
25 #define UTILS_DOMETALKER_H
27 #include <davix/davix.hpp>
32 #include <boost/property_tree/ptree.hpp>
68 for(
size_t i = 0; i < ctx->
groups.size(); i++) {
112 bool execute(
const boost::property_tree::ptree ¶ms);
113 bool execute(
const std::string &str);
114 bool execute(
const std::ostringstream &ss);
117 bool execute(
const std::string &key,
const std::string &value);
120 bool execute(
const std::string &key1,
const std::string &value1,
121 const std::string &key2,
const std::string &value2);
124 bool execute(
const std::string &key1,
const std::string &value1,
125 const std::string &key2,
const std::string &value2,
126 const std::string &key3,
const std::string &value3);
137 const boost::property_tree::ptree&
jresp();
145 for (
int i = 0; i < 12; i++) {
146 if (!strcmp(verb,
reqTypes[i]))
return i;
157 const char *sslclientshortname,
158 const char *sslclientvorg,
159 const char *sslclienthost,
160 const char *sslclientdn,
Definition: DomeTalker.h:92
Security context. To be created by the Authn.
Definition: authn.h:73
Definition: DomeTalker.h:105
Definition: DomeTalker.h:90
std::string clientName
Definition: authn.h:26
Definition: DomeTalker.h:93
std::string clientName
The remote user that originated a request. Typically a DN.
Definition: DomeTalker.h:38
const boost::property_tree::ptree & jresp()
std::string oidc_audience
The OIDC audience.
Definition: DomeTalker.h:46
SecurityCredentials credentials
Definition: authn.h:82
void calcXrdHttpHashes(char *hash, const char *fn, int16_t request, const char *sslclientshortname, const char *sslclientvorg, const char *sslclienthost, const char *sslclientdn, time_t tim, const char *key)
DomeTalker(DavixCtxPool &pool, const DomeCredentials &creds, std::string uri, std::string verb, std::string cmd)
std::string target_
Definition: DomeTalker.h:174
Definition: DavixPool.h:48
std::string response_
Definition: DomeTalker.h:180
Definition: DomeTalker.h:36
std::vector< GroupInfo > groups
Definition: authn.h:85
int getXrdHttpReqIndex(const char *verb)
Definition: DomeTalker.h:144
Definition: DomeTalker.h:97
int status_
Definition: DomeTalker.h:183
Definition: DavixPool.h:90
std::string oidc_audience
Definition: authn.h:31
Definition: DomeTalker.h:88
Authentication API. Any sort of security check is plugin-specific.
Definition: DavixPool.h:97
DomeCredentials(std::string cn, std::string ra, std::vector< std::string > gr)
Definition: DomeTalker.h:54
DomeHttpCode
Definition: DomeTalker.h:87
DavixCtxPool & pool_
Definition: DomeTalker.h:168
std::string oidc_issuer
The OIDC issuer.
Definition: DomeTalker.h:48
void setcommand(const DomeCredentials &creds, const char *verb, const char *cmd)
Davix::DavixError * err_
Definition: DomeTalker.h:179
std::string oidc_issuer
Definition: authn.h:32
std::string remoteAddress
The remote address of the user's machine.
Definition: DomeTalker.h:40
Definition: DomeTalker.h:91
static const char * reqTypes[12]
Definition: DomeTalker.h:143
const std::string & response()
std::string oidc_scope
The OIDC scope.
Definition: DomeTalker.h:50
std::string uri_
Definition: DomeTalker.h:170
bool parsedJson_
Definition: DomeTalker.h:182
std::string cmd_
Definition: DomeTalker.h:172
bool oidc_authorized
The OIDC authorization is complete. Other (e.g. group-based) auth steps can be skipped.
Definition: DomeTalker.h:52
std::string verb_
Definition: DomeTalker.h:171
Small utilities used throughout dome.
DavixStuff * ds_
Definition: DomeTalker.h:177
Definition: DomeTalker.h:94
DavixGrabber grabber_
Definition: DomeTalker.h:176
DomeCredentials()
Definition: DomeTalker.h:57
Definition: DomeTalker.h:96
std::string oidc_scope
Definition: authn.h:33
int http_status(const DmException &e)
std::string name
Definition: authn.h:51
std::string remoteAddress
Definition: authn.h:27
UserInfo user
Definition: authn.h:84
boost::property_tree::ptree json_
Definition: DomeTalker.h:181
int compareXrdHttpHashes(const char *h1, const char *h2)
DomeCredentials creds_
Definition: DomeTalker.h:169
std::vector< std::string > groups
The groups the user belongs to.
Definition: DomeTalker.h:42
DomeCredentials(const SecurityContext *ctx)
Definition: DomeTalker.h:58