| # 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 "" |