blob: d4161f54743c0acd72c57de796c4ed21b7dcd755 [file]
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.
from typing import Optional
from pypaimon.api.rest_util import RESTUtil
from pypaimon.common.options import Options
from pypaimon.common.options.config import CatalogOptions
class ResourcePaths:
V1 = "v1"
DATABASES = "databases"
TABLES = "tables"
TABLE_DETAILS = "table-details"
PARTITIONS = "partitions"
FUNCTIONS = "functions"
FUNCTION_DETAILS = "function-details"
TAGS = "tags"
BRANCHES = "branches"
RENAME = "rename"
FORWARD = "forward"
def __init__(self, prefix: str):
self.base_path = "/{}/{}".format(self.V1, prefix).rstrip("/")
@classmethod
def for_catalog_properties(
cls, options: Options) -> "ResourcePaths":
prefix = options.get(CatalogOptions.PREFIX, "")
return cls(prefix)
@staticmethod
def config() -> str:
return "/{}/config".format(ResourcePaths.V1)
def databases(self) -> str:
return "{}/{}".format(self.base_path, self.DATABASES)
def database(self, name: str) -> str:
return "{}/{}/{}".format(self.base_path, self.DATABASES, RESTUtil.encode_string(name))
def tables(self, database_name: Optional[str] = None) -> str:
if database_name:
return "{}/{}/{}/{}".format(self.base_path, self.DATABASES,
RESTUtil.encode_string(database_name), self.TABLES)
return "{}/{}".format(self.base_path, self.TABLES)
def table(self, database_name: str, table_name: str) -> str:
return ("{}/{}/{}/{}/{}".format(self.base_path, self.DATABASES, RESTUtil.encode_string(database_name),
self.TABLES, RESTUtil.encode_string(table_name)))
def table_details(self, database_name: str) -> str:
return "{}/{}/{}/{}".format(self.base_path, self.DATABASES, database_name, self.TABLE_DETAILS)
def table_token(self, database_name: str, table_name: str) -> str:
return ("{}/{}/{}/{}/{}/token".format(self.base_path, self.DATABASES, RESTUtil.encode_string(database_name),
self.TABLES, RESTUtil.encode_string(table_name)))
def rename_table(self) -> str:
return "{}/{}/rename".format(self.base_path, self.TABLES)
def commit_table(self, database_name: str, table_name: str) -> str:
return ("{}/{}/{}/{}/{}/commit".format(self.base_path, self.DATABASES, RESTUtil.encode_string(database_name),
self.TABLES, RESTUtil.encode_string(table_name)))
def rollback_table(self, database_name: str, table_name: str) -> str:
return ("{}/{}/{}/{}/{}/rollback".format(self.base_path, self.DATABASES, RESTUtil.encode_string(database_name),
self.TABLES, RESTUtil.encode_string(table_name)))
def table_snapshot(self, database_name: str, table_name: str) -> str:
return ("{}/{}/{}/{}/{}/snapshot".format(self.base_path, self.DATABASES, RESTUtil.encode_string(database_name),
self.TABLES, RESTUtil.encode_string(table_name)))
def partitions(self, database_name: str, table_name: str) -> str:
return ("{}/{}/{}/{}/{}/{}".format(self.base_path, self.DATABASES, RESTUtil.encode_string(database_name),
self.TABLES, RESTUtil.encode_string(table_name), self.PARTITIONS))
def functions(self, database_name: Optional[str] = None) -> str:
if database_name:
return "{}/{}/{}/{}".format(self.base_path, self.DATABASES,
RESTUtil.encode_string(database_name), self.FUNCTIONS)
return "{}/{}".format(self.base_path, self.FUNCTIONS)
def function_details(self, database_name: str) -> str:
return "{}/{}/{}/{}".format(self.base_path, self.DATABASES,
RESTUtil.encode_string(database_name), self.FUNCTION_DETAILS)
def function(self, database_name: str, function_name: str) -> str:
return "{}/{}/{}/{}/{}".format(self.base_path, self.DATABASES, RESTUtil.encode_string(database_name),
self.FUNCTIONS, RESTUtil.encode_string(function_name))
def tags(self, database_name: str, table_name: str) -> str:
return "{}/{}/{}/{}/{}/{}".format(
self.base_path, self.DATABASES, RESTUtil.encode_string(database_name),
self.TABLES, RESTUtil.encode_string(table_name), self.TAGS)
def tag(self, database_name: str, table_name: str, tag_name: str) -> str:
return "{}/{}/{}/{}/{}/{}/{}".format(
self.base_path, self.DATABASES, RESTUtil.encode_string(database_name),
self.TABLES, RESTUtil.encode_string(table_name), self.TAGS,
RESTUtil.encode_string(tag_name))
def branches(self, database_name: str, table_name: str) -> str:
return "{}/{}/{}/{}/{}/{}".format(
self.base_path, self.DATABASES, RESTUtil.encode_string(database_name),
self.TABLES, RESTUtil.encode_string(table_name), self.BRANCHES)
def branch(self, database_name: str, table_name: str, branch_name: str) -> str:
return "{}/{}/{}/{}/{}/{}/{}".format(
self.base_path, self.DATABASES, RESTUtil.encode_string(database_name),
self.TABLES, RESTUtil.encode_string(table_name), self.BRANCHES,
RESTUtil.encode_string(branch_name))
def rename_branch(self, database_name: str, table_name: str, branch_name: str) -> str:
return "{}/{}".format(
self.branch(database_name, table_name, branch_name), self.RENAME)
def forward_branch(self, database_name: str, table_name: str, branch_name: str) -> str:
return "{}/{}".format(
self.branch(database_name, table_name, branch_name), self.FORWARD)