summaryrefslogtreecommitdiff
path: root/docs/tutorials/wiki/src/authorization
diff options
context:
space:
mode:
authorMartin <martin.frlin@gmail.com>2016-12-06 16:36:56 +0100
committerMartin <martin.frlin@gmail.com>2016-12-06 16:36:56 +0100
commitb01a0233aa03b4b5a9ddd640a7a114f68d1c763d (patch)
tree150c06b1dc6b4b05cef403d5ef9280acedf5756e /docs/tutorials/wiki/src/authorization
parent0705eeaa820b32a4c3f2a05df21e99077586cf5e (diff)
downloadpyramid-b01a0233aa03b4b5a9ddd640a7a114f68d1c763d.tar.gz
pyramid-b01a0233aa03b4b5a9ddd640a7a114f68d1c763d.tar.bz2
pyramid-b01a0233aa03b4b5a9ddd640a7a114f68d1c763d.zip
Changed wiki tutorial to showcase passwrd hashing with bcrypt. Relates to #2204
Diffstat (limited to 'docs/tutorials/wiki/src/authorization')
-rw-r--r--docs/tutorials/wiki/src/authorization/setup.py1
-rw-r--r--docs/tutorials/wiki/src/authorization/tutorial/security.py15
-rw-r--r--docs/tutorials/wiki/src/authorization/tutorial/views.py4
3 files changed, 16 insertions, 4 deletions
diff --git a/docs/tutorials/wiki/src/authorization/setup.py b/docs/tutorials/wiki/src/authorization/setup.py
index beeed75c9..68e3c0abd 100644
--- a/docs/tutorials/wiki/src/authorization/setup.py
+++ b/docs/tutorials/wiki/src/authorization/setup.py
@@ -18,6 +18,7 @@ requires = [
'ZODB3',
'waitress',
'docutils',
+ 'bcrypt',
]
tests_require = [
diff --git a/docs/tutorials/wiki/src/authorization/tutorial/security.py b/docs/tutorials/wiki/src/authorization/tutorial/security.py
index d88c9c71f..4115c780c 100644
--- a/docs/tutorials/wiki/src/authorization/tutorial/security.py
+++ b/docs/tutorials/wiki/src/authorization/tutorial/security.py
@@ -1,5 +1,16 @@
-USERS = {'editor':'editor',
- 'viewer':'viewer'}
+import bcrypt
+
+
+def hash_password(pw):
+ return bcrypt.hashpw(pw.encode('utf-8'), bcrypt.gensalt())
+
+def check_password(expected_hash, pw):
+ if expected_hash is not None:
+ return bcrypt.checkpw(pw.encode('utf-8'), expected_hash)
+ return False
+
+USERS = {'editor': hash_password('editor'),
+ 'viewer': hash_password('viewer')}
GROUPS = {'editor':['group:editors']}
def groupfinder(userid, request):
diff --git a/docs/tutorials/wiki/src/authorization/tutorial/views.py b/docs/tutorials/wiki/src/authorization/tutorial/views.py
index c271d2cc1..e4560dfe1 100644
--- a/docs/tutorials/wiki/src/authorization/tutorial/views.py
+++ b/docs/tutorials/wiki/src/authorization/tutorial/views.py
@@ -14,7 +14,7 @@ from pyramid.security import (
)
-from .security import USERS
+from .security import USERS, check_password
from .models import Page
# regular expression used to find WikiWords
@@ -94,7 +94,7 @@ def login(request):
if 'form.submitted' in request.params:
login = request.params['login']
password = request.params['password']
- if USERS.get(login) == password:
+ if check_password(USERS.get(login), password):
headers = remember(request, login)
return HTTPFound(location=came_from,
headers=headers)