utils.py 2.6 KB

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