Files
oceanbase/src/archive/ob_archive_path.h
gm 4a92b6d7df reformat source code
according to code styles, 'AccessModifierOffset' should be -2.
2021-06-17 10:40:36 +08:00

76 lines
4.6 KiB
C++

/**
* Copyright (c) 2021 OceanBase
* OceanBase CE is licensed under Mulan PubL v2.
* You can use this software according to the terms and conditions of the Mulan PubL v2.
* You may obtain a copy of Mulan PubL v2 at:
* http://license.coscl.org.cn/MulanPubL-2.0
* THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
* EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
* MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
* See the Mulan PubL v2 for more details.
*/
#include "clog/ob_log_define.h"
#include "common/ob_partition_key.h"
#include "ob_log_archive_struct.h"
#ifndef OCEANBASE_ARCHIVE_OB_ARCHIVE_PATH_H_
#define OCEANBASE_ARCHIVE_OB_ARCHIVE_PATH_H_
namespace oceanbase {
namespace archive {
class ObArchivePathUtil {
public:
// oss:/backup/cluster_name/cluster_id/incarnation_1/tenant_id/clog/round/
int build_base_path(const char* root_path, const char* cluster_name, const int64_t cluster_id,
const uint64_t tenant_id, const int64_t incarnantion, const int64_t archive_round, const int64_t path_buf_len,
char* base_path);
// oss:/backup/cluster_name/cluster_id/incarnation_1/tenant_id/clog/round/TYPE/table_id/partition-id/
// TYPE: data/index
int build_file_prefix(const common::ObPGKey& pg_key, const char* base_path, const LogArchiveFileType file_type,
const int64_t path_buf_len, char* dest_path_buf);
// oss:/backup/cluster_name/cluster_id/incarnation_1/tenant_id/clog/round/TYPE/table_id/partition-id/
// TYPE: data/index
int build_archive_file_prefix(const common::ObPGKey& pg_key, const LogArchiveFileType file_type,
const int64_t incarnation, const int64_t round, const int64_t path_buf_len, char* dest_path);
// oss:/backup/cluster_name/cluster_id/incarnation_1/tenant_id/clog/round/TYPE/table_id/partition-id/file_id
// TYPE: data/index
int build_archive_file_path(const common::ObPGKey& pg_key, const LogArchiveFileType file_type, const uint64_t file_id,
const int64_t incarnation, const int64_t round, const int64_t path_buf_len, char* dest_path);
// oss:/backup/cluster_name/cluster_id/incarnation_1/tenant_id/clog/round/TYPE/table_id/partition-id/file_id
// TYPE: data/index
int build_file_path(const common::ObPGKey& pg_key, const char* base_path, const LogArchiveFileType file_type,
const uint64_t file_id, const int64_t path_buf_len, char* dest_path_buf);
// only two kinds of archive files, data/index
bool is_valid_file_type(const LogArchiveFileType file_type);
// oss:/backup/cluster_name/cluster_id/incarnation_1/tenant_id/clog/round/archive_key/
int build_archive_key_prefix(const int64_t incarnation, const int64_t round, const uint64_t tenant_id,
const int64_t path_buf_len, char* path, const int64_t storage_info_len, char* info);
// oss:/backup/cluster_name/cluster_id/incarnation_1/tenant_id/clog/round/archive_key/ARCHIVE_KEY
// ARCHIVE_KEY: tableID_partitionID
int build_archive_key_path(const common::ObPGKey& pkey, const int64_t incarnation, const int64_t round,
const int64_t path_buf_len, char* path, const int64_t storage_info_len, char* info);
// oss:/backup/cluster_name/cluster_id/incarnation_1/clog_info/
int build_server_start_archive_prefix(const int64_t incarnation, const int64_t round, const int64_t path_buf_len,
char* path, const int64_t storage_info_len, char* info);
// oss:/backup/cluster_name/cluster_id/incarnation_1/clog_info/SERVER_START_TS
// SERVER_START_TS: serverID_ip_port
int build_server_start_archive_path(const int64_t incarnation, const int64_t round, const int64_t path_buf_len,
char* dest_path, const int64_t storage_info_len, char* info);
private:
int build_archive_file_prefix_(const common::ObPGKey& pg_key, const LogArchiveFileType file_type,
const int64_t incarnation, const int64_t round, const int64_t path_buf_len, char* dest_path, int64_t& pos);
int build_file_prefix_(const common::ObPGKey& pg_key, const char* base_path, const LogArchiveFileType file_type,
const int64_t path_buf_len, char* dest_path_buf, int64_t& pos);
const char* get_file_prefix_with_type_(const LogArchiveFileType file_type);
int build_archive_key_prefix_(const int64_t incarnation, const int64_t round, const uint64_t tenant_id,
const int64_t path_buf_len, char* dest_path, int64_t& pos, const int64_t storage_info_len, char* storage_info);
int build_server_start_archive_prefix_(const int64_t incarnation, const int64_t round, const int64_t path_buf_len,
char* dest_path, int64_t& pos, const int64_t storage_info_len, char* info);
};
} // namespace archive
} // namespace oceanbase
#endif /* OCEANBASE_ARCHIVE_OB_ARCHIVE_PATH_H_ */