SharePoint - 将权限掩码转换为角色

时间:2010-10-05 14:40:59

标签: sharepoint permissions

我在检索列表或网站的权限时遇到问题。我正在使用SharePoint的权限Web服务和GetPermissionCollection方法。 这个方法返回如下:

<Permission MemberID="4" Mask="1067654015" MemberIsUser="False" MemberGlobal="True" GroupName="Collaboration demo Owners" />

我希望能够将权限掩码转换为它所属的角色。 (就像你通过网站查看权限一样)。

我发现使用UserGroup Webservice,我可以检索角色列表及其基本权限。来自此服务的GetRolesAndPermissionsForSite方法返回一些思考:

<Role ID="1073741829" Name="Full Control" Description="Has full control." Hidden="False" Type="Administrator" BasePermissions="9223372036854775807"....

有没有办法将此BasePermissions转换为Mask以便进行比较?或者是否有更简单的方法将权限掩码转换为它所属的角色(权限级别)?

1 个答案:

答案 0 :(得分:0)

由于@zanlok answer

,我制作了这个javascript示例

我使用了JQuery,SPServices js(http://spservices.codeplex.com/) 这个掩码代码的链接 http://msdn.microsoft.com/en-us/library/dd304243%28PROT.13%29.aspx 我希望这可以帮到你,我这样做是因为我也需要它,但它也可以帮助别人。

您需要将divid替换为要放置html的控件的值,并将LIST NAME替换为列表名称。

该脚本将吐出有权访问列表的所有人,并说明他们是否可以阅读,添加,更改和删除内容。希望这会对你有所帮助。

$('#divid').html('Working...').SPServices({
    operation: "GetPermissionCollection",
    objectName: 'LIST NAME HERE',
    objectType: "List",
    completefunc: function (xData, Status) {
        var out = "<ul>";
        $(xData.responseXML).find("Permission").each(function () {
            if ($(this).attr("MemberIsUser") === "True") {
                out += "<li>User: " + $(this).attr("UserLogin") + "</li>";
            } else {
                out += "<li>Group: " + $(this).attr("GroupName") + "</li>";
            }
            var readmask = 0x0000000000000001;
            var addmask = 0x0000000000000002;
            var editmask = 0x0000000000000004;
            var deletemask = 0x0000000000000008;
            out += "<li>Mask: " + $(this).attr("Mask") + "</li>";
            var canread = readmask & $(this).attr("Mask").toString(16) > 0 ? "Yes" : "No";
            var canadd = addmask & $(this).attr("Mask").toString(16) > 0 ? "Yes" : "No";
            var canedit = editmask & $(this).attr("Mask").toString(16) > 0 ? "Yes" : "No";
            var candelete = deletemask & $(this).attr("Mask").toString(16) > 0 ? "Yes" : "No";
            out += "<li>Can Read: " + canread + "</li>";
            out += "<li>Can Add: " + canadd + "</li>";
            out += "<li>Can Edit: " + canedit + "</li>";
            out += "<li>Can Delete: " + candelete + "</li>";
        });
        out += "</ul>";
        $('#divid').html(out);
    }
});