mirror of
				https://git.wownero.com/lza_menace/suchwow.git
				synced 2024-08-15 01:03:19 +00:00 
			
		
		
		
	starting refactor and extending app
This commit is contained in:
		
							parent
							
								
									d199943b45
								
							
						
					
					
						commit
						37af78e539
					
				
					 8 changed files with 109 additions and 48 deletions
				
			
		| 
						 | 
					@ -3,13 +3,12 @@ import uuid
 | 
				
			||||||
import os
 | 
					import os
 | 
				
			||||||
import json
 | 
					import json
 | 
				
			||||||
import requests
 | 
					import requests
 | 
				
			||||||
from flask import Flask, g, request, redirect, url_for, abort
 | 
					from flask import Flask, request, redirect, url_for, abort
 | 
				
			||||||
from flask import jsonify, render_template, flash, session
 | 
					from flask import jsonify, render_template, flash, session
 | 
				
			||||||
from flask import send_from_directory, make_response
 | 
					from flask import send_from_directory, make_response
 | 
				
			||||||
from flask_session import Session
 | 
					from flask_session import Session
 | 
				
			||||||
from playhouse.flask_utils import PaginatedQuery
 | 
					 | 
				
			||||||
from werkzeug.utils import secure_filename
 | 
					from werkzeug.utils import secure_filename
 | 
				
			||||||
from suchwow.models import Meme, db
 | 
					from suchwow.models import Post, Profile, Comment, Notification, db
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
app = Flask(__name__)
 | 
					app = Flask(__name__)
 | 
				
			||||||
| 
						 | 
					@ -17,9 +16,9 @@ app.config.from_envvar("FLASK_SECRETS")
 | 
				
			||||||
app.secret_key = app.config["SECRET_KEY"]
 | 
					app.secret_key = app.config["SECRET_KEY"]
 | 
				
			||||||
Session(app)
 | 
					Session(app)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
OPENID_URL = app.config["OIDC_URL"][0]
 | 
					OPENID_URL = app.config["OIDC_URL"]
 | 
				
			||||||
OPENID_CLIENT_ID = app.config["OIDC_CLIENT_ID"][0]
 | 
					OPENID_CLIENT_ID = app.config["OIDC_CLIENT_ID"]
 | 
				
			||||||
OPENID_CLIENT_SECRET = app.config["OIDC_CLIENT_SECRET"][0]
 | 
					OPENID_CLIENT_SECRET = app.config["OIDC_CLIENT_SECRET"]
 | 
				
			||||||
