mirror of
https://github.com/Llloooggg/Jarvis.git
synced 2026-03-06 12:06:23 +03:00
Merge branch 'master' into frontend
This commit is contained in:
70
__init__.py
70
__init__.py
@@ -1,9 +1,16 @@
|
|||||||
from flask import Flask, render_template, flash, redirect, url_for, session, logging, request
|
from flask import Flask, render_template, request
|
||||||
from flask_sqlalchemy import SQLAlchemy
|
import db_routing
|
||||||
|
from flask_httpauth import HTTPBasicAuth
|
||||||
|
import os
|
||||||
|
import hashlib
|
||||||
|
|
||||||
app = Flask(__name__, static_folder="static", template_folder="templates")
|
|
||||||
|
if not os.path.exists('./data.db'):
|
||||||
|
db_routing.db.create_all()
|
||||||
|
|
||||||
|
app = Flask('Jarvis', static_folder='static', template_folder='templates')
|
||||||
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///data.db'
|
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///data.db'
|
||||||
db = SQLAlchemy(app)
|
auth = HTTPBasicAuth()
|
||||||
|
|
||||||
|
|
||||||
@app.route('/', methods=['GET'])
|
@app.route('/', methods=['GET'])
|
||||||
@@ -11,28 +18,45 @@ def index():
|
|||||||
return render_template('index.html')
|
return render_template('index.html')
|
||||||
|
|
||||||
|
|
||||||
@app.route("/registration", methods=["GET", "POST"])
|
@app.route('/registration', methods=['GET', 'POST'])
|
||||||
def register():
|
def register():
|
||||||
if request.method == "POST":
|
if request.method == 'POST':
|
||||||
|
userLogin = request.form['UserLogin']
|
||||||
UserLogin = request.form['UserLogin']
|
userPassw = request.form['UserPassw']
|
||||||
UserPass = request.form['UserPass']
|
if db_routing.add_user(userLogin, passw_hash(userPassw)):
|
||||||
|
return render_template('content.html')
|
||||||
#db.session.add(UserLogin, UserPass)
|
return render_template('registration.html')
|
||||||
#db.session.commit()
|
|
||||||
|
|
||||||
#return redirect(url_for(""))
|
|
||||||
|
|
||||||
print(UserLogin, ' ', UserPass)
|
|
||||||
# return страница с контентом
|
|
||||||
|
|
||||||
return render_template("registration.html")
|
|
||||||
|
|
||||||
|
|
||||||
# @app.route('/login', methods=['GET'])
|
@auth.verify_password
|
||||||
# def login():
|
def verify_password(user_login, user_passw):
|
||||||
# return render_template('login.html')
|
User = db_routing.find_user(user_login)
|
||||||
|
if User:
|
||||||
|
userSalt = User.UserPassw[:32]
|
||||||
|
if passw_hash(user_passw, userSalt) == User.UserPassw:
|
||||||
|
return True
|
||||||
|
else:
|
||||||
|
return False
|
||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
@app.route('/content', methods=['GET'])
|
||||||
|
@auth.login_required
|
||||||
|
def content():
|
||||||
|
return render_template('content.html')
|
||||||
|
|
||||||
|
|
||||||
|
# @app.errorhandler(404)
|
||||||
|
# def not_found(error):
|
||||||
|
# return render_template('404.html'), 404
|
||||||
|
|
||||||
|
|
||||||
|
def passw_hash(user_passw, salt=os.urandom(32)):
|
||||||
|
key = hashlib.pbkdf2_hmac('sha256', user_passw.encode('utf-8'), salt, 100000)
|
||||||
|
storage = salt + key
|
||||||
|
# salt_from_storage = storage[:32] # 32 длина соли
|
||||||
|
# key_from_storage = storage[32:]
|
||||||
|
return storage
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
app.run()
|
app.run()
|
||||||
|
|||||||
27
db_routing.py
Normal file
27
db_routing.py
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
from flask_sqlalchemy import SQLAlchemy
|
||||||
|
from __init__ import app
|
||||||
|
|
||||||
|
|
||||||
|
db = SQLAlchemy(app)
|
||||||
|
|
||||||
|
|
||||||
|
class User(db.Model):
|
||||||
|
__tablename__ = 'users'
|
||||||
|
UserID = db.Column(db.Integer, primary_key=True)
|
||||||
|
UserName = db.Column(db.String(80), unique=True, nullable=False)
|
||||||
|
UserPassw = db.Column(db.String(120), nullable=False)
|
||||||
|
|
||||||
|
|
||||||
|
def add_user(user_name, passw_hash):
|
||||||
|
if not find_user(user_name):
|
||||||
|
new_user = User(UserName=user_name, UserPassw=passw_hash)
|
||||||
|
db.session.add(new_user)
|
||||||
|
db.session.commit()
|
||||||
|
return True
|
||||||
|
else:
|
||||||
|
print('Логин занят')
|
||||||
|
return False
|
||||||
|
|
||||||
|
|
||||||
|
def find_user(user_name):
|
||||||
|
return User.query.filter_by(UserName=user_name).first()
|
||||||
@@ -1,5 +1,6 @@
|
|||||||
click==7.1.1
|
click==7.1.1
|
||||||
Flask==1.1.1
|
Flask==1.1.1
|
||||||
|
Flask-HTTPAuth==3.3.0
|
||||||
Flask-SQLAlchemy==2.4.1
|
Flask-SQLAlchemy==2.4.1
|
||||||
itsdangerous==1.1.0
|
itsdangerous==1.1.0
|
||||||
Jinja2==2.11.1
|
Jinja2==2.11.1
|
||||||
|
|||||||
@@ -79,7 +79,7 @@
|
|||||||
<div class="form__field-title" >
|
<div class="form__field-title" >
|
||||||
Введите пароль
|
Введите пароль
|
||||||
</div>
|
</div>
|
||||||
<input type="password" class="form__input-text" placeholder="Введите пароль" name = "UserPass">
|
<input type="password" class="form__input-text" placeholder="Введите пароль" name = "UserPassw">
|
||||||
</label>
|
</label>
|
||||||
</div>
|
</div>
|
||||||
<div class="form__btns">
|
<div class="form__btns">
|
||||||
|
|||||||
Reference in New Issue
Block a user