Source: https://o365info.com/connect-pnp-powershell/
Must use Powershell version 7 for this to work
To connect to SharePoint Online with PowerShell, you must first Install the PnP PowerShell module. Then, create an application registration in Microsoft Entra ID. After that, you can use the Connect-PnPOnline cmdlet to connect interactively without entering your credentials. In this article, you will learn how to connect to SharePoint Online using the PnP PowerShell module.
Table of contents
Create application registration in Microsoft Entra ID
To connect interactively to your tenant with PnP PowerShell, you must create an application registration in Microsoft Entra ID. There are two methods to do this:
- PowerShell (automatically)
- Microsoft Entra ID (manually)
Register PnP application with PowerShell (automatic)
To register the PnP application with PowerShell, you must run the command below. You must specify the tenant domain name to register the application in Microsoft Entra.
A prompt will appear where you must sign in with your global admin credentials. After that, another prompt will appear to accept the permissions.
data:image/s3,"s3://crabby-images/7434e/7434efd545ae60b2992a4074f8c4d8d956887cac" alt="How to Connect to SharePoint Online using PnP PowerShell login prompt"
The application client ID will appear at the end of the PowerShell output. Ensure that you copy and save it because you need to use it to connect with PnP later.
Register PnP application in Microsoft Entra ID (manual)
There are a few steps involved when registering an application in Microsoft Entra ID. First, you need to register an application. Then, you need to add an authentication platform. Lastly, you need to assign API permissions to the PnP application.
Step 1. Register new application
Register an application in the Microsoft Entra ID with the steps below:
- Sign in to Microsoft Entra ID
- Click Identity > Applications > App registrations
- Click New registration
data:image/s3,"s3://crabby-images/b7ea4/b7ea4968ceed25185511c79b05c23f56ae17bcc4" alt="How to Connect SharePoint Online using PnP PowerShell register new application in Microsoft Entra"
- Type the Name PnP SharePoint
- Select Accounts in this organization directory only (Single tenant)
- Click Register
data:image/s3,"s3://crabby-images/de9ff/de9ff6992f7c6e461a1ddf88c81438201003f5ff" alt="How to Connect SharePoint Online using PnP PowerShell register application"
- You successfully created an application, and the Application (client) ID appears
data:image/s3,"s3://crabby-images/cc3bf/cc3bf13daffa3018ab6dfc1657294fe2390df200" alt="How to Connect SharePoint Online using PnP PowerShell with application client ID"
Step 2. Add authentication to application
To add an authentication to the application, follow these steps:
- Click Authentication on the application overview page
- Click Add a platform
data:image/s3,"s3://crabby-images/58685/58685c3dc0e3755ea6f0042e6ba6de9c22ee75fe" alt="Connect SharePoint Online using PnP PowerShell add authentication"
- Click Mobile and desktop applications
data:image/s3,"s3://crabby-images/2fc3c/2fc3c02a75f2d78a4a8eb5e48018dea2b372d83c" alt="Configure platform in Microsoft Entra"
- Type custom redirect URls http://localhost (this should really be http and not https)
- Click Configure
data:image/s3,"s3://crabby-images/d7f08/d7f083f05b16d253c7787623ffc5e54242137e07" alt="Configure custom redirect URLs localhost"
Step 3. Assign API permissions to application
To assign API permissions to the application, follow these steps:
- Click API permissions on the application overview page
- Click Add a permission
data:image/s3,"s3://crabby-images/46e74/46e74b9bfef1bb421e108f5073ec44baf7b6bfcd" alt="Assign API permissions to the application PnP SharePoint in Microsoft Entra"
- Click Microsoft APIs
- Click SharePoint
data:image/s3,"s3://crabby-images/f4711/f4711842bd4870385203b37bebbe67eed7709ca6" alt="Request Microsoft API permissions SharePoint"
- Click Delegated permissions
- Type AllSites
- Expand AllSites
- Select AllSites.Read
- Click Add permissions
data:image/s3,"s3://crabby-images/8653a/8653ad4e4ef0d728d90cbd20bb46dd8180114dde" alt="Reguest delegated permissions in Microsoft Entra"
- Click Grant admin consent for m365info
- Click Yes
data:image/s3,"s3://crabby-images/feb15/feb15d2df68466480a02792cb265f27cb5dc4966" alt="Grant admin consent confirmation in Microsoft Entra ID"
- The green check mark shows that you granted admin consent successfully
data:image/s3,"s3://crabby-images/fb458/fb4581519c3a9f2b0725692e114ac84e23e06aa3" alt="Granted admin consent successfully in Microsoft Entra ID"
Connect PnP PowerShell
To connect to PnP PowerShell, you need to specify your SharePoint URL and application Client ID.
To check that you are connected to SharePoint Online, run the Get-PnpSite cmdlet below.
Disconnect PnP PowerShell
Always disconnect your PnP PowerShell session when you finish your work.
That’s it!