0

我正在做一个连接到 Documentum 数据存储的 java 项目。我正在尝试使用 API 类手动创建 ACL。以下是我的代码:

            StringBuilder newAcl = new StringBuilder();
            newAcl.append(selectedItem.getName());
            newAcl.append(selectedItem.getId());
            newAcl.append("_acl");
            IDfACL acl = (IDfACL)_session.newObject("dm_acl");

            acl.setObjectName(newAcl.toString());
            acl.setDescription(newAcl.toString());

            acl.save();

            IDfPermit permit = new DfPermit();

            permit.setAccessorName(newAcl.toString());
            permit.setPermitType(IDfPermit.DF_ACCESS_PERMIT);
            permit.setPermitValue(IDfACL.DF_XPERMIT_CHANGE_FOLDER_LINKS_STR);
            permit.setPermitValue(IDfACL.DF_PERMIT_READ_STR);
            acl.grantPermit(permit);

            acl.save();

问题是我可以成功创建我正在尝试创建的 ACL,并且可以从 dm_acl table object 中检索它。我唯一坚持的是如何设置所有者,因为我从未在我的代码中指定过,一旦我检查 dm_acl 表,它就会说所有者是 dm_admin 。知道如何解决吗?此外,虽然我可以在 dm_acl 中成功创建 ACL,但我也收到错误消息:

[DM_ACL_E_USER_NOT_EXIST] 错误:“ACL 'China InvestmentsCIL_acl' 中给出的 owner_name 或 accessor_name 'China InvestmentsCIL_acl' 不存在。”

4

2 回答 2

0

问题是在您的代码中您没有正确定义 ACL 访问器。从消息中您可以看到 您正在尝试将 ACL 的名称设置为访问者的名称。

permit.setAccessorName(newAcl.toString());

它应该是您为其设置权限的现有用户/组的名称。

于 2016-09-22T13:23:41.073 回答
0

您面临的[DM_ACL_E_USER_NOT_EXIST]错误可能是因为在某个时间点,您在创建 ACL 时拥有该所有者/组,同时以某种方式将其删除。现在,当您更新dm_acl对象时,您将面临这个问题。

于 2016-09-15T06:04:21.687 回答