Get-AADExportDefaultSchema.ps1
<#
.Synopsis Gets the default export schema definition .Description Gets the default export schema definition. Defining the order in which elements are exported. .Example Get-AADExportDefaultSchema #> function Get-AADExportDefaultSchema { $global:TenantID = (Get-MgContext).TenantId return @( # Organization @{ GraphUri = 'organization' Path = 'Organization/Organization.json' Tag = @('All', 'Config', 'Organization') DelegatedPermission = 'Directory.Read.All' ApplicationPermission = 'Directory.Read.All' }, @{ GraphUri = 'organization/{0}/settings' -f $TenantID Path = 'Organization/Settings.json' ApiVersion = 'beta' Tag = @('All', 'Config', 'Organization') DelegatedPermission = 'User.Read.All' }, @{ GraphUri = 'organization/{0}/branding/localizations' -f $TenantID Path = 'Organization/Branding/Localizations.json' Tag = @('All', 'Config', 'Organization') DelegatedPermission = 'User.Read.All' }, @{ GraphUri = 'organization/{0}/certificateBasedAuthConfiguration' -f $TenantID Path = 'Organization/CertificateBasedAuthConfiguration.json' Tag = @('All', 'Config', 'Organization') DelegatedPermission = 'Organization.Read.All' ApplicationPermission = 'Organization.Read.All' }, @{ GraphUri = 'domains' Path = 'Domains' Tag = @('All', 'Config','Domains') DelegatedPermission = 'Directory.Read.All' ApplicationPermission = 'Directory.Read.All' }, @{ GraphUri = 'identity/apiConnectors' Path = 'Identity/APIConnectors' ApiVersion = 'beta' IgnoreError = 'The feature self service sign up is not enabled for the tenant' Tag = @('All', 'Config', 'Identity') DelegatedPermission = 'APIConnectors.ReadWrite.All' ApplicationPermission = 'APIConnectors.ReadWrite.All' }, @{ GraphUri = 'identityProviders' Path = 'IdentityProviders' Tag = @('All', 'Config', 'Identity') DelegatedPermission = 'IdentityProvider.Read.All' }, @{ GraphUri = 'subscribedSkus' Path = 'SubscribedSkus' Tag = @('All', 'Config', 'SKUs') DelegatedPermission = 'Directory.Read.All' ApplicationPermission = 'Directory.Read.All' }, @{ GraphUri = 'directoryRoles' Path = 'DirectoryRoles' Tag = @('All', 'Config', 'Roles') DelegatedPermission = 'Directory.Read.All' ApplicationPermission = 'Directory.Read.All' Children = @( @{ GraphUri = 'directoryRoles/{id}/members' Select = 'id, userPrincipalName, displayName' Path = 'Members' Tag = @('All', 'Config', 'Roles') DelegatedPermission = 'Directory.Read.All' ApplicationPermission = 'Directory.Read.All' } @{ GraphUri = 'directoryroles/{id}/scopedMembers' Path = 'ScopedMembers' Tag = @('All', 'Config', 'Roles') DelegatedPermission = 'Directory.Read.All' ApplicationPermission = 'Directory.Read.All' } ) }, # B2C @{ GraphUri = 'identity/userFlows' Path = 'Identity/UserFlows' Tag = @('B2C') DelegatedPermission = 'IdentityUserFlow.Read.All' ApplicationPermission = 'IdentityUserFlow.Read.All' }, @{ GraphUri = 'identity/b2cUserFlows' Path = 'Identity/B2CUserFlows' Tag = @('B2C') DelegatedPermission = 'IdentityUserFlow.Read.All' ApplicationPermission = 'IdentityUserFlow.Read.All' Children = @( @{ GraphUri = 'identity/b2cUserFlows/{id}/identityProviders' Path = 'IdentityProviders' Tag = @('B2C') DelegatedPermission = 'IdentityUserFlow.Read.All' ApplicationPermission = 'IdentityUserFlow.Read.All' }, @{ GraphUri = 'identity/b2cUserFlows/{id}/userAttributeAssignments' QueryParameters = @{ expand = 'userAttribute' } Path = 'UserAttributeAssignments' Tag = @('B2C') DelegatedPermission = 'IdentityUserFlow.Read.All' ApplicationPermission = 'IdentityUserFlow.Read.All' }, @{ GraphUri = 'identity/b2cUserFlows/{id}/apiConnectorConfiguration' QueryParameters = @{ expand = 'postFederationSignup,postAttributeCollection' } Path = 'ApiConnectorConfiguration' Tag = @('B2C') DelegatedPermission = 'IdentityUserFlow.Read.All' ApplicationPermission = 'IdentityUserFlow.Read.All' }, @{ GraphUri = 'identity/b2cUserFlows/{id}/languages' Path = 'Languages' Tag = @('B2C') DelegatedPermission = 'IdentityUserFlow.Read.All' ApplicationPermission = 'IdentityUserFlow.Read.All' } ) }, # B2B @{ GraphUri = 'identity/userFlowAttributes' Path = 'Identity/UserFlowAttributes' ApiVersion = 'beta' Tag = @('Config', 'B2B', 'B2C') DelegatedPermission = 'IdentityUserFlow.Read.All' ApplicationPermission = 'IdentityUserFlow.Read.All' IgnoreError = 'The feature self service sign up is not enabled for the tenant' }, @{ GraphUri = 'identity/b2xUserFlows' Path = 'Identity/B2XUserFlows' ApiVersion = 'beta' Tag = @('All', 'Config', 'B2B') DelegatedPermission = 'IdentityUserFlow.Read.All' ApplicationPermission = 'IdentityUserFlow.Read.All' Children = @( @{ GraphUri = 'identity/b2xUserFlows/{id}/identityProviders' Path = 'IdentityProviders' ApiVersion = 'beta' Tag = @('All', 'Config', 'B2B') DelegatedPermission = 'IdentityUserFlow.Read.All' ApplicationPermission = 'IdentityUserFlow.Read.All' }, @{ GraphUri = 'identity/b2xUserFlows/{id}/userAttributeAssignments' QueryParameters = @{ expand = 'userAttribute' } Path = 'AttributeAssignments' ApiVersion = 'beta' Tag = @('All', 'Config', 'B2B') DelegatedPermission = 'IdentityUserFlow.Read.All' ApplicationPermission = 'IdentityUserFlow.Read.All' }, @{ GraphUri = 'identity/b2xUserFlows/{id}/apiConnectorConfiguration' QueryParameters = @{ expand = 'postFederationSignup,postAttributeCollection' } Path = 'APIConnectors' ApiVersion = 'beta' Tag = @('All', 'Config', 'B2B') DelegatedPermission = 'IdentityUserFlow.Read.All' ApplicationPermission = 'IdentityUserFlow.Read.All' }, @{ GraphUri = 'identity/b2xUserFlows/{id}/languages' Path = 'Languages' ApiVersion = 'beta' Tag = @('All', 'Config', 'B2B') DelegatedPermission = 'IdentityUserFlow.Read.All' ApplicationPermission = 'IdentityUserFlow.Read.All' } ) }, # Policies @{ GraphUri = 'policies/identitySecurityDefaultsEnforcementPolicy' Path = 'Policies/IdentitySecurityDefaultsEnforcementPolicy' Tag = @('All', 'Config', 'Policies') DelegatedPermission = 'Policy.Read.All' ApplicationPermission = 'Policy.Read.All' }, @{ GraphUri = 'policies/authorizationPolicy' Path = 'Policies/AuthorizationPolicy' Tag = @('All', 'Config', 'Policies') DelegatedPermission = 'Policy.Read.All' ApplicationPermission = 'Policy.Read.All' }, @{ GraphUri = 'policies/featureRolloutPolicies' Path = 'Policies/FeatureRolloutPolicies' Tag = @('All', 'Config', 'Policies') DelegatedPermission = 'Directory.ReadWrite.All' }, @{ GraphUri = 'policies/activityBasedTimeoutPolicies' Path = 'Policies/ActivityBasedTimeoutPolicy' Tag = @('All', 'Config', 'Policies') DelegatedPermission = 'Policy.Read.All' ApplicationPermission = 'Policy.Read.All' }, @{ GraphUri = 'policies/homeRealmDiscoveryPolicies' Path = 'Policies/HomeRealmDiscoveryPolicy' Tag = @('All', 'Config', 'Policies') DelegatedPermission = 'Policy.Read.All' ApplicationPermission = 'Policy.Read.All' }, @{ GraphUri = 'policies/claimsMappingPolicies' Path = 'Policies/ClaimsMappingPolicy' Tag = @('All', 'Config', 'Policies') DelegatedPermission = 'Policy.Read.All' ApplicationPermission = 'Policy.Read.All' }, @{ GraphUri = 'policies/tokenIssuancePolicies' Path = 'Policies/TokenIssuancePolicy' Tag = @('All', 'Config', 'Policies') DelegatedPermission = 'Policy.Read.All' ApplicationPermission = 'Policy.Read.All' }, @{ GraphUri = 'policies/tokenLifetimePolicies' Path = 'Policies/TokenLifetimePolicy' Tag = @('All', 'Config', 'Policies') DelegatedPermission = 'Policy.Read.All' ApplicationPermission = 'Policy.Read.All' }, @{ GraphUri = 'policies/authenticationMethodsPolicy/authenticationMethodConfigurations/email' Path = 'Policies/AuthenticationMethodsPolicy/AuthenticationMethodConfigurations/Email.json' Tag = @('All', 'Config', 'Policies') DelegatedPermission = 'Policy.Read.All' ApplicationPermission = 'Policy.Read.All' }, @{ GraphUri = 'policies/authenticationMethodsPolicy/authenticationMethodConfigurations/fido2' Path = 'Policies/AuthenticationMethodsPolicy/AuthenticationMethodConfigurations/FIDO2.json' Tag = @('All', 'Config', 'Policies') DelegatedPermission = 'Policy.Read.All' ApplicationPermission = 'Policy.Read.All' }, @{ GraphUri = 'policies/authenticationMethodsPolicy/authenticationMethodConfigurations/microsoftAuthenticator' Path = 'Policies/AuthenticationMethodsPolicy/AuthenticationMethodConfigurations/MicrosoftAuthenticator.json' Tag = @('All', 'Config', 'Policies') DelegatedPermission = 'Policy.Read.All' ApplicationPermission = 'Policy.Read.All' }, @{ GraphUri = 'policies/authenticationMethodsPolicy/authenticationMethodConfigurations/sms' Path = 'Policies/AuthenticationMethodsPolicy/AuthenticationMethodConfigurations/SMS.json' Tag = @('All', 'Config', 'Policies') DelegatedPermission = 'Policy.Read.All' ApplicationPermission = 'Policy.Read.All' }, @{ GraphUri = 'policies/authenticationMethodsPolicy/authenticationMethodConfigurations/temporaryAccessPass' Path = 'Policies/AuthenticationMethodsPolicy/AuthenticationMethodConfigurations/TemporaryAccessPass.json' Tag = @('All', 'Config', 'Policies') DelegatedPermission = 'Policy.Read.All' ApplicationPermission = 'Policy.Read.All' }, @{ GraphUri = 'policies/authenticationMethodsPolicy/authenticationMethodConfigurations/softwareOath' Path = 'Policies/AuthenticationMethodsPolicy/AuthenticationMethodConfigurations/SoftwareOath.json' Tag = @('All', 'Config', 'Policies') DelegatedPermission = 'Policy.Read.All' ApplicationPermission = 'Policy.Read.All' }, @{ GraphUri = 'policies/authenticationMethodsPolicy/authenticationMethodConfigurations/voice' Path = 'Policies/AuthenticationMethodsPolicy/AuthenticationMethodConfigurations/Voice.json' Tag = @('All', 'Config', 'Policies') DelegatedPermission = 'Policy.Read.All' ApplicationPermission = 'Policy.Read.All' }, @{ GraphUri = 'policies/authenticationMethodsPolicy/authenticationMethodConfigurations/x509Certificate' Path = 'Policies/AuthenticationMethodsPolicy/AuthenticationMethodConfigurations/X509Certificate.json' Tag = @('All', 'Config', 'Policies') DelegatedPermission = 'Policy.Read.All' ApplicationPermission = 'Policy.Read.All' }, @{ GraphUri = 'policies/adminConsentRequestPolicy' Path = 'Policies/AdminConsentRequestPolicy' Tag = @('All', 'Config', 'Policies') DelegatedPermission = 'Policy.Read.All' ApplicationPermission = 'Policy.Read.All' }, @{ GraphUri = 'policies/permissionGrantPolicies' Path = 'Policies/PermissionGrantPolicies' Tag = @('All', 'Config', 'Policies') DelegatedPermission = 'Policy.Read.PermissionGrant' ApplicationPermission = 'Policy.Read.PermissionGrant' }, @{ GraphUri = 'policies/externalIdentitiesPolicy' Path = 'Policies/ExternalIdentitiesPolicy' ApiVersion = 'beta' Tag = @('All', 'Config', 'Policies') DelegatedPermission = 'Policy.Read.All' ApplicationPermission = 'Policy.Read.All' }, @{ GraphUri = 'policies/crossTenantAccessPolicy' Path = 'Policies/CrossTenantAccessPolicy' ApiVersion = 'beta' Tag = @('All', 'Config', 'Policies') DelegatedPermission = 'Policy.Read.All' ApplicationPermission = 'Policy.Read.All' }, @{ GraphUri = 'policies/crossTenantAccessPolicy/default' Path = 'Policies/CrossTenantAccessPolicy/Default' ApiVersion = 'beta' Tag = @('All', 'Config', 'Policies') DelegatedPermission = 'Policy.Read.All' ApplicationPermission = 'Policy.Read.All' }, @{ GraphUri = 'policies/crossTenantAccessPolicy/partners' Path = 'Policies/CrossTenantAccessPolicy/Partners' ApiVersion = 'beta' Tag = @('All', 'Config', 'Policies') DelegatedPermission = 'Policy.Read.All' ApplicationPermission = 'Policy.Read.All' }, @{ GraphUri = 'identity/customAuthenticationExtensions' Path = 'Identity/CustomAuthenticationExtensions' ApiVersion = 'beta' Tag = @('All', 'Config') DelegatedPermission = 'Application.Read.All' ApplicationPermission = 'Application.Read.All' }, # Conditional Access @{ GraphUri = 'identity/conditionalAccess/policies' Path = 'Identity/Conditional/AccessPolicies' Tag = @('All', 'Config', 'ConditionalAccess') DelegatedPermission = 'Policy.Read.All' ApplicationPermission = 'Policy.Read.All' }, @{ GraphUri = 'identity/conditionalAccess/namedLocations' Path = 'Identity/Conditional/NamedLocations' Tag = @('All', 'Config', 'ConditionalAccess') DelegatedPermission = 'Policy.Read.All' ApplicationPermission = 'Policy.Read.All' }, # Identity Governance, @{ GraphUri = 'identityGovernance/entitlementManagement/accessPackages' Path = 'IdentityGovernance\EntitlementManagement\AccessPackages' ApiVersion = 'beta' Tag = @('All', 'Governance', 'EntitlementManagement') DelegatedPermission = 'EntitlementManagement.Read.All' ApplicationPermission = 'EntitlementManagement.Read.All' Children = @( @{ Command = 'Get-AADExportAccessPackageAssignmentPolicies' Path = 'AssignmentPolicies' Tag = @('All', 'Governance', 'EntitlementManagement') DelegatedPermission = 'EntitlementManagement.Read.All' ApplicationPermission = 'EntitlementManagement.Read.All' }, @{ Command = 'Get-AADExportAccessPackageAssignments' Path = 'Assignments' Tag = @('All', 'Governance', 'EntitlementManagement') DelegatedPermission = 'EntitlementManagement.Read.All' ApplicationPermission = 'EntitlementManagement.Read.All' }, @{ Command = 'Get-AADExportAccessPackageResourceScopes' Path = 'ResourceScopes' Tag = @('All', 'Governance', 'EntitlementManagement') DelegatedPermission = 'EntitlementManagement.Read.All' ApplicationPermission = 'EntitlementManagement.Read.All' } ) }, @{ GraphUri = 'identityGovernance/accessReviews/definitions' Path = 'IdentityGovernance/AccessReviews' ApiVersion = 'beta' Tag = @('All', 'AccessReviews', 'Governance') DelegatedPermission = 'AccessReview.Read.All' ApplicationPermission = 'AccessReview.Read.All' Children = @( @{ GraphUri = 'identityGovernance/accessReviews/definitions/{id}/instances' Path = '' Tag = @('All', 'AccessReviews', 'Governance') DelegatedPermission = 'AccessReview.Read.All' ApplicationPermission = 'AccessReview.Read.All' Children = @( @{ GraphUri = 'identityGovernance/accessReviews/definitions/{id}/instances/{id}/contactedReviewers' Path = 'Reviewers' ApiVersion = 'beta' Tag = @('All', 'AccessReviews', 'Governance') DelegatedPermission = 'AccessReview.Read.All' ApplicationPermission = 'AccessReview.Read.All' } ) } ) }, @{ GraphUri = 'identityGovernance/termsOfUse/agreements' Path = 'IdentityGovernance/TermsOfUse/Agreements' Tag = @('All', 'Config', 'Governance') DelegatedPermission = 'Agreement.Read.All' }, @{ GraphUri = 'identityGovernance/entitlementManagement/connectedOrganizations' Path = 'IdentityGovernance/EntitlementManagement/ConnectedOrganizations' ApiVersion = 'beta' Tag = @('All', 'Config') DelegatedPermission = 'EntitlementManagement.Read.All' ApplicationPermission = 'EntitlementManagement.Read.All' Children = @( @{ GraphUri = 'identityGovernance/entitlementManagement/connectedOrganizations/{id}/externalSponsors' Path = 'ExternalSponsors' ApiVersion = 'beta' Tag = @('All', 'Config', 'Governance') DelegatedPermission = 'EntitlementManagement.Read.All' ApplicationPermission = 'EntitlementManagement.Read.All' }, @{ GraphUri = 'identityGovernance/entitlementManagement/connectedOrganizations/{id}/internalSponsors' Path = 'InternalSponsors' ApiVersion = 'beta' Tag = @('All', 'Config', 'Governance') DelegatedPermission = 'EntitlementManagement.Read.All' ApplicationPermission = 'EntitlementManagement.Read.All' } ) }, @{ GraphUri = 'identityGovernance/entitlementManagement/settings' Path = 'IdentityGovernance/EntitlementManagement/Settings' ApiVersion = 'beta' Tag = @('All', 'Config', 'Governance') DelegatedPermission = 'EntitlementManagement.Read.All' ApplicationPermission = 'EntitlementManagement.Read.All' }, @{ GraphUri = 'AdministrativeUnits' Path = 'AdministrativeUnits' ApiVersion = 'beta' Tag = @('All', 'Config', 'AdministrativeUnits') DelegatedPermission = 'Directory.Read.All' ApplicationPermission = 'Directory.Read.All' Children = @( @{ GraphUri = 'administrativeUnits/{id}/members' Select = 'Id' Path = 'Members' ApiVersion = 'beta' Tag = @('All', 'Config', 'AdministrativeUnits') DelegatedPermission = 'Directory.Read.All' ApplicationPermission = 'Directory.Read.All' }, @{ GraphUri = 'administrativeUnits/{id}/scopedRoleMembers' Path = 'ScopedRoleMembers' ApiVersion = 'beta' Tag = @('All', 'Config', 'AdministrativeUnits') DelegatedPermission = 'Directory.Read.All' ApplicationPermission = 'Directory.Read.All' }, @{ GraphUri = 'administrativeUnits/{id}/extensions' Path = 'Extensions' ApiVersion = 'beta' Tag = @('All', 'Config', 'AdministrativeUnits') DelegatedPermission = 'Directory.Read.All' ApplicationPermission = 'Directory.Read.All' } ) }, # PIM @{ GraphUri = 'privilegedAccess/aadroles/resources' Path = 'PrivilegedAccess/AADRoles/Resources' ApiVersion = 'beta' Tag = @('All', 'Config', 'PIM', 'PIMAAD') DelegatedPermission = 'PrivilegedAccess.ReadWrite.AzureAD' ApplicationPermission = 'PrivilegedAccess.Read.AzureAD' Children = @( @{ GraphUri = 'privilegedAccess/aadroles/resources/{id}/roleDefinitions' Path = 'RoleDefinitions' ApiVersion = 'beta' Filter = "Type ne 'BuiltInRole'" Tag = @('All', 'Config', 'PIM', 'PIMAAD') DelegatedPermission = 'PrivilegedAccess.ReadWrite.AzureAD' ApplicationPermission = 'PrivilegedAccess.Read.AzureAD' }, @{ GraphUri = 'privilegedAccess/aadroles/resources/{id}/roleSettings' Path = 'RoleSettings' ApiVersion = 'beta' Filter = 'isDefault eq false' Tag = @('All', 'Config', 'PIM', 'PIMAAD') DelegatedPermission = 'PrivilegedAccess.ReadWrite.AzureAD' ApplicationPermission = 'PrivilegedAccess.Read.AzureAD' }, @{ GraphUri = 'privilegedAccess/aadroles/resources/{id}/roleAssignments' Path = 'RoleAssignments' ApiVersion = 'beta' Filter = 'endDateTime eq null' Tag = @('All', 'Config', 'PIM', 'PIMAAD') DelegatedPermission = 'PrivilegedAccess.ReadWrite.AzureAD' ApplicationPermission = 'PrivilegedAccess.Read.AzureAD' } ) }, @{ GraphUri = 'privilegedAccess/azureResources/resources' Path = 'PrivilegedAccess/AzureResources/Resources' ApiVersion = 'beta' IgnoreError = 'The tenant has not onboarded to PIM.' Tag = @('All', 'Config', 'PIM', 'PIMAzure') DelegatedPermission = 'PrivilegedAccess.ReadWrite.AzureResources' ApplicationPermission = 'PrivilegedAccess.Read.AzureResources' Children = @( @{ GraphUri = 'privilegedAccess/azureResources/resources/{id}/roleDefinitions' Path = 'RoleDefinitions' ApiVersion = 'beta' Filter = "Type ne 'BuiltInRole'" Tag = @('All', 'Config', 'PIM', 'PIMAzure') DelegatedPermission = 'PrivilegedAccess.ReadWrite.AzureResources' ApplicationPermission = 'PrivilegedAccess.Read.AzureResources' }, @{ GraphUri = 'privilegedAccess/azureResources/resources/{id}/roleSettings' Path = 'RoleSettings' ApiVersion = 'beta' Filter = 'isDefault eq false' Tag = @('All', 'Config', 'PIM', 'PIMAzure') DelegatedPermission = 'PrivilegedAccess.ReadWrite.AzureResources' ApplicationPermission = 'PrivilegedAccess.Read.AzureResources' }, @{ GraphUri = 'privilegedAccess/azureResources/resources/{id}/roleAssignments' Path = 'RoleAssignments' ApiVersion = 'beta' Filter = 'endDateTime eq null' Tag = @('All', 'Config', 'PIM', 'PIMAzure') DelegatedPermission = 'PrivilegedAccess.ReadWrite.AzureResources' ApplicationPermission = 'PrivilegedAccess.Read.AzureResources' } ) }, #Application Proxy @{ GraphUri = 'onPremisesPublishingProfiles/provisioning' QueryParameters = @{ expand = 'publishedResources,agents,agentGroups' } Path = 'OnPremisesPublishingProfiles/Provisioning.json' ApiVersion = 'beta' Tag = @('All', 'Config', 'AppProxy') DelegatedPermission = 'OnPremisesPublishingProfiles.ReadWrite.All' }, @{ GraphUri = 'onPremisesPublishingProfiles/provisioning/publishedResources' QueryParameters = @{ expand = 'agentGroups' } Path = 'OnPremisesPublishingProfiles/Provisioning/PublishedResources' ApiVersion = 'beta' Tag = @('All', 'Config', 'AppProxy') DelegatedPermission = 'OnPremisesPublishingProfiles.ReadWrite.All' }, @{ GraphUri = 'onPremisesPublishingProfiles/provisioning/agentGroups' QueryParameters = @{ expand = 'agents,publishedResources' } Path = 'OnPremisesPublishingProfiles/Provisioning/AgentGroups' ApiVersion = 'beta' Tag = @('All', 'Config', 'AppProxy') DelegatedPermission = 'OnPremisesPublishingProfiles.ReadWrite.All' }, @{ GraphUri = 'onPremisesPublishingProfiles/provisioning/agents' QueryParameters = @{ expand = 'agentGroups' } Path = 'OnPremisesPublishingProfiles/Provisioning/Agents' ApiVersion = 'beta' Tag = @('All', 'Config', 'AppProxy') DelegatedPermission = 'OnPremisesPublishingProfiles.ReadWrite.All' }, @{ GraphUri = 'onPremisesPublishingProfiles/applicationProxy/connectors' Path = 'OnPremisesPublishingProfiles/ApplicationProxy/Connectors' ApiVersion = 'beta' Tag = @('All', 'Config', 'AppProxy') DelegatedPermission = 'Directory.ReadWrite.All' }, @{ GraphUri = 'onPremisesPublishingProfiles/applicationProxy/connectorGroups' Path = 'OnPremisesPublishingProfiles/ApplicationProxy/ConnectorGroups' ApiVersion = 'beta' Tag = @('All', 'Config', 'AppProxy') DelegatedPermission = 'Directory.ReadWrite.All' Children = @( @{ GraphUri = 'onPremisesPublishingProfiles/applicationProxy/connectorGroups/{id}/applications' Path = 'Applications' ApiVersion = 'beta' IgnoreError = 'ApplicationsForGroup_NotFound' Tag = @('All', 'Config', 'AppProxy') DelegatedPermission = 'Directory.ReadWrite.All' }, @{ GraphUri = 'onPremisesPublishingProfiles/applicationProxy/connectorGroups/{id}/members' Path = 'Members' ApiVersion = 'beta' IgnoreError = 'ConnectorGroup_NotFound' Tag = @('All', 'Config', 'AppProxy') DelegatedPermission = 'Directory.ReadWrite.All' } ) }, # Groups # need to looks at app roles assignements # expanding app roles assignements breaks 'ne' filtering (needs eventual consistency and count) @{ GraphUri = 'groups' Filter = "groupTypes/any(c:c eq 'DynamicMembership')" Path = 'Groups' QueryParameters = @{ '$count' = 'true'; expand = 'extensions' } ApiVersion = 'beta' Tag = @('All', 'Config', 'Groups') DelegatedPermission = 'Directory.Read.All' ApplicationPermission = 'Directory.Read.All' Children = @( @{ GraphUri = 'groups/{id}/members' Select = 'id, userPrincipalName, displayName' Path = 'Members' Tag = @('All', 'Groups') DelegatedPermission = 'Directory.Read.All' ApplicationPermission = 'Directory.Read.All' } @{ GraphUri = 'groups/{id}/owners' Select = 'id, userPrincipalName, displayName' Path = 'Owners' Tag = @('All', 'Config', 'Groups') DelegatedPermission = 'Directory.Read.All' ApplicationPermission = 'Directory.Read.All' } ) }, @{ GraphUri = 'groupSettings' Path = 'GroupSettings' Tag = @('All', 'Config', 'Groups') DelegatedPermission = 'Directory.Read.All' ApplicationPermission = 'Directory.Read.All' }, # Applications @{ GraphUri = 'applications' Path = 'Applications' Tag = @('All', 'Applications') DelegatedPermission = 'Directory.Read.All' ApplicationPermission = 'Directory.Read.All' Children = @( @{ GraphUri = 'applications/{id}/extensionProperties' Path = 'ExtensionProperties' Tag = @('All', 'Applications') DelegatedPermission = 'Directory.Read.All' ApplicationPermission = 'Directory.Read.All' }, @{ GraphUri = 'applications/{id}/owners' Select = 'id, userPrincipalName, displayName' Path = 'Owners' Tag = @('All', 'Applications') DelegatedPermission = 'Directory.Read.All' ApplicationPermission = 'Directory.Read.All' }, @{ GraphUri = 'applications/{id}/tokenIssuancePolicies' Path = 'TokenIssuancePolicies' Tag = @('All', 'Applications') DelegatedPermission = 'Policy.Read.All' ApplicationPermission = 'Policy.Read.All','Application.ReadWrite.All' }, @{ GraphUri = 'applications/{id}/tokenLifetimePolicies' Path = 'TokenLifetimePolicies' Tag = @('All', 'Applications') DelegatedPermission = 'Policy.Read.All' ApplicationPermission = 'Policy.Read.All','Application.ReadWrite.All' } ) }, # Service Principals @{ GraphUri = 'servicePrincipals' Path = 'ServicePrincipals' Tag = @('All', 'ServicePrincipals') DelegatedPermission = 'Directory.Read.All' ApplicationPermission = 'Directory.Read.All' Children = @( @{ GraphUri = 'servicePrincipals/{id}/appRoleAssignments' Path = 'AppRoleAssignments' Tag = @('All', 'ServicePrincipals') DelegatedPermission = 'Directory.Read.All' ApplicationPermission = 'Directory.Read.All' }, @{ GraphUri = 'servicePrincipals/{id}/appRoleAssignedTo' Path = 'AppRoleAssignedTo' Tag = @('All', 'ServicePrincipals') DelegatedPermission = 'Directory.Read.All' ApplicationPermission = 'Directory.Read.All' }, @{ GraphUri = 'servicePrincipals/{id}/oauth2PermissionGrants' Path = 'Oauth2PermissionGrants' Tag = @('All', 'ServicePrincipals') DelegatedPermission = 'Directory.Read.All' ApplicationPermission = 'Directory.Read.All' }, @{ GraphUri = 'servicePrincipals/{id}/delegatedPermissionClassifications' Path = 'DelegatedPermissionClassifications' Tag = @('All', 'ServicePrincipals') DelegatedPermission = 'Directory.Read.All' ApplicationPermission = 'Directory.Read.All' }, @{ GraphUri = 'servicePrincipals/{id}/owners' Select = 'id, userPrincipalName, displayName' Path = 'Owners' Tag = @('All', 'ServicePrincipals') DelegatedPermission = 'Directory.Read.All' ApplicationPermission = 'Directory.Read.All' }, @{ GraphUri = 'servicePrincipals/{id}/claimsMappingPolicies' Path = 'claimsMappingPolicies' Tag = @('All', 'ServicePrincipals') DelegatedPermission = 'Policy.Read.All' ApplicationPermission = 'Policy.Read.All','Application.ReadWrite.All' }, @{ GraphUri = 'servicePrincipals/{id}/homeRealmDiscoveryPolicies' Path = 'homeRealmDiscoveryPolicies' Tag = @('All', 'ServicePrincipals') DelegatedPermission = 'Policy.Read.All' ApplicationPermission = 'Policy.Read.All','Application.ReadWrite.All' }, @{ GraphUri = 'servicePrincipals/{id}/tokenIssuancePolicies' Path = 'tokenIssuancePolicies' Tag = @('All', 'ServicePrincipals') DelegatedPermission = 'Policy.Read.All' ApplicationPermission = 'Policy.Read.All','Application.ReadWrite.All' }, @{ GraphUri = 'servicePrincipals/{id}/tokenLifetimePolicies' Path = 'tokenLifetimePolicies' Tag = @('All', 'ServicePrincipals') DelegatedPermission = 'Policy.Read.All' ApplicationPermission = 'Policy.Read.All','Application.ReadWrite.All' } ) }, # Users # Todo look at app roles assignments @{ GraphUri = 'users' Path = 'Users' Filter = $null QueryParameters = @{ '$count' = 'true'; expand = "extensions" } ApiVersion = 'beta' Tag = @('All', 'Users') DelegatedPermission = 'Directory.Read.All' ApplicationPermission = 'Directory.Read.All' Children = @( @{ GraphUri = 'users/{id}/authentication/fido2Methods' Path = 'Authentication/FIDO2Methods' Tag = @('All', 'Users') DelegatedPermission = 'UserAuthenticationMethod.Read.All' ApplicationPermission = 'UserAuthenticationMethod.Read.All' }, @{ GraphUri = 'users/{id}/authentication/microsoftAuthenticatorMethods' Path = 'Authentication/MicrosoftAuthenticatorMethods' Tag = @('All', 'Users') DelegatedPermission = 'UserAuthenticationMethod.Read.All' ApplicationPermission = 'UserAuthenticationMethod.Read.All' }, @{ GraphUri = 'users/{id}/authentication/windowsHelloForBusinessMethods' Path = 'Authentication/WindowsHelloForBusinessMethods' Tag = @('All', 'Users') DelegatedPermission = 'UserAuthenticationMethod.Read.All' ApplicationPermission = 'UserAuthenticationMethod.Read.All' }, @{ GraphUri = 'users/{id}/authentication/temporaryAccessPassMethods' Path = 'Authentication/TemporaryAccessPassMethods' ApiVersion = 'beta' Tag = @('All', 'Users') DelegatedPermission = 'UserAuthenticationMethod.Read.All' ApplicationPermission = 'UserAuthenticationMethod.Read.All' }, @{ GraphUri = 'users/{id}/authentication/phoneMethods' Path = 'Authentication/PhoneMethods' ApiVersion = 'beta' Tag = @('All', 'Users') DelegatedPermission = 'UserAuthenticationMethod.Read.All' ApplicationPermission = 'UserAuthenticationMethod.Read.All' }, @{ GraphUri = 'users/{id}/authentication/emailMethods' Path = 'Authentication/EmailMethods' ApiVersion = 'beta' Tag = @('All', 'Users') DelegatedPermission = 'UserAuthenticationMethod.Read.All' ApplicationPermission = 'UserAuthenticationMethod.Read.All' }, @{ GraphUri = 'users/{id}/authentication/passwordMethods' Path = 'Authentication/PasswordMethods' ApiVersion = 'beta' Tag = @('All', 'Users') DelegatedPermission = 'UserAuthenticationMethod.Read.All' ApplicationPermission = 'UserAuthenticationMethod.Read.All' } ) } ) } |