Update model & translations'

This commit is contained in:
Samuel Ortion 2022-05-26 13:58:46 +02:00
parent 3a8faf6d5f
commit 899487245d
18 changed files with 160 additions and 65 deletions

44
app.py
View File

@ -4,8 +4,11 @@ from flask import session
from flask import request
from flask import redirect
from flask import url_for
from flask import g
from flask_migrate import Migrate
from flask_babel import Babel, gettext
from werkzeug.security import generate_password_hash, check_password_hash
from config import secret_key, database_uri
@ -18,8 +21,41 @@ app.secret_key = secret_key
app.config['SQLALCHEMY_DATABASE_URI'] = database_uri
app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False
app.config['BABEL_DEFAULT_LOCALE'] = 'en'
babel = Babel(app)
db.init_app(app)
@babel.localeselector
def get_locale():
# if a user is logged in, use the locale from the user settings
user = getattr(g, 'user', None)
if user is not None:
return user.locale
elif session['lang']:
return session['lang']
# otherwise try to guess the language from the user accept
# header the browser transmits. We support fr/en in this
# example. The best match wins.
return request.accept_languages.best_match(['fr', 'en'])
@babel.timezoneselector
def get_timezone():
user = getattr(g, 'user', None)
if user is not None:
return user.timezone
@app.route('/lang')
def get_lang():
return render_template('lang.html')
@app.route('/lang', methods=["POST"])
def set_lang():
lang = request.form["lang"]
session['lang'] = lang
return redirect('/')
@app.route("/")
def home():
if 'username' in session:
@ -33,10 +69,10 @@ def signup():
username = request.form['username']
email = request.form['email']
password = request.form['password']
registered_user = User.query.filter_by(username=username).first()
registered_user = User.query.filter_by(user_name=username).first()
if registered_user is None:
password_hash = generate_password_hash(password)
registered_user = User(username=username, email=email, password=password_hash)
registered_user = User(user_name=username, user_email=email, user_password=password_hash)
db.session.add(registered_user)
db.session.commit()
else:
@ -50,11 +86,11 @@ def login():
if request.method == "POST":
username = request.form['username']
password = request.form['password']
user = User.query.filter_by(username=username).first()
user = User.query.filter_by(user_name=username).first()
if user is None:
return render_template("auth/login.html", message="No user with this username already registered")
else:
password_hash = user.password
password_hash = user.user_password
if check_password_hash(password_hash, password):
session["username"] = username
return redirect(url_for("home"))

4
babel.cfg Normal file
View File

