Skip to content
Switch branches/tags

Name already in use

A tag already exists with the provided branch name. Many Git commands accept both tag and branch names, so creating this branch may cause unexpected behavior. Are you sure you want to create this branch?
Go to file
Cannot retrieve contributors at this time
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import create_engine, ForeignKey
# importing all data types for columns
from sqlalchemy import Column, Integer, String, DateTime, Date, Float
from sqlalchemy.orm import sessionmaker, scoped_session, relationship, backref, session
from sqlalchemy.orm import relationship, backref, relation
from sqlalchemy.dialects import postgresql
from sqlalchemy import select, func, types, sql, update
import datetime
import os
import psycopg2
from wtforms import Form, BooleanField, TextField, PasswordField, validators
database_url = os.environ['DATABASE_URL']
engine = create_engine(database_url, echo=False)
session = scoped_session(sessionmaker(bind=engine, autocommit = False, autoflush = False))
Base = declarative_base()
Base.query = session.query_property()
### Class declarations
class User(Base):
__tablename__ = "users"
id = Column(Integer, primary_key = True)
user_name = Column(String(64), nullable=True)
email = Column(String(64), nullable=True)
password = Column(String(64), nullable=True)
photos = relationship("Photo", backref="users", lazy="joined")
# users are the parents of the photo children
class Photo(Base):
__tablename__ = "photos"
id = Column(Integer, primary_key = True)
user_id = Column(Integer, ForeignKey(''))
file_location = Column(String(100), nullable=True)
latitude = Column(Float, nullable=True)
longitude = Column(Float, nullable=True)
photo_location_id = Column(Integer, ForeignKey(''), nullable=True)
timestamp = Column(DateTime)
caption = Column(String(101), nullable=True)
up_vote = Column(Integer, default=0)
down_vote = Column(Integer, default=0)
thumbnail = Column(String(101), nullable=True)
#remove the "/uploads" from the file_location and thumbnail so lightboxes render properly
def filename(self):
return self.file_location.split("/")[-1]
def thumbnail_filename(self):
return self.thumbnail.split("/")[-1]
# through table linking user and photo
class Vote(Base):
__tablename__ = "votes"
id = Column(Integer, primary_key = True)
# change to single value column 1 == up -1 == down
# Note: did not make nullable=False in postgres
value = Column(Integer, nullable=False)
photo_id = Column(Integer, ForeignKey(''))
give_vote_user_id = Column(Integer, ForeignKey(''))
receive_vote_user_id = Column(Integer, ForeignKey(''))
timestamp = Column(DateTime, default=datetime.datetime.utcnow)
give_vote_user = relationship("User", primaryjoin="", backref=backref("votes_given", order_by=id))
receive_vote_user = relationship("User", primaryjoin="", backref=backref("votes_received", order_by=id))
photo = relationship("Photo", backref=backref("votes", order_by=id))
# if tag doesn't already exist - create a new tag and tag id --> add this logic
class Tag(Base):
__tablename__ = "tags"
id = Column(Integer, primary_key = True)
tag_title = Column(String(64), nullable=True)
#links photos and tags
class Photo_Tag(Base):
__tablename__ = "photo_tags"
#id = Column(Integer, primary_key = True) don't need it because created composite key (two foreign keys)
photo_id = Column(Integer, ForeignKey(''), primary_key = True)
tag_id = Column(Integer, ForeignKey(''), primary_key = True)
class Location(Base):
__tablename__ = "locations"
id = Column(Integer, primary_key = True)
country = Column(String(64), nullable=True)
city = Column(String(64), nullable=True)
neighborhood = Column(String(64), nullable=True)
### End of class declarations
def create_db():
def connect(db_uri=database_url):
global engine
global session
engine = create_engine(db_uri, echo=False)
# engine = create_engine("postgres://lauren:@localhost/lauren", echo=True)
session = scoped_session(sessionmaker(bind=engine,
autocommit = False,
autoflush = False))
def main():
""" """
if __name__ == "__main__":