Compare commits
7 Commits
frontend
...
moreOnStyl
Author | SHA1 | Date | |
---|---|---|---|
|
20db73836c | ||
05bc3112d6 | |||
a3b7ff3f9f
|
|||
62833a2bd6
|
|||
be7dcf5903
|
|||
e794fc6032
|
|||
17ab0b1840
|
1
.gitignore
vendored
Normal file
1
.gitignore
vendored
Normal file
@@ -0,0 +1 @@
|
|||||||
|
__pycacahe__/*
|
@@ -1,3 +1,9 @@
|
|||||||
# freeriders
|
# freeriders
|
||||||
|
|
||||||
Web app for tracking current ticket numbers
|
Web app for tracking current ticket numbers
|
||||||
|
|
||||||
|
# Architecture
|
||||||
|
|
||||||
|
- keep all ticket numbers and timestamps in SQL table "tickets"
|
||||||
|
- display last ticket number
|
||||||
|
- don't allow tickets that are out of probable ticket number range
|
||||||
|
@@ -4,7 +4,7 @@ Priority: optional
|
|||||||
Architecture: all
|
Architecture: all
|
||||||
Essential: no
|
Essential: no
|
||||||
Installed-Size: 2000
|
Installed-Size: 2000
|
||||||
Depends: python3-flask, gunicorn
|
Depends: gunicorn, python3-flask-sqlalchemy
|
||||||
Homepage: https://gitea.dmz.rs/Decentrala/freeriders
|
Homepage: https://gitea.dmz.rs/Decentrala/freeriders
|
||||||
Maintainer: Decentrala <dmz@dmz.rs>
|
Maintainer: Decentrala <dmz@dmz.rs>
|
||||||
Description: Web app that tracks bus transport ticket numbers
|
Description: Web app that tracks bus transport ticket numbers
|
||||||
|
@@ -1,5 +1,16 @@
|
|||||||
from flask import Flask
|
from flask import Flask
|
||||||
|
from flask_sqlalchemy import SQLAlchemy
|
||||||
|
import os # if you wanna have db credenitalas in os.environ
|
||||||
|
|
||||||
app = Flask(__name__)
|
app = Flask(__name__)
|
||||||
|
|
||||||
|
# SQLAlchemy setup
|
||||||
|
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///freeriders.db'
|
||||||
|
|
||||||
|
#MySql setup
|
||||||
|
#app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql://user:pass@localhost/dbname'
|
||||||
|
|
||||||
|
app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False
|
||||||
|
db = SQLAlchemy(app)
|
||||||
|
|
||||||
from freeriders import routes
|
from freeriders import routes
|
||||||
|
6
freeriders/models.py
Normal file
6
freeriders/models.py
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
from freeriders import db
|
||||||
|
|
||||||
|
class Tickets(db.Model):
|
||||||
|
id = db.Column(db.Integer, primary_key=True)
|
||||||
|
ticket = db.Column(db.Integer, nullable=False)
|
||||||
|
timestamp = db.Column(db.Integer, nullable=False)
|
@@ -1,10 +1,38 @@
|
|||||||
from flask import render_template, request, redirect
|
from flask import render_template, request, redirect
|
||||||
from freeriders import app
|
from freeriders import app, db
|
||||||
|
from freeriders.models import Ticket
|
||||||
|
import time
|
||||||
|
|
||||||
@app.route('/', methods=['POST', 'GET'])
|
@app.route('/sms', methods=['GET'])
|
||||||
def changepassword():
|
def sms():
|
||||||
if request.method == 'GET':
|
if request.method == 'GET':
|
||||||
return render_template('index.html')
|
try:
|
||||||
elif request.method == 'POST':
|
lastticket = Ticket.query.order_by(Ticket.timestamp.desc()).first()
|
||||||
|
return render_template('sms.html', ticket = lastticket)
|
||||||
|
except:
|
||||||
|
return 'Error retriving last ticket'
|
||||||
|
else:
|
||||||
|
return 'HTTP request method not recogniezed'
|
||||||
|
|
||||||
|
@app.route('/submit', methods=['POST', 'GET'])
|
||||||
|
def submit():
|
||||||
|
if request.method == 'GET':
|
||||||
|
return render_template('submit.html')
|
||||||
|
elif request.method == 'POST':
|
||||||
|
timenow = int(time.time())
|
||||||
|
ticket_input = request.form['ticket']
|
||||||
|
|
||||||
|
if ticket_input.isdigit() and len(ticket_input) == 10:
|
||||||
|
ticket = Ticket(ticket = int(ticket_input), timestamp = timenow)
|
||||||
|
else:
|
||||||
|
return 'Ticket format is wrong. Only 10 digits allowed.'
|
||||||
|
|
||||||
|
try:
|
||||||
|
db.session.add(ticket)
|
||||||
|
db.session.commit()
|
||||||
|
return 'Ticket added'
|
||||||
|
except:
|
||||||
|
return 'Adding ticket failed'
|
||||||
|
|
||||||
else:
|
else:
|
||||||
return 'HTTP request method not recogniezed'
|
return 'HTTP request method not recogniezed'
|
||||||
|
@@ -1,9 +1,9 @@
|
|||||||
:root {
|
:root {
|
||||||
--border-radus: 1rem;
|
--border-radus: 1rem;
|
||||||
--background: #EEE;
|
--background: #F9F9F9;
|
||||||
--header-background: #DDD;
|
--header-background: #EEE;
|
||||||
--header-height: 3rem;
|
--header-height: 3rem;
|
||||||
--input-bar-height: 2rem;
|
--input-bar-height: 3rem;
|
||||||
}
|
}
|
||||||
|
|
||||||
body{
|
body{
|
||||||
@@ -14,14 +14,13 @@ body{
|
|||||||
}
|
}
|
||||||
|
|
||||||
main {
|
main {
|
||||||
max-width: 400px;
|
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
align-self: flex-start;
|
align-self: flex-start;
|
||||||
gap: 1rem;
|
gap: 1rem;
|
||||||
margin: 0 auto;
|
margin: 0 auto;
|
||||||
padding: 1rem 0.5rem;
|
padding: 2rem 0.5rem;
|
||||||
height: calc(100vh - 5rem);
|
height: calc(100vh - var(--header-height) - var(--input-bar-height));
|
||||||
overflow-y: scroll;
|
overflow-y: scroll;
|
||||||
box-sizing: border-box;
|
box-sizing: border-box;
|
||||||
}
|
}
|
||||||
@@ -30,22 +29,25 @@ header {
|
|||||||
background-color: var(--header-background);
|
background-color: var(--header-background);
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: row;
|
flex-direction: row;
|
||||||
padding: 1rem;
|
align-items: center;
|
||||||
|
padding: 0 1rem;
|
||||||
gap: 1rem;
|
gap: 1rem;
|
||||||
font-weight: bold;
|
font-weight: bold;
|
||||||
width: 100vw;
|
width: 100vw;
|
||||||
height: var(header-height);
|
height: var(--header-height);
|
||||||
box-sizing: border-box;
|
box-sizing: border-box;
|
||||||
}
|
}
|
||||||
|
|
||||||
footer {
|
footer {
|
||||||
width: 100vw;
|
width: 100vw;
|
||||||
height: var(input-bar-height);
|
height: var(--input-bar-height);
|
||||||
background-color: #FDD;
|
background-color: var(--background);
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: row;
|
flex-direction: row;
|
||||||
|
align-items: center;
|
||||||
padding: 0 1rem;
|
padding: 0 1rem;
|
||||||
box-sizing: border-box;
|
box-sizing: border-box;
|
||||||
|
gap: 1rem;
|
||||||
}
|
}
|
||||||
|
|
||||||
.request {
|
.request {
|
||||||
@@ -68,3 +70,11 @@ footer {
|
|||||||
align-self: center;
|
align-self: center;
|
||||||
margin-top: 0.5rem;
|
margin-top: 0.5rem;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.textbox{
|
||||||
|
background-color: var(--header-background);
|
||||||
|
width: 80%;
|
||||||
|
height: 1rem;
|
||||||
|
padding: 0.2rem;
|
||||||
|
border-radius: 2rem;
|
||||||
|
}
|
10
init_db.py
Executable file
10
init_db.py
Executable file
@@ -0,0 +1,10 @@
|
|||||||
|
#!/usr/bin/env python3
|
||||||
|
from freeriders import db
|
||||||
|
|
||||||
|
print('[i] Trying to create databse...')
|
||||||
|
try:
|
||||||
|
db.create_all()
|
||||||
|
print('[+] Success you can proceed with deployment!')
|
||||||
|
except:
|
||||||
|
print('[-] Creating db failed :/')
|
||||||
|
|
@@ -1 +1,2 @@
|
|||||||
flask
|
flask
|
||||||
|
SQLAlchemy
|
||||||
|
Reference in New Issue
Block a user