You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
86 lines
3.5 KiB
86 lines
3.5 KiB
from flask import render_template, flash, redirect, url_for, request |
|
from flask_login import login_user, logout_user, current_user, login_required |
|
from sqlalchemy import and_ |
|
from app import app, db |
|
from app.models import Player, Game, Role, GamePlayer, Objective |
|
from app.forms import LoginForm, RegistrationForm, CreateGameForm, AddObjectiveForm |
|
|
|
@app.route('/') |
|
@app.route('/index') |
|
@login_required |
|
def index(): |
|
return render_template("index.html", title='Home') |
|
|
|
@app.route('/login', methods=['GET', 'POST']) |
|
def login(): |
|
if current_user.is_authenticated: |
|
return redirect(url_for('index')) |
|
form = LoginForm() |
|
if form.validate_on_submit(): |
|
player = Player.query.filter_by(name=form.username.data).first() |
|
if player is None or not player.check_password(form.password.data): |
|
flash('Invalid username or password') |
|
return redirect(url_for('login')) |
|
login_user(player, remember=form.remember_me.data) |
|
return redirect(url_for('index')) |
|
return render_template('login.html', title='Sign In', form=form) |
|
|
|
@app.route('/logout') |
|
@login_required |
|
def logout(): |
|
logout_user() |
|
return redirect(url_for('index')) |
|
|
|
@app.route('/register', methods=['GET', 'POST']) |
|
def register(): |
|
if current_user.is_authenticated: |
|
return redirect(url_for('index')) |
|
form = RegistrationForm() |
|
if form.validate_on_submit(): |
|
player = Player(name=form.username.data) |
|
player.set_password(form.password.data) |
|
player.set_auth_hash() |
|
db.session.add(player) |
|
db.session.commit() |
|
flash('Congratulations, you are now a registered user!') |
|
return redirect(url_for('login')) |
|
return render_template('register.html', title='Register', form=form) |
|
|
|
@app.route('/create_game', methods=['GET', 'POST']) |
|
@login_required |
|
def create_game(): |
|
print(current_user.is_authenticated) |
|
form = CreateGameForm() |
|
if form.validate_on_submit(): |
|
game = Game(name=form.game_name.data, start_time=form.start_time.data, end_time=form.end_time.data) |
|
game.game_players.append(GamePlayer(player=current_user, role=Role['owner'])) #check if this works, otherwise use 'owner' |
|
db.session.add(game) |
|
db.session.commit() |
|
flash(f"'{game.name}' had been created!") |
|
return redirect(url_for('game_dashboard', game_name=game.name)) |
|
return render_template('create_game.html', title='Create Game', form=form) |
|
|
|
@app.route('/game/<game_name>/dashboard') |
|
@login_required |
|
def game_dashboard(game_name): |
|
game = Game.query.filter(Game.game_players.any(and_(GamePlayer.player.has(Player.name == current_user.name), GamePlayer.role == 'owner'))).first_or_404() |
|
return render_template('game_dashboard.html', title = 'Game Dashboard', game=game) |
|
|
|
@app.route('/game/<game_name>/player/<player_name>') |
|
@login_required |
|
def game_player(game_name, player_name): |
|
return redirect(url_for('indsex')) |
|
|
|
@app.route('/game/<game_name>/add_objective', methods=['GET', 'POST']) |
|
@login_required |
|
def add_objective(game_name): |
|
game = Game.query.filter_by(name = game_name).first_or_404() |
|
form = AddObjectiveForm() |
|
if form.validate_on_submit(): |
|
objective = Objective(name=form.objective_name.data, longitude=form.longitude.data, latitude=form.latitude.data) |
|
objective.set_hash() |
|
game.objectives.append(objective) |
|
db.session.commit() |
|
flash(f"Objective has been added!") |
|
return redirect(url_for('game_dashboard', game_name=game.name)) |
|
return render_template('add_objective.html', title = f'Add Objective for {game_name}', form=form) |