[IMP]pms_api_rest: added availability plan service and datamodel

This commit is contained in:
braisab
2022-05-11 17:23:35 +02:00
committed by Darío Lodeiros
parent 3c07b97544
commit d804461efe
5 changed files with 189 additions and 1 deletions

View File

@@ -18,5 +18,6 @@ from . import pms_user
from . import pms_pricelist
from . import pms_pricelist_item
from . import pms_availability_plan
from . import pms_availability_plan_rule
from . import pms_search_param

View File

@@ -0,0 +1,10 @@
from marshmallow import fields
from odoo.addons.datamodel.core import Datamodel
class PmsAvailabilityPlanInfo(Datamodel):
_name = "pms.availability.plan.info"
id = fields.Integer(required=False, allow_none=True)
name = fields.String(required=False, allow_none=True)
pms_property_ids = fields.List(fields.Integer(required=False, allow_none=True))

View File

@@ -0,0 +1,25 @@
from marshmallow import fields
from odoo.addons.datamodel.core import Datamodel
class PmsAvailabilityPlanRuleSearchParam(Datamodel):
_name = "pms.availability.plan.rule.search.param"
date_from = fields.String(required=True, allow_none=False)
date_to = fields.String(required=True, allow_none=False)
pms_property_id = fields.Integer(required=True, allow_none=False)
class PmsAvailabilityPlanRuleInfo(Datamodel):
_name = "pms.availability.plan.rule.info"
availabilityRuleId = fields.Integer(required=False, allow_none=True)
minStay = fields.Integer(required=False, allow_none=True)
minStayArrival = fields.Integer(required=False, allow_none=True)
maxStay = fields.Integer(required=False, allow_none=True)
maxStayArrival = fields.Integer(required=False, allow_none=True)
closed = fields.Boolean(required=False, allow_none=True)
closedDeparture = fields.Boolean(required=False, allow_none=True)
closedArrival = fields.Boolean(required=False, allow_none=True)
roomTypeId = fields.Integer(required=False, allow_none=True)
date = fields.String(required=False, allow_none=True)
quota = fields.Integer(required=False, allow_none=True)

View File

@@ -8,3 +8,4 @@ from . import pms_reservation_service
from . import pms_property_service
from . import pms_login_service
from . import pms_pricelist_service
from . import pms_availability_plan_service

View File

@@ -0,0 +1,151 @@
from datetime import datetime, timedelta
from odoo.exceptions import MissingError
from odoo.addons.base_rest import restapi
from odoo.addons.base_rest_datamodel.restapi import Datamodel
from odoo.addons.component.core import Component
class PmsAvailabilityPlanService(Component):
_inherit = "base.rest.service"
_name = "pms.availability.plan.service"
_usage = "availability-plans"
_collection = "pms.services"
@restapi.method(
[
(
[
"/",
],
"GET",
)
],
input_param=Datamodel("pms.search.param", is_list=False),
output_param=Datamodel("pms.availability.plan.info", is_list=True),
auth="jwt_api_pms",
)
def get_availability_plans(self, pms_search_param, **args):
availability_plans_all_properties = self.env["pms.availability.plan"].search(
[("pms_property_ids", "=", False)]
)
availabilities = set()
if pms_search_param.pms_property_ids:
for index, prop in enumerate(pms_search_param.pms_property_ids):
availabilities_with_query_property = self.env[
"pms.availability.plan"
].search([("pms_property_ids", "=", prop)])
if index == 0:
availabilities = set(availabilities_with_query_property.ids)
else:
availabilities = availabilities.intersection(
set(availabilities_with_query_property.ids)
)
availabilities_total = list(
set(list(availabilities) + availability_plans_all_properties.ids)
)
else:
availabilities_total = list(availability_plans_all_properties.ids)
domain = [
("id", "in", availabilities_total),
]
PmsAvialabilityPlanInfo = self.env.datamodels["pms.availability.plan.info"]
result_availabilities = []
for availability in self.env["pms.availability.plan"].search(domain):
result_availabilities.append(
PmsAvialabilityPlanInfo(
id=availability.id,
name=availability.name,
pms_property_ids=availability.pms_property_ids.mapped("id"),
)
)
return result_availabilities
@restapi.method(
[
(
[
"/<int:availability_plan>",
],
"GET",
)
],
input_param=Datamodel("pms.availability.plan.rule.search.param", is_list=False),
output_param=Datamodel("pms.availability.plan.rule.info", is_list=True),
auth="jwt_api_pms",
)
def get_availability_plan_rules(
self, availability_plan_id, availability_plan_rule_search_param
):
result = []
record_availability_plan_id = self.env["pms.availability.plan"].browse(
availability_plan_id
)
if not record_availability_plan_id:
raise MissingError
PmsAvailabilityPlanInfo = self.env.datamodels["pms.availability.plan.rule.info"]
rooms = self.env["pms.room"].search(
[
(
"pms_property_id",
"=",
availability_plan_rule_search_param.pms_property_id,
)
]
)
date_from = datetime.strptime(
availability_plan_rule_search_param.date_from, "%Y-%m-%d"
).date()
date_to = datetime.strptime(
availability_plan_rule_search_param.date_to, "%Y-%m-%d"
).date()
for date in (
date_from + timedelta(d) for d in range((date_to - date_from).days + 1)
):
for room_type in self.env["pms.room.type"].search(
[("id", "in", rooms.mapped("room_type_id").ids)]
):
rule = self.env["pms.availability.plan.rule"].search(
[
("date", "=", date),
(
"availability_plan_id",
"=",
record_availability_plan_id.id,
),
("room_type_id", "=", room_type.id),
]
)
if rule:
availability_plan_rule_info = PmsAvailabilityPlanInfo(
roomTypeId=room_type.id,
date=str(
datetime.combine(date, datetime.min.time()).isoformat()
),
)
if rule:
availability_plan_rule_info.availabilityRuleId = rule.id
availability_plan_rule_info.minStay = rule.min_stay
availability_plan_rule_info.minStayArrival = (
rule.min_stay_arrival
)
availability_plan_rule_info.maxStay = rule.max_stay
availability_plan_rule_info.maxStayArrival = (
rule.max_stay_arrival
)
availability_plan_rule_info.closed = rule.closed
availability_plan_rule_info.closedDeparture = (
rule.closed_departure
)
availability_plan_rule_info.closedArrival = rule.closed_arrival
availability_plan_rule_info.quota = rule.quota
result.append(availability_plan_rule_info)
return result