SMS-proj is a project to send receive SMS messages.
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.
sms-proj/app_auth.py

68 lines
2.2 KiB

import hashlib, binascii, os
import flask
from flask import request
import functools
import os
import pprint
#import google_auth
import configparser
config = configparser.ConfigParser()
config.read('config.ini')
app_debug = config.get("app","debug")
app_salt = config.get("auth","FN_FLASK_SECRET_KEY")
6 years ago
app = flask.Blueprint('app_auth', __name__)
app.debug = True
def no_cache(view):
@functools.wraps(view)
def no_cache_impl(*args, **kwargs):
response = flask.make_response(view(*args, **kwargs))
response.headers['Cache-Control'] = 'no-store, no-cache, must-revalidate, max-age=0'
response.headers['Pragma'] = 'no-cache'
response.headers['Expires'] = '-1'
return response
return functools.update_wrapper(no_cache_impl, view)
6 years ago
def is_logged_in():
#return True if loggedIn in flask.session else False
return True if 'loggedIn' in flask.session else False
if flask.session.loggedIn:
pprint.pprint('Flask session loginhash:')
pprint.pprint(flask.session.loggedIn)
return True
return False
@app.route('/auth/login', methods=['POST'])
@no_cache
def auth_login():
"""Login using provided credentials"""
pprint.pprint('Got credentials offff')
pprint.pprint(request.form)
return "Success %s" % request.form['email']
@app.route('/auth/register', methods=['POST'])
@no_cache
def auth_register_login():
"""Create a login using the supplied credentials in request.form"""
pprint.pprint('Got credentials offff')
pprint.pprint(request.form)
return "Success %s" % request.form['passwd']
def hash_password(password):
"""Hash a password for storing."""
pwdhash = hashlib.pbkdf2_hmac('sha512', password,
app_salt.encode('ascii'), 100000)
pwdhash = binascii.hexlify(pwdhash).decode('ascii')
return pwdhash
def verify_password(stored_password, provided_password):
"""Verify a stored password against one provided by user"""
pwdhash = hashlib.pbkdf2_hmac('sha512', provided_password,
app_salt.encode('ascii'), 100000)
pwdhash = binascii.hexlify(pwdhash).decode('ascii')
return pwdhash == stored_password