diff options
author | Philip Paquette <pcpaquette@gmail.com> | 2018-09-26 07:48:55 -0400 |
---|---|---|
committer | Philip Paquette <pcpaquette@gmail.com> | 2019-04-18 11:14:24 -0400 |
commit | 6187faf20384b0c5a4966343b2d4ca47f8b11e45 (patch) | |
tree | 151ccd21aea20180432c13fe4b58240d3d9e98b6 /diplomacy/server/user.py | |
parent | 96b7e2c03ed98705754f13ae8efa808b948ee3a8 (diff) |
Release v1.0.0 - Diplomacy Game Engine - AGPL v3+ License
Diffstat (limited to 'diplomacy/server/user.py')
-rw-r--r-- | diplomacy/server/user.py | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/diplomacy/server/user.py b/diplomacy/server/user.py new file mode 100644 index 0000000..cfb6ad4 --- /dev/null +++ b/diplomacy/server/user.py @@ -0,0 +1,37 @@ +# ============================================================================== +# Copyright (C) 2019 - Philip Paquette, Steven Bocco +# +# This program is free software: you can redistribute it and/or modify it under +# the terms of the GNU Affero General Public License as published by the Free +# Software Foundation, either version 3 of the License, or (at your option) any +# later version. +# +# This program is distributed in the hope that it will be useful, but WITHOUT +# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS +# FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more +# details. +# +# You should have received a copy of the GNU Affero General Public License along +# with this program. If not, see <https://www.gnu.org/licenses/>. +# ============================================================================== +""" User object, defined with a username and a hashed password. """ +from diplomacy.utils import strings +from diplomacy.utils.common import is_valid_password +from diplomacy.utils.jsonable import Jsonable + +class User(Jsonable): + """ User class. """ + __slots__ = ['username', 'password_hash'] + model = { + strings.USERNAME: str, + strings.PASSWORD_HASH: str + } + + def __init__(self, **kwargs): + self.username = None + self.password_hash = None + super(User, self).__init__(**kwargs) + + def is_valid_password(self, password): + """ Return True if given password matches user hashed password. """ + return is_valid_password(password, self.password_hash) |