May 12 2023 02:45 PM - edited Dec 11 2023 10:47 AM
Hi whomever may find this!
With the old MS Partner Community Forums going read-only as of March 8th, 2023 I thought I'd post a few useful links here in case someone is searching and unable to post on the old forums.
The 2 main GDAP related threads on the old forum that feature info on getting Secure App Model to work with GDAP and the Exchange Online V3 PowerShell module (with the ExO automation App ID: a0c73c16-a7e3-4564-9a95-2bdf47383716 being retired eventually) are:
These are both long threads, lots of info in a meandering kind of way. They disappeared after June 30th, 2023 - so these are links to the Internet Archive's WaybackMachine. But they're how we worked it all out - so useful background.
So the best place to find current, step-by-step instructions for getting things to work is this post:
My Automations Break with GDAP: The Fix!
It appears Nick has collected up all the info from the above 2 links, tested it, and made a fairly complete blog post, so start there. (note: for the ExO V3 stuff you must use the Customer's initial onmicrosoft.com domain for things to work properly) Big thanks to him!
Nick has 2 additional posts that may be of interest as well. One on Leveraging APIs for unattended Automation. And one on Updating the GDAP Consents across all your Customers.
For some background info you can check out some of these links:
Hopefully that helps someone!
--Saul
[Edited to add the WaybackMachine links and Nick's new posts]
May 14 2023 09:34 PM
Jun 23 2023 01:31 AM - edited Jun 23 2023 01:35 AM
Excellent post!
For Exchange you can also talk directly to Exchange REST. An important pitfall there is the existence of the "anchor mailbox" concept. Usually that's either the environments system mailbox (for example to enable Unified Audit logs) or the mailbox of whatever resource you're trying to make a change to.
The system anchor mailbox in any given tenant is almost identical, the only difference is the TLD. The TLD for the mailbox will always be the initial onmicrosoft domain.
"UPN:SystemMailbox{bb558c35-97f1-4cb9-8ff7-d53741dc928c}@$($OnMicrosoft)"
Jun 23 2023 09:03 AM
Thanks @rvdwegen92 ,
Yes I'm aware that you can directly connect to ExO using REST - that's how the new ExO V3 module does it (if you install it and look at the code you'll see some of how it works). And also how Kelvin's CIPP back-end API connects to Exch Online.
However I imagine if someone is doing that they A) already know how to connect and B) have specific purposes: generally trying to create some kind of larger automated system, using APIs entirely and not relying on PowerShell at all. (CIPP uses PowerShell, but it could just as easily be written in Node/JS for example if it uses only REST APIs)
I think for the average scripter trying to automate some aspects of AAD, Azure, ExO, etc using the Secure App Model they are probably looking at using existing PowerShell modules due to likely familiarity with them plus re-using existing code. I do for any of my ExO scripts, just simpler.
For anyone writing a full app using APIs - I'd definitely recommend using the ExO REST APIs! 🙂
--Saul
Jun 30 2023 02:00 AM
Jun 30 2023 09:17 AM
@SimonasPikelis , the old MSOnline / Msol module does not work with GDAP. You'll need to migrate to MS Graph.
--Saul
Aug 17 2023 10:25 PM
But as I know, MS Graph does not have tools for setting up per-user MFA (to check or to set Enable, Enforce, Disable status). So I still use MSOnline module for that. And this is not working without DAP.
Aug 20 2023 09:41 PM
Hi @bKeski,
That is correct, as of now this cannot be done via MS Graph.
Nevertheless, the old PowerShell modules will been discontinued until March 2024:
Aug 20 2023 10:33 PM
Aug 28 2023 11:53 AM
@bKeski ,
Correct, and as others have noted: Per-User MFA isn't yet fully available in the MS Graph API, though parts of it are in the beta end-point:
https://learn.microsoft.com/en-us/graph/api/resources/userregistrationdetails?view=graph-rest-beta
You can add your voice to speed this up:
https://feedbackportal.microsoft.com/feedback/idea/12d10bfb-10e3-ec11-a81b-000d3a03dba2
Sadly, while the MS Online and Azure AD Graph based modules will be deprecated March 30th, 2024 [and "Once these modules are deprecated, they will continue to work for a minimum of six (6) months before being retired"], they are currently not receiving any new features:
I assume this means making them work with GDAP - they only support DAP.
So while they may continue to work throughout most of 2024 they won't work for Partners using GDAP (which is now required) since they rely upon DAP. I don't have an answer for that.
Maybe @JillArmour can dig into things on the Microsoft side of things and see what we're supposed to do: we must use GDAP not DAP, but that means using MS Graph, but it doesn't support Per-User MFA actions, and the older MSOnline module relies upon the older Azure AD Graph which doesn't support GDAP. So we're stuck.
And Per-User MFA is still supported, even if it's not the ideal way of managing MFA.
--Saul
Aug 29 2023 09:51 AM
Jun 19 2024 12:54 PM
Do you have any articles about using Get-MsalToken instead of the partner center powershell module? Ps7 doesn't play well with the az and partnercenter modules togeather.
Is this an abandonware? · microsoft/Partner-Center-PowerShell · Discussion #400 · GitHub
Jun 19 2024 01:39 PM
Jun 20 2024 07:41 AM
Yes, I'm not sure I would put much stock in Microsoft's desire (or willingness) to update and support various PowerShell modules these days (with 2 exceptions: the auto/machine-generated MgGraph module, which "works" but isn't really user-friendly. And the ExchangeOnlineManagement module, currently at V3 -- which is generally pretty good) ... the PartnerCenter and other modules are either not maintained or are deprecated (and will likely stop working entirely when AzureAD Graph is retired).
I would suggest making direct REST API calls, which can be done in PowerShell, for example:
$body = @{
"grant_type" = "refresh_token"
"refresh_token" = $RefreshToken
"client_id" = $ClientId
"client_secret" = $ClientSecret
"resource" = "https://api.partnercenter.microsoft.com"
}
$response = Invoke-RestMethod -Uri "https://login.microsoftonline.com/$TenantId/oauth2/token" -Method Post -Body $body -ContentType "application/x-www-form-urlencoded"
This is how Kelvin's CIPP app works (the source-code for the back-end API will show you some examples using PowerShell - including authenticating to Partner Center, Graph, and even API access to Exch Online. Or you can use any language (I've mainly switched to JavaScript/Node). Nick's T-Minus365 site I linked to above has some examples as well, look for the REST API / Invoke-RestMethod sections.
Unless the community is going create a module, or fork and maintain existing modules, you're better off making yourself a collection of a few scripts/functions (eg, to redeem an RefreshToken for an AccessToken, make API calls with the AccessToken, and perform a "get-all" for when there's more than one page of results, and some functions to provision the GDAP App Consent, etc) than relying upon a PowerShell module that may work now, but may not in the future...
--Saul