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);
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,
Small utilities used throughout dome.
Definition: DavixPool.h:90
Definition: DavixPool.h:97
Definition: DavixPool.h:48
Base exception class.
Definition: exceptions.h:17
Definition: DomeTalker.h:105
DavixGrabber grabber_
Definition: DomeTalker.h:176
bool execute(const boost::property_tree::ptree ¶ms)
std::string response_
Definition: DomeTalker.h:180
DavixCtxPool & pool_
Definition: DomeTalker.h:168
static const char * reqTypes[12]
Definition: DomeTalker.h:143
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)
int compareXrdHttpHashes(const char *h1, const char *h2)
std::string target_
Definition: DomeTalker.h:174
std::string verb_
Definition: DomeTalker.h:171
DomeTalker(DavixCtxPool &pool, std::string uri, std::string verb, std::string cmd)
bool execute(const std::string &key1, const std::string &value1, const std::string &key2, const std::string &value2, const std::string &key3, const std::string &value3)
bool execute(const std::string &str)
int getXrdHttpReqIndex(const char *verb)
Definition: DomeTalker.h:144
boost::property_tree::ptree json_
Definition: DomeTalker.h:181
DavixStuff * ds_
Definition: DomeTalker.h:177
DomeCredentials creds_
Definition: DomeTalker.h:169
Davix::DavixError * err_
Definition: DomeTalker.h:179
DomeTalker(DavixCtxPool &pool, const DomeCredentials &creds, std::string uri, std::string verb, std::string cmd)
std::string cmd_
Definition: DomeTalker.h:172
bool parsedJson_
Definition: DomeTalker.h:182
int status_
Definition: DomeTalker.h:183
std::string uri_
Definition: DomeTalker.h:170
bool execute(const std::string &key1, const std::string &value1, const std::string &key2, const std::string &value2)
const boost::property_tree::ptree & jresp()
bool execute(const std::string &key, const std::string &value)
bool execute(const std::ostringstream &ss)
void setcommand(const DomeCredentials &creds, const char *verb, const char *cmd)
const std::string & response()
Security context. To be created by the Authn.
Definition: authn.h:73
SecurityCredentials credentials
Definition: authn.h:82
UserInfo user
Definition: authn.h:84
std::vector< GroupInfo > groups
Definition: authn.h:85
std::string oidc_issuer
Definition: authn.h:32
std::string remoteAddress
Definition: authn.h:27
std::string oidc_scope
Definition: authn.h:33
std::string oidc_audience
Definition: authn.h:31
std::string clientName
Definition: authn.h:26
std::string name
Definition: authn.h:51
Authentication API. Any sort of security check is plugin-specific.
Namespace for the dmlite C++ API.
Definition: authn.h:16
DomeHttpCode
Definition: DomeTalker.h:87
@ DOME_HTTP_INSUFFICIENT_STORAGE
Definition: DomeTalker.h:97
@ DOME_HTTP_INTERNAL_SERVER_ERROR
Definition: DomeTalker.h:96
@ DOME_HTTP_UNPROCESSABLE
Definition: DomeTalker.h:94
@ DOME_HTTP_NOT_FOUND
Definition: DomeTalker.h:92
@ DOME_HTTP_CONFLICT
Definition: DomeTalker.h:93
@ DOME_HTTP_BAD_REQUEST
Definition: DomeTalker.h:90
@ DOME_HTTP_OK
Definition: DomeTalker.h:88
@ DOME_HTTP_DENIED
Definition: DomeTalker.h:91
int http_status(const DmException &e)
Definition: DomeTalker.h:36
std::string remoteAddress
The remote address of the user's machine.
Definition: DomeTalker.h:40
std::string clientName
The remote user that originated a request. Typically a DN.
Definition: DomeTalker.h:38
DomeCredentials(const SecurityContext *ctx)
Definition: DomeTalker.h:58
DomeCredentials(std::string cn, std::string ra, std::vector< std::string > gr)
Definition: DomeTalker.h:54
std::vector< std::string > groups
The groups the user belongs to.
Definition: DomeTalker.h:42
bool oidc_authorized
The OIDC authorization is complete. Other (e.g. group-based) auth steps can be skipped.
Definition: DomeTalker.h:52
std::string oidc_audience
The OIDC audience.
Definition: DomeTalker.h:46
std::string oidc_issuer
The OIDC issuer.
Definition: DomeTalker.h:48
std::string oidc_scope
The OIDC scope.
Definition: DomeTalker.h:50
DomeCredentials()
Definition: DomeTalker.h:57