blob: eaefb59c1d9c0647b6e01c2a9218e264e81d69ef [file] [log] [blame]
# 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.
import json
from pyhugegraph.api.common import HugeParamsBase
from pyhugegraph.utils.huge_decorator import decorator_create, decorator_params
from pyhugegraph.utils.log import log
from pyhugegraph.utils.util import ResponseValidation
# TODO: support UpdateStrategy for PropertyKey (refer java-client/rest-api)
class PropertyKey(HugeParamsBase):
# Data Type: [OBJECT, BOOLEAN, BYTE, INT, LONG, FLOAT, DOUBLE, TEXT, BLOB, DATE]
@decorator_params
def asObject(self) -> "PropertyKey":
self._parameter_holder.set("data_type", "OBJECT")
return self
@decorator_params
def asBool(self) -> "PropertyKey":
self._parameter_holder.set("data_type", "BOOLEAN")
return self
@decorator_params
def asByte(self) -> "PropertyKey":
self._parameter_holder.set("data_type", "BYTE")
return self
@decorator_params
def asInt(self) -> "PropertyKey":
self._parameter_holder.set("data_type", "INT")
return self
@decorator_params
def asLong(self) -> "PropertyKey":
self._parameter_holder.set("data_type", "LONG")
return self
@decorator_params
def asFloat(self) -> "PropertyKey":
self._parameter_holder.set("data_type", "FLOAT")
return self
@decorator_params
def asDouble(self) -> "PropertyKey":
self._parameter_holder.set("data_type", "DOUBLE")
return self
@decorator_params
def asText(self) -> "PropertyKey":
self._parameter_holder.set("data_type", "TEXT")
return self
@decorator_params
def asBlob(self) -> "PropertyKey":
self._parameter_holder.set("data_type", "BLOB")
return self
@decorator_params
def asDate(self) -> "PropertyKey":
self._parameter_holder.set("data_type", "DATE")
return self
# Cardinality Type [SINGLE, LIST, SET]
@decorator_params
def valueSingle(self) -> "PropertyKey":
self._parameter_holder.set("cardinality", "SINGLE")
return self
@decorator_params
def valueList(self) -> "PropertyKey":
self._parameter_holder.set("cardinality", "LIST")
return self
@decorator_params
def valueSet(self) -> "PropertyKey":
self._parameter_holder.set("cardinality", "SET")
return self
# Aggregate Type [NONE, MAX, MIN, SUM, OLD]
@decorator_params
def calcMax(self) -> "PropertyKey":
self._parameter_holder.set("aggregate_type", "MAX")
return self
@decorator_params
def calcMin(self) -> "PropertyKey":
self._parameter_holder.set("aggregate_type", "MIN")
return self
@decorator_params
def calcSum(self) -> "PropertyKey":
self._parameter_holder.set("aggregate_type", "SUM")
return self
@decorator_params
def calcOld(self) -> "PropertyKey":
self._parameter_holder.set("aggregate_type", "OLD")
return self
@decorator_params
def userdata(self, *args) -> "PropertyKey":
user_data = self._parameter_holder.get_value("user_data")
if not user_data:
self._parameter_holder.set("user_data", {})
user_data = self._parameter_holder.get_value("user_data")
i = 0
while i < len(args):
user_data[args[i]] = args[i + 1]
i += 2
return self
def ifNotExist(self) -> "PropertyKey":
path = f"schema/propertykeys/{self._parameter_holder.get_value('name')}"
if _ := self._sess.request(path, validator=ResponseValidation(strict=False)):
self._parameter_holder.set("not_exist", False)
return self
@decorator_create
def create(self):
dic = self._parameter_holder.get_dic()
property_keys = {"name": dic["name"]}
if "data_type" in dic:
property_keys["data_type"] = dic["data_type"]
if "cardinality" in dic:
property_keys["cardinality"] = dic["cardinality"]
path = "schema/propertykeys"
self.clean_parameter_holder()
if response := self._sess.request(path, "POST", data=json.dumps(property_keys)):
return f"create PropertyKey success, Detail: {response!s}"
log.error("create PropertyKey failed, Detail: %s", str(response))
return ""
@decorator_params
def append(self):
property_name = self._parameter_holder.get_value("name")
user_data = self._parameter_holder.get_value("user_data")
if not user_data:
user_data = {}
data = {"name": property_name, "user_data": user_data}
path = f"schema/propertykeys/{property_name}/?action=append"
self.clean_parameter_holder()
if response := self._sess.request(path, "PUT", data=json.dumps(data)):
return f"append PropertyKey success, Detail: {response!s}"
log.error("append PropertyKey failed, Detail: %s", str(response))
return ""
@decorator_params
def eliminate(self):
property_name = self._parameter_holder.get_value("name")
user_data = self._parameter_holder.get_value("user_data")
if not user_data:
user_data = {}
data = {"name": property_name, "user_data": user_data}
path = f"schema/propertykeys/{property_name}/?action=eliminate"
self.clean_parameter_holder()
if response := self._sess.request(path, "PUT", data=json.dumps(data)):
return f"eliminate PropertyKey success, Detail: {response!s}"
log.error("eliminate PropertyKey failed, Detail: %s", str(response))
return ""
@decorator_params
def remove(self):
dic = self._parameter_holder.get_dic()
path = f"schema/propertykeys/{dic['name']}"
self.clean_parameter_holder()
if response := self._sess.request(path, "DELETE"):
return f"delete PropertyKey success, Detail: {response!s}"
log.error("delete PropertyKey failed, Detail: %s", str(response))
return ""