def genkey(instid): data = json.loads(request.data) user = session.query(User).filter_by(id=instid).first() if not user: return "User not found", 404 # should eventually perform check in password complexity if data.has_key('name') and data['name']: key = APIKey() key.name = data['name'] key.user = user token = maketoken() key.token = token #encrypt later session.add(key) session.commit() return json.dumps({'token':token}) else: return "missing key name", 400
def init_database(dbengine, session): """initialize database""" Base.metadata.create_all(dbengine) session.expire_all() # init roles and test users # this should go somewhere else later for role in ['Admin','Instrument','Time Series', 'API']: if not session.query(Role).filter_by(name=role).count(): r = Role(name=role) session.add(r) session.commit() if not session.query(User).filter_by(email='*****@*****.**').count(): u = User( first_name='Test', last_name='Admin', email='*****@*****.**', username='******', password=user_manager.hash_password('12345678'), is_enabled=True) r = session.query(Role).filter_by(name='Admin').first() u.roles.append(r) session.add(u) session.commit() if not session.query(User).filter_by(email='*****@*****.**').count(): u = User( first_name='Test', last_name='User', email='*****@*****.**', username='******', password=user_manager.hash_password('12345678'), is_enabled=True) session.add(u) session.commit()