// -*- mode:C++; tab-width:8; c-basic-offset:2; indent-tabs-mode:t -*- // vim: ts=8 sw=2 smarttab ft=cpp #pragma once #include #include "rgw_lib.h" #include "rgw_file_int.h" namespace rgw { class RGWLibProcess : public RGWProcess { RGWAccessKey access_key; std::mutex mtx; std::condition_variable cv; int gen; bool shutdown; typedef flat_map FSMAP; FSMAP mounted_fs; using lock_guard = std::lock_guard; using unique_lock = std::unique_lock; public: RGWLibProcess(CephContext* cct, RGWProcessEnv& pe, int num_threads, std::string uri_prefix, RGWFrontendConfig* _conf) : RGWProcess(cct, pe, num_threads, std::move(uri_prefix), _conf), gen(0), shutdown(false) {} void run() override; void checkpoint(); void stop() { shutdown = true; for (const auto& fs: mounted_fs) { fs.second->stop(); } cv.notify_all(); } void register_fs(RGWLibFS* fs) { lock_guard guard(mtx); mounted_fs.insert(FSMAP::value_type(fs, fs)); ++gen; } void unregister_fs(RGWLibFS* fs) { lock_guard guard(mtx); FSMAP::iterator it = mounted_fs.find(fs); if (it != mounted_fs.end()) { mounted_fs.erase(it); ++gen; } } void enqueue_req(RGWLibRequest* req) { lsubdout(g_ceph_context, rgw, 10) << __func__ << " enqueue request req=" << std::hex << req << std::dec << dendl; req_throttle.get(1); req_wq.queue(req); } /* enqueue_req */ /* "regular" requests */ void handle_request(const DoutPrefixProvider *dpp, RGWRequest* req) override; // async handler, deletes req int process_request(RGWLibRequest* req); int process_request(RGWLibRequest* req, RGWLibIO* io); void set_access_key(RGWAccessKey& key) { access_key = key; } /* requests w/continue semantics */ int start_request(RGWLibContinuedReq* req); int finish_request(RGWLibContinuedReq* req); }; /* RGWLibProcess */ class RGWLibFrontend : public RGWProcessFrontend { public: RGWLibFrontend(RGWProcessEnv& pe, RGWFrontendConfig *_conf) : RGWProcessFrontend(pe, _conf) {} int init() override; void stop() override { RGWProcessFrontend::stop(); get_process()->stop(); } RGWLibProcess* get_process() { return static_cast(pprocess); } inline void enqueue_req(RGWLibRequest* req) { static_cast(pprocess)->enqueue_req(req); // async } inline int execute_req(RGWLibRequest* req) { return static_cast(pprocess)->process_request(req); // !async } inline int start_req(RGWLibContinuedReq* req) { return static_cast(pprocess)->start_request(req); } inline int finish_req(RGWLibContinuedReq* req) { return static_cast(pprocess)->finish_request(req); } }; /* RGWLibFrontend */ } /* namespace rgw */