Files
@ e6c802a8dede
Branch filter:
Location: kallithea/pylons_app/controllers/users.py - annotation
e6c802a8dede
3.6 KiB
text/x-python
repo edit
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 | f6ac79182600 f6ac79182600 f6ac79182600 f6ac79182600 f6ac79182600 f6ac79182600 3ada2f409c1c 3ada2f409c1c 73f413946c14 25e516447a33 f6ac79182600 f6ac79182600 f6ac79182600 f6ac79182600 f6ac79182600 f6ac79182600 f6ac79182600 73f413946c14 f6ac79182600 f6ac79182600 f6ac79182600 b68b2246e5a6 f6ac79182600 f6ac79182600 f6ac79182600 f6ac79182600 8e250e86a670 3ada2f409c1c 20dc7a5eb748 f6ac79182600 f6ac79182600 f6ac79182600 f6ac79182600 73f413946c14 f6ac79182600 73f413946c14 73f413946c14 73f413946c14 73f413946c14 73f413946c14 73f413946c14 73f413946c14 73f413946c14 73f413946c14 73f413946c14 73f413946c14 73f413946c14 73f413946c14 73f413946c14 f6ac79182600 f6ac79182600 f6ac79182600 20dc7a5eb748 f6ac79182600 f6ac79182600 f6ac79182600 f6ac79182600 f6ac79182600 f6ac79182600 f6ac79182600 f6ac79182600 f6ac79182600 73f413946c14 f6ac79182600 73f413946c14 73f413946c14 3f65447f6c02 73f413946c14 73f413946c14 73f413946c14 73f413946c14 73f413946c14 73f413946c14 73f413946c14 73f413946c14 73f413946c14 73f413946c14 73f413946c14 f6ac79182600 f6ac79182600 f6ac79182600 f6ac79182600 f6ac79182600 f6ac79182600 f6ac79182600 f6ac79182600 8e250e86a670 3ada2f409c1c 3ada2f409c1c 8e250e86a670 3ada2f409c1c 8e250e86a670 8e250e86a670 8e250e86a670 f6ac79182600 f6ac79182600 f6ac79182600 73f413946c14 8e250e86a670 f6ac79182600 f6ac79182600 f6ac79182600 73f413946c14 9a2affee4a45 73f413946c14 20dc7a5eb748 9a2affee4a45 73f413946c14 73f413946c14 73f413946c14 | import logging
from pylons import request, response, session, tmpl_context as c, url, app_globals as g
from pylons.controllers.util import abort, redirect
from pylons_app.lib.base import BaseController, render
from formencode import htmlfill
from pylons_app.model.db import Users, UserLogs
import crypt
log = logging.getLogger(__name__)
class UsersController(BaseController):
"""REST Controller styled on the Atom Publishing Protocol"""
# To properly map this controller, ensure your config/routing.py
# file has a resource setup:
# map.resource('user', 'users')
def __before__(self):
c.admin_user = session.get('admin_user')
c.admin_username = session.get('admin_username')
super(UsersController, self).__before__()
def index(self, format='html'):
"""GET /users: All items in the collection"""
# url('users')
c.users_list = self.sa.query(Users).all()
return render('admin/users/users.html')
def create(self):
"""POST /users: Create a new item"""
# url('users')
params = dict(request.params)
try:
new_user = Users()
new_user.active = params.get('active', False)
new_user.username = params.get('username')
new_user.password = crypt.crypt(params.get('password'), '6a')
new_user.admin = False
self.sa.add(new_user)
self.sa.commit()
except:
self.sa.rollback()
raise
return redirect(url('users'))
def new(self, format='html'):
"""GET /users/new: Form to create a new item"""
# url('new_user')
return render('admin/users/user_add.html')
def update(self, id):
"""PUT /users/id: Update an existing item"""
# Forms posted to this method should contain a hidden field:
# <input type="hidden" name="_method" value="PUT" />
# Or using helpers:
# h.form(url('user', id=ID),
# method='put')
# url('user', id=ID)
params = dict(request.params)
try:
new_user = self.sa.query(Users).get(id)
new_user.active = params.get('active', False)
new_user.username = params.get('username')
if params.get('new_password'):
new_user.password = crypt.crypt(params.get('new_password'), '6a')
self.sa.add(new_user)
self.sa.commit()
except:
self.sa.rollback()
raise
return redirect(url('users'))
def delete(self, id):
"""DELETE /users/id: Delete an existing item"""
# Forms posted to this method should contain a hidden field:
# <input type="hidden" name="_method" value="DELETE" />
# Or using helpers:
# h.form(url('user', id=ID),
# method='delete')
# url('user', id=ID)
try:
self.sa.delete(self.sa.query(Users).get(id))
self.sa.commit()
except:
self.sa.rollback()
raise
return redirect(url('users'))
def show(self, id, format='html'):
"""GET /users/id: Show a specific item"""
# url('user', id=ID)
def edit(self, id, format='html'):
"""GET /users/id/edit: Form to edit an existing item"""
# url('edit_user', id=ID)
c.user = self.sa.query(Users).get(id)
defaults = c.user.__dict__
return htmlfill.render(
render('admin/users/user_edit.html'),
defaults=defaults,
encoding="UTF-8",
force_defaults=False
)
|