build area updated
This commit is contained in:
parent
ffb85a62f6
commit
952d742999
|
|
@ -1,5 +1,153 @@
|
||||||
|
import typing
|
||||||
|
|
||||||
|
from databases import (
|
||||||
|
Build,
|
||||||
|
BuildArea,
|
||||||
|
)
|
||||||
|
|
||||||
|
from api_validations.validations_request import (
|
||||||
|
InsertBuildArea,
|
||||||
|
UpdateBuildArea,
|
||||||
|
ListOptions,
|
||||||
|
)
|
||||||
|
|
||||||
|
from api_validations.core_response import AlchemyJsonResponse
|
||||||
from api_events.events.abstract_class import MethodToEvent, ActionsSchema
|
from api_events.events.abstract_class import MethodToEvent, ActionsSchema
|
||||||
from api_objects.auth.token_objects import EmployeeTokenObject, OccupantTokenObject
|
from api_objects.auth.token_objects import EmployeeTokenObject, OccupantTokenObject
|
||||||
|
|
||||||
|
|
||||||
class BuildingBuildAreaEvents(MethodToEvent): ...
|
class BuildListEventMethods(MethodToEvent):
|
||||||
|
|
||||||
|
event_type = "SELECT"
|
||||||
|
__event_keys__ = {
|
||||||
|
"0bb51845-65a2-4340-8872-a3b5aad95468": "build_area_list",
|
||||||
|
}
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def build_area_list(
|
||||||
|
cls,
|
||||||
|
list_options: ListOptions,
|
||||||
|
token_dict: typing.Union[EmployeeTokenObject, OccupantTokenObject],
|
||||||
|
):
|
||||||
|
if isinstance(token_dict, OccupantTokenObject):
|
||||||
|
build_ids = Build.filter_all(
|
||||||
|
Build.id == token_dict.selected_occupant.build_id,
|
||||||
|
*Build.valid_record_args(Build),
|
||||||
|
).data
|
||||||
|
build_id_list = [build.id for build in build_ids]
|
||||||
|
BuildArea.pre_query = BuildArea.filter_all(
|
||||||
|
BuildArea.build_id.in_(build_id_list),
|
||||||
|
*BuildArea.valid_record_args(BuildArea),
|
||||||
|
).query
|
||||||
|
elif isinstance(token_dict, EmployeeTokenObject):
|
||||||
|
build_ids = Build.select_action(
|
||||||
|
employee_id=token_dict.selected_company.employee_id
|
||||||
|
)
|
||||||
|
build_id_list = [build.id for build in build_ids]
|
||||||
|
BuildArea.pre_query = BuildArea.filter_all(
|
||||||
|
BuildArea.build_id.in_(build_id_list),
|
||||||
|
*BuildArea.valid_record_args(BuildArea),
|
||||||
|
).query
|
||||||
|
BuildArea.filter_attr = list_options
|
||||||
|
records = BuildArea.filter_all(
|
||||||
|
*BuildArea.get_smart_query(smart_query=list_options.query),
|
||||||
|
*BuildArea.valid_record_args(BuildArea),
|
||||||
|
)
|
||||||
|
return AlchemyJsonResponse(
|
||||||
|
completed=True,
|
||||||
|
message="Update Build record",
|
||||||
|
result=records
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
class BuildCreateEventMethods(MethodToEvent):
|
||||||
|
|
||||||
|
event_type = "CREATE"
|
||||||
|
__event_keys__ = {
|
||||||
|
"a10571fa-ac1d-4546-9272-cacb911d8004": "build_area_create",
|
||||||
|
}
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def build_area_create(
|
||||||
|
cls,
|
||||||
|
data: InsertBuildArea,
|
||||||
|
token_dict: typing.Union[EmployeeTokenObject, OccupantTokenObject],
|
||||||
|
):
|
||||||
|
if isinstance(token_dict, OccupantTokenObject):
|
||||||
|
if not token_dict.selected_occupant.build_uuid == data.build_uu_id:
|
||||||
|
BuildArea.raise_http_exception(
|
||||||
|
status_code="HTTP_403_FORBIDDEN",
|
||||||
|
error_case="UNAUTHORIZED",
|
||||||
|
message=f"Occupant can not create build area for {data.build_uu_id}",
|
||||||
|
data={
|
||||||
|
"build_uu_id": data.build_uu_id,
|
||||||
|
},
|
||||||
|
)
|
||||||
|
elif isinstance(token_dict, EmployeeTokenObject):
|
||||||
|
build_ids = Build.select_action(
|
||||||
|
employee_id=token_dict.selected_company.employee_id
|
||||||
|
).all()
|
||||||
|
if not str(data.build_uu_id) in [str(build.uu_id) for build in build_ids]:
|
||||||
|
BuildArea.raise_http_exception(
|
||||||
|
status_code="HTTP_403_FORBIDDEN",
|
||||||
|
error_case="UNAUTHORIZED",
|
||||||
|
message=f"Employee can not create build area for {data.build_uu_id}",
|
||||||
|
data={
|
||||||
|
"build_uu_id": data.build_uu_id,
|
||||||
|
},
|
||||||
|
)
|
||||||
|
data_dict = data.excluded_dump()
|
||||||
|
created_build_part = BuildArea.find_or_create(**data_dict)
|
||||||
|
created_build_part.save()
|
||||||
|
created_build_part.update(is_confirmed=True)
|
||||||
|
created_build_part.save()
|
||||||
|
return AlchemyJsonResponse(
|
||||||
|
completed=True,
|
||||||
|
message="Update Build record",
|
||||||
|
result=created_build_part,
|
||||||
|
)
|
||||||
|
|
||||||
|
class BuildUpdateEventMethods(MethodToEvent):
|
||||||
|
|
||||||
|
event_type = "UPDATE"
|
||||||
|
__event_keys__ = {
|
||||||
|
"58178738-7489-4f8f-954e-5c8f083c1845": "build_area_update",
|
||||||
|
}
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def build_area_update(cls, build_uu_id: str, data: UpdateBuildArea, token_dict):
|
||||||
|
return AlchemyJsonResponse(
|
||||||
|
completed=False,
|
||||||
|
message="Update Build record",
|
||||||
|
result=None,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
class BuildPatchEventMethods(MethodToEvent):
|
||||||
|
|
||||||
|
event_type = "PATCH"
|
||||||
|
__event_keys__ = {
|
||||||
|
"d6bd8a5f-fa76-49da-b82e-4a95f1bcce39": "build_area_patch",
|
||||||
|
}
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def build_area_patch(cls, build_uu_id: str, data, token_dict):
|
||||||
|
return AlchemyJsonResponse(
|
||||||
|
completed=False,
|
||||||
|
message="Update Build record",
|
||||||
|
result=None,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
BuildListEventMethod = BuildListEventMethods(
|
||||||
|
action=ActionsSchema(endpoint="/building/area/list")
|
||||||
|
)
|
||||||
|
BuildCreateEventMethod = BuildCreateEventMethods(
|
||||||
|
action=ActionsSchema(endpoint="/building/area/create")
|
||||||
|
)
|
||||||
|
BuildUpdateEventMethod = BuildUpdateEventMethods(
|
||||||
|
action=ActionsSchema(endpoint="/building/area/update")
|
||||||
|
)
|
||||||
|
BuildPatchEventMethod = BuildPatchEventMethods(
|
||||||
|
action=ActionsSchema(endpoint="/building/area/patch")
|
||||||
|
)
|
||||||
|
|
|
||||||
|
|
@ -338,7 +338,7 @@ class People(CrudCollection, SelectAction):
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def create_action(cls, data: InsertPerson, token):
|
def create_action(cls, data: InsertPerson, token):
|
||||||
from databases import Employees, Duties
|
from databases import Duties
|
||||||
|
|
||||||
token_duties_id, token_company_id = (
|
token_duties_id, token_company_id = (
|
||||||
token.selected_company.duty_id,
|
token.selected_company.duty_id,
|
||||||
|
|
@ -364,11 +364,13 @@ class People(CrudCollection, SelectAction):
|
||||||
create_dict["surname"] = str(create_dict["surname"]).upper()
|
create_dict["surname"] = str(create_dict["surname"]).upper()
|
||||||
create_dict["birth_place"] = str(create_dict["birth_place"]).upper()
|
create_dict["birth_place"] = str(create_dict["birth_place"]).upper()
|
||||||
created_people = cls.find_or_create(**create_dict)
|
created_people = cls.find_or_create(**create_dict)
|
||||||
RelationshipDutyPeople.find_or_create(
|
created_people.update(is_confirmed=True)
|
||||||
|
duty_people = RelationshipDutyPeople.find_or_create(
|
||||||
company_id=token.selected_company.company_id,
|
company_id=token.selected_company.company_id,
|
||||||
duties_id=bulk_duty.id,
|
duties_id=bulk_duty.id,
|
||||||
member_id=created_people.id,
|
member_id=created_people.id,
|
||||||
)
|
)
|
||||||
|
duty_people.update(is_confirmed=True)
|
||||||
return created_people
|
return created_people
|
||||||
|
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,21 +1,144 @@
|
||||||
from service_app_test.api_configs import BothAPIS
|
from service_app_test.api_configs import BothAPIS
|
||||||
|
from service_app_test.bases import FilterObject
|
||||||
|
|
||||||
|
|
||||||
def migrate_build(requester: BothAPIS):
|
def migrate_build(requester: BothAPIS):
|
||||||
|
# Migrate old data
|
||||||
|
filter_object = FilterObject(
|
||||||
|
page=1,
|
||||||
|
size=100,
|
||||||
|
)
|
||||||
|
response = requester.wag_api.post(
|
||||||
|
endpoint="/building/build/list",
|
||||||
|
data=filter_object.dump(),
|
||||||
|
)
|
||||||
|
response_json = response.json()
|
||||||
|
response_datas = response_json["data"]
|
||||||
|
for response_data in response_datas:
|
||||||
|
new_response_data = dict()
|
||||||
|
for key, value in dict(response_data).items():
|
||||||
|
if value is not None and not str(value) == "None":
|
||||||
|
new_response_data[key] = response_data[key]
|
||||||
|
new_response_data.pop("uu_id", None)
|
||||||
|
print("new_response_data", new_response_data)
|
||||||
|
exit()
|
||||||
|
response = requester.local_api.post(
|
||||||
|
endpoint="/building/build/create",
|
||||||
|
data=new_response_data,
|
||||||
|
)
|
||||||
|
print("response", response.text)
|
||||||
return
|
return
|
||||||
|
|
||||||
|
|
||||||
def migrate_build_area(requester: BothAPIS):
|
def migrate_build_area(requester: BothAPIS, build_uu_id: str):
|
||||||
|
# Migrate old data
|
||||||
|
filter_object = FilterObject(
|
||||||
|
page=1,
|
||||||
|
size=100,
|
||||||
|
)
|
||||||
|
response = requester.wag_api.post(
|
||||||
|
endpoint="/building/area/list",
|
||||||
|
data=filter_object.dump(),
|
||||||
|
)
|
||||||
|
print('response', response.text)
|
||||||
|
exit()
|
||||||
|
response_json = response.json()
|
||||||
|
response_datas = response_json["data"]
|
||||||
|
for response_data in response_datas:
|
||||||
|
new_response_data = dict()
|
||||||
|
for key, value in dict(response_data).items():
|
||||||
|
if value is not None and not str(value) == "None":
|
||||||
|
new_response_data[key] = response_data[key]
|
||||||
|
new_response_data.pop("uu_id", None)
|
||||||
|
new_response_data['build_uu_id'] = str(build_uu_id)
|
||||||
|
exit()
|
||||||
|
print("new_response_data", new_response_data)
|
||||||
|
response = requester.local_api.post(
|
||||||
|
endpoint="/building/area/create",
|
||||||
|
data=new_response_data,
|
||||||
|
)
|
||||||
|
print("response", response.text)
|
||||||
return
|
return
|
||||||
|
|
||||||
|
|
||||||
def migrate_build_part(requester: BothAPIS):
|
def migrate_build_part(requester: BothAPIS, build_uu_id: str):
|
||||||
|
# Migrate old data
|
||||||
|
filter_object = FilterObject(
|
||||||
|
page=1,
|
||||||
|
size=100,
|
||||||
|
)
|
||||||
|
response = requester.wag_api.post(
|
||||||
|
endpoint="/build/list",
|
||||||
|
data=filter_object.dump(),
|
||||||
|
)
|
||||||
|
response_json = response.json()
|
||||||
|
response_datas = response_json["data"]
|
||||||
|
for response_data in response_datas:
|
||||||
|
new_response_data = dict()
|
||||||
|
for key, value in dict(response_data).items():
|
||||||
|
if value is not None and not str(value) == "None":
|
||||||
|
new_response_data[key] = response_data[key]
|
||||||
|
new_response_data.pop("uu_id", None)
|
||||||
|
print("new_response_data", new_response_data)
|
||||||
|
new_response_data['build_uu_id'] = str(build_uu_id)
|
||||||
|
exit()
|
||||||
|
response = requester.local_api.post(
|
||||||
|
endpoint="/build/create",
|
||||||
|
data=new_response_data,
|
||||||
|
)
|
||||||
|
print("response", response.text)
|
||||||
return
|
return
|
||||||
|
|
||||||
|
|
||||||
def migrate_build_iban(requester: BothAPIS):
|
def migrate_build_iban(requester: BothAPIS):
|
||||||
|
# Migrate old data
|
||||||
|
filter_object = FilterObject(
|
||||||
|
page=1,
|
||||||
|
size=100,
|
||||||
|
)
|
||||||
|
response = requester.wag_api.post(
|
||||||
|
endpoint="/build/list",
|
||||||
|
data=filter_object.dump(),
|
||||||
|
)
|
||||||
|
response_json = response.json()
|
||||||
|
response_datas = response_json["data"]
|
||||||
|
for response_data in response_datas:
|
||||||
|
new_response_data = dict()
|
||||||
|
for key, value in dict(response_data).items():
|
||||||
|
if value is not None and not str(value) == "None":
|
||||||
|
new_response_data[key] = response_data[key]
|
||||||
|
new_response_data.pop("uu_id", None)
|
||||||
|
print("new_response_data", new_response_data)
|
||||||
|
response = requester.local_api.post(
|
||||||
|
endpoint="/build/create",
|
||||||
|
data=new_response_data,
|
||||||
|
)
|
||||||
|
print("response", response.text)
|
||||||
return
|
return
|
||||||
|
|
||||||
|
|
||||||
def migrate_build_living_space(requester: BothAPIS):
|
def migrate_build_living_space(requester: BothAPIS):
|
||||||
|
# Migrate old data
|
||||||
|
filter_object = FilterObject(
|
||||||
|
page=1,
|
||||||
|
size=100,
|
||||||
|
)
|
||||||
|
response = requester.wag_api.post(
|
||||||
|
endpoint="/build/list",
|
||||||
|
data=filter_object.dump(),
|
||||||
|
)
|
||||||
|
response_json = response.json()
|
||||||
|
response_datas = response_json["data"]
|
||||||
|
for response_data in response_datas:
|
||||||
|
new_response_data = dict()
|
||||||
|
for key, value in dict(response_data).items():
|
||||||
|
if value is not None and not str(value) == "None":
|
||||||
|
new_response_data[key] = response_data[key]
|
||||||
|
new_response_data.pop("uu_id", None)
|
||||||
|
print("new_response_data", new_response_data)
|
||||||
|
response = requester.local_api.post(
|
||||||
|
endpoint="/build/create",
|
||||||
|
data=new_response_data,
|
||||||
|
)
|
||||||
|
print("response", response.text)
|
||||||
return
|
return
|
||||||
|
|
|
||||||
|
|
@ -1,6 +1,33 @@
|
||||||
from service_app_test.api_configs import BothAPIS
|
from service_app_test.api_configs import BothAPIS
|
||||||
|
from service_app_test.bases import FilterObject
|
||||||
|
|
||||||
|
|
||||||
def migrate_people(requester: BothAPIS):
|
def migrate_people(requester: BothAPIS):
|
||||||
# Migrate old data
|
# Migrate old data
|
||||||
pass
|
filter_object = FilterObject(
|
||||||
|
page=1,
|
||||||
|
size=100,
|
||||||
|
)
|
||||||
|
response = requester.wag_api.post(
|
||||||
|
endpoint="/people/list",
|
||||||
|
data=filter_object.dump(),
|
||||||
|
)
|
||||||
|
response_json = response.json()
|
||||||
|
response_datas = response_json["data"]
|
||||||
|
counter = 0
|
||||||
|
for response_data in response_datas:
|
||||||
|
new_response_data = dict()
|
||||||
|
for key, value in dict(response_data).items():
|
||||||
|
if value is not None and not str(value) == "None":
|
||||||
|
new_response_data[key] = response_data[key]
|
||||||
|
new_response_data.pop("uu_id", None)
|
||||||
|
print("new_response_data", new_response_data)
|
||||||
|
new_response_data["national_identity_id"] = f"000000000{str(counter).zfill(2)}"
|
||||||
|
response = requester.local_api.post(
|
||||||
|
endpoint="/people/create",
|
||||||
|
data=new_response_data,
|
||||||
|
)
|
||||||
|
print("response", response.text)
|
||||||
|
if response.ok:
|
||||||
|
counter += 1
|
||||||
|
return
|
||||||
|
|
|
||||||
|
|
@ -43,11 +43,12 @@ both_apis = BothAPIS()
|
||||||
both_apis.wag_api = wag_api
|
both_apis.wag_api = wag_api
|
||||||
both_apis.local_api = local_api
|
both_apis.local_api = local_api
|
||||||
|
|
||||||
migrate_company(requester=both_apis)
|
# migrate_company(requester=both_apis)
|
||||||
migrate_people(requester=both_apis)
|
# migrate_people(requester=both_apis)
|
||||||
|
# migrate_build(requester=both_apis)
|
||||||
|
migrate_build_area(requester=both_apis, build_uu_id="string")
|
||||||
exit()
|
exit()
|
||||||
migrate_build(requester=both_apis)
|
|
||||||
migrate_build_area(requester=both_apis)
|
|
||||||
migrate_build_part(requester=both_apis)
|
migrate_build_part(requester=both_apis)
|
||||||
migrate_build_iban(requester=both_apis)
|
migrate_build_iban(requester=both_apis)
|
||||||
migrate_build_living_space(requester=both_apis)
|
migrate_build_living_space(requester=both_apis)
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue