extensions.py 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. #!/usr/bin/env python
  2. # -*- coding=UTF-8 -*-
  3. # **************************************************************************
  4. # Copyright © 2016 jianglin
  5. # File Name: extensions.py
  6. # Author: jianglin
  7. # Email: xiyang0807@gmail.com
  8. # Created: 2016-05-20 13:02:50 (CST)
  9. # Last Update:星期日 2016-7-24 21:51:35 (CST)
  10. # By:
  11. # Description:
  12. # **************************************************************************
  13. from flask import request, g
  14. from flask.json import JSONEncoder
  15. from flask_wtf.csrf import CsrfProtect
  16. from flask_maple import Bootstrap, Error, Captcha
  17. from flask_login import LoginManager
  18. from flask_babelex import Babel
  19. from flask_babelex import lazy_gettext as _
  20. from flask_mail import Mail
  21. from flask_principal import Principal
  22. from flask_avatar import Avatar
  23. from flask_cache import Cache
  24. from flask_maple_rbac import Rbac
  25. from redis import StrictRedis
  26. def register_avatar(app):
  27. Avatar(app)
  28. def register_form(app):
  29. csrf = CsrfProtect()
  30. csrf.init_app(app)
  31. def register_rbac(app):
  32. from maple.user.models import Role
  33. from maple.permission.models import Route, Permiss
  34. from flask_login import current_user
  35. rbac = Rbac(app,
  36. role_model=Role,
  37. route_model=Route,
  38. permission_model=Permiss,
  39. user_loader=current_user,
  40. skip_startswith_rules=['/admin', '/static'],
  41. skip_rules=['topic.topic', 'static_from_root', 'avatar',
  42. 'upload.avatar_file'])
  43. return rbac
  44. def register_babel(app):
  45. babel = Babel()
  46. babel.init_app(app)
  47. class CustomJSONEncoder(JSONEncoder):
  48. """This class adds support for lazy translation texts to Flask's
  49. JSON encoder. This is necessary when flashing translated texts."""
  50. def default(self, obj):
  51. from speaklater import is_lazy_string
  52. if is_lazy_string(obj):
  53. try:
  54. return unicode(obj) # python 2
  55. except NameError:
  56. return str(obj) # python 3
  57. return super(CustomJSONEncoder, self).default(obj)
  58. app.json_encoder = CustomJSONEncoder
  59. @babel.localeselector
  60. def get_locale():
  61. # return 'zh'
  62. user = getattr(g, 'user', None)
  63. if user is not None:
  64. if g.user.is_authenticated:
  65. return user.setting.locale or 'zh'
  66. return request.accept_languages.best_match(app.config[
  67. 'LANGUAGES'].keys())
  68. @babel.timezoneselector
  69. def get_timezone():
  70. user = getattr(g, 'user', None)
  71. if user is not None:
  72. if g.user.is_authenticated:
  73. return user.setting.timezone or 'UTC'
  74. return 'UTC'
  75. def register_maple(app):
  76. Bootstrap(app,
  77. css=('styles/monokai.css', 'styles/mine.css',
  78. 'tags/css/bootstrap-tokenfield.css'),
  79. js=('styles/upload.js', 'styles/forums.js', 'styles/mine.js',
  80. 'styles/topic.js', 'tags/bootstrap-tokenfield.min.js'),
  81. use_auth=True)
  82. Captcha(app)
  83. Error(app)
  84. def register_redis(app):
  85. redis_data = StrictRedis(db=app.config['CACHE_REDIS_DB'],
  86. password=app.config['CACHE_REDIS_PASSWORD'],
  87. decode_responses=True)
  88. return redis_data
  89. def register_cache(app):
  90. cache = Cache(config={'CACHE_TYPE': 'null'})
  91. cache.init_app(app)
  92. return cache
  93. def register_mail(app):
  94. mail = Mail()
  95. mail.init_app(app)
  96. return mail
  97. def register_login(app):
  98. login_manager = LoginManager()
  99. login_manager.init_app(app)
  100. login_manager.login_view = "auth.login"
  101. login_manager.session_protection = "strong"
  102. login_manager.login_message = _("Please login to access this page.")
  103. # login_manager.anonymous_user = Anonymous
  104. from maple.user.models import User
  105. # @login_manager.token_loader
  106. # def load_token(token):
  107. # max_age = app.config["REMEMBER_COOKIE_DURATION"].total_seconds()
  108. # data = login_serializer.loads(token, max_age=max_age)
  109. # user = User.load_by_name(data[0])
  110. # if user and data[1] == user.password:
  111. # return user
  112. # return None
  113. @login_manager.user_loader
  114. def user_loader(id):
  115. user = User.query.get(int(id))
  116. return user
  117. return login_manager
  118. def register_principal(app):
  119. principal = Principal()
  120. principal.init_app(app)
  121. def register_jinja2(app):
  122. from maple.main.records import load_online_users
  123. from .filters import Filters, safe_clean
  124. app.jinja_env.globals['Title'] = Filters.Title
  125. app.jinja_env.globals['hot_tags'] = Filters.hot_tags
  126. app.jinja_env.globals['recent_tags'] = Filters.recent_tags
  127. app.jinja_env.globals['notice_count'] = Filters.notice_count
  128. app.jinja_env.filters['get_last_reply'] = Filters.get_last_reply
  129. app.jinja_env.filters['get_user_infor'] = Filters.get_user_infor
  130. app.jinja_env.filters['get_read_count'] = Filters.get_read_count
  131. app.jinja_env.filters['timesince'] = Filters.timesince
  132. app.jinja_env.filters['get_online_users'] = load_online_users
  133. app.jinja_env.filters['markdown'] = Filters.safe_markdown
  134. app.jinja_env.filters['safe_clean'] = safe_clean
  135. app.jinja_env.filters['is_collected'] = Filters.is_collected