这是我试图通过 XACML/ABAC 实现的一个要求,用于学习目的:
信息模型
资源:建筑、单元
- 有许多建筑物(例如 B1、B2、B3、... Bn)
- 每个建筑物都有许多单元(即单元是建筑物的子单元)(例如 B1U1、B1U2、B1U3...)
主题:家政人员
规则
- 管家可以“打开”一个“单元”,如果
- 他们对该“单元”具有“开放”权限或
- 如果他们对该“单元”所在的“建筑物”拥有“开放”许可。
任何指针?
更新
基本上这是我关心的问题:如果要求类似于,如果她/他对“unitX”具有“打开”权限,则管家可以“打开”“unitX”。在这里,我只写了一个简单的规则。
但是,根据我的实际要求,担心的是:
由于没有一个特定的资源,而是许多相同类型的资源,我应该为每个资源编写单独的策略吗?前任。建立“B1”的单独政策,“B2”的另一个政策等等?
政策将如何“了解”建筑与单元之间的层级关系。
现在我进一步考虑了这一点,我认为以下方法应该可行(?)
- 请求将包括以下内容
资源:/{buildingId}/{unitId} //这是策略将如何知道父子关系
动作:打开
主题:subjectId,可能还有该主题拥有的所有权限(仍在考虑如何表示权限,有什么建议吗?)
- 使用规则定义一个策略: // 伪代码 if(subject.permissions include open on {buildingId} OR open on {unitId}) then permit else deny。
有什么建议么?
谢谢,
贾廷