spacer
Skip to content

sp-admin

The @pnp/sp-admin library enables you to call the static SharePoint admin API's:

  • _api/Microsoft.Online.SharePoint.TenantManagement.Office365Tenant
  • _api/Microsoft.Online.SharePoint.TenantAdministration.SiteProperties
  • _api/Microsoft.Online.SharePoint.TenantAdministration.Tenant

These APIs typically require an elevated level of permissions and should not be relied upon in general user facing solutions. Before using this library please understand the impact of what you are doing as you are updating settings at the tenant level for all users. Also keep in mind these endpoints do not support application permissions, therefore you will need to get a user token for delegated access, ergo they cannot be used unattended.

Warning

These APIs are officially not documented which means there is no SLA provided by Microsoft. Furthermore, they can be updated without notification.

Use

To use the library you first install the package:

npm install @pnp/sp-admin --save

Then import the package into your solution, it will attach a node to the sp fluent interface using selective imports.

import "@pnp/sp-admin";

Basic Example

In this example we get all of the web templates' information.

import { spfi } from "@pnp/sp";
import "@pnp/sp-admin";

const sp = spfi(...);

// note the "admin" node now available
const templates = await sp.admin.tenant.getSPOTenantAllWebTemplates();

tenant

The tenant node represents calls to the _api/Microsoft.Online.SharePoint.TenantAdministration.Tenant api.

When calling the tenant endpoint you must target the -admin site as shown here. If you do not you will get only errors.

import { spfi } from "@pnp/sp";
import "@pnp/sp-admin";

const spAdmin = spfi("https://{tenant}-admin.sharepoint.com");

// The MSAL scope will be: "https://{tenant}-admin.sharepoint.com/.default"

// default props
const defaultProps = await spAdmin.admin.tenant();

// all props
const allProps = await spAdmin.admin.tenant.select("*")();

// select specific props
const selectedProps = await spAdmin.admin.tenant.select("AllowEditing", "DefaultContentCenterSite")();

// call method
const templates = await spAdmin.admin.tenant.getSPOTenantAllWebTemplates();

// get site properties by url
const props = await spAdmin.admin.tenant.getSitePropertiesByUrl("https://contoso.sharepoint.com/sites/dev", true);

// set site properties by id -- GUID of SharePoint site (not root web)
await spAdmin.admin.tenant.setSitePropertiesById("{siteId}", {LockedState: "ReadOnly"});

office365Tenant

The office365Tenant node represents calls to the _api/Microsoft.Online.SharePoint.TenantManagement.Office365Tenant end point and is accessible from any site url.

import { spfi } from "@pnp/sp";
import "@pnp/sp-admin";

const sp = spfi(...);

// default props
const defaultProps = await sp.admin.office365Tenant();

// all props
const allProps = await sp.admin.office365Tenant.select("*")();

// selected props
const selectedProps = await sp.admin.office365Tenant.select("AllowEditing", "DefaultContentCenterSite")();

// call method
const externalUsers = await sp.admin.office365Tenant.getExternalUsers();

siteProperties

The siteProperties node is primarily for accessing detailed properties about a site and tenant.

import { spfi } from "@pnp/sp";
import "@pnp/sp-admin";

const sp = spfi(...);

// default props
const defaultProps = await sp.admin.siteProperties();

// all props
const allProps = await sp.admin.siteProperties.select("*")();

// selected props
const selectedProps = await sp.admin.siteProperties.select("LockState")();

// call method
await sp.admin.siteProperties.clearSharingLockDown("https://tenant.sharepoint.com/sites/site1");

For more information on the methods available and how to use them, please review the code comments in the source.

call

All those nodes support a call method to easily allow calling methods not explicitly added to the library. If there is a method you use often that would be a good candidate to add, please open an issue or submit a PR. The call method is meant to help unblock folks before methods are added.

This sample shows using call to invoke the "AddTenantCdnOrigin" method of office365Tenant. While we already support for this method, it helps to show the relationship between call and an existing method.

import { spfi } from "@pnp/sp";
import { SPOTenantCdnType } from '@pnp/sp-admin';

const sp = spfi(...);

// call AddTenantCdnOrigin
await sp.admin.office365Tenant.call<void>("AddTenantCdnOrigin", {
    "cdnType": SPOTenantCdnType.Public,
    "originUrl": "*/clientsideassets"
});

const spTenant = spfi("https://{tenant}-admin.sharepoint.com");

// call GetSiteSubscriptionId which takes no args
const id = await spTenant.admin.tenant.call<string>("GetSiteSubscriptionId");