@ -0,0 +1,4 @@
[python: **.py]
[jinja2: templates/**.html]
encoding = utf-8
extensions=jinja2.ext.autoescape,jinja2.ext.with_

35
language/message.pot Normal file
View File

@ -0,0 +1,35 @@
# Translations template for PROJECT.
# Copyright (C) 2022 ORGANIZATION
# This file is distributed under the same license as the PROJECT project.
# FIRST AUTHOR <EMAIL@ADDRESS>, 2022.
#
#, fuzzy
msgid ""
msgstr ""
"Project-Id-Version: PROJECT VERSION\n"
"Report-Msgid-Bugs-To: EMAIL@ADDRESS\n"
"POT-Creation-Date: 2022-05-26 12:11+0200\n"
"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
"Language-Team: LANGUAGE <LL@li.org>\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=utf-8\n"
"Content-Transfer-Encoding: 8bit\n"
"Generated-By: Babel 2.10.1\n"
#: templates/base.html:15
msgid "Welcome"
msgstr ""
#: templates/index.html:3
msgid "Welcome to BirdQuizz !"
msgstr ""
#: templates/menu.html:3
msgid "Home"
msgstr ""
#: templates/menu.html:4
msgid "Game"
msgstr ""

Binary file not shown.

View File

@ -0,0 +1,36 @@
# French translations for PROJECT.
# Copyright (C) 2022 ORGANIZATION
# This file is distributed under the same license as the PROJECT project.
# FIRST AUTHOR <EMAIL@ADDRESS>, 2022.
#
msgid ""
msgstr ""
"Project-Id-Version: PROJECT VERSION\n"
"Report-Msgid-Bugs-To: EMAIL@ADDRESS\n"
"POT-Creation-Date: 2022-05-26 12:11+0200\n"
"PO-Revision-Date: 2022-05-26 13:10+0200\n"
"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
"Language: fr\n"
"Language-Team: fr <LL@li.org>\n"
"Plural-Forms: nplurals=2; plural=(n > 1);\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=utf-8\n"
"Content-Transfer-Encoding: 8bit\n"
"Generated-By: Babel 2.10.1\n"
#: templates/base.html:15
msgid "Welcome"
msgstr "Bienvenue"
#: templates/index.html:3
msgid "Welcome to BirdQuizz !"
msgstr "Bienvenue au BirdQuizz !"
#: templates/menu.html:3
msgid "Home"
msgstr "Accueil"
#: templates/menu.html:4
msgid "Game"
msgstr "Jeu"

2
make_migration.sh Normal file
View File

@ -0,0 +1,2 @@
flask db migrate -m "Initial migration."
flask db upgrade

View File

@ -1,34 +0,0 @@
"""Initial migration.
Revision ID: d9b0e75aca5e
Revises:
Create Date: 2022-05-26 10:57:06.959999
"""
from alembic import op
import sqlalchemy as sa
# revision identifiers, used by Alembic.
revision = 'd9b0e75aca5e'
down_revision = None
branch_labels = None
depends_on = None
def upgrade():
# ### commands auto generated by Alembic - please adjust! ###
op.create_table('userscore',
sa.Column('user_id', sa.Integer(), nullable=False),
sa.Column('score_value', sa.Integer(), nullable=True),
sa.Column('user_level', sa.Integer(), nullable=True),
sa.ForeignKeyConstraint(['user_id'], ['user.id'], ),
sa.PrimaryKeyConstraint('user_id')
)
# ### end Alembic commands ###
def downgrade():
# ### commands auto generated by Alembic - please adjust! ###
op.drop_table('userscore')
# ### end Alembic commands ###

View File

@ -6,17 +6,9 @@ db = SQLAlchemy()
class User(db.Model):
__tablename__ = 'user'
id = db.Column(db.Integer, primary_key=True)
username = db.Column(db.String(64), unique=True)
email = db.Column(db.String(64), unique=True, index=True)
password = db.Column(db.String(128))
class Score(db.Model):
__tablename__ = 'userscore'
user_id = db.Column(db.Integer, db.ForeignKey(User.id), primary_key=True)
score_value = db.Column(db.Integer)
user_id = db.Column(db.Integer, primary_key=True)
user_name = db.Column(db.String(64), unique=True)
user_email = db.Column(db.String(64), unique=True, index=True)
user_password = db.Column(db.String(128))
user_level = db.Column(db.Integer, default=1)
user = relationship("User", foreign_keys="User.id")
user_score = db.Column(db.Integer, default=0)

View File

@ -1,6 +1,8 @@
alembic==1.7.7
Babel==2.10.1
click==8.1.3
Flask==2.1.2
Flask-Babel==2.0.0
Flask-Migrate==3.1.0
Flask-SQLAlchemy==2.5.1
greenlet==1.1.2
@ -11,5 +13,6 @@ MarkupSafe==2.1.1
mysql-connector-python==8.0.29
protobuf==3.20.1
PyMySQL==1.0.2
pytz==2022.1
SQLAlchemy==1.4.36
Werkzeug==2.1.2

View File

@ -9,11 +9,13 @@
{% endif %}
<form action="/login" method="POST">
<label for="username">Username</label>
<label for="username">{{ _('Username') }}</label>
<input type="text" name="username" id="username">
<label for="password">Password</label>
<label for="password">{{ _('Password') }}</label>
<input type="password" name="password" id="password">
<input type="submit" value="Login">
<input type="submit" value="{{ _('Login') }}">
</form>
<a href="/signup">{{ _('Sign up') }}</a>
{% endblock %}

View File

@ -9,13 +9,13 @@
{% endif %}
<form action="/signup" method="POST">
<label for="username">Username</label>
<label for="username">{{ _('Username') }}</label>
<input type="text" name="username" id="username">
<label for="email">Email</label>
<label for="email">{{ _('Email') }}</label>
<input type="email" name="email" id="email">
<label for="password">Password</label>
<label for="password">{{ _('Password') }}</label>
<input type="password" name="password" id="password">
<input type="submit" value="Sign up">
<input type="submit" value="{{ _('Sign up') }}">
</form>
{% endblock %}

View File

@ -12,7 +12,7 @@
{% include 'menu.html' %}
<h1>BirdQuizz</h1>
{% if username is defined %}
<p>Welcome <span class="username">{{ username }}</span></p>
<p>{{ _('Welcome') }} <span class="username">{{ username }}</span></p>
{% endif %}
</header>
<main>

View File

@ -1,4 +1,7 @@
{% extends "base.html" %}
{% block content %}
<p>{{ message }}</p>
<p>
<a href="/game/new">{{ _('New Question') }}</a>
</p>
{% endblock %}

View File

@ -1,5 +1,5 @@
{% extends "base.html" %}
<a href="/game/new" class="button">
New Game
{{ _('New Game') }}
</a>

View File

@ -7,7 +7,7 @@
<option value="{{ item }}">{{ item }}</option>
{% endfor %}
</select>
<input type="submit" value="Send Answer">
<input type="submit" value="{{ _('Send Answer') }}">
</form>
{% endblock %}

View File

@ -1,4 +1,4 @@
{% extends "base.html" %}
{% block content %}
Welcome to BirdQuizz !
{{ _('Welcome to BirdQuizz !') }}
{% endblock %}

11
templates/lang.html Normal file
View File

@ -0,0 +1,11 @@
{% extends "base.html" %}
{% block content %}
<h2>{{ _('Select your language !') }}</h2>
<form action="/lang" method="POST">
<select name="lang" id="lang">
<option value="fr">Français</option>
<option value="en">English</option>
</select>
<input type="submit" value="{{ _('Translate') }}">
</form>
{% endblock %}

View File

@ -1,6 +1,11 @@
<nav>
<ul>
<li><a href="/">Home</a></li>
<li><a href="/game">Game</a></li>
<li><a href="/">{{ _('Home') }}</a></li>
<li><a href="/game">{{ _('Game') }}</a></li>
{% if username is defined %}
<li><a href="/logout">{{ _('Logout') }}</a></li>
{% else %}
<li><a href="/login">{{ _('Login') }}</a></li>
{% endif %}
</ul>
</nav>