OPENID_REDIRECT_URI = "http://localhost:5000/auth"
 | 
					OPENID_REDIRECT_URI = "http://localhost:5000/auth"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -27,9 +26,22 @@ def allowed_file(filename):
 | 
				
			||||||
    return "." in filename and \
 | 
					    return "." in filename and \
 | 
				
			||||||
           filename.rsplit(".", 1)[1].lower() in app.config["ALLOWED_EXTENSIONS"]
 | 
					           filename.rsplit(".", 1)[1].lower() in app.config["ALLOWED_EXTENSIONS"]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					def debug_login():
 | 
				
			||||||
 | 
					    session["auth"] = {
 | 
				
			||||||
 | 
					        "state": "active",
 | 
				
			||||||
 | 
					        "session_state": "debug",
 | 
				
			||||||
 | 
					        "code": "abcdefg",
 | 
				
			||||||
 | 
					        "preferred_username": "debuguser",
 | 
				
			||||||
 | 
					        "debug": True
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    return
 | 
				
			||||||
 | 
					
 | 
				
			||||||
def login_required(f):
 | 
					def login_required(f):
 | 
				
			||||||
    @wraps(f)
 | 
					    @wraps(f)
 | 
				
			||||||
    def decorated_function(*args, **kwargs):
 | 
					    def decorated_function(*args, **kwargs):
 | 
				
			||||||
 | 
					        if app.debug:
 | 
				
			||||||
 | 
					            debug_login()
 | 
				
			||||||
 | 
					            return f(*args, **kwargs)
 | 
				
			||||||
        if "auth" not in session or not session["auth"]:
 | 
					        if "auth" not in session or not session["auth"]:
 | 
				
			||||||
            return redirect(url_for("login"))
 | 
					            return redirect(url_for("login"))
 | 
				
			||||||
        return f(*args, **kwargs)
 | 
					        return f(*args, **kwargs)
 | 
				
			||||||
| 
						 | 
					@ -38,31 +50,31 @@ def login_required(f):
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@app.route("/")
 | 
					@app.route("/")
 | 
				
			||||||
def index():
 | 
					def index():
 | 
				
			||||||
    page = request.args.get('page')
 | 
					    page = request.args.get("page", "1")
 | 
				
			||||||
    if page.isdigit() is False:
 | 
					    if page.isdigit() is False:
 | 
				
			||||||
        flash("Wow, wtf hackerman. Cool it.")
 | 
					        flash("Wow, wtf hackerman. Cool it.")
 | 
				
			||||||
        page = 1
 | 
					        page = 1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    memes = Meme.select().order_by(Meme.timestamp).paginate(int(page), 10)
 | 
					    posts = Post.select().order_by(Post.timestamp).paginate(int(page), 10)
 | 
				
			||||||
    return render_template("index.html", memes=memes, page=page)
 | 
					    return render_template("index.html", posts=posts, page=page)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@app.route("/meme/<id>")
 | 
					@app.route("/post/<id>")
 | 
				
			||||||
def meme(id):
 | 
					def read_post(id):
 | 
				
			||||||
    if Meme.filter(id=id):
 | 
					    if Post.filter(id=id):
 | 
				
			||||||
        meme = Meme.get(Meme.id == id)
 | 
					        post = Post.get(Post.id == id)
 | 
				
			||||||
        return render_template("meme.html", meme=meme)
 | 
					        return render_template("post.html", post=post)
 | 
				
			||||||
    else:
 | 
					    else:
 | 
				
			||||||
        return "no meme there brah"
 | 
					        return "no meme there brah"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@app.route("/uploads/<path:filename>")
 | 
					@app.route("/uploads/<path:filename>")
 | 
				
			||||||
def uploaded_file(filename):
 | 
					def uploaded_file(filename):
 | 
				
			||||||
    return send_from_directory(app.config['UPLOAD_FOLDER'], filename)
 | 
					    return send_from_directory(app.config["UPLOAD_FOLDER"], filename)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@app.route("/submit", methods=["GET", "POST"])
 | 
					@app.route("/post/create", methods=["GET", "POST"])
 | 
				
			||||||
@login_required
 | 
					@login_required
 | 
				
			||||||
def submit():
 | 
					def create_post():
 | 
				
			||||||
    if request.method == "POST":
 | 
					    if request.method == "POST":
 | 
				
			||||||
        meme_title = request.form.get('title')
 | 
					        post_title = request.form.get("title")
 | 
				
			||||||
        # check if the post request has the file part
 | 
					        # check if the post request has the file part
 | 
				
			||||||
        if "file" not in request.files:
 | 
					        if "file" not in request.files:
 | 
				
			||||||
            flash("You didn't upload a caliente meme, bro! You're fuckin up!")
 | 
					            flash("You didn't upload a caliente meme, bro! You're fuckin up!")
 | 
				
			||||||
| 
						 | 
					@ -73,21 +85,25 @@ def submit():
 | 
				
			||||||
        if file.filename == "":
 | 
					        if file.filename == "":
 | 
				
			||||||
            flash("You didn't upload a caliente meme, bro! You're fuckin up!")
 | 
					            flash("You didn't upload a caliente meme, bro! You're fuckin up!")
 | 
				
			||||||
            return redirect(request.url)
 | 
					            return redirect(request.url)
 | 
				
			||||||
        if meme_title is "":
 | 
					        if post_title is "":
 | 
				
			||||||
            flash("You didn't give your meme a spicy title, bro! You're fuckin up!")
 | 
					            flash("You didn't give your meme a spicy title, bro! You're fuckin up!")
 | 
				
			||||||
            return redirect(request.url)
 | 
					            return redirect(request.url)
 | 
				
			||||||
        if file and allowed_file(file.filename):
 | 
					        if file and allowed_file(file.filename):
 | 
				
			||||||
            filename = secure_filename(file.filename)
 | 
					            filename = secure_filename(file.filename)
 | 
				
			||||||
            save_path = os.path.join(app.config["UPLOAD_FOLDER"], filename)
 | 
					            save_path = os.path.join(app.config["UPLOAD_FOLDER"], filename)
 | 
				
			||||||
            file.save(save_path)
 | 
					            file.save(save_path)
 | 
				
			||||||
            meme = Meme(
 | 
					            # gen wallet
 | 
				
			||||||
                title=meme_title,
 | 
					            post = Post(
 | 
				
			||||||
 | 
					                title=post_title,
 | 
				
			||||||
 | 
					                subtitle=request.form.get("subtitle", ""),
 | 
				
			||||||
                submitter=session["auth"]["preferred_username"],
 | 
					                submitter=session["auth"]["preferred_username"],
 | 
				
			||||||
                image_name=filename,
 | 
					                image_name=filename,
 | 
				
			||||||
 | 
					                account_index=0,
 | 
				
			||||||
 | 
					                address_index=0
 | 
				
			||||||
            )
 | 
					            )
 | 
				
			||||||
            meme.save()
 | 
					            post.save()
 | 
				
			||||||
            return redirect(url_for("meme", id=meme.id))
 | 
					            return redirect(url_for("read_post", id=post.id))
 | 
				
			||||||
    return render_template("submit.html")
 | 
					    return render_template("create_post.html")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@app.route("/login")
 | 
					@app.route("/login")
 | 
				
			||||||
def login():
 | 
					def login():
 | 
				
			||||||
| 
						 | 
					@ -99,6 +115,10 @@ def login():
 | 
				
			||||||
          f"response_type=code&" \
 | 
					          f"response_type=code&" \
 | 
				
			||||||
          f"state={state}"
 | 
					          f"state={state}"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if app.debug:
 | 
				
			||||||
 | 
					        debug_login()
 | 
				
			||||||
 | 
					        return redirect(url_for("index"))
 | 
				
			||||||
 | 
					    else:
 | 
				
			||||||
        return redirect(url)
 | 
					        return redirect(url)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -169,9 +189,9 @@ def logout():
 | 
				
			||||||
def not_found(error):
 | 
					def not_found(error):
 | 
				
			||||||
    return make_response(jsonify({"error": "Page not found"}), 404)
 | 
					    return make_response(jsonify({"error": "Page not found"}), 404)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@app.cli.command('dbinit')
 | 
					@app.cli.command("dbinit")
 | 
				
			||||||
def dbinit():
 | 
					def dbinit():
 | 
				
			||||||
    db.create_tables([Meme])
 | 
					    db.create_tables([Post, Profile, Comment, Notification])
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if __name__ == "__main__":
 | 
					if __name__ == "__main__":
 | 
				
			||||||
    app.run()
 | 
					    app.run()
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -5,5 +5,5 @@ OIDC_REDIRECT_URL = 'http://localhost:5000/auth'
 | 
				
			||||||
SECRET = 'yyyyyyyyyyyyy',
 | 
					SECRET = 'yyyyyyyyyyyyy',
 | 
				
			||||||
SESSION_TYPE = 'filesystem'
 | 
					SESSION_TYPE = 'filesystem'
 | 
				
			||||||
UPLOAD_FOLDER = '/path/to/the/uploads'
 | 
					UPLOAD_FOLDER = '/path/to/the/uploads'
 | 
				
			||||||
ALLOWED_EXTENSIONS = set(['png', 'jpg', 'jpeg', 'gif'])
 | 
					ALLOWED_EXTENSIONS = {'png', 'jpg', 'jpeg', 'gif'}
 | 
				
			||||||
MAX_CONTENT_LENGTH = 16 * 1024 * 1024
 | 
					MAX_CONTENT_LENGTH = 16 * 1024 * 1024
 | 
				
			||||||
| 
						 | 
					@ -4,11 +4,45 @@ from datetime import datetime
 | 
				
			||||||
 | 
					
 | 
				
			||||||
db = SqliteDatabase('data/sqlite.db')
 | 
					db = SqliteDatabase('data/sqlite.db')
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class Meme(Model):
 | 
					class Post(Model):
 | 
				
			||||||
    id = AutoField()
 | 
					    id = AutoField()
 | 
				
			||||||
    title = CharField()
 | 
					    title = CharField()
 | 
				
			||||||
 | 
					    subtitle = CharField()
 | 
				
			||||||
 | 
					    # submitter = ForeignKeyField(Profile, field=Profile.username)
 | 
				
			||||||
    submitter = CharField()
 | 
					    submitter = CharField()
 | 
				
			||||||
    image_name = CharField()
 | 
					    image_name = CharField()
 | 
				
			||||||
 | 
					    readonly = BooleanField(default=False)
 | 
				
			||||||
 | 
					    hidden = BooleanField(default=False)
 | 
				
			||||||
 | 
					    account_index = IntegerField()
 | 
				
			||||||
 | 
					    address_index = IntegerField()
 | 
				
			||||||
 | 
					    timestamp = DateTimeField(default=datetime.now)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    class Meta:
 | 
				
			||||||
 | 
					        database = db
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					class Profile(Model):
 | 
				
			||||||
 | 
					    id = AutoField()
 | 
				
			||||||
 | 
					    username = CharField()
 | 
				
			||||||
 | 
					    address = CharField()
 | 
				
			||||||
 | 
					    notifications = IntegerField()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    class Meta:
 | 
				
			||||||
 | 
					        database = db
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					class Comment(Model):
 | 
				
			||||||
 | 
					    id = AutoField()
 | 
				
			||||||
 | 
					    comment = TextField()
 | 
				
			||||||
 | 
					    commenter = ForeignKeyField(Profile, field=Profile.username)
 | 
				
			||||||
 | 
					    post = ForeignKeyField(Post, field=id)
 | 
				
			||||||
 | 
					    timestamp = DateTimeField(default=datetime.now)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    class Meta:
 | 
				
			||||||
 | 
					        database = db
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					class Notification(Model):
 | 
				
			||||||
 | 
					    type = CharField()
 | 
				
			||||||
 | 
					    message = TextField()
 | 
				
			||||||
 | 
					    username = ForeignKeyField(Profile, field=Profile.username)
 | 
				
			||||||
    timestamp = DateTimeField(default=datetime.now)
 | 
					    timestamp = DateTimeField(default=datetime.now)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    class Meta:
 | 
					    class Meta:
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
							
								
								
									
										0
									
								
								suchwow/routes/__init__.py
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								suchwow/routes/__init__.py
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -5,6 +5,7 @@
 | 
				
			||||||
<h1>Upload new File</h1>
 | 
					<h1>Upload new File</h1>
 | 
				
			||||||
<form method=post enctype=multipart/form-data>
 | 
					<form method=post enctype=multipart/form-data>
 | 
				
			||||||
  <input type="text" name="title"><br>
 | 
					  <input type="text" name="title"><br>
 | 
				
			||||||
 | 
					  <input type="text" name="subtitle"><br>
 | 
				
			||||||
  <input type=file name=file>
 | 
					  <input type=file name=file>
 | 
				
			||||||
  <input type=submit value=Submit>
 | 
					  <input type=submit value=Submit>
 | 
				
			||||||
</form>
 | 
					</form>
 | 
				
			||||||
| 
						 | 
					@ -2,7 +2,7 @@
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 {% block content %}
 | 
					 {% block content %}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 <a href="{{ url_for('submit') }}">Submit A Meme</a><br>
 | 
					 <a href="{{ url_for('create_post') }}">Submit A Meme</a><br>
 | 
				
			||||||
 <a href="{{ url_for('debug') }}">Debug</a>
 | 
					 <a href="{{ url_for('debug') }}">Debug</a>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 {% block header %}
 | 
					 {% block header %}
 | 
				
			||||||
| 
						 | 
					@ -10,10 +10,11 @@
 | 
				
			||||||
 {% endblock %}
 | 
					 {% endblock %}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<ul>
 | 
					<ul>
 | 
				
			||||||
 {% for meme in memes %}
 | 
					 {% for post in posts %}
 | 
				
			||||||
   <li><a href="{{ url_for('meme', id=meme.id) }}">{{ meme.title }}</a></li>
 | 
					   <li><a href="{{ url_for('read_post', id=post.id) }}">{{ post.title }}</a></li>
 | 
				
			||||||
 {% endfor %}
 | 
					 {% endfor %}
 | 
				
			||||||
</ul>
 | 
					</ul>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
{{ page }}
 | 
					{{ page }}
 | 
				
			||||||
 {% endblock %}
 | 
					
 | 
				
			||||||
 | 
					{% endblock %}
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1,14 +0,0 @@
 | 
				
			||||||
{% extends 'base.html' %}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
{% block header %}
 | 
					 | 
				
			||||||
  <h1>{% block title %}View Meme{% endblock %}</h1>
 | 
					 | 
				
			||||||
{% endblock %}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
{% block content %}
 | 
					 | 
				
			||||||
<p>Submitter: {{ session['auth']['preferred_username'] }}</p>
 | 
					 | 
				
			||||||
<p>ID: {{ meme.id }}</p>
 | 
					 | 
				
			||||||
<p>Title: {{ meme.title }}</p>
 | 
					 | 
				
			||||||
<p>Submitted: {{ meme.timestamp }}</p>
 | 
					 | 
				
			||||||
<p>Image Name: {{ meme.image_name }}</p>
 | 
					 | 
				
			||||||
<img src="{{ url_for('uploaded_file', filename=meme.image_name) }}" width=400/>
 | 
					 | 
				
			||||||
{% endblock %}
 | 
					 | 
				
			||||||
							
								
								
									
										19
									
								
								suchwow/templates/post.html
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								suchwow/templates/post.html
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,19 @@
 | 
				
			||||||
 | 
					{% extends 'base.html' %}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					{% block header %}
 | 
				
			||||||
 | 
					  <h1>{% block title %}View Post{% endblock %}</h1>
 | 
				
			||||||
 | 
					{% endblock %}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					{% block content %}
 | 
				
			||||||
 | 
					    {% if post.hidden %}
 | 
				
			||||||
 | 
					You cannot see this post
 | 
				
			||||||
 | 
					    {% else %}
 | 
				
			||||||
 | 
					<p>Submitter: {{ post.submitter }}</p>
 | 
				
			||||||
 | 
					<p>ID: {{ post.id }}</p>
 | 
				
			||||||
 | 
					<p>Title: {{ post.title }}</p>
 | 
				
			||||||
 | 
					<p>Subtitle: {{ post.subtitle }}</p>
 | 
				
			||||||
 | 
					<p>Submitted: {{ post.timestamp }}</p>
 | 
				
			||||||
 | 
					<p>Image Name: {{ post.image_name }}</p>
 | 
				
			||||||
 | 
					<img src="{{ url_for('uploaded_file', filename=post.image_name) }}" width=500/>
 | 
				
			||||||
 | 
					    {% endif %}
 | 
				
			||||||
 | 
					{% endblock %}
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue