utils.py 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. #-*- coding:utf-8 -*-
  2. import json
  3. import requests
  4. from flask import g, redirect, session, abort
  5. from functools import wraps
  6. from rrd import config
  7. from rrd import corelib
  8. from rrd.utils import randbytes
  9. from rrd.model.user import User, UserToken
  10. def require_login(redir="/auth/login"):
  11. def _(f):
  12. @wraps(f)
  13. def __(*a, **kw):
  14. if not g.user:
  15. return redirect(redir or "/auth/login")
  16. return f(*a, **kw)
  17. return __
  18. return _
  19. def require_login_abort(status_code=403, msg="login first"):
  20. def _(f):
  21. @wraps(f)
  22. def __(*a, **kw):
  23. if not g.user:
  24. return abort(status_code, msg)
  25. return f(*a, **kw)
  26. return __
  27. return _
  28. def require_login_json(json_msg={"ok":False, "msg":"login first"}):
  29. def _(f):
  30. @wraps(f)
  31. def __(*a, **kw):
  32. if not g.user:
  33. return json.dumps(json_msg)
  34. return f(*a, **kw)
  35. return __
  36. return _
  37. def set_user_cookie(user_token, session_):
  38. if not user_token:
  39. return None
  40. session_[config.SITE_COOKIE] = "%s:%s" % (user_token.name, user_token.sig)
  41. def clear_user_cookie(session_):
  42. session_[config.SITE_COOKIE] = ""
  43. def get_usertoken_from_session(session_):
  44. if config.SITE_COOKIE in session_:
  45. cookies = session_[config.SITE_COOKIE]
  46. if not cookies:
  47. return None
  48. name, sig = cookies.split(":")
  49. return UserToken(name, sig)
  50. def get_current_user_profile(user_token):
  51. if not user_token:
  52. return
  53. h = {"Content-type": "application/json"}
  54. r = corelib.auth_requests("GET", "%s/user/current" %config.API_ADDR, headers=h)
  55. if r.status_code != 200:
  56. return
  57. j = r.json()
  58. return User(j["id"], j["name"], j["cnname"], j["email"], j["phone"], j["im"], j["qq"], j["role"])
  59. def logout_user(user_token):
  60. if not user_token:
  61. return
  62. r = corelib.auth_requests("GET", "%s/user/logout" %config.API_ADDR)
  63. if r.status_code != 200:
  64. raise Exception("%s:%s" %(r.status_code, r.text))
  65. clear_user_cookie(session)
  66. def login_user(name, password):
  67. params = {
  68. "name": name,
  69. "password": password,
  70. }
  71. r = requests.post("%s/user/login" %config.API_ADDR, data=params)
  72. if r.status_code != 200:
  73. raise Exception("{} : {}".format(r.status_code, r.text))
  74. j = r.json()
  75. ut = UserToken(j["name"], j["sig"])
  76. set_user_cookie(ut, session)
  77. return ut