2023-03-04 13:45:26 +00:00
|
|
|
"""
|
|
|
|
Onlylegs Gallery - Routing
|
|
|
|
"""
|
2023-03-08 09:01:20 +00:00
|
|
|
from datetime import datetime as dt
|
2023-03-04 13:45:26 +00:00
|
|
|
|
2023-03-09 23:31:58 +00:00
|
|
|
from flask import Blueprint, render_template, url_for
|
2023-01-10 14:40:43 +00:00
|
|
|
from werkzeug.exceptions import abort
|
2023-03-03 00:26:46 +00:00
|
|
|
|
|
|
|
from sqlalchemy.orm import sessionmaker
|
2023-01-26 14:43:08 +00:00
|
|
|
|
2023-03-04 13:45:26 +00:00
|
|
|
from . import db
|
2023-01-31 17:32:22 +00:00
|
|
|
from . import metadata as mt
|
2023-01-26 14:43:08 +00:00
|
|
|
|
2023-01-31 23:44:44 +00:00
|
|
|
|
2023-01-10 14:40:43 +00:00
|
|
|
blueprint = Blueprint('gallery', __name__)
|
2023-03-04 13:45:26 +00:00
|
|
|
db_session = sessionmaker(bind=db.engine)
|
|
|
|
db_session = db_session()
|
2023-01-10 14:40:43 +00:00
|
|
|
|
|
|
|
|
|
|
|
@blueprint.route('/')
|
|
|
|
def index():
|
2023-03-04 13:45:26 +00:00
|
|
|
"""
|
|
|
|
Home page of the website, shows the feed of latest images
|
|
|
|
"""
|
2023-03-05 18:16:28 +00:00
|
|
|
images = db_session.query(db.Posts.file_name,
|
2023-03-08 09:01:20 +00:00
|
|
|
db.Posts.image_colours,
|
|
|
|
db.Posts.created_at,
|
|
|
|
db.Posts.id).order_by(db.Posts.id.desc()).all()
|
2023-03-05 16:22:11 +00:00
|
|
|
|
2023-03-09 23:31:58 +00:00
|
|
|
return render_template('index.html', images=images)
|
2023-01-10 14:40:43 +00:00
|
|
|
|
2023-03-04 13:45:26 +00:00
|
|
|
@blueprint.route('/image/<int:image_id>')
|
|
|
|
def image(image_id):
|
|
|
|
"""
|
|
|
|
Image view, shows the image and its metadata
|
|
|
|
"""
|
2023-03-05 18:16:28 +00:00
|
|
|
img = db_session.query(db.Posts).filter(db.Posts.id == image_id).first()
|
2023-03-08 13:36:35 +00:00
|
|
|
|
2023-03-03 00:26:46 +00:00
|
|
|
if img is None:
|
2023-03-09 23:31:58 +00:00
|
|
|
abort(404, 'Image not found :<')
|
2023-01-25 15:13:56 +00:00
|
|
|
|
2023-03-09 23:31:58 +00:00
|
|
|
img.author_username = db_session.query(db.Users.username).filter(db.Users.id == img.author_id).first()[0]
|
2023-03-09 12:22:25 +00:00
|
|
|
|
2023-03-09 23:31:58 +00:00
|
|
|
groups = db_session.query(db.GroupJunction.group_id).filter(db.GroupJunction.post_id == image_id).all()
|
|
|
|
img.groups = []
|
|
|
|
for group in groups:
|
|
|
|
group = db_session.query(db.Groups).filter(db.Groups.id == group[0]).first()
|
|
|
|
img.groups.append(group)
|
|
|
|
|
|
|
|
next = db_session.query(db.Posts.id).filter(db.Posts.id > image_id).order_by(db.Posts.id.asc()).first()
|
2023-03-09 12:22:25 +00:00
|
|
|
prev = db_session.query(db.Posts.id).filter(db.Posts.id < image_id).order_by(db.Posts.id.desc()).first()
|
|
|
|
|
|
|
|
if next is not None:
|
2023-03-09 23:31:58 +00:00
|
|
|
next = url_for('gallery.image', image_id=next[0])
|
2023-03-09 12:22:25 +00:00
|
|
|
if prev is not None:
|
2023-03-09 23:31:58 +00:00
|
|
|
prev = url_for('gallery.image', image_id=prev[0])
|
2023-01-25 15:13:56 +00:00
|
|
|
|
2023-03-09 23:31:58 +00:00
|
|
|
return render_template('image.html', image=img, next_url=next, prev_url=prev)
|
2023-01-10 14:40:43 +00:00
|
|
|
|
|
|
|
@blueprint.route('/profile')
|
|
|
|
def profile():
|
2023-03-04 13:45:26 +00:00
|
|
|
"""
|
|
|
|
Profile overview, shows all profiles on the onlylegs gallery
|
|
|
|
"""
|
2023-01-10 14:40:43 +00:00
|
|
|
return render_template('profile.html', user_id='gwa gwa')
|
|
|
|
|
2023-03-04 13:45:26 +00:00
|
|
|
@blueprint.route('/profile/<int:user_id>')
|
|
|
|
def profile_id(user_id):
|
|
|
|
"""
|
|
|
|
Shows user ofa given id, displays their uploads and other info
|
|
|
|
"""
|
2023-03-08 09:01:20 +00:00
|
|
|
return render_template('profile.html', user_id=user_id)
|