controller.py 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. import json
  2. from bottle import request, response
  3. import model
  4. def missing_attributes(attrs):
  5. for attr in attrs:
  6. if attr not in request.json:
  7. return attr
  8. else:
  9. return False
  10. def login():
  11. missing = missing_attributes(['username', 'password'])
  12. if missing:
  13. return bad_request('Missing value for attribute ' + str(missing))
  14. username = request.json['username']
  15. password = request.json['password']
  16. session_id = model.login(username, password)
  17. if session_id:
  18. return {'session_id': session_id}
  19. else:
  20. return forbidden('Invalid login data')
  21. def register():
  22. missing = missing_attributes(['username', 'password'])
  23. if missing:
  24. return bad_request('Missing value for attribute ' + str(missing))
  25. username = request.json['username']
  26. password = request.json['password']
  27. if model.user_exists(username):
  28. return forbidden('User already exists.')
  29. model.register(username, password)
  30. return {'message': "successfully registered user"}
  31. def not_found(msg=None):
  32. response.status = 404
  33. response.content_type = 'application/json'
  34. if msg is None:
  35. return json.dumps({"error": "404: Page not found"})
  36. else:
  37. return json.dumps({"error": "404: Page not found: " + msg})
  38. def forbidden(msg=None):
  39. response.status = 403
  40. response.content_type = 'application/json'
  41. if msg is None:
  42. return json.dumps({"error": "403: Forbidden"})
  43. else:
  44. return json.dumps({"error": "403: Forbidden: " + msg})
  45. def bad_request(msg=None):
  46. response.status = 400
  47. response.content_type = 'application/json'
  48. if msg is None:
  49. return json.dumps({"error": "400: Bad request"})
  50. else:
  51. return json.dumps({"error": "400: Bad request: " + msg})