|
Portal门户 -
Liferay相关
|
|
Wednesday, 28 May 2008 08:04 |
当前的Liferay权限结构是从4.0版本开始的。jsr168中基于role的权限设计只解决了开发技术层面,并没有和实际的应用关联起来。在Liferay中权限设计有很大的扩展,并可在多个层次进行配置。
首先要解释的是Liferay的权限模型。首先看一下Liferay的定义 A permission is defined as an action acting on a resource 在Liferay中,权限作用是判断当前用户是否允许在Resource上进行某项操作(action)。 Resource代表着一个个的可操作的实体。在Portal系统中,最直观的Resource就是一个个的Portlet。但是由于应用的原 因,在Portlet下还可以根据应用的功能再细分,最典型的就是Message Board Portlet下还分Category和Message两类Resource。这些Resource是很直观的。此外还存在一些特殊的Resource可 以控制,比如每张Page也是Resource。另外由于在Liferay中可以配置多个Community,每个Community都可以多次放置同一 种Portlet作为多个Instance的,所以对于Resource又附加了Scope的概念。Resource有三种Scope: Enterprise、Community和Individual。Enterprise代表整个Portal系统中的一类资源,Community需要 指明是哪个Community下的一类资源,Individual则是独立的Resource。
举个例子,我们要定义一个Permission View+Message Board Topic / Enterprise 上面的定义说明,“查看当前Portal系统中任一个Message Board的Topic”。 再举个例子 Update Message Board Topic / "Developer" Community Scope 上面的定义说明,“修改 Developer 这个 Community 下的任一个 Message Board Topic ”。 在Liferay Portal中所有Portlet都会有默认的View/Configuration Action。其他的Resource和Action都需要开发人员预先设计,并在代码中调用PermissionChecker检验当前用户是否拥有权 限。这是后话,今后在开发相关的文章中再讨论。 如果理解了上面关于Resource、Scope和Action,接下去我们就可以讨论Liferay中如何进行设置,将Permission和User联系起来从而将权限赋予某人。 首先说最简单的Individual类型的Resource的配置方法。如果以管理员身份登录系统,那么在任何一个portlet的右上角都有一个齿轮图标,点击该图标后选择Permissions标签就可进行该portlet得配置。 假设我们以管理员身份登录后切换到support Community,对Message Boards权限进行配置。 新出现的页面第一排中如果选择Users、Organizations、Locations、User Groups,下方还将出现Current和Available。
Current中是当前已经配置的结果,Available是可供选择的人员、机构的列表。 我们选择User->Available->Test HKG 1上打钩。点击Update Permissions。将所有权限都选择到Current下。配置后再查看Users->Current,现在Test HKG 1已经在Current下了。 使用
This e-mail address is being protected from spambots. You need JavaScript enabled to view it
账户登录系统,可以看到Support下的Message Boards上出现了配置图标。而且有Add Category按钮。
然后看一下如何配置其他scope的权限。 首先以管理员身份登录系统,将Enterprise Admin添加到页面上。选择Roles,添加一个Role名称为SupportMBAdmin,选择Delegate。
在portlet列表中选择Message Boards,随后将Configuration后的Scope选择为Community,Next->Available->选择 Support->Finish。随后使用SupportMBAdmin的assign,将Test HKG 2选中。 使用
This e-mail address is being protected from spambots. You need JavaScript enabled to view it
账户登录系统,可以看到Support下的Message Boards上出现了配置图标。 hkg.1和hkg.2有什么区别呢? hkg.1获得的是Individual的Resource。只有这个Portlet是可以允许他配置的。 hkg.2获得的是support Community下任一个Message Boards的配置权限。 最后要说明的是,个人页面上的Portlet的Permission配置是没有意义的。因为其他人不能查看你的页面,也就无法配置了。
|