gpt4 book ai didi

javascript - 使用 JavaScript 更改 SharePoint 列表的权限

转载 作者:搜寻专家 更新时间:2023-11-01 05:11:36 24 4
gpt4 key购买 nike

我有一个创建列表的应用程序。我希望该应用程序还可以将列表权限设置为仅允许管理员对列表进行更改。我知道如何隐藏列表,但我知道这不会阻止聪明的用户输入列表的 URL 并无论如何修改它。

我没有看到使用 JavaScript 更改列表权限的方法。我可用于列表的功能似乎不允许修改权限,但我可能忽略了正确的功能。

关于我应该查看哪些函数的任何指示?

最佳答案

如何通过 JSOM 为 List 对象启用唯一权限

使用SP.SecurableObject.hasUniqueRoleAssignments property以确定 Angular 色分配是为列表唯一定义的还是从父安全对象继承的。

使用SP.SecurableObject.breakRoleInheritance(copyRoleAssignments, clearSubscopes) Method为 List 对象设置唯一的 Angular 色分配。

例子

var listTitle = 'Documents';
var context = SP.ClientContext.get_current();
var list = context.get_web().get_lists().getByTitle(listTitle);

context.load(list,'HasUniqueRoleAssignments');
context.executeQueryAsync(
function(){
var hasUniqueAssgns = list.get_hasUniqueRoleAssignments();
if(!hasUniqueAssgns) {
list.breakRoleInheritance(false, true);
context.executeQueryAsync(
function(){
console.log('Success');
},
function(sender,args){
console.log(args.get_message());
}
);
}
},
function(sender,args){
console.log(args.get_message());
}
);

如何通过 JSOM 为 List 对象授予自定义权限

以下示例演示了如何打破 List 对象的 Angular 色继承并为当前用户授予 Full Control 权限

例子

var listTitle = 'Documents';
var context = SP.ClientContext.get_current();
var list = context.get_web().get_lists().getByTitle(listTitle);
var currentUser = context.get_web().get_currentUser();

list.breakRoleInheritance(false, true); // break role inheritance first!

var roleDefBindingColl = SP.RoleDefinitionBindingCollection.newObject(context);
roleDefBindingColl.add(context.get_web().get_roleDefinitions().getByType(SP.RoleType.administrator));
list.get_roleAssignments().add(currentUser, roleDefBindingColl);

context.executeQueryAsync(
function(){
console.log('Success');
},
function(sender,args){
console.log(args.get_message());
}
);

关于javascript - 使用 JavaScript 更改 SharePoint 列表的权限,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24897837/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com