SharePoint - преобразование маски разрешений в роль - PullRequest
3 голосов
/ 05 октября 2010

У меня проблема с получением прав доступа к списку или сайту. Я использую веб-службу разрешений SharePoint и метод GetPermissionCollection. Этот метод возвращает что-то вроде этого:

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

Я хотел бы иметь возможность преобразовать маску разрешений в роли, к которым она принадлежит. (как если бы вы просматривали разрешения на веб-сайте).

Я обнаружил, что с помощью веб-службы UserGroup я могу получить список ролей и их базовых разрешений. Метод GetRolesAndPermissionsForSite из этого сервиса возвращает что-то вроде этого:

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

Есть ли способ преобразовать эти BasePermissions в Mask для их сравнения? Или есть какой-нибудь более простой способ преобразовать маску разрешений в роль (уровень разрешений), к которой она принадлежит?

1 Ответ

0 голосов
/ 02 февраля 2011

Я сделал этот образец javascript благодаря @ zanlok answer

Я использовал JQuery, SPServices js (http://spservices.codeplex.com/) и эту ссылку для кодов масок http://msdn.microsoft.com/en-us/library/dd304243%28PROT.13%29.aspx Надеюсь, это поможет вам, я сделал это, потому что мне это тоже было нужно, однако это также может помочь другим.

Вам нужно заменить divid значением элемента управления, который вы хотите разместить в html, иИМЯ СПИСКА ЗДЕСЬ с названием списка.

Скрипт выплюнет всех, кто имеет доступ к списку, и скажет, могут ли они читать, добавлять, изменять и удалять объекты. Надеется, что это поможет вам.

$('#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);
    }
});
...