Certificate-Based Authentication
Certificate-based authentication provides a secure way to connect to SharePoint and supports both basic integration and permission sync functionality. Use certificate authentication when:- You need permission sync capabilities
- You prefer certificate-based security over client secrets
- Your organization requires certificate-based authentication
Setting up
Step 1: Create Azure App Registration
Open Azure Portal
Log in to Azure Portal for your organization.
Name and register app
Name it something like “Onyx SharePoint Connector - Certificate”, leave everything else as default,
and click Register.
Step 2: Generate and Upload Certificate
Option A: Generate Self-Signed Certificate
Option B: Use Organization Certificate
Obtain a certificate from your organization’s Certificate Authority (CA) following your internal security policies.We only support PFX format for certificate uploads in Azure.
Step 3: Upload Certificate to Azure
Open Certificates & secrets
In your Azure App Registration, navigate to the “Certificates & secrets” tab.
Step 4: Configure API Permissions
Basic Permissions (No Permission Sync)
If you are not planning to enable permission sync, you only need basic permissions:Select Sites.Read.All
Navigate to the “Sites” permission group. Select the checkbox for Sites.Read.All.
- Advanced: If you want to limit the sites this app has access to, select Sites.Selected. However, if you do this, you will need to add the App you are currently registering to each site you want to index.
Extended Permissions (With Permission Sync)
If you plan to enable permission sync, you’ll need additional permissions:Microsoft Graph application permissions
Click Microsoft Graph, then click on Application permissions.
Add the following additional Microsoft Graph permissions:
- Directory.Read.All - Used to query the overall organizational directory structure, including how users, groups, organizational units, and other directory objects relate to each other.
- Group.Read.All - Used to read detailed group-specific information such as group properties, settings, types (Security vs Microsoft 365), and configurations.
- GroupMember.Read.All - Used to retrieve and expand all members within a group, including nested group memberships. This allows Onyx to determine which users have access to SharePoint content through group membership.
- Member.Read.Hidden - Allows reading memberships of security groups that are marked as “hidden” in Entra ID.
- User.Read.All - Used to retrieve complete user profiles and enumerate all users in the directory. Click Add permissions.
Microsoft Graph delegated permission
Click Add a permission again in API Permissions tab. Click Microsoft Graph,
then click on Delegated permissions. Add the following delegated permission:
- User.Read - This delegated permission allows the application to sign in on behalf of a user and read the signed-in user’s basic profile information. Unlike application permissions which work without a user context, this delegated permission is required when the app needs to establish an authenticated identity context for making API calls to Microsoft Graph and SharePoint. It provides the minimum required access for user authentication flows. Click Add permissions.
SharePoint application permissions
Click Add a permission again in API Permissions tab. Click SharePoint,
then click on Application permissions. Add the following SharePoint permissions:
- Sites.FullControl.All - Despite the name, Onyx only uses this to retrieve details about permissions. No write operations are performed.
- User.Read.All - Used to list all users within the directory for permission mapping. Click Add permissions.
Step 5: Configure in Onyx
Enter credential details
- Application (client) ID from Step 1
- Directory (tenant) ID from Step 1
- Certificate File: Upload your certificate file (.pfx file)
- Certificate Password: Enter password which you used to export the certificate file
Step 6: Enable Permission Sync (Optional)
When creating your SharePoint connector with certificate authentication:Permission sync is available only on Cloud and the Enterprise Edition of Onyx.
Permission Sync Details
When permission sync is enabled:- Document-level permissions: Onyx will respect SharePoint document permissions
- Site-level permissions: Users will only see documents from sites they have access to
- Group permissions: SharePoint group memberships are synchronized
- Real-time sync: Permissions are updated regularly to reflect SharePoint changes