diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-21 11:54:28 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-21 11:54:28 +0000 |
commit | e6918187568dbd01842d8d1d2c808ce16a894239 (patch) | |
tree | 64f88b554b444a49f656b6c656111a145cbbaa28 /src/rgw/rgw_rest_usage.cc | |
parent | Initial commit. (diff) | |
download | ceph-e6918187568dbd01842d8d1d2c808ce16a894239.tar.xz ceph-e6918187568dbd01842d8d1d2c808ce16a894239.zip |
Adding upstream version 18.2.2.upstream/18.2.2
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/rgw/rgw_rest_usage.cc')
-rw-r--r-- | src/rgw/rgw_rest_usage.cc | 121 |
1 files changed, 121 insertions, 0 deletions
diff --git a/src/rgw/rgw_rest_usage.cc b/src/rgw/rgw_rest_usage.cc new file mode 100644 index 000000000..9207a68cd --- /dev/null +++ b/src/rgw/rgw_rest_usage.cc @@ -0,0 +1,121 @@ +// -*- mode:C++; tab-width:8; c-basic-offset:2; indent-tabs-mode:t -*- +// vim: ts=8 sw=2 smarttab ft=cpp + +#include "rgw_op.h" +#include "rgw_usage.h" +#include "rgw_rest_usage.h" +#include "rgw_sal.h" + +#include "include/str_list.h" + +#define dout_subsys ceph_subsys_rgw + +using namespace std; + +class RGWOp_Usage_Get : public RGWRESTOp { + +public: + RGWOp_Usage_Get() {} + + int check_caps(const RGWUserCaps& caps) override { + return caps.check_cap("usage", RGW_CAP_READ); + } + void execute(optional_yield y) override; + + const char* name() const override { return "get_usage"; } +}; + +void RGWOp_Usage_Get::execute(optional_yield y) { + map<std::string, bool> categories; + + string uid_str; + string bucket_name; + uint64_t start, end; + bool show_entries; + bool show_summary; + + RESTArgs::get_string(s, "uid", uid_str, &uid_str); + RESTArgs::get_string(s, "bucket", bucket_name, &bucket_name); + std::unique_ptr<rgw::sal::User> user = driver->get_user(rgw_user(uid_str)); + std::unique_ptr<rgw::sal::Bucket> bucket; + + if (!bucket_name.empty()) { + driver->get_bucket(nullptr, user.get(), std::string(), bucket_name, &bucket, null_yield); + } + + RESTArgs::get_epoch(s, "start", 0, &start); + RESTArgs::get_epoch(s, "end", (uint64_t)-1, &end); + RESTArgs::get_bool(s, "show-entries", true, &show_entries); + RESTArgs::get_bool(s, "show-summary", true, &show_summary); + + string cat_str; + RESTArgs::get_string(s, "categories", cat_str, &cat_str); + + if (!cat_str.empty()) { + list<string> cat_list; + list<string>::iterator iter; + get_str_list(cat_str, cat_list); + for (iter = cat_list.begin(); iter != cat_list.end(); ++iter) { + categories[*iter] = true; + } + } + + op_ret = RGWUsage::show(this, driver, user.get(), bucket.get(), start, end, show_entries, show_summary, &categories, flusher); +} + +class RGWOp_Usage_Delete : public RGWRESTOp { + +public: + RGWOp_Usage_Delete() {} + + int check_caps(const RGWUserCaps& caps) override { + return caps.check_cap("usage", RGW_CAP_WRITE); + } + void execute(optional_yield y) override; + + const char* name() const override { return "trim_usage"; } +}; + +void RGWOp_Usage_Delete::execute(optional_yield y) { + string uid_str; + string bucket_name; + uint64_t start, end; + + RESTArgs::get_string(s, "uid", uid_str, &uid_str); + RESTArgs::get_string(s, "bucket", bucket_name, &bucket_name); + std::unique_ptr<rgw::sal::User> user = driver->get_user(rgw_user(uid_str)); + std::unique_ptr<rgw::sal::Bucket> bucket; + + if (!bucket_name.empty()) { + driver->get_bucket(nullptr, user.get(), std::string(), bucket_name, &bucket, null_yield); + } + + RESTArgs::get_epoch(s, "start", 0, &start); + RESTArgs::get_epoch(s, "end", (uint64_t)-1, &end); + + if (rgw::sal::User::empty(user.get()) && + bucket_name.empty() && + !start && + end == (uint64_t)-1) { + bool remove_all; + RESTArgs::get_bool(s, "remove-all", false, &remove_all); + if (!remove_all) { + op_ret = -EINVAL; + return; + } + } + + op_ret = RGWUsage::trim(this, driver, user.get(), bucket.get(), start, end); +} + +RGWOp *RGWHandler_Usage::op_get() +{ + return new RGWOp_Usage_Get; +} + +RGWOp *RGWHandler_Usage::op_delete() +{ + return new RGWOp_Usage_Delete; +} + + |