Show More
@@ -2,7 +2,7 | |||
|
2 | 2 | # encoding: utf-8 |
|
3 | 3 | # authentication and permission libraries |
|
4 | 4 | # Copyright (C) 2009-2010 Marcin Kuzminski <marcin@python-works.com> |
|
5 | ||
|
5 | # | |
|
6 | 6 | # This program is free software; you can redistribute it and/or |
|
7 | 7 | # modify it under the terms of the GNU General Public License |
|
8 | 8 | # as published by the Free Software Foundation; version 2 |
@@ -17,13 +17,7 | |||
|
17 | 17 | # along with this program; if not, write to the Free Software |
|
18 | 18 | # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, |
|
19 | 19 | # MA 02110-1301, USA. |
|
20 | """ | |
|
21 | Created on April 4, 2010 | |
|
22 | ||
|
23 | @author: marcink | |
|
24 | """ | |
|
25 | 20 | from beaker.cache import cache_region |
|
26 | from functools import wraps | |
|
27 | 21 | from pylons import config, session, url, request |
|
28 | 22 | from pylons.controllers.util import abort, redirect |
|
29 | 23 | from pylons_app.lib.utils import get_repo_slug |
@@ -32,7 +26,13 from pylons_app.model.db import User, Re | |||
|
32 | 26 | from sqlalchemy.exc import OperationalError |
|
33 | 27 | from sqlalchemy.orm.exc import NoResultFound, MultipleResultsFound |
|
34 | 28 | import crypt |
|
29 | from decorator import decorator | |
|
35 | 30 | import logging |
|
31 | """ | |
|
32 | Created on April 4, 2010 | |
|
33 | ||
|
34 | @author: marcink | |
|
35 | """ | |
|
36 | 36 | |
|
37 | 37 | log = logging.getLogger(__name__) |
|
38 | 38 | |
@@ -146,7 +146,7 def fill_perms(user): | |||
|
146 | 146 | user.permissions['repositories'][perm.Repo2Perm.repository.repo_name] = p |
|
147 | 147 | |
|
148 | 148 | else: |
|
149 | user.permissions['global'].add('') | |
|
149 | user.permissions['global'].add('repository.create') | |
|
150 | 150 | for perm in default_perms: |
|
151 | 151 | if perm.Repository.private: |
|
152 | 152 | #disable defaults for private repos, |
@@ -192,29 +192,24 def get_user(session): | |||
|
192 | 192 | # CHECK DECORATORS |
|
193 | 193 | #=============================================================================== |
|
194 | 194 | class LoginRequired(object): |
|
195 | """ | |
|
196 | Must be logged in to execute this function else redirect to login page | |
|
197 | """ | |
|
195 | """Must be logged in to execute this function else redirect to login page""" | |
|
198 | 196 | |
|
199 | 197 | def __call__(self, func): |
|
200 | @wraps(func) | |
|
201 | def _wrapper(*fargs, **fkwargs): | |
|
198 | return decorator(self.__wrapper, func) | |
|
199 | ||
|
200 | def __wrapper(self, func, *fargs, **fkwargs): | |
|
202 | 201 |
|
|
203 | 202 |
|
|
204 | 203 |
|
|
205 | 204 |
|
|
206 |
|
|
|
205 | return func(*fargs, **fkwargs) | |
|
207 | 206 |
|
|
208 | 207 |
|
|
209 | 208 |
|
|
210 | 209 |
|
|
211 | 210 | |
|
212 | return _wrapper | |
|
213 | ||
|
214 | 211 | class PermsDecorator(object): |
|
215 | """ | |
|
216 | Base class for decorators | |
|
217 | """ | |
|
212 | """Base class for decorators""" | |
|
218 | 213 | |
|
219 | 214 | def __init__(self, *required_perms): |
|
220 | 215 | available_perms = config['available_permissions'] |
@@ -225,33 +220,37 class PermsDecorator(object): | |||
|
225 | 220 | self.user_perms = None |
|
226 | 221 | |
|
227 | 222 | def __call__(self, func): |
|
228 | @wraps(func) | |
|
229 | def _wrapper(*fargs, **fkwargs): | |
|
223 | return decorator(self.__wrapper, func) | |
|
224 | ||
|
225 | ||
|
226 | def __wrapper(self, func, *fargs, **fkwargs): | |
|
227 | # _wrapper.__name__ = func.__name__ | |
|
228 | # _wrapper.__dict__.update(func.__dict__) | |
|
229 | # _wrapper.__doc__ = func.__doc__ | |
|
230 | ||
|
230 | 231 |
|
|
231 | 232 |
|
|
232 | 233 |
|
|
233 | 234 |
|
|
234 | 235 |
|
|
235 | 236 |
|
|
236 | return func(*fargs) | |
|
237 | ||
|
238 | return func(*fargs, **fkwargs) | |
|
237 | 239 |
|
|
238 | 240 |
|
|
239 | 241 |
|
|
240 | 242 |
|
|
241 | 243 |
|
|
242 | return _wrapper | |
|
244 | ||
|
243 | 245 | |
|
244 | 246 | |
|
245 | 247 | def check_permissions(self): |
|
246 | """ | |
|
247 | Dummy function for overriding | |
|
248 | """ | |
|
248 | """Dummy function for overriding""" | |
|
249 | 249 | raise Exception('You have to write this function in child class') |
|
250 | 250 | |
|
251 | 251 | class HasPermissionAllDecorator(PermsDecorator): |
|
252 | """ | |
|
253 | Checks for access permission for all given predicates. All of them have to | |
|
254 | be meet in order to fulfill the request | |
|
252 | """Checks for access permission for all given predicates. All of them | |
|
253 | have to be meet in order to fulfill the request | |
|
255 | 254 | """ |
|
256 | 255 | |
|
257 | 256 | def check_permissions(self): |
@@ -261,8 +260,7 class HasPermissionAllDecorator(PermsDec | |||
|
261 | 260 | |
|
262 | 261 | |
|
263 | 262 | class HasPermissionAnyDecorator(PermsDecorator): |
|
264 | """ | |
|
265 | Checks for access permission for any of given predicates. In order to | |
|
263 | """Checks for access permission for any of given predicates. In order to | |
|
266 | 264 | fulfill the request any of predicates must be meet |
|
267 | 265 | """ |
|
268 | 266 | |
@@ -272,8 +270,7 class HasPermissionAnyDecorator(PermsDec | |||
|
272 | 270 | return False |
|
273 | 271 | |
|
274 | 272 | class HasRepoPermissionAllDecorator(PermsDecorator): |
|
275 | """ | |
|
276 | Checks for access permission for all given predicates for specific | |
|
273 | """Checks for access permission for all given predicates for specific | |
|
277 | 274 | repository. All of them have to be meet in order to fulfill the request |
|
278 | 275 | """ |
|
279 | 276 | |
@@ -289,8 +286,7 class HasRepoPermissionAllDecorator(Perm | |||
|
289 | 286 | |
|
290 | 287 | |
|
291 | 288 | class HasRepoPermissionAnyDecorator(PermsDecorator): |
|
292 | """ | |
|
293 | Checks for access permission for any of given predicates for specific | |
|
289 | """Checks for access permission for any of given predicates for specific | |
|
294 | 290 | repository. In order to fulfill the request any of predicates must be meet |
|
295 | 291 | """ |
|
296 | 292 | |
@@ -309,9 +305,7 class HasRepoPermissionAnyDecorator(Perm | |||
|
309 | 305 | #=============================================================================== |
|
310 | 306 | |
|
311 | 307 | class PermsFunction(object): |
|
312 | """ | |
|
313 | Base function for other check functions | |
|
314 | """ | |
|
308 | """Base function for other check functions""" | |
|
315 | 309 | |
|
316 | 310 | def __init__(self, *perms): |
|
317 | 311 | available_perms = config['available_permissions'] |
@@ -343,9 +337,7 class PermsFunction(object): | |||
|
343 | 337 | return False |
|
344 | 338 | |
|
345 | 339 | def check_permissions(self): |
|
346 | """ | |
|
347 | Dummy function for overriding | |
|
348 | """ | |
|
340 | """Dummy function for overriding""" | |
|
349 | 341 | raise Exception('You have to write this function in child class') |
|
350 | 342 | |
|
351 | 343 | class HasPermissionAll(PermsFunction): |
@@ -382,7 +374,6 class HasRepoPermissionAll(PermsFunction | |||
|
382 | 374 | |
|
383 | 375 | class HasRepoPermissionAny(PermsFunction): |
|
384 | 376 | |
|
385 | ||
|
386 | 377 | def __call__(self, repo_name=None, check_Location=''): |
|
387 | 378 | self.repo_name = repo_name |
|
388 | 379 | return super(HasRepoPermissionAny, self).__call__(check_Location) |
General Comments 0
You need to be logged in to leave comments.
Login now