diff options
| author | 2018-03-29 09:56:24 +0100 | |
|---|---|---|
| committer | 2018-03-29 09:56:24 +0100 | |
| commit | 5fcd1647e5f8f55240492b6df3b3ff15bab86bf7 (patch) | |
| tree | 63c348feb999ca358716ebd9f08b0f5259d68ad1 /pysite/mixins.py | |
| parent | Make flake8 happier (diff) | |
| parent | Oauth (#45) (diff) | |
Merge remote-tracking branch 'origin/master'
Diffstat (limited to 'pysite/mixins.py')
| -rw-r--r-- | pysite/mixins.py | 48 | 
1 files changed, 47 insertions, 1 deletions
| diff --git a/pysite/mixins.py b/pysite/mixins.py index 059f871d..5b1a780f 100644 --- a/pysite/mixins.py +++ b/pysite/mixins.py @@ -6,7 +6,7 @@ from _weakref import ref  from pysite.database import RethinkDB -class DBMixin(): +class DBMixin:      """      Mixin for classes that make use of RethinkDB. It can automatically create a table with the specified primary      key using the attributes set at class-level. @@ -59,3 +59,49 @@ class DBMixin():      @property      def db(self) -> RethinkDB:          return self._db() + + +class OauthMixin: +    """ +    Mixin for the classes that need access to a logged in user's information. This class should be used +    to grant route's access to user information, such as name, email, id, ect. + +    There will almost never be a need for someone to inherit this, as BaseView does that for you. + +    This class will add 3 properties to your route: + +        * logged_in (bool): True if user is registered with the site, False else wise. + +        * user_data (dict): A dict that looks like this: + +        { +            "user_id": Their discord ID, +            "username": Their discord username (without discriminator), +            "discriminator": Their discord discriminator, +            "email": Their email, in which is connected to discord +        } + +        user_data returns None, if the user isn't logged in. + +        * oauth (OauthBackend): The instance of pysite.oauth.OauthBackend, connected to the RouteManager. +    """ + +    @classmethod +    def setup(cls: "OauthMixin", manager: "pysite.route_manager.RouteManager", blueprint: Blueprint): + +        if hasattr(super(), "setup"): +            super().setup(manager, blueprint)  # pragma: no cover + +        cls._oauth = ref(manager.oauth_backend) + +    @property +    def logged_in(self) -> bool: +        return self.user_data is not None + +    @property +    def user_data(self) -> dict: +        return self.oauth.user_data() + +    @property +    def oauth(self): +        return self._oauth() | 
