rgw: Support certain archaic and antiquated distributions

Signed-off-by: Adam C. Emerson <aemerson@redhat.com>
This commit is contained in:
Adam C. Emerson 2017-06-05 15:46:45 -04:00
parent 42fb84b811
commit af8d9bdf07
2 changed files with 25 additions and 19 deletions

View File

@ -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);

View File

@ -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;
} }