utils.py 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. #-*- coding:utf-8 -*-
  2. import json
  3. import requests
  4. from flask import g, redirect, session
  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(msg="please login first", redir=""):
  11. def _(f):
  12. @wraps(f)
  13. def __(*a, **kw):
  14. if not g.user:
  15. if redir:
  16. return redirect(redir or "/")
  17. else:
  18. return json.dumps({"msg": msg})
  19. return f(*a, **kw)
  20. return __
  21. return _
  22. def set_user_cookie(user_token, session_):
  23. if not user_token:
  24. return None
  25. session_[config.SITE_COOKIE] = "%s:%s" % (user_token.name, user_token.sig)
  26. def clear_user_cookie(session_):
  27. session_[config.SITE_COOKIE] = ""
  28. def get_usertoken_from_session(session_):
  29. if config.SITE_COOKIE in session_:
  30. cookies = session_[config.SITE_COOKIE]
  31. if not cookies:
  32. return None
  33. name, sig = cookies.split(":")
  34. return UserToken(name, sig)
  35. def get_current_user_profile(user_token):
  36. if not user_token:
  37. return
  38. h = {"Content-type": "application/json"}
  39. r = corelib.auth_requests(user_token, "GET", "%s/user/current" %config.API_ADDR, headers=h)
  40. if r.status_code != 200:
  41. return
  42. j = r.json()
  43. return User(j["id"], j["name"], j["cnname"], j["email"], j["phone"], j["im"], j["qq"], j["role"])
  44. def logout_user(user_token):
  45. if not user_token:
  46. return
  47. r = auth_requests(user_token, "POST", "%s/user/logout" %config.API_ADDR)
  48. if r.status_code != 200:
  49. raise Exception("%s:%s", r.status_code, r.text)
  50. clear_user_cookie(session)
  51. def login_user(name, password):
  52. params = {
  53. "name": name,
  54. "password": password,
  55. }
  56. r = requests.post("%s/user/login" %config.API_ADDR, data=params)
  57. if r.status_code != 200:
  58. raise Exception("{} : {}".format(r.status_code, r.text))
  59. j = r.json()
  60. ut = UserToken(j["name"], j["sig"])
  61. set_user_cookie(ut, session)
  62. return ut