Custom Reports
CIPP's custom reporting functionality empowers advanced users to create tailored reports for any best practice scenarios you can imagine. While CIPP includes multiple default reports that are rapidly expanding, custom reports let you take control of exactly what data is presented. By defining your own JSON templates, you can specify APIs, commands, and display styles to meet unique organizational needs.
Best Practices for Building Custom BPA Reports
1. Starting with Existing Templates
Begin with a pre-configured report like the "CIPP Best Practices Table View"
to use as a foundation. Copy and modify the template to suit your needs. This approach simplifies the process and ensures compatibility with CIPP's structure.
2. Defining Data Sources
Custom reports pull data from sources such as:
Microsoft Graph API: Requires specifying endpoints, fields, and parameters.
PowerShell Commands: Allows extracting specific metrics from Exchange or similar environments.
3. Understanding Report Structures
Each custom report is a JSON template with three key components:
Fields: Specifies which data points to extract.
Display Format: Determines how the data appears (e.g., Booleans, tables, or JSON objects).
Data Sources: Defines the API endpoints or PowerShell commands to use.
4. Validating and Executing
Once configured, force a data refresh to validate your report. This step ensures all APIs and commands execute correctly, and the report functions as intended.
Step-by-Step Guide to Creating a Custom Report
1. Setting the Foundation
Every report begins with a title and presentation style. For example, to create a table-based report:
Alternatively, for a tenant-based overview, set the style to "Tenant"
.
2. Adding Fields
Define the data points to fetch from an API, specifying the endpoint, parameters, and how the data should be presented:
This example fetches SharePoint settings, extracting sharing capabilities and Mac sync status.
3. Fetching Exchange Data
For Exchange, define commands instead of API URLs:
This configuration retrieves mailbox details, including size and last login date.
4. The End Result
By following the steps above, you've crafted a detailed JSON structure for the "Company IT Overview" report. This report fetches data from SharePoint, Exchange, and presents insights in a tabular format. You can modify this structure to fetch different data or adjust the presentation as needed.
Feature Requests / Ideas
We value your feedback and ideas. Please raise any feature requests on GitHub.
Last updated