This article shows how to retrieve all permission levels in SharePoint using REST. Develop the project using the following method in the NAPA Tool.
On your Developer Site, open the "Napa" Office 365 Development Tools and then choose Add New Project.
- Choose the App for SharePoint template, name the project Create Site and then choose the Create button
- Replace APP.js with the source code below
- Publish Your App.
Prerequisites
The following is an important procedure to be done before creating the app. Specify the permissions that your app needs as in the following. Choose the Properties button at the bottom of the page.
- In the Properties window, choose Permissions.
- In the Content category, set the Write permissions for the Tenant scope.
- In the Social category, set the Read permissions for the User Profiles scope.
- Close the Properties window.
Default AspxSource Code
- 'use strict';
-
- var hostweburl;
- var appweburl;
-
-
-
- $(document).ready(function () {
-
-
- hostweburl = decodeURIComponent(getQueryStringParameter("SPHostUrl"));
- appweburl = decodeURIComponent(getQueryStringParameter("SPAppWebUrl"));
-
-
-
-
-
-
-
- $.getScript(hostweburl + "/_layouts/15/SP.RequestExecutor.js",getuserpermission);
- });
-
-
- function getuserpermission () {
- var executor;
-
-
- executor = new SP.RequestExecutor(appweburl);
-
- executor.executeAsync({
-
- url: appweburl + "/_api/SP.AppContextSite(@target)/web/RoleDefinitions?@target='" + hostweburl + "'",
- method: "GET",
- headers: {
- "Accept": "application/json; odata=verbose"
- },
- success: getPermissionLevelsSuccessHandler,
- error: getPermissionLevelsErrorHandler
- });
- }
-
-
- function getPermissionLevelsSuccessHandler(data) {
- var jsonObject = JSON.parse(data.body);
- var PermissionLevels = document.getElementById("retrivePermissionLevels");
-
- if (PermissionLevels.hasChildNodes()) {
- while (PermissionLevels.childNodes.length >= 1) {
- PermissionLevels.removeChild(PermissionLevels.firstChild);
- }
- }
- var results = jsonObject.d.results;
- for (var i = 0; i < results.length; i++) {
- var retrivegroup = document.createElement("option");
- retrivegroup.value = results[i].Name;
- retrivegroup.innerText = results[i].Name;
- PermissionLevels.appendChild(retrivegroup);
- }
- }
- function getPermissionLevelsErrorHandler (data, errorCode, errorMessage) {
- alert("Could not get site permission levels: " + errorMessage);
- }
-
-
-
-
- function getQueryStringParameter(paramToRetrieve) {
- var params = document.URL.split("?")[1].split("&");
- for (var i = 0; i < params.length; i = i + 1) {
- var singleParam = params[i].split("=");
- if (singleParam[0] == paramToRetrieve) return singleParam[1];
- }
- }
Publish: Publish the app and click the Trust it Button.Output: Role permission retrieved Successfully.