-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmodel.py
87 lines (57 loc) · 3.02 KB
/
model.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
81
82
83
84
85
86
import os
from flask_sqlalchemy import SQLAlchemy
database= SQLAlchemy()
#using the skeleton for the connection in the sql-alchemy 1 lecture
def database_connect(app,database_name):
db_uri = os.environ.get('DATABASE_URI',"postgresql:///")
app.config["SQLALCHEMY_DATABASE_URI"] = f"{db_uri}{database_name}"
app.config["SQLALCHEMY_ECHO"] = True
app.config["SQLALCHEMY_TRACK_MODIFICATIONS"] = False
database.app = app
database.init_app(app)
class Animal(database.Model):
"""Animals at risk"""
__tablename__ = "animals"
id = database.Column(database.Integer,primary_key=True,autoincrement=True)
api_id = database.Column(database.Text, nullable=True)
image = database.Column(database.Text, nullable=True)
name = database.Column(database.Text, nullable=False)
type = database.Column(database.Text, nullable=False)
breed = database.Column(database.Text, nullable=False)
join_date = database.Column(database.Date, nullable=True)
#age is not an integer in database due to RescueGroups.org API using strings
age = database.Column(database.Text, nullable=True)
weight = database.Column(database.Integer, nullable=True)
gender = database.Column(database.Text, nullable=True)
scheduled_euthanasia_date = database.Column(database.Date, nullable=True)
adopt_code = database.Column(database.Text, nullable=True)
bio = database.Column(database.Text, nullable=True)
url = database.Column(database.Text, nullable=True)
entry_source = database.Column(database.Text, nullable=False)
shelter_id = database.Column(database.Integer, database.ForeignKey('shelters.id'))
avail_date = database.Column(database.Date, nullable=True)
groupstatus = database.Column(database.Text, nullable=True)
status = database.Column(database.Text, nullable=True)
#provides data to shelters regarding where their animals are being viewed
tracker = database.Column(database.Text, nullable=False)
shelter = database.relationship('Shelter',back_populates="animal")
def __repr__(self):
return f"<id={self.id} name={self.name} type={self.type}>"
class Shelter(database.Model):
"""Shelters that have animals at risk"""
__tablename__ = "shelters"
id= database.Column(database.Integer,primary_key=True,autoincrement=True)
name = database.Column(database.Text, nullable=False)
street_address = database.Column(database.Text, nullable=True)
city = database.Column(database.Text, nullable=False)
state = database.Column(database.Text, nullable=False)
#changed zipcode to text in order to accomodate non numeric shelter zipcodes
zipcode = database.Column(database.Text, nullable=False)
website = database.Column(database.Text, nullable=True)
source = database.Column(database.Text, nullable=True)
animal = database.relationship('Animal',back_populates="shelter")
def __repr__(self):
return f"<id={self.id} name={self.name}>"
if __name__== "__main__":
from server import app
database_connect(app, "pawsforalarm")