Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[microsoft-teams-new-bootstrapper] Can we download the MSIX? #163

Open
flcdrg opened this issue Dec 29, 2023 · 20 comments
Open

[microsoft-teams-new-bootstrapper] Can we download the MSIX? #163

flcdrg opened this issue Dec 29, 2023 · 20 comments

Comments

@flcdrg
Copy link
Owner

flcdrg commented Dec 29, 2023

The bootstrapper.exe can download the MSIX. Is it possible for chocolateyInstall.ps1 to do this instead?

https://learn.microsoft.com/en-us/microsoftteams/new-teams-bulk-install-client#option-1b-download-and-install-new-teams-using-an-offline-installer

@QuimaxW
Copy link

QuimaxW commented Dec 29, 2023

My hunch is that these links will be stable to the current version of the msix, regardless of it's version on a given day.

x86: https://go.microsoft.com/fwlink/?linkid=2196060&clcid=0x409
x64: https://go.microsoft.com/fwlink/?linkid=2196106
ARM64: https://go.microsoft.com/fwlink/?linkid=2196207&clcid=0x409

I don't think the chocolatey package could be versioned off of those though.

@QuimaxW
Copy link

QuimaxW commented Dec 29, 2023

Redistribution rights shouldn't be an issue as the machine installing the package is pulling everything from Microsoft's servers at the time of install. Only folks who are internalizing the package for their organizational use would need worry about redistribution. However, as Microsoft has instructions for doing exactly that, it's being expected in that scenario that the redistribution is happening.

Another workaround for my case would be that we build a custom package for this that would have everything in the package.

@flcdrg
Copy link
Owner Author

flcdrg commented Dec 29, 2023

Those links resolve to

Those URLs at first glance don't look like they probably change when the binary files change, which is disappointing. Will have to take another look when a new version is released.

@flcdrg
Copy link
Owner Author

flcdrg commented Dec 29, 2023

For reference, the AppManifest.xml file inside the x64 msix contains this, which might be useful as a version marker.

  <Identity Name="MSTeams" Version="23320.3021.2567.4799" Publisher="CN=Microsoft Corporation, O=Microsoft Corporation, L=Redmond, S=Washington, C=US" ProcessorArchitecture="x64" />

@flcdrg
Copy link
Owner Author

flcdrg commented Jan 18, 2024

A new version of the package was generated overnight. Interestingly the msix files haven't changed (and are a bit outdated compared to the version of Teams I have installed locally).

I'm going to create a separate package for the MSIX files, with the intention that this package can depend on that one.

@flcdrg
Copy link
Owner Author

flcdrg commented Jan 18, 2024

Interesting to compare the bootstrapper version numbers to the ones reported in Teams.

image

image

@teknowledgist
Copy link

Maybe this is an ignorant comment, but I don't understand why the bootstrapper and MSIX are separate Chocolatey packages. The goal here is to have a known version of (New) Teams installed, right? Do either of the bootstrapper or MSIX make it possible to know which version of Teams is ultimately installed?

If not, then is it even possible to know there is a one-to-one match between the Teams version and either of these download versions? How can we know what version of Teams, Chocolatey will be installing?

If the Teams version can be identified, then why not just make the package download both the bootstrapper and MSIX files and keep the package management simple? The chocolateyinstall.ps1 code might not be so simple, but the user will have a lot less confusing time of tracking it. Look at the Adobe reader package, for example. It might have to download/install the "base" version and then an updater, or it might just need to install the updater. In the end though, the user doesn't need to worry about all that.

If I'm misunderstanding something, feel free to explain (or not) and I'll shut up.

@flcdrg
Copy link
Owner Author

flcdrg commented Jan 22, 2024

It is a good question and one I thought about (and one that could be reversed in the future). I decided to go with separate packages as the two parts do seem to be versioned separately, and updated on a different schedule.

