⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 auth.py

📁 Network Administration Visualized 网络管理可视化源码
💻 PY
字号:
# -*- coding: ISO8859-1 -*-## Copyright 2003, 2004 Norwegian University of Science and Technology## This file is part of Network Administration Visualized (NAV)## NAV is free software; you can redistribute it and/or modify# it under the terms of the GNU General Public License as published by# the Free Software Foundation; either version 2 of the License, or# (at your option) any later version.## NAV 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 General Public License for more details.## You should have received a copy of the GNU General Public License# along with NAV; if not, write to the Free Software# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA### $Id: auth.py 3387 2006-03-13 10:52:22Z mortenv $# Authors: Morten Vold <morten.vold@itea.ntnu.no>#"""Provides simple authorization API for NAV."""from nav.db import navprofilesimport reADMINGROUP = 1ANONYMOUSGROUP = 2AUTHENTICATEDGROUP = 3def hasPrivilege(user, action, target):    """    Magically resolves whether 'user' has been granted privileges to    perform 'action' on 'target'.  The user parameter may be either    None or an instance of nav.db.navprofiles.Account (e.g. taken from    req.session['user'])    """    if type(user) is navprofiles.Account:        # Verify that the account object already has cached privilege        # data; cache them if not.        try:            user._privDict        except:            user.cachePrivileges()        privileges = user._privDict        groupIds = user._groupList    elif not user:        privileges = {}        groupIds = []    else:        raise "user parameter is of invalid type %s" % type(user)    # If user is a member of the Administrators group, we grant    # him/her any privilege asked for.    if ADMINGROUP in groupIds:        return True    # We don't match the target directly, since this may be open to    # interpretation based on what the action is.  E.g. if the    # action is 'web_access', we must treat the registered targets    # as regular expressions to match against the target that was    # asked for.    # If we know an action needs tailored parsing of the target    # attribute, we provide for that here.  Anything unknown is    # matched as plaintext.    if action == 'web_access' and action in privileges:        return _matchRegexpTarget(target, privileges[action])    else:        return action in privileges and target in privileges[action]def _matchRegexpTarget(target, regexpList):    """Run through a list of regexp expressions and return true if    the target matches any of the regexps in the privilege rows.    """    for r in regexpList:        regexp = re.compile(r)        if regexp.search(target):            return True    return Falsedef cachePrivileges(account):    """Load and cache from the database all privileges associated    with this account"""    from nav.db import navprofiles    groups = account.getChildren(navprofiles.Accountingroup)    groupIds = [int(group.group) for group in groups]    # Make sure the user is always considered a member of the    # Anonymous group.    if ANONYMOUSGROUP not in groupIds: groupIds.append(ANONYMOUSGROUP)    # Make sure an authenticated user is always considered a member    # of the "Authenticated users" group    if account.id > 0: groupIds.append(AUTHENTICATEDGROUP)    groupString = ','.join([str(id) for id in groupIds])    sql = """SELECT DISTINCT action, target             FROM privilegebygroup             WHERE accountgroupid IN (%s)""" % (groupString)    cursor = account.cursor()    cursor.execute(sql)    # Create a dictionary of privileges    privDict = {}    for action, target in cursor.fetchall():        if action not in privDict:            privDict[action] = []        privDict[action].append(target)    # Cache both the privilege dictionary and the group id list in    # the account object    account._groupList = groupIds    account._privDict = privDicttry:    navprofiles.Account.cachePrivilegesexcept:    navprofiles.Account.cachePrivileges = cachePrivileges

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -