mirror of
https://github.com/Xevion/v1.xevion.dev.git
synced 2025-12-08 08:09:03 -06:00
first heavy refactor
This commit is contained in:
@@ -16,5 +16,5 @@ db = SQLAlchemy(app)
|
|||||||
migrate = Migrate(app, db)
|
migrate = Migrate(app, db)
|
||||||
|
|
||||||
from app import models
|
from app import models
|
||||||
from app import routes, dashboard, custom
|
from app import routes, simple_routes, hidden, dashboard, custom
|
||||||
app.jinja_env.globals.update(get_hidden=routes.get_hidden)
|
app.jinja_env.globals.update(get_hidden=routes.get_hidden)
|
||||||
22
app/ftbhot.py
Normal file
22
app/ftbhot.py
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
from app import app
|
||||||
|
import flask
|
||||||
|
|
||||||
|
@app.route('/ftbhot/about')
|
||||||
|
@app.route('/ftbhot/about/')
|
||||||
|
def ftbhot_about():
|
||||||
|
return flask.render_template('/ftbhot/about.html')
|
||||||
|
|
||||||
|
@app.route('/ftbhot/auth')
|
||||||
|
@app.route('/ftbhot/auth/')
|
||||||
|
def ftbhot_auth():
|
||||||
|
return 'WIP'
|
||||||
|
|
||||||
|
@app.route('/ftbhot')
|
||||||
|
@app.route('/ftbhot/')
|
||||||
|
def ftbhot():
|
||||||
|
return flask.render_template('/ftbhot/embed.html')
|
||||||
|
|
||||||
|
@app.route('/ftbhot/json')
|
||||||
|
@app.route('/ftbhot/json/')
|
||||||
|
def ftbhot_embed():
|
||||||
|
return flask.render_template('/ftbhot/current.json')
|
||||||
74
app/hidden.py
Normal file
74
app/hidden.py
Normal file
@@ -0,0 +1,74 @@
|
|||||||
|
from app import app, db, login
|
||||||
|
from app.custom import require_role
|
||||||
|
from flask_login import current_user, login_user, logout_user, login_required
|
||||||
|
|
||||||
|
@app.route('/hidden<id>/')
|
||||||
|
@login_required
|
||||||
|
@require_role(roles=['Hidden'])
|
||||||
|
def hidden(id):
|
||||||
|
if not validate_id(id):
|
||||||
|
return '<span style="color: red;">error:</span> bad id'
|
||||||
|
# Handled within request
|
||||||
|
tags = request.args.get('tags') or 'trap'
|
||||||
|
try:
|
||||||
|
page = int(request.args.get('page') or 1)
|
||||||
|
except (TypeError, ValueError):
|
||||||
|
return '\"page\" parameter must be Integer.<br>Invalid \"page\" parameter: \"{}\"'.format(request.args.get('page'))
|
||||||
|
# Handled within building
|
||||||
|
try:
|
||||||
|
count = int(request.args.get('count') or 50)
|
||||||
|
except (TypeError, ValueError):
|
||||||
|
return '\"count\" parameter must be Integer.<br>Invalid \"count\": \"{}\"'.format(request.args.get('count'))
|
||||||
|
base64 = boolparse(request.args.get('base64'))
|
||||||
|
# Handled within Jinja template
|
||||||
|
showfull = boolparse(request.args.get('showfull'))
|
||||||
|
showtags = boolparse(request.args.get('showtags'))
|
||||||
|
# Request, Parse & Build Data
|
||||||
|
data = build_data(tags, page-1, count, base64, showfull)
|
||||||
|
# Handling for limiters
|
||||||
|
if base64:
|
||||||
|
if showfull:
|
||||||
|
count = min(25, count)
|
||||||
|
else:
|
||||||
|
count = min(50, count)
|
||||||
|
search = Search(user_id=current_user.id, exact_url=str(request.url), query_args=json.dumps(request.args.to_dict()))
|
||||||
|
db.session.add(search)
|
||||||
|
db.session.commit()
|
||||||
|
return render_template('hidden.html', title='Gelbooru Browser', data=data, tags=tags, page=page, count=count, base64=base64, showfull=showfull, showtags=showtags)
|
||||||
|
|
||||||
|
def base64ify(url):
|
||||||
|
return base64.b64encode(requests.get(url).content).decode()
|
||||||
|
|
||||||
|
gelbooru_api_url = "https://gelbooru.com/index.php?page=dapi&s=post&q=index&tags={}&pid={}&limit={}"
|
||||||
|
gelbooru_view_url = "https://gelbooru.com/index.php?page=post&s=view&id={}"
|
||||||
|
|
||||||
|
def build_data(tags, page, count, base64, showfull):
|
||||||
|
# URL Building & Request
|
||||||
|
temp = gelbooru_api_url.format(tags, page, count)
|
||||||
|
response = requests.get(temp).text
|
||||||
|
# XML Parsing & Data Building
|
||||||
|
parse = xmltodict.parse(response)
|
||||||
|
build = []
|
||||||
|
|
||||||
|
try:
|
||||||
|
parse['posts']['post']
|
||||||
|
except KeyError:
|
||||||
|
return build
|
||||||
|
|
||||||
|
for index, element in enumerate(parse['posts']['post'][:count]):
|
||||||
|
temp = {
|
||||||
|
'index' : str(index + 1),
|
||||||
|
'real_url' : element['@file_url'],
|
||||||
|
'sample_url' : element['@preview_url'],
|
||||||
|
# strips tags, ensures no empty tags (may be unnescary)
|
||||||
|
'tags' : list(filter(lambda tag : tag != '', [tag.strip() for tag in element['@tags'].split(' ')])),
|
||||||
|
'view' : gelbooru_view_url.format(element['@id'])
|
||||||
|
}
|
||||||
|
if base64:
|
||||||
|
if not showfull:
|
||||||
|
temp['base64'] = base64ify(temp['sample_url'])
|
||||||
|
else:
|
||||||
|
temp['base64'] = base64ify(temp['real_url'])
|
||||||
|
|
||||||
|
build.append(temp)
|
||||||
|
return build
|
||||||
134
app/routes.py
134
app/routes.py
@@ -3,16 +3,15 @@ from app.models import User, Search
|
|||||||
from app.forms import LoginForm, RegistrationForm
|
from app.forms import LoginForm, RegistrationForm
|
||||||
from app.custom import require_role
|
from app.custom import require_role
|
||||||
from werkzeug.urls import url_parse
|
from werkzeug.urls import url_parse
|
||||||
from flask import render_template, redirect, url_for, flash, request, jsonify, abort, send_file, send_from_directory
|
from flask import render_template, redirect, url_for, flash, request, jsonify, abort, send_file
|
||||||
from flask_login import current_user, login_user, logout_user, login_required
|
from flask_login import current_user, login_user, logout_user, login_required
|
||||||
from io import BytesIO
|
from io import BytesIO
|
||||||
from textwrap import wrap
|
from textwrap import wrap
|
||||||
from PIL import Image, ImageDraw, ImageFont
|
from PIL import Image, ImageDraw, ImageFont
|
||||||
from multiprocessing import Value
|
from multiprocessing import Value
|
||||||
import mistune
|
import flask
|
||||||
import requests
|
import requests
|
||||||
import xmltodict
|
import xmltodict
|
||||||
import base64
|
|
||||||
import random
|
import random
|
||||||
import string
|
import string
|
||||||
import faker
|
import faker
|
||||||
@@ -23,29 +22,8 @@ import sys
|
|||||||
|
|
||||||
print = pprint.PrettyPrinter().pprint
|
print = pprint.PrettyPrinter().pprint
|
||||||
fake = faker.Faker()
|
fake = faker.Faker()
|
||||||
markdown = mistune.Markdown()
|
|
||||||
strgen = lambda length, charset=string.ascii_letters, weights=None : ''.join(random.choices(list(charset), k=length, weights=weights))
|
strgen = lambda length, charset=string.ascii_letters, weights=None : ''.join(random.choices(list(charset), k=length, weights=weights))
|
||||||
|
|
||||||
@app.route('/ftbhot/about')
|
|
||||||
@app.route('/ftbhot/about/')
|
|
||||||
def ftbhot_about():
|
|
||||||
return render_template('/ftbhot/about.html')
|
|
||||||
|
|
||||||
@app.route('/ftbhot/auth')
|
|
||||||
@app.route('/ftbhot/auth/')
|
|
||||||
def ftbhot_auth():
|
|
||||||
return 'WIP'
|
|
||||||
|
|
||||||
@app.route('/ftbhot')
|
|
||||||
@app.route('/ftbhot/')
|
|
||||||
def ftbhot():
|
|
||||||
return render_template('/ftbhot/embed.html')
|
|
||||||
|
|
||||||
@app.route('/ftbhot/json')
|
|
||||||
@app.route('/ftbhot/json/')
|
|
||||||
def ftbhot_embed():
|
|
||||||
return render_template('/ftbhot/current.json')
|
|
||||||
|
|
||||||
@app.route('/time/')
|
@app.route('/time/')
|
||||||
def time():
|
def time():
|
||||||
value = request.args.get('value')
|
value = request.args.get('value')
|
||||||
@@ -78,18 +56,6 @@ def timeformat(value, lengths=[60, 60, 24, 365], strings=['second', 'minute', 'h
|
|||||||
build = ', '.join(build)
|
build = ', '.join(build)
|
||||||
return build
|
return build
|
||||||
|
|
||||||
@app.route('/keybase.txt')
|
|
||||||
def keybase():
|
|
||||||
return app.send_static_file('keybase.txt')
|
|
||||||
|
|
||||||
@app.route('/modpacks')
|
|
||||||
def modpacks():
|
|
||||||
return markdown(open(os.path.join(app.root_path, 'static', 'MODPACKS.MD'), 'r').read())
|
|
||||||
|
|
||||||
@app.route('/favicon.ico')
|
|
||||||
def favicon():
|
|
||||||
return send_from_directory(os.path.join(app.root_path, 'static'), 'favicon.ico', mimetype='image/vnd.microsoft.icon')
|
|
||||||
|
|
||||||
@app.route('/avatar/')
|
@app.route('/avatar/')
|
||||||
@app.route('/avatar/<id>/')
|
@app.route('/avatar/<id>/')
|
||||||
@app.route('/avatar/<id>')
|
@app.route('/avatar/<id>')
|
||||||
@@ -106,15 +72,11 @@ def getAvatar(id=''):
|
|||||||
url = cdn.format(id, user['avatar'])
|
url = cdn.format(id, user['avatar'])
|
||||||
return "<img src=\"{}\">".format(url)
|
return "<img src=\"{}\">".format(url)
|
||||||
|
|
||||||
@app.errorhandler(401)
|
|
||||||
def unauthorized(e):
|
|
||||||
return redirect(url_for('login'))
|
|
||||||
|
|
||||||
def serve_pil_image(pil_img):
|
def serve_pil_image(pil_img):
|
||||||
img_io = BytesIO()
|
img_io = BytesIO()
|
||||||
pil_img.save(img_io, 'JPEG', quality=50)
|
pil_img.save(img_io, 'JPEG', quality=50)
|
||||||
img_io.seek(0)
|
img_io.seek(0)
|
||||||
return send_file(img_io, mimetype='image/jpeg')
|
return flask.send_file(img_io, mimetype='image/jpeg')
|
||||||
|
|
||||||
@app.route('/panzer/')
|
@app.route('/panzer/')
|
||||||
@app.route('/panzer')
|
@app.route('/panzer')
|
||||||
@@ -139,16 +101,11 @@ def create_panzer(string):
|
|||||||
draw.text((topleft[0], topleft[1] + (y * 33)), text, font=font2)
|
draw.text((topleft[0], topleft[1] + (y * 33)), text, font=font2)
|
||||||
return img
|
return img
|
||||||
|
|
||||||
|
|
||||||
@app.route('/profile/')
|
@app.route('/profile/')
|
||||||
@login_required
|
@login_required
|
||||||
def profile():
|
def profile():
|
||||||
return render_template('profile.html')
|
return render_template('profile.html')
|
||||||
|
|
||||||
@app.route('/api/')
|
|
||||||
def api():
|
|
||||||
return 'fuckoff bots'
|
|
||||||
|
|
||||||
@app.route('/userinfo/')
|
@app.route('/userinfo/')
|
||||||
@login_required
|
@login_required
|
||||||
@require_role(roles=['Admin'])
|
@require_role(roles=['Admin'])
|
||||||
@@ -214,18 +171,6 @@ def logout():
|
|||||||
logout_user()
|
logout_user()
|
||||||
return redirect(url_for('index'))
|
return redirect(url_for('index'))
|
||||||
|
|
||||||
def boolparse(string, default=False):
|
|
||||||
# falses = ['false', '0']
|
|
||||||
trues = ['true', '1']
|
|
||||||
if string is None:
|
|
||||||
return default
|
|
||||||
elif string.lower() in trues:
|
|
||||||
return True
|
|
||||||
# elif string.lower() in falses:
|
|
||||||
# return False
|
|
||||||
else:
|
|
||||||
return False
|
|
||||||
|
|
||||||
# The only implementation I could get to work
|
# The only implementation I could get to work
|
||||||
def validate_id(id):
|
def validate_id(id):
|
||||||
id = str(id).strip()
|
id = str(id).strip()
|
||||||
@@ -250,75 +195,4 @@ def hidden_history(id):
|
|||||||
def hidden_help(id):
|
def hidden_help(id):
|
||||||
if not validate_id(id):
|
if not validate_id(id):
|
||||||
return '<span style="color: red;">error:</span> bad id'
|
return '<span style="color: red;">error:</span> bad id'
|
||||||
return render_template('hidden_help.html')
|
return render_template('hidden_help.html')
|
||||||
|
|
||||||
@app.route('/hidden<id>/')
|
|
||||||
@login_required
|
|
||||||
@require_role(roles=['Hidden'])
|
|
||||||
def hidden(id):
|
|
||||||
if not validate_id(id):
|
|
||||||
return '<span style="color: red;">error:</span> bad id'
|
|
||||||
# Handled within request
|
|
||||||
tags = request.args.get('tags') or 'trap'
|
|
||||||
try:
|
|
||||||
page = int(request.args.get('page') or 1)
|
|
||||||
except (TypeError, ValueError):
|
|
||||||
return '\"page\" parameter must be Integer.<br>Invalid \"page\" parameter: \"{}\"'.format(request.args.get('page'))
|
|
||||||
# Handled within building
|
|
||||||
try:
|
|
||||||
count = int(request.args.get('count') or 50)
|
|
||||||
except (TypeError, ValueError):
|
|
||||||
return '\"count\" parameter must be Integer.<br>Invalid \"count\": \"{}\"'.format(request.args.get('count'))
|
|
||||||
base64 = boolparse(request.args.get('base64'))
|
|
||||||
# Handled within Jinja template
|
|
||||||
showfull = boolparse(request.args.get('showfull'))
|
|
||||||
showtags = boolparse(request.args.get('showtags'))
|
|
||||||
# Request, Parse & Build Data
|
|
||||||
data = build_data(tags, page-1, count, base64, showfull)
|
|
||||||
# Handling for limiters
|
|
||||||
if base64:
|
|
||||||
if showfull:
|
|
||||||
count = min(25, count)
|
|
||||||
else:
|
|
||||||
count = min(50, count)
|
|
||||||
search = Search(user_id=current_user.id, exact_url=str(request.url), query_args=json.dumps(request.args.to_dict()))
|
|
||||||
db.session.add(search)
|
|
||||||
db.session.commit()
|
|
||||||
return render_template('hidden.html', title='Gelbooru Browser', data=data, tags=tags, page=page, count=count, base64=base64, showfull=showfull, showtags=showtags)
|
|
||||||
|
|
||||||
def base64ify(url):
|
|
||||||
return base64.b64encode(requests.get(url).content).decode()
|
|
||||||
|
|
||||||
gelbooru_api_url = "https://gelbooru.com/index.php?page=dapi&s=post&q=index&tags={}&pid={}&limit={}"
|
|
||||||
gelbooru_view_url = "https://gelbooru.com/index.php?page=post&s=view&id={}"
|
|
||||||
|
|
||||||
def build_data(tags, page, count, base64, showfull):
|
|
||||||
# URL Building & Request
|
|
||||||
temp = gelbooru_api_url.format(tags, page, count)
|
|
||||||
response = requests.get(temp).text
|
|
||||||
# XML Parsing & Data Building
|
|
||||||
parse = xmltodict.parse(response)
|
|
||||||
build = []
|
|
||||||
|
|
||||||
try:
|
|
||||||
parse['posts']['post']
|
|
||||||
except KeyError:
|
|
||||||
return build
|
|
||||||
|
|
||||||
for index, element in enumerate(parse['posts']['post'][:count]):
|
|
||||||
temp = {
|
|
||||||
'index' : str(index + 1),
|
|
||||||
'real_url' : element['@file_url'],
|
|
||||||
'sample_url' : element['@preview_url'],
|
|
||||||
# strips tags, ensures no empty tags (may be unnescary)
|
|
||||||
'tags' : list(filter(lambda tag : tag != '', [tag.strip() for tag in element['@tags'].split(' ')])),
|
|
||||||
'view' : gelbooru_view_url.format(element['@id'])
|
|
||||||
}
|
|
||||||
if base64:
|
|
||||||
if not showfull:
|
|
||||||
temp['base64'] = base64ify(temp['sample_url'])
|
|
||||||
else:
|
|
||||||
temp['base64'] = base64ify(temp['real_url'])
|
|
||||||
|
|
||||||
build.append(temp)
|
|
||||||
return build
|
|
||||||
22
app/simple_routes.py
Normal file
22
app/simple_routes.py
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
from app import app
|
||||||
|
from flask import send_from_directory, redirect, url_for
|
||||||
|
import mistune
|
||||||
|
import os
|
||||||
|
|
||||||
|
markdown = mistune.Markdown()
|
||||||
|
|
||||||
|
@app.route('/keybase.txt')
|
||||||
|
def keybase():
|
||||||
|
return app.send_static_file('keybase.txt')
|
||||||
|
|
||||||
|
@app.route('/modpacks')
|
||||||
|
def modpacks():
|
||||||
|
return markdown(open(os.path.join(app.root_path, 'static', 'MODPACKS.MD'), 'r').read())
|
||||||
|
|
||||||
|
@app.route('/favicon.ico')
|
||||||
|
def favicon():
|
||||||
|
return send_from_directory(os.path.join(app.root_path, 'static'), 'favicon.ico', mimetype='image/vnd.microsoft.icon')
|
||||||
|
|
||||||
|
@app.errorhandler(401)
|
||||||
|
def unauthorized(e):
|
||||||
|
return redirect(url_for('login'))
|
||||||
Reference in New Issue
Block a user