Even then, the MSIX downloads don't always appear to be the latest version that you can get if you check for updates within Teams, but maybe Microsoft are just being a bit conservative when they update the download URLs.

Also worth noting - this package is only good for pre-installing Teams on a machine the first time.. It isn't any good for updating Teams once you are using it (as far as I know). So the choco version numbers would also quickly be outdated once the client starts self-updating.

@flcdrg
Copy link
Owner Author

flcdrg commented Jan 22, 2024

The "two package" solutions is just in preview, so now is a good time to discuss if it makes sense or not. Feedback welcome!

@QuimaxW
Copy link

QuimaxW commented Jan 22, 2024

@teknowledgist - My goal was to have a self-contained package that would internalize properly and not require a separate download which would slow down deployments. This would also have a benefit of bringing in a fairly current version of Teams as well.

However, as @flcdrg mentioned, unless one has a way of turning off the auto-updating of Teams, this package becomes quickly out of sync with Microsoft's versions. Just keeping with the current version could be a full time job to do it manually. We'd need a script that would download the bootstrapper and the msix, extract the version number, update the nuspec file(s), and upload those back to the community repo on a near nightly basis.

What I'm likely to do for our internal repo is have a script run weekly to pull the MSI file down to a local http server. Use the bootstrapper package, modified to use this http location as the source for the MSIx. This would follow the same model we use for Office365, where the package version is only bumped when we need to force a reinstall of the product.

@flcdrg
Copy link
Owner Author

flcdrg commented Jan 23, 2024

@QuimaxW I don't use Chocolatey for Business, though I have heard of the internalising stuff. Does the internalising thing mean you'd prefer a single package, or is having two packages fine?

As far as I know, this "install it just once" is pretty much the same behaviour as the old Teams Enterprise installer. Once the bits are on the machine then Teams will self-update for each user on that machine.

@teknowledgist
Copy link

That Chocolatey package versions can be used "just for install" and the app upgrades itself is not terribly unique. Look at Firefox or Chrome. I do think Teams is different from those in that the self-updates are per-user.

The "Old Teams" enterprise installer was actually an installer-installer. It would install the per-user installer so that said installer would run on login of each user. The per-user installer would either install Teams or would upgrade Teams, but the Chocolatey package version would still match the enterprise installer version. I don't know if the per-user installer would install the "installed" version on first run and then update to the latest (whether immediately automatically, immediately if incompatibilities were discovered, or the next time the user logged in) or would download the latest version to install. I do know that the "install on login" slowed down new user logins and was tremendously annoying in classrooms and labs where Teams might be wanted, but only on demand. The per-user nature of it also meant that a choco uninstall would only remove the "installer-installer", but all existing user profiles would continue to have (and update) Teams.

I am assuming the "New Teams" installer is a similar kind of bastard, and thus, I still think the package should be focused on the version of Teams that will result on a clean install (i.e. first login). I should clarify that to the version of Teams before it updates itself. For example, the version of Teams that a new user would see if there was no Internet access for Teams to update itself. Like "Old Teams", the version any user has/uses will not match the Chocolatey package version, but the "primed" installer should continue to match the Chocolatey version.

My issue with having two packages is that they each seem meaningless without the other. Who cares if they have version xyz of the bootstrapper (or MSIX) if they don't know what version of Teams will result from a fresh install of it? How are you going to know what versions of the two downloads are compatible with each other? I think a "mono-package" is better for internalizing too. You are basically "freezing" the installer version and don't need to worry about the versions of the individual downloads.

As for how you determine the version of Teams to name/version the package... I don't know. MS is really terrible about some software download and/or versioning. I have to troubleshoot the OneDrive package all the time because they change the URL without changing the version or the reverse, or sometimes change both without updating the announcement page.

Anyway, that's my $.02. Thanks for the discussion opportunity.

@flcdrg
Copy link
Owner Author

flcdrg commented Jan 24, 2024

You're bringing me around to the idea of having a single package - but yes as you hint at, then the question is, how do I version that package?

The MSIX version seems like it would be useful (as it corresponds with what you'd see in the UI - see screenshot above), but it is already a 4-part version, so there's no way to safely increment it when a new bootstrapper.exe was released but the MSIX was not updated.

The version numbers is probably the stumbling block to having a "mono-package"

@teknowledgist
Copy link

I suspect it is unlikely that the bootstrapper would update without the MSIX changing. However, given that this IS Microsoft...

OneDrive is also a "full", 4-part version, so when MS plays their three-card monte game and changes download URLs without changing the version (or other disorganization), I just add one to the last number. I don't know any software anywhere that both uses a full version number AND releases single increments on the last number. Take your example above. How likely is Microsoft to release version 23320.3027.2591.1506 after version 23320.3027.2591.1505? There is no Chocolatey rule that says the package version has to match the software version except for a possible date string in the build version slot.

@flcdrg
Copy link
Owner Author

flcdrg commented Jan 24, 2024

Unfortunately Microsoft have done just that. The MSIX was last updated early December, but bootstrapper was updated as recently as a week ago.

The date string in the build version slot is an interesting idea. It would be helpful to see how Microsoft do change the MSIX versions over time. If they always rev the 3rd number, then we could mess with the 4th safely.

@flcdrg
Copy link
Owner Author

flcdrg commented Jan 24, 2024

Found a published Teams client version history here - https://learn.microsoft.com/en-us/officeupdates/teams-app-versioning?WT.mc_id=DOP-MVP-5001655#windows-version-history

The current MSIX download version is 23320.3021.2567.4799 which doesn't match any of the recent Windows versions, but seems to be between the two December releases

Release year Release date Teams version Slimcore version
2023 December 27 23320.3027.2591.1505 2023.44.01.03
2023 December 07 23306.3315.2560.6525 2023.43.01.22

The 4th number does change, so that is promising

@flcdrg
Copy link
Owner Author

flcdrg commented Feb 10, 2024

Thanks @ItzLevvie for that detailed info. That will be helpful in figuring out a version for the package.

@flcdrg
Copy link
Owner Author

flcdrg commented Mar 1, 2024

I've just published a preview version of a combined package - https://community.chocolatey.org/packages/microsoft-teams-new-bootstrapper/1.0.2402201.24004-pre. The version number uses the first 3 parts of the bootstrapper version and the first component (the YYDDD bit) of the Teams 2.1 Enterprise version.

choco install microsoft-teams-new-bootstrapper --version=1.0.2402201.24004-pre --pre 

Questions:

  1. I added the MSIX version to the title, but is that too much (it is also documented in the description)
  2. Anything else you think needs including (description updates etc)?
  3. The package will be updated on new bootstrapper versions. Would you expect it to be also updated for every MSIX release, or just the "lkg" versions?

thanks!

@michael-franck
Copy link
Contributor

Mind if I pitch in on point 3. I would suggest to also update on MSIX releases.

Getting the version from the file should be fairly straightforward in Chocolatey.

Set-Alias -Name 7z -Value $Env:chocolateyInstall\tools\7z.exe
7z e <msixBundle> AppxManifest.xml
[xml]$manifest =  get-content .\AppxManifest.xml
$version = $manifest.Package.Identity.Version

@flcdrg
Copy link
Owner Author

flcdrg commented May 12, 2024

@ItzLevvie do you happen to know if there are version-specific URLs for teamsbootstrapper.exe?

I'm not sure if there's inconsistencies in the CDN, but while working on updating this package, I noticed I'm getting different versions being offered when hitting https://statics.teams.cdn.office.net/production-teamsprovision/lkg/teamsbootstrapper.exe - sometimes the older version, sometimes the newer one. Obviously this doesn't play nice with Chocolatey's requirement to compare a checksum hash.

eg.
image

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants