-
Notifications
You must be signed in to change notification settings - Fork 0
/
place.py
80 lines (74 loc) · 3.12 KB
/
place.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
#!/usr/bin/python
""" holds class Place"""
import models
from models.base_model import BaseModel, Base
from os import getenv
import sqlalchemy
from sqlalchemy import Column, String, Integer, Float, ForeignKey, Table
from sqlalchemy.orm import relationship
if models.storage_t == 'db':
place_amenity = Table('place_amenity', Base.metadata,
Column('place_id', String(60),
ForeignKey('places.id', onupdate='CASCADE',
ondelete='CASCADE'),
primary_key=True),
Column('amenity_id', String(60),
ForeignKey('amenities.id', onupdate='CASCADE',
ondelete='CASCADE'),
primary_key=True))
class Place(BaseModel, Base):
"""Representation of Place """
if models.storage_t == 'db':
__tablename__ = 'places'
city_id = Column(String(60), ForeignKey('cities.id'), nullable=False)
user_id = Column(String(60), ForeignKey('users.id'), nullable=False)
name = Column(String(128), nullable=False)
description = Column(String(1024), nullable=True)
number_rooms = Column(Integer, nullable=False, default=0)
number_bathrooms = Column(Integer, nullable=False, default=0)
max_guest = Column(Integer, nullable=False, default=0)
price_by_night = Column(Integer, nullable=False, default=0)
latitude = Column(Float, nullable=True)
longitude = Column(Float, nullable=True)
reviews = relationship("Review",
backref="place",
cascade="all, delete, delete-orphan")
amenities = relationship("Amenity",
secondary=place_amenity,
viewonly=False)
else:
city_id = ""
user_id = ""
name = ""
description = ""
number_rooms = 0
number_bathrooms = 0
max_guest = 0
price_by_night = 0
latitude = 0.0
longitude = 0.0
amenity_ids = []
def __init__(self, *args, **kwargs):
"""initializes Place"""
super().__init__(*args, **kwargs)
if models.storage_t != 'db':
@property
def reviews(self):
"""getter attribute returns the list of Review instances"""
from models.review import Review
review_list = []
all_reviews = models.storage.all(Review)
for review in all_reviews.values():
if review.place_id == self.id:
review_list.append(review)
return review_list
@property
def amenities(self):
"""getter attribute returns the list of Amenity instances"""
from models.amenity import Amenity
amenity_list = []
all_amenities = models.storage.all(Amenity)
for amenity in all_amenities.values():
if amenity.place_id == self.id:
amenity_list.append(amenity)
return amenity_list