- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有一个简单的根资源工厂:
class Root:
__acl__ = [
(Allow, Authenticated, 'edit')
]
现在对于一些“特殊”的路由,我需要创建另一个资源工厂
config.add_route('special', '/special/test', factory=SpecialFactory)
class SpecialFactory:
__acl__ = [
(Allow, Authenticated, 'special_edit')
]
现在,我想让 Root
成为 SpecialFactory
的父级——我应该怎么做?
这是正确的方法吗...
class SpecialFactory:
def __init__(self, request):
self.request = request
self.__parent__ = Root(request)
self.__name__ = 'special'
__acl__ = [
(Allow, Authenticated, 'special_edit')
]
我也不完全理解 __name__
的用途以及它应该设置成什么。
此外,Pyramid 何时遍历 __parent__
链,何时不遍历?对于这样的 View 配置:
@view_config(route_name='special', permission='special_edit')
def something(req):
pass
Pyramid 会“收集”两种权限(special_edit
和edit
)还是只收集一种(special_edit
)?
请详细解释计算权限的“流程”。
最佳答案
__name__
仅在通过遍历生成 url 时才会考虑,所以不用担心。
首先,工厂参数是一个工厂。意思是,它是接受 request
对象的“某个对象”,并期望接收回一个实际上是树根的对象。
class Root:
def __init__(self, request):
self.request = request
def resource_factory(request):
return Root(request)
add_route(..., factory=resource_factory)
请注意,这里的工厂很明显。一个常用的捷径是利用这样一个事实,即构造一个对象的实例实际上会返回它自己。所以 Root(request)
从外面看起来完全一样,并返回与 resource_factory(request)
相同的对象。
太好了,现在我们有了一个“根”对象,我们可以从中开始遍历。当然,这不一定是树的实际根,它只是遍历的起点。
您还没有向 add_route
添加 traverse
参数,因此遍历不会去任何地方,它只会返回根对象作为上下文。查找上下文对象是遍历练习的全部目标。
所以,现在我们有了上下文。是的。
Pyramid 的授权通过将用户的“有效委托(delegate)人”、“上下文”和“许可”相结合来工作。这三件事是您的授权策略将用来确定是否允许或拒绝操作的内容。
“有效委托(delegate)人”来自身份验证策略,代表请求背后的用户。
“上下文”和“权限”随心所欲。在大多数情况下,它们是 request.context
和 View 的权限,但是 pyramid.security.has_permission()
可以接受任何上下文对象和任何权限,并返回允许或拒绝结果。
因此,我们已经获得了授权所需的 3 项内容。现在,如何授权?好吧,这取决于授权策略。默认情况下,ACLAuthorizationPolicy
。那么它是如何工作的呢?
ACLAuthorizationPolicy
从 context
开始,并通过该对象的“沿袭”向后移动。 “沿袭”定义为通过跟随每个对象的 __parent__
回到末尾而创建的列表,其中没有更多的 __parent__
可以跟随。因此,在您的示例中,上下文将是 SpecialFactory
的一个实例,上下文的“沿袭”是列表 [ SpecialFactory(request), Root(request) ]
.
ACL 匹配的工作方式(在 ACLAuthorizationPolicy
中)是它遍历沿袭中的每个对象,从上下文回到根,在中搜索每个对象的 __acl__
命令。它找到的第一场比赛是赢家。 ACL 中的条目由“(Allow
or Deny
, principal
, permission
)”定义,匹配项是ACL 中包含我们正在寻找的相同权限的条目,因为委托(delegate)人与当前用户的有效委托(delegate)人列表中的委托(delegate)人之一相匹配。一旦找到匹配项,搜索就会停止并返回结果。
如果此算法对您不起作用,请更换授权策略。它是高度可插拔的,默认实现很容易理解(总共只有几行代码)。您甚至可以制定完全不关心上下文的自己的策略,此时您可以忽略所有这些遍历废话。这取决于你。
关于python - Pyramid :多个资源工厂——如何,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16169590/
有人告诉我,如果我只有一个“东西”,比如家(不是多个家),我应该在 routes.rb 中使用资源 :home,而不是资源 :home。但是当我查看路由时,POST 函数似乎想要 home#creat
Activity 开始。这些代码框架顺利通过。 // Initialize array adapters. One for already paired devices and //
资源 search-hadoop.com search-hadoop.com索引所有邮件列表,非常适合历史搜索。当你遇到问题时首先在这里搜索,因为很可能有人已经遇到了你的问题。 邮件列表 在A
我是 WPF 的新手,正在努力使用位于单独程序集中的样式。这就是我正在做的:- 我有一个带有\Themes 文件夹的类库项目,其中包含一个“generic.xaml”,它合并了\Themes 内的子文
我正在编写一个使用虚拟树状文件结构的插件。基本上它就像一个包含文件的标准文件系统,区别在于这些文件实际上并不存在于文件系统中的特定位置,而只是 java 对象。 这些当前由使用 SettingProv
如果我在 XAML 中使用以下内容,我会收到错误消息: 错
我正在使用 laravel 资源来获取 api 的数据: return [ 'id' => $this->id, 'unread' =>
我有以下 pom.xml: 4.0.0 mycompany resource-fail 0.0.1-SNAPSHOT BazBat
许多GDI +类都实现IDisposable,但是我不确定何时应该调用Dispose。对于使用new或静态方法(例如Graphics.CreateGraphics)创建的实例来说,这很明显。但是,由属
我正在构建一组 RESTful 资源,其工作方式如下:(我将使用“people”作为示例): 获取/people/{key} - 返回一个人对象 (JSON) GET/people?first_nam
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
我有一个使用 $resource 的简单 Controller : var Regions = $resource('mocks/regions.json'); $scope.regions =
在 Azure 门户中,如何查看不同资源之间的依赖关系。我特别想查看哪些资源正在使用我要删除的存储。 最佳答案 您可以使用应用程序洞察应用程序 map 来执行此操作: 您还可以打开存储帐户的日志记录:
我正在使用 ionic 生成资源(图标和启动画面)。我正在使用 ionic v2.1.0 和 cordova v6.4.0。 到目前为止我一直在使用(它在以前的版本中工作): cordova plat
是否可以使用 Assets 包含子文件夹中的文件? 示例:[base_url]/assets/css/pepper-grinder/jquery-ui-1.8.11.custom.min.css 最佳
我正在阅读一些尝试教授 Android 开发的书。在书中,作者概述了 res/下的一些目录。他提到 res/menu 包含基于 XML 的菜单规范。他还提到了保存“通用文件”的 res/raw。当我创
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 9 年前。 Improv
我在服务器上使用 express-resource。在我的 AngularJS Controller 中: var User = $resource('/services/users/:use
因此,每当我运行我的应用程序时,它都会立即崩溃并给出以下错误: No package identifier when getting value for resource number 0x00000
对于我正在创建的(网络)应用程序,我需要使用基本身份验证在我的 UIWebView 中加载页面。 现在设置我使用的授权 header : NSString *result = [NSString st
我是一名优秀的程序员,十分优秀!