forked from irods/irods_capability_storage_tiering
-
Notifications
You must be signed in to change notification settings - Fork 0
/
storage_tiering_utilities.cpp
94 lines (80 loc) · 2.65 KB
/
storage_tiering_utilities.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
#include "storage_tiering_utilities.hpp"
#include "rcMisc.h"
namespace irods {
std::string any_to_string(boost::any& _a) {
if(_a.type() == typeid(std::string)) {
return boost::any_cast<std::string>(_a);
}
else if(_a.type() == typeid(std::string*)) {
return *boost::any_cast<std::string*>(_a);
}
else if(_a.type() == typeid(msParam_t*)) {
msParam_t* msp = boost::any_cast<msParam_t*>(_a);
if(msp->type == STR_MS_T) {
return static_cast<char*>(msp->inOutStruct);
}
else {
rodsLog(
LOG_ERROR,
"not a string type [%s]",
msp->type);
}
}
THROW(
SYS_INVALID_INPUT_PARAM,
boost::format("parameter is not a string [%s]")
% _a.type().name());
} // any_to_string
void exception_to_rerror(
const irods::exception& _exception,
rError_t& _error) {
std::string msg;
for(const auto& i : _exception.message_stack()) {
msg += i;
}
addRErrorMsg(
&_error,
_exception.code(),
msg.c_str());
} // exception_to_rerror
void exception_to_rerror(
const int _code,
const char* _what,
rError_t& _error) {
addRErrorMsg(
&_error,
_code,
_what);
} // exception_to_rerror
static std::string collapse_error_stack(
rError_t& _error) {
std::stringstream ss;
for(int i = 0; i < _error.len; ++i) {
rErrMsg_t* err_msg = _error.errMsg[i];
if(err_msg->status != STDOUT_STATUS) {
ss << "status: " << err_msg->status << " ";
}
ss << err_msg->msg << " - ";
}
return ss.str();
} // collapse_error_stack
void invoke_policy(
ruleExecInfo_t* _rei,
const std::string& _action,
std::list<boost::any> _args) {
irods::rule_engine_context_manager<
irods::unit,
ruleExecInfo_t*,
irods::AUDIT_RULE> re_ctx_mgr(
irods::re_plugin_globals->global_re_mgr,
_rei);
irods::error err = re_ctx_mgr.exec_rule(_action, irods::unpack(_args));
if(!err.ok()) {
if(_rei->status < 0) {
std::string msg = collapse_error_stack(_rei->rsComm->rError);
THROW(_rei->status, msg);
}
THROW(err.code(), err.result());
}
} // invoke_policy
} // namespace irods