# 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.exceptions import CreateError, UpdateError, RemoveError | |
from pyhugegraph.utils.huge_decorator import decorator_params, decorator_create | |
from pyhugegraph.utils.util import check_if_success, check_if_authorized | |
class PropertyKey(HugeParamsBase): | |
def __init__(self, graph_instance, session): | |
super().__init__(graph_instance) | |
self.__session = session | |
@decorator_params | |
def asInt(self): | |
self._parameter_holder.set("data_type", "INT") | |
return self | |
@decorator_params | |
def asText(self): | |
self._parameter_holder.set("data_type", "TEXT") | |
return self | |
@decorator_params | |
def asDouble(self): | |
self._parameter_holder.set("data_type", "DOUBLE") | |
return self | |
@decorator_params | |
def asDate(self): | |
self._parameter_holder.set("data_type", "DATE") | |
return self | |
@decorator_params | |
def valueSingle(self): | |
self._parameter_holder.set("cardinality", "SINGLE") | |
return self | |
@decorator_params | |
def valueList(self): | |
self._parameter_holder.set("cardinality", "LIST") | |
return self | |
@decorator_params | |
def valueSet(self): | |
self._parameter_holder.set("cardinality", "SET") | |
return self | |
@decorator_params | |
def calcMax(self): | |
self._parameter_holder.set("aggregate_type", "MAX") | |
return self | |
@decorator_params | |
def calcMin(self): | |
self._parameter_holder.set("aggregate_type", "MIN") | |
return self | |
@decorator_params | |
def calcSum(self): | |
self._parameter_holder.set("aggregate_type", "SUM") | |
return self | |
@decorator_params | |
def calcOld(self): | |
self._parameter_holder.set("aggregate_type", "OLD") | |
return self | |
@decorator_params | |
def userdata(self, *args): | |
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): | |
url = ( | |
f"{self._host}/graphs/{self._graph_name}/schema/propertykeys/" | |
f'{self._parameter_holder.get_value("name")}' | |
) | |
response = self.__session.get(url, auth=self._auth, headers=self._headers) | |
if response.status_code == 200 and check_if_authorized(response): | |
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"] | |
url = f"{self._host}/graphs/{self._graph_name}/schema/propertykeys" | |
response = self.__session.post( | |
url, data=json.dumps(property_keys), auth=self._auth, headers=self._headers | |
) | |
self.clean_parameter_holder() | |
if check_if_success( | |
response, | |
CreateError( | |
f'CreateError: "create PropertyKey failed", Detail: {str(response.content)}' | |
), | |
): | |
return f"create PropertyKey success, Detail: {str(response.content)}" | |
return f"create PropertyKey failed, Detail: {str(response.content)}" | |
@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} | |
url = ( | |
f"{self._host}/graphs/{self._graph_name}/schema/propertykeys/" | |
f"{property_name}/?action=append" | |
) | |
response = self.__session.put( | |
url, data=json.dumps(data), auth=self._auth, headers=self._headers | |
) | |
self.clean_parameter_holder() | |
if check_if_success( | |
response, | |
UpdateError( | |
f'UpdateError: "append PropertyKey failed", Detail: {str(response.content)}' | |
), | |
): | |
return f"append PropertyKey success, Detail: {str(response.content)}" | |
return f"append PropertyKey failed, Detail: {str(response.content)}" | |
@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} | |
url = ( | |
f"{self._host}/graphs/{self._graph_name}/schema/propertykeys/" | |
f"{property_name}/?action=eliminate" | |
) | |
response = self.__session.put( | |
url, data=json.dumps(data), auth=self._auth, headers=self._headers | |
) | |
self.clean_parameter_holder() | |
error = UpdateError( | |
f'UpdateError: "eliminate PropertyKey failed", Detail: {str(response.content)}' | |
) | |
if check_if_success(response, error): | |
return f"eliminate PropertyKey success, Detail: {str(response.content)}" | |
return f"eliminate PropertyKey failed, Detail: {str(response.content)}" | |
@decorator_params | |
def remove(self): | |
dic = self._parameter_holder.get_dic() | |
url = f'{self._host}/graphs/{self._graph_name}/schema/propertykeys/{dic["name"]}' | |
response = self.__session.delete(url) | |
self.clean_parameter_holder() | |
if check_if_success( | |
response, | |
RemoveError( | |
f'RemoveError: "delete PropertyKey failed", Detail: {str(response.content)}' | |
), | |
): | |
return f'delete PropertyKey success, Detail: {dic["name"]}' | |
return f"delete PropertyKey failed, Detail: {str(response.content)}" |