mirror of
https://github.com/ceph/ceph
synced 2025-01-03 01:22:53 +00:00
rgw: Support certain archaic and antiquated distributions
Signed-off-by: Adam C. Emerson <aemerson@redhat.com>
This commit is contained in:
parent
42fb84b811
commit
af8d9bdf07
@ -3,11 +3,12 @@
|
|||||||
|
|
||||||
|
|
||||||
#include <cstring>
|
#include <cstring>
|
||||||
#include <regex>
|
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
#include <stack>
|
#include <stack>
|
||||||
#include <utility>
|
#include <utility>
|
||||||
|
|
||||||
|
#include <boost/regex.hpp>
|
||||||
|
|
||||||
#include "rapidjson/reader.h"
|
#include "rapidjson/reader.h"
|
||||||
|
|
||||||
#include "rgw_auth.h"
|
#include "rgw_auth.h"
|
||||||
@ -22,10 +23,7 @@ using std::find;
|
|||||||
using std::int64_t;
|
using std::int64_t;
|
||||||
using std::move;
|
using std::move;
|
||||||
using std::pair;
|
using std::pair;
|
||||||
using std::regex;
|
|
||||||
using std::regex_match;
|
|
||||||
using std::size_t;
|
using std::size_t;
|
||||||
using std::smatch;
|
|
||||||
using std::string;
|
using std::string;
|
||||||
using std::stringstream;
|
using std::stringstream;
|
||||||
using std::ostream;
|
using std::ostream;
|
||||||
@ -36,6 +34,11 @@ using std::unordered_map;
|
|||||||
using boost::container::flat_set;
|
using boost::container::flat_set;
|
||||||
using boost::none;
|
using boost::none;
|
||||||
using boost::optional;
|
using boost::optional;
|
||||||
|
using boost::regex;
|
||||||
|
using boost::regex_constants::ECMAScript;
|
||||||
|
using boost::regex_constants::optimize;
|
||||||
|
using boost::regex_match;
|
||||||
|
using boost::smatch;
|
||||||
|
|
||||||
using rapidjson::BaseReaderHandler;
|
using rapidjson::BaseReaderHandler;
|
||||||
using rapidjson::UTF8;
|
using rapidjson::UTF8;
|
||||||
@ -201,13 +204,15 @@ ARN::ARN(const rgw_bucket& b, const string& o)
|
|||||||
}
|
}
|
||||||
|
|
||||||
optional<ARN> ARN::parse(const string& s, bool wildcards) {
|
optional<ARN> ARN::parse(const string& s, bool wildcards) {
|
||||||
static const regex rx_wild("arn:([^:]*):([^:]*):([^:]*):([^:]*):([^:]*)",
|
static const char str_wild[] = "arn:([^:]*):([^:]*):([^:]*):([^:]*):([^:]*)";
|
||||||
std::regex_constants::ECMAScript |
|
static const regex rx_wild(str_wild,
|
||||||
std::regex_constants::optimize);
|
sizeof(str_wild) - 1,
|
||||||
static const regex rx_no_wild(
|
ECMAScript | optimize);
|
||||||
"arn:([^:*]*):([^:*]*):([^:*]*):([^:*]*):([^:*]*)",
|
static const char str_no_wild[]
|
||||||
std::regex_constants::ECMAScript |
|
= "arn:([^:*]*):([^:*]*):([^:*]*):([^:*]*):([^:*]*)";
|
||||||
std::regex_constants::optimize);
|
static const regex rx_no_wild(str_no_wild,
|
||||||
|
sizeof(str_no_wild) - 1,
|
||||||
|
ECMAScript | optimize);
|
||||||
|
|
||||||
smatch match;
|
smatch match;
|
||||||
|
|
||||||
@ -703,9 +708,9 @@ static optional<Principal> parse_principal(CephContext* cct, TokenID t,
|
|||||||
return Principal::tenant(std::move(a->account));
|
return Principal::tenant(std::move(a->account));
|
||||||
}
|
}
|
||||||
|
|
||||||
static const regex rx("([^/]*)/(.*)",
|
static const char rx_str[] = "([^/]*)/(.*)";
|
||||||
std::regex_constants::ECMAScript |
|
static const regex rx(rx_str, sizeof(rx_str) - 1,
|
||||||
std::regex_constants::optimize);
|
ECMAScript | optimize);
|
||||||
smatch match;
|
smatch match;
|
||||||
if (regex_match(a->resource, match, rx)) {
|
if (regex_match(a->resource, match, rx)) {
|
||||||
ceph_assert(match.size() == 2);
|
ceph_assert(match.size() == 2);
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <ctime>
|
#include <ctime>
|
||||||
#include <regex>
|
|
||||||
|
#include <boost/regex.hpp>
|
||||||
|
|
||||||
#include "common/errno.h"
|
#include "common/errno.h"
|
||||||
#include "common/Formatter.h"
|
#include "common/Formatter.h"
|
||||||
@ -377,14 +378,14 @@ bool RGWRole::validate_input()
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::regex regex_name("[A-Za-z0-9:=,.@-]+");
|
boost::regex regex_name("[A-Za-z0-9:=,.@-]+");
|
||||||
if (! std::regex_match(name, regex_name)) {
|
if (! boost::regex_match(name, regex_name)) {
|
||||||
ldout(cct, 0) << "ERROR: Invalid chars in name " << dendl;
|
ldout(cct, 0) << "ERROR: Invalid chars in name " << dendl;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::regex regex_path("(/[!-~]+/)|(/)");
|
boost::regex regex_path("(/[!-~]+/)|(/)");
|
||||||
if (! std::regex_match(path,regex_path)) {
|
if (! boost::regex_match(path,regex_path)) {
|
||||||
ldout(cct, 0) << "ERROR: Invalid chars in path " << dendl;
|
ldout(cct, 0) << "ERROR: Invalid chars in path " << dendl;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user