Skip to content

Commit

Permalink
Merge remote-tracking branch 'upstream/Dev' into Dev
Browse files Browse the repository at this point in the history
  • Loading branch information
FabienTschanz committed Oct 10, 2023
2 parents 3eeba6b + 235e283 commit 116abae
Show file tree
Hide file tree
Showing 64 changed files with 16,502 additions and 11,972 deletions.
34 changes: 34 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,39 @@

# UNRELEASED

* EXODistributionGroup
* Fixes the export of group membership to use Identity.

# 1.23.1004.1

* AADEntitlementManagementAccessPackageAssignmentPolicy
* [BREAKING CHANGE] Fixes customExtension property where the schema and assignement
were not managed correctly.
FIXES [#3639](https://github.com/microsoft/Microsoft365DSC/issues/3639)
* AADEntitlementManagementConnectedOrganization
* Fixed [[#3738](https://github.com/microsoft/Microsoft365DSC/issues/3738)]
* EXOCalendarProcessing
* Initial release.
* EXODistributionGroup
* [BREAKING CHANGE] Identity is now a primary key.
FIXES [#3741](https://github.com/microsoft/Microsoft365DSC/issues/3741)
* Added support for multiple new properties to align with supporting cmdlet.
* EXOMailboxAutoReplyConfiguration
* Initial release.
* EXOMailboxCalendarFolder
* Initial release.
* EXOMailboxPermission
* Initial release.
* EXOPlace
* Initial release.
* IntunePolicySets
* New Configuration for Intune Policy Sets
* DEPENDENCIES
* Updated MSCloudLoginAssistant to version 1.0.121.
* MISC
* TestHarness.psm1
* Added code around DscTestsPath parameter to target a single test file
during development

# 1.23.927.1

Expand All @@ -16,6 +47,9 @@
* Improvements to how rules are evaluated and how drifts are logged.
* O365OrgSettings
* Changes to how ToDo discrepencies are being fixed in the SET method.
* M365DSCDRGUtil
* Added support for Intune URIs to be dynamic based on target
cloud instance (Commercial, GCC-H..etc)
* DEPENDENCIES
* Updated Microsoft.Graph to version 2.6.1.
* Updated Microsoft.PowerApps.Administration.PowerShell to version 2.0.117.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -271,11 +271,9 @@ function Get-TargetResource
foreach ($customExtensionHandler in $getValue.CustomExtensionHandlers)
{
$customExt = @{
Id = $customExtensionHandler.Id
#Id = $customExtensionHandler.Id #Read Only
Stage = $customExtensionHandler.Stage
CustomExtension = @{
Id = $customExtensionHandler.CustomExtension.Id
}
CustomExtensionId = $customExtensionHandler.CustomExtension.Id
}
$formattedCustomExtensionHandlers += $customExt
}
Expand Down Expand Up @@ -476,6 +474,21 @@ function Set-TargetResource
}
}
}
If ($null -ne $CreateParameters.CustomExtensionHandlers -and $CreateParameters.CustomExtensionHandlers.count -gt 0 )
{
$formattedCustomExtensionHandlers = @()
foreach ($customExtensionHandler in $CreateParameters.CustomExtensionHandlers)
{
$extensionId= $customExtensionHandler.CustomExtensionId
$formattedCustomExtensionHandlers += @{
stage = $customExtensionHandler.Stage
customExtension = @{
id = $extensionId
}
}
}
$CreateParameters.CustomExtensionHandlers = $formattedCustomExtensionHandlers
}
New-MgBetaEntitlementManagementAccessPackageAssignmentPolicy `
-BodyParameter $CreateParameters
}
Expand Down Expand Up @@ -503,7 +516,7 @@ function Set-TargetResource
# Convert back user principal names to Ids
if ($null -ne $UpdateParameters.AccessReviewSettings -and $null -ne $UpdateParameters.AccessReviewSettings.Reviewers)
{
Write-Verbose -Message "Updating Reviewers' Id"
#Write-Verbose -Message "Updating Reviewers' Id"
for ($i = 0; $i -lt $UpdateParameters.AccessReviewSettings.Reviewers.Length; $i++)
{
$reviewer = $UpdateParameters.AccessReviewSettings.Reviewers[$i]
Expand All @@ -516,10 +529,10 @@ function Set-TargetResource
}
if ($null -ne $UpdateParameters.RequestorSettings -and $null -ne $UpdateParameters.RequestorSettings.AllowedRequestors)
{
Write-Verbose -Message "Updating Requestors' Id"
#Write-Verbose -Message "Updating Requestors' Id"
for ($i = 0; $i -lt $UpdateParameters.RequestorSettings.AllowedRequestors.Length; $i++)
{
Write-Verbose -Message "Requestor: $($UpdateParameters.RequestorSettings.AllowedRequestors[$i].Id)"
#Write-Verbose -Message "Requestor: $($UpdateParameters.RequestorSettings.AllowedRequestors[$i].Id)"
$requestor = $UpdateParameters.RequestorSettings.AllowedRequestors[$i]
$user = Get-MgUser -Filter "startswith(UserPrincipalName, '$($requestor.Id.Split('@')[0])')" -ErrorAction SilentlyContinue
if ($null -ne $user)
Expand All @@ -528,6 +541,23 @@ function Set-TargetResource
}
}
}
If ($null -ne $UpdateParameters.CustomExtensionHandlers -and $UpdateParameters.CustomExtensionHandlers.count -gt 0 )
{
$formattedCustomExtensionHandlers = @()
foreach ($customExtensionHandler in $UpdateParameters.CustomExtensionHandlers)
{
$extensionId= $customExtensionHandler.CustomExtensionId
$formattedCustomExtensionHandlers += @{
stage = $customExtensionHandler.Stage
customExtension = @{
id = $extensionId
}
}
}
$UpdateParameters.CustomExtensionHandlers = $formattedCustomExtensionHandlers
}

#write-verbose ($UpdateParameters|convertto-json -Depth 100)
Set-MgBetaEntitlementManagementAccessPackageAssignmentPolicy `
-BodyParameter $UpdateParameters `
-AccessPackageAssignmentPolicyId $currentInstance.Id
Expand Down Expand Up @@ -885,23 +915,6 @@ function Export-TargetResource
}
if ($null -ne $Results.CustomExtensionHandlers )
{
$complexMapping = @(
@{
Name = 'AuthenticationConfiguration'
CimInstanceName = 'MicrosoftGraphcustomextensionauthenticationconfiguration'
IsRequired = $false
}
@{
Name = 'ClientConfiguration'
CimInstanceName = 'MicrosoftGraphcustomextensionclientconfiguration'
IsRequired = $false
}
@{
Name = 'EndpointConfiguration'
CimInstanceName = 'MicrosoftGraphcustomextensionauthenticationconfiguration'
IsRequired = $false
}
)
$complexTypeStringResult = Get-M365DSCDRGComplexTypeToString `
-ComplexObject $Results.CustomExtensionHandlers `
-CIMInstanceName MicrosoftGraphcustomextensionhandler `
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -84,38 +84,10 @@ class MSFT_MicrosoftGraphrequestorsettings
[ClassVersion("1.0.0")]
class MSFT_MicrosoftGraphcustomextensionhandler
{
[Write, Description("Indicates which custom workflow extension will be executed at this stage."), EmbeddedInstance("MSFT_MicrosoftGraphcustomaccesspackageworkflowextension")] String CustomExtension;
[Write, Description("Indicates which custom workflow extension will be executed at this stage.")] String CustomExtensionId;
[Write, Description("Indicates the stage of the access package assignment request workflow when the access package custom extension runs."), ValueMap{"assignmentRequestCreated","assignmentRequestApproved","assignmentRequestGranted","assignmentRequestRemoved","assignmentFourteenDaysBeforeExpiration","assignmentOneDayBeforeExpiration","unknownFutureValue"}, Values{"assignmentRequestCreated","assignmentRequestApproved","assignmentRequestGranted","assignmentRequestRemoved","assignmentFourteenDaysBeforeExpiration","assignmentOneDayBeforeExpiration","unknownFutureValue"}] String Stage;
[Write, Description("Identifier of the stage.")] String Id;
};
[ClassVersion("1.0.0")]
class MSFT_MicrosoftGraphcustomaccesspackageworkflowextension
{
[Write, Description("Configuration for securing the API call to the logic app. For example, using OAuth client credentials flow."), EmbeddedInstance("MSFT_MicrosoftGraphcustomextensionauthenticationconfiguration")] String AuthenticationConfiguration;
[Write, Description("HTTP connection settings that define how long Azure AD can wait for a connection to a logic app, how many times you can retry a timed-out connection and the exception scenarios when retries are allowed."), EmbeddedInstance("MSFT_MicrosoftGraphcustomextensionclientconfiguration")] String ClientConfiguration;
[Write, Description("Description for the customAccessPackageWorkflowExtension object.")] String Description;
[Write, Description("Display name for the customAccessPackageWorkflowExtension object.")] String DisplayName;
[Write, Description("The type and details for configuring the endpoint to call the logic app's workflow."), EmbeddedInstance("MSFT_MicrosoftGraphcustomextensionendpointconfiguration")] String EndpointConfiguration;
[Write, Description("Identifier for the customAccessPackageWorkflowExtension object.")] String Id;
};
[ClassVersion("1.0.0")]
class MSFT_MicrosoftGraphcustomextensionauthenticationconfiguration
{
[Write, Description("The appID of the Azure AD application to use to authenticate a logic app with a custom access package workflow extension.")] String ResourceId;
};
[ClassVersion("1.0.0")]
class MSFT_MicrosoftGraphcustomextensionclientconfiguration
{
[Write, Description("The max duration in milliseconds that Azure AD will wait for a response from the logic app before it shuts down the connection. The valid range is between 200 and 2000 milliseconds. Default duration is 1000.")] UInt32 TimeoutInMilliseconds;
};
[ClassVersion("1.0.0")]
class MSFT_MicrosoftGraphcustomextensionendpointconfiguration
{
[Write, Description("The name of the logic app."), EmbeddedInstance("MSFT_MicrosoftGraphcustomextensionauthenticationconfiguration")] String LogicAppWorkflowName;
[Write, Description("The Azure resource group name for the logic app."), EmbeddedInstance("MSFT_MicrosoftGraphcustomextensionclientconfiguration")] String ResourceGroupName;
[Write, Description("Identifier of the Azure subscription for the logic app.")] String SubscriptionId;
};

[ClassVersion("1.0.0.0"), FriendlyName("AADEntitlementManagementAccessPackageAssignmentPolicy")]
class MSFT_AADEntitlementManagementAccessPackageAssignmentPolicy : OMI_BaseResource
{
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -313,8 +313,10 @@ function Set-TargetResource
$CreateParameters.$key = Convert-M365DSCDRGComplexTypeToHashtable -ComplexObject $CreateParameters.$key
}
}

$newConnectedOrganization = New-MgBetaEntitlementManagementConnectedOrganization -BodyParameter $CreateParameters
$TenantId = $CreateParameters.IdentitySources.ExternalTenantId
$url = $Global:MSCloudLoginConnectionProfile.MicrosoftGraph.ResourceUrl + "beta/tenantRelationships/microsoft.graph.findTenantInformationByTenantId(tenantId='$tenantid')"
$DomainName = (Invoke-MgGraphRequest -Method 'GET' -Uri $url).defaultDomainName
$newConnectedOrganization = New-MgBetaEntitlementManagementConnectedOrganization -Description $CreateParameters.Description -DisplayName $CreateParameters.DisplayName -State $CreateParameters.State -DomainName $DomainName

foreach ($sponsor in $ExternalSponsors)
{
Expand Down
Loading

0 comments on commit 116abae

Please sign in to comment.