Files
M365FoundationsCISReport/README copy.md
2024-08-04 16:03:14 -05:00

5.5 KiB

M365FoundationsCISReport Module

PSScriptAnalyzer pages-build-deployment

License

This PowerShell module is based on CIS benchmarks and is distributed under the Creative Commons Attribution-NonCommercial-ShareAlike 4.0 International License. This means:

  • Non-commercial: You may not use the material for commercial purposes.
  • ShareAlike: If you remix, transform, or build upon the material, you must distribute your contributions under the same license as the original.
  • Attribution: Appropriate credit must be given, provide a link to the license, and indicate if changes were made.

For full license details, please visit Creative Commons Attribution-NonCommercial-ShareAlike 4.0 International License.

Register for and download CIS Benchmarks

Table of Contents

  1. Invoke-M365SecurityAudit
  2. Export-M365SecurityAuditTable
  3. Get-AdminRoleUserLicense
  4. Get-MFAStatus
  5. Grant-M365SecurityAuditConsent
  6. New-M365SecurityAuditAuthObject
  7. Remove-RowsWithEmptyCSVStatus
  8. Sync-CISExcelAndCsvData

Module Dependencies

The M365FoundationsCISReport module relies on several other PowerShell modules to perform its operations. The default run ensures these modules are installed with the specified versions. Use -NoModuleCheck to skip this step if you have installed the required modules previously and would like to suppress any output for automated runs.

Required Modules for Audit Functions

Default modules used for audit functions:

  • ExchangeOnlineManagement

    • Required Version: 3.3.0
  • Microsoft.Graph

    • Required Version: 2.4.0
  • PnP.PowerShell (Optional, if PnP App authentication is used for SharePoint Online)

    • Required Version: 2.5.0
  • Microsoft.Online.SharePoint.PowerShell (If PnP authentication is not used (Default) )

    • Required Version: 16.0.24009.12000
  • MicrosoftTeams

    • Required Version: 5.5.0
  • ImportExcel (If importing or exporting Excel files)

    • Required Version: 7.8.9

EXAMPLES

# Example 1: Performing a security audit based on CIS benchmarks
$auditResults = Invoke-M365SecurityAudit -TenantAdminUrl "https://contoso-admin.sharepoint.com"
$auditResults = Invoke-M365SecurityAudit -TenantAdminUrl "https://contoso-admin.sharepoint.com" -DomainName "contoso.com" -ApprovedCloudStorageProviders "DropBox" -ApprovedFederatedDomains "northwind.com"
# Suppressed output for automated runs
$auditResults = Invoke-M365SecurityAudit -TenantAdminUrl "https://contoso-admin.sharepoint.com" -NoModuleCheck -NoModuleCheck -DoNotConfirmConnections -Confirm:$false

# Example 2: Exporting a security audit and it's nested tables to zipped CSV files
Export-M365SecurityAuditTable -AuditResults $auditResults -ExportPath "C:\temp" -ExportOriginalTests -ExportNestedTables
    # Output Ex: 2024.07.07_14.55.55_M365FoundationsAudit_368B2E2F.zip

# Example 3: Retrieving licenses for users in administrative roles
Get-AdminRoleUserLicense

# Example 4: Getting MFA status of users
Get-MFAStatus -UserId "user@domain.com"

# Example 5: Removing rows with empty status values from a CSV file
Remove-RowsWithEmptyCSVStatus -FilePath "C:\Reports\Report.xlsx" -WorksheetName "Sheet1"

# Example 6: Synchronizing CIS benchmark data with audit results
Sync-CISExcelAndCsvData -ExcelPath "path\to\excel.xlsx" -CsvPath "path\to\data.csv" -SheetName "Combined Profiles"

# Example 7: Granting Microsoft Graph permissions to the auditor
Grant-M365SecurityAuditConsent -UserPrincipalNameForConsent 'user@example.com'

# Example 8: (PowerShell 7.x Only) Creating a new authentication object for the security audit for app-based authentication.
$authParams = New-M365SecurityAuditAuthObject `
  -ClientCertThumbPrint "ABCDEF1234567890ABCDEF1234567890ABCDEF12" `
  -ClientId "12345678-1234-1234-1234-123456789012" `
  -TenantId "12345678-1234-1234-1234-123456789012" `
  -OnMicrosoftUrl "yourcompany.onmicrosoft.com" `
  -SpAdminUrl "https://yourcompany-admin.sharepoint.com"
Invoke-M365SecurityAudit -AuthParams $authParams -TenantAdminUrl "https://yourcompany-admin.sharepoint.com"

NOTE

Ensure that you have the necessary permissions and administrative roles in your Microsoft 365 environment to run these cmdlets. Proper configuration and setup are required for accurate audit results.

TROUBLESHOOTING NOTE

If you encounter any issues while using the cmdlets, ensure that your environment meets the module prerequisites. Check for any updates or patches that may address known bugs. For issues related to specific cmdlets, refer to the individual help files for troubleshooting tips.

SEE ALSO