- Updated the New-IntuneWin32AppPackage function to work properly after the latest version of the IntuneWinAppUtil.exe was recently updated.
- Improved the output from the
Get-IntuneWin32AppAssignment
function with new properties such as FilterID, FilterType, DeliveryOptimizationPriority, Notifications, RestartSettings and InstallTimeSettings. Also improved function to generate same type of output instead of different per parameter set. Fixed issue #108 related to the same function. - All function of this module that requires the usage of an access token, has been updated to make use of the
Test-AccessToken
function, to ensure an eligible token is present. - Fixed issue #78 where
Get-IntuneWin32App
could not return more than the first 1000 objects, if more existed. This function now supports pagination. - Added support for the new 'Installation time required' configuration option for Win32 applications, to the
Add-IntuneWin32App
function as a new parameter namedMaximumInstallationTimeInMinutes
. - Added client certification authentication flow support in the
Connect-MSIntuneGraph
function. - Added a new function named
Remove-IntuneWin32AppAssignmentGroup
function to support the removal of a group from assignment configuration of a specific Win32 app. - Added Filter support for the
Add-IntuneWin32AppAssignmentAllDevices
,Add-IntuneWin32AppAssignmentAllUsers
andAdd-IntuneWin32AppAssignmentGroup
functions. - Improved
New-IntuneWin32AppPackage
function to better handle paths passed into the function, to use both -Path and -LiteralPath parameters to support wildcard characters. This fixes issue #113. - Both functions
Remove-IntuneWin32AppDependency
andRemove-IntuneWin32AppSupersedence
have been improved to only remove the actual relationships objects they originally were intended to remove, not all types as it would previously. This fixed what has been reported in #105. - Private function
Get-IntuneWin32AppRelationshipsExistence
converted to public function and renamed toGet-IntuneWin32AppRelationship
.
- Added a new function named
Test-AccessToken
, to assist when the current token is about to expire. This function will returnFalse
when the existing token is about to expire, within the give time frame defined in RenewalThresholdMinutes function parameter. Default is 10 minutes. Add-IntuneWin32App
andSet-IntuneWin32App
functions have been updated to support the new feature to allow of uninstallations of applications with an available assignment. At release of this version of the IntuneWin32App module, this feature has not publicly been announced by Microsoft, other than mentioned briefly in the 'In Development' documentation. However it has been available to be configured through Graph API for a couple of months at this point, hence this new functionality within the module is just for preparation of what's to come. The code of this module might have to be changed once the feature is publicly available and documented. Use this at your own risk.- Fixed an issue with the Scope Tag functionality in the
Add-IntuneWin32App
function, where it would not return any Scope Tag id when authenticated as a user that is a member of a role in Intune (previously it only worked if the authenticated user was e.g. an Intune Administrator). - Fixed issue #68 related to the
Add-IntuneWin32App
function when a RequirementRule object was not passed as parameter input, and the function would use default values. - Added a new sample file called
9-Token refresh.ps1
to demonstrate how to handle token refresh scenarios in long running scripts. New-IntuneWin32AppRequirementRule
function has been updated to support the newly added minimum operating system version of Windows 10 and 11. This change introduces a breaking change of existing scripts, since the new values that can be provided for the MinimumSupportedWindowsRelease parameter have been altered with a prefix of W10_ and W11_ to easier separate between the different operating system versions.
- Properly fixed the issue with the public
New-IntuneWin32AppRequirementRule
and the privateNew-IntuneWin32AppBody
functions to ensure the minimumFreeDiskSpaceInMB, MinimumMemoryInMB, MinimumNumberOfProcessors and minimumCpuSpeedInMHz objets are dynamically added to the request body, only if specificed on the command line with theNew-IntuneWin32AppRequirementRule
function. - Added parameter AzCopyWindowStyle to
Add-IntuneWin32App
function, to support what's discussed in issue #64. - Updated public
Add-IntuneWin32App
,New-IntuneWin32AppIcon
,Expand-IntuneWin32AppPackage
,Get-IntuneWin32AppMetaData
,New-IntuneWin32AppDetectionRuleScript
,New-IntuneWin32AppRequirementRuleScript
,Update-IntuneWin32AppPackageFile
and privateExpand-IntuneWin32AppCompressedFile
functions with improved file name validation which replaces the regex validation which was prohibiting usage of the module on non-Windows platforms, but also preventing accessing files on network shares. - Added support for a new parameter named ScopeTagName for the
Add-IntuneWin32App
function. Scope Tags can now be added when creating the Win 32 application in Intune. This parameter supports multiple Scope Tags to be added at the same time. - Improved error handling in
Invoke-AzureADGraphRequest
andInvoke-IntuneGraphRequest
functions reported in issue #65. - Added UnattendedInstall and UnattendedUninstall parameter switches to the
Add-IntuneWin32App
function. For MSI based setup installers, you can now specify whether to automatically append the install and/or uninstall command lines with the /quiet switch. - Fixed bug reported in issue #57.
New-IntuneWin32AppPackage
function now uses the -q switch when invoking the IntuneWinAppUtil.exe wrapper utility. In addition to this, the check for existing .intunewin file has been embeded into the function itself, where the new Force parameter can be used to always overwrite an existing .intunewin file in the output directory.- Added a new function named
Set-IntuneWin32App
. Use this function to update properties of an existing Win32 app in Intune, for instance to change the app version, description, display name, owner or notes among other properties. - Added a new function named
Get-IntuneWin32AppCategory
, to retrieve a given mobile app category, also referred to as category, by display name or to list all available categories. - Updated
Add-IntuneWin32App
function with a new parameter named CategoryName, that supports multiple category names, to add support for adding categories to the Win32 app when creating it. - Updated
Add-IntuneWin32App
function with a new behavior when the UseAzCopy switch is used, to fallback to the native file transfer method if the content size is less than 100MB. - Deprecated and removed the
Add-IntuneWin32AppAssignment
function, use the following functions instead to manage all assignments aspects:Add-IntuneWin32AppAssignmentAllDevices
,Add-IntuneWin32AppAssignmentAllUsers
,Add-IntuneWin32AppAssignmentGroup
. - Deprecated and removed the
New-IntuneWin32AppDetectionRuleFile
function, use the following functions instead to manage all detection rule aspects:New-IntuneWin32AppDetectionRuleFile
,New-IntuneWin32AppDetectionRuleMSI
,New-IntuneWin32AppDetectionRuleRegistry
,New-IntuneWin32AppDetectionRuleScript
.
- Add-IntuneWin32App function now has a new parameter switch named UseAzCopy. When this switch is used, AzCopy.exe is used to transfer the files to the storage account instead of the native method.
- New-IntuneWin32AppRequirementRule has been updated to construct the proper objects. The minimumFreeDiskSpaceInMB, MinimumMemoryInMB, MinimumNumberOfProcessors and minimumCpuSpeedInMHz objects when not specified as parameters now adds a 'null' string instead of $null (not being part of the object returned).
- Private function Invoke-IntuneGraphRequest has been updated with UTF-8 encoding content type support. From this version and on, when the script file is properly encoded with UTF-8 with BOM, special characters should now work as expected.
- Connect-MSIntuneGraph function has been updated to store the TenantID parameter in a global variable named $Global:AccessTokenTenantID.
- Private function Invoke-AzureStorageBlobUpload used in Add-IntuneWin32App function now refreshes an access token 10 minutes before it's about to expire. This should prevent uploads of large applications from failing due to the access token has expired.
- Private function New-IntuneWin32AppBody used in Add-IntuneWin32App function, was updated where the minimumSupportedOperatingSystem property is replaced by minimumSupportedWindowsRelease. This caused the Add-IntuneWin32App function to return Bad Request since the request body was malformed.
NOTE:
This change introduces a new parameter for New-IntuneWin32AppRequirementRule function named MinimumSupportedWindowsRelease that replaces the MinimumSupportedOperatingSystem parameter. - Also fixed a bug in private function New-IntuneWin32AppBody where minimumFreeDiskSpaceInMB, minimumMemoryInMB, minimumNumberOfProcessors and minimumCpuSpeedInMHz properties where not handled at all.
- Add-IntuneWin32App function was updated where a break command that would prevent the Win32 app body JSON output from being display in case an error occured, was removed.
- New-IntuneWin32AppRequirementRuleScript and New-IntuneWin32AppDetectionRuleScript functions was fixed as reported on: MSEndpointMgr#41
- New-IntuneWin32AppRequirementRuleScript has been updated with correct variables for 'Version'.
- Added ClientSecret parameter in the Connect-MSIntuneGraph function to support the client secret auth flow
- New-IntuneWin32AppReturnCode function now supports Failed as a return code type
- Fixed an issue where the ExpiresOn property of the access token was stored in local time instead of UTC
- Added AppVersion optional parameter for Add-IntuneWin32App function
- Fixed an issue in the Update-IntuneWin32AppPackageFile function where the PATCH operation would remove the largeIcon property value of the Win32 app
- Fixed an issue in the New-IntuneWin32AppDetectionRuleScript and New-IntuneWin32AppRequirementRuleScript functions when using a non-UTF encoded multi-line script file, it would not be imported to Intune
- Switched from PSIntuneAuth module to use the MSAL.PS module. Delegated authentication including DeviceCode flows are now supported.
- New function added to extend the functionality of the module:
- Remove-IntuneWin32App
- Get-IntuneWin32AppDependency
- New-IntuneWin32AppDependency
- Add-IntuneWin32AppDependency
- Remove-IntuneWin32AppDependency
- Get-IntuneWin32AppSupersedence
- New-IntuneWin32AppSupersedence
- Add-IntuneWin32AppSupersedence
- Remove-IntuneWin32AppSupersedence
- Get-IntuneWin32AppAssignment function now includes the GroupMode property (Include/Exclude) in the output
- Add-IntuneWin32App function includes a fix in private functions it relies upon to successfully upload the packaged content. This fix addresses bug #3 where the SAS Uri renewal process wasn't working properly.
- Connect-MSIntuneGraph function has been added to replace the TenantName parameter for all functions that requires an authentication token. Use this function to retrieve the authentication token before running any of the functions that creates, updates or changes any aspect of a Win32 app.
- New functions added to extend the functionality of the module:
- Connect-MSIntuneGraph
- New-IntuneWin32AppDetectionRuleScript
- New-IntuneWin32AppDetectionRuleMSI
- New-IntuneWin32AppDetectionRuleRegistry
- New-IntuneWin32AppDetectionRuleFile
- Update-IntuneWin32AppPackageFile
- Add-IntuneWin32AppAssignmentAllDevices
- Add-IntuneWin32AppAssignmentAllUsers
- Add-IntuneWin32AppAssignmentGroup
- New-IntuneWin32AppRequirementRuleScript
- New-IntuneWin32AppRequirementRuleRegistry
- New-IntuneWin32AppRequirementRuleFile
- Get-IntuneWin32AppAssignment
- Remove-IntuneWin32AppAssignment
- Add-IntuneWin32AppAssignment function is deprecated from this release going forward, use any of the new functions added in this release, for instance Add-IntuneWin32AppAssignmentGroup.
- New-IntuneWin32AppDetectionRule function is deprecated from this release going forward, use any of the new functions added in this release, for instance New-IntuneWin32AppDetectionRuleMSI.
- Add-IntuneWin32App function now supports additional properties, such as Information URL, Display app in Company Portal, Privacy URL, Developer, Owner and Comments.
- Add-IntuneWin32AppAssignmentAllDevices, Add-IntuneWin32AppAssignmentAllUsers and Add-IntuneWin32AppAssignmentGroup functions now support restart settings including available and deadline configurations.
- Add-IntuneWin32App function now cleans up the sub-folder created with the extracted .intunewin file.
- Get-IntuneWin32AppAssignment function has a new parameter called GroupName, that can be used to retrieve a list of the assignments targeted for a given group.
- Improved output for attempting to update the PSIntuneAuth module in the internal Get-AuthToken function.
- Added a new function called Get-MSIMetaData to retrieve MSI file properties like ProductCode and more.
- Added a new function called New-IntuneWin32AppRequirementRule to create a customized requirement rule for the Win32 app. This function does not support 'Additional requirement rules' as of yet, but will be implemented in a future version.
- Function Add-IntuneWin32App now supports an optional RequirementRule parameter. Use New-IntuneWin32AppRequirementRule function to create a suitable object for this parameter. If the RequirementRule parameter is not specified for Add-IntuneWin32App, default values of 'applicableArchitectures' with a value of 'x64,x86' and 'minimumSupportedOperatingSystem' with a value of 'v10_1607' will be used when adding the Win32 app.
- Updated Get-IntuneWin32App function to load all properties for objects return and support multiple objects returned for wildcard search when specifying display name.
- Initial release, se README.md for documentation.