// -*- mode:C++; tab-width:8; c-basic-offset:2; indent-tabs-mode:t -*- // vim: ts=8 sw=2 smarttab ft=cpp /* * Ceph - scalable distributed file system * * Copyright (C) 2019 Red Hat, Inc. * * This is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License version 2.1, as published by the Free Software * Foundation. See file COPYING. * */ #pragma once #include "rgw/rgw_service.h" #include "svc_rados.h" class RGWSI_BILog_RADOS : public RGWServiceInstance { public: struct Svc { RGWSI_BucketIndex_RADOS *bi{nullptr}; } svc; RGWSI_BILog_RADOS(CephContext *cct); void init(RGWSI_BucketIndex_RADOS *bi_rados_svc); int log_start(const DoutPrefixProvider *dpp, const RGWBucketInfo& bucket_info, int shard_id); int log_stop(const DoutPrefixProvider *dpp, const RGWBucketInfo& bucket_info, int shard_id); int log_trim(const DoutPrefixProvider *dpp, const RGWBucketInfo& bucket_info, int shard_id, std::string& start_marker, std::string& end_marker); int log_list(const DoutPrefixProvider *dpp, const RGWBucketInfo& bucket_info, int shard_id, std::string& marker, uint32_t max, std::list& result, bool *truncated); int get_log_status(const DoutPrefixProvider *dpp, const RGWBucketInfo& bucket_info, int shard_id, map *markers, optional_yield y); };