198 lines
8.9 KiB
XML
198 lines
8.9 KiB
XML
<?xml version="1.0" encoding="UTF-8"?>
|
|
<!--
|
|
TeamsISO — MSI installer (WiX v5)
|
|
|
|
Produces: TeamsISO-Setup-<Version>.msi (per-machine install).
|
|
|
|
Build:
|
|
dotnet publish src/TeamsISO.App/TeamsISO.App.csproj -c Release -r win-x64 (no self contained) -o publish/TeamsISO
|
|
dotnet build installer/TeamsISO.Installer.wixproj -c Release
|
|
|
|
Runtime expectations:
|
|
- .NET 8 Desktop runtime present on target (framework-dependent build)
|
|
- NDI 6 Runtime present — checked in CheckNdiRuntime; absence WARNS
|
|
but does not block install (operators can install NDI after the app)
|
|
-->
|
|
<Wix xmlns="http://wixtoolset.org/schemas/v4/wxs"
|
|
xmlns:ui="http://wixtoolset.org/schemas/v4/wxs/ui">
|
|
|
|
<Package Name="TeamsISO"
|
|
Manufacturer="Wild Dragon LLC"
|
|
Version="1.0.0.0"
|
|
UpgradeCode="9F4A8B2C-1D3E-4A5B-9C6D-8E7F0A1B2C3D"
|
|
Scope="perMachine"
|
|
Compressed="yes"
|
|
InstallerVersion="500">
|
|
|
|
<!--
|
|
SummaryInformation fields surface in File Explorer's "Details" tab and
|
|
in the Windows Installer "About" dialog. Description and Keywords are
|
|
what users see if they right-click the MSI before installing; Comments
|
|
is the longer copy that appears alongside the version in some
|
|
installer dialogs.
|
|
-->
|
|
<SummaryInformation
|
|
Description="TeamsISO — per-participant NDI ISO controller for Microsoft Teams. Splits each Teams participant into a normalized NDI source for vMix / OBS / Ross / hardware switchers."
|
|
Manufacturer="Wild Dragon LLC"
|
|
Keywords="NDI, Microsoft Teams, ISO recording, broadcast, live production, vMix, OBS, switcher, Wild Dragon" />
|
|
|
|
<!--
|
|
MajorUpgrade: a newer install replaces an older one in-place. We
|
|
disallow downgrades because the engine config schema only carries a
|
|
forward-migration path; downgrading would leave operators with a
|
|
config the older binary doesn't understand.
|
|
-->
|
|
<MajorUpgrade DowngradeErrorMessage="A newer version of TeamsISO is already installed. Uninstall it before installing this older version."
|
|
Schedule="afterInstallInitialize" />
|
|
|
|
<!--
|
|
Single MSI feature; users see only the install/uninstall screens.
|
|
-->
|
|
<Feature Id="Main" Title="TeamsISO" Level="1">
|
|
<ComponentGroupRef Id="ApplicationFiles" />
|
|
<ComponentGroupRef Id="Shortcuts" />
|
|
<ComponentGroupRef Id="DesktopShortcut" />
|
|
<ComponentGroupRef Id="ArpEntry" />
|
|
</Feature>
|
|
|
|
<!--
|
|
Friendly install UI. WixToolset.UI.wixext provides several flavors;
|
|
WixUI_InstallDir lets the user pick the directory.
|
|
-->
|
|
<ui:WixUI Id="WixUI_InstallDir" />
|
|
<Property Id="WIXUI_INSTALLDIR" Value="INSTALLFOLDER" />
|
|
|
|
<!--
|
|
Add/Remove Programs metadata. ARPHELPLINK is the "Help" link; ARPURLINFOABOUT
|
|
is the manufacturer/about link; ARPCONTACT is the support contact shown
|
|
when the user clicks "Support information" from the ARP entry. ARPCOMMENTS
|
|
is the long description displayed in some Settings → Apps surfaces.
|
|
-->
|
|
<Property Id="ARPHELPLINK" Value="https://forge.wilddragon.net/zgaetano/teamsiso" />
|
|
<Property Id="ARPURLINFOABOUT" Value="https://wilddragon.net" />
|
|
<Property Id="ARPCONTACT" Value="Wild Dragon LLC — support@wilddragon.net" />
|
|
<Property Id="ARPCOMMENTS" Value="TeamsISO turns Microsoft Teams' raw NDI broadcast into clean, normalized, per-participant NDI sources for ingestion by a live-production switcher (vMix, OBS, Ross, hardware capture). Each participant gets an individually-addressable source with configurable framerate, resolution, aspect mode, and audio routing." />
|
|
<!-- ARPNOMODIFY is set by WixUI_InstallDir; don't redeclare. -->
|
|
<Property Id="ARPNOREPAIR" Value="1" />
|
|
|
|
<!--
|
|
ARP icon — references the same .ico the WPF host uses. WiX requires the
|
|
icon resource to live next to the wxs OR be reachable at build time;
|
|
we point at the published copy under src/TeamsISO.App/Assets so the icon
|
|
embedded in the MSI matches the icon in the running exe.
|
|
-->
|
|
<Icon Id="TeamsISOIcon" SourceFile="$(var.AssetsDir)teamsiso.ico" />
|
|
<Property Id="ARPPRODUCTICON" Value="TeamsISOIcon" />
|
|
|
|
<!--
|
|
NDI Runtime detection. We check for NDI_RUNTIME_DIR_V6 in the system
|
|
environment block. Missing → warn during install, don't block. The
|
|
engine surfaces a clear MessageBox with an install-NDI link at first
|
|
launch if the runtime really isn't there.
|
|
-->
|
|
<Property Id="NDIRUNTIMEDIR" Value="0">
|
|
<RegistrySearch Id="NdiRuntimeDirV6Search"
|
|
Root="HKLM"
|
|
Key="SYSTEM\CurrentControlSet\Control\Session Manager\Environment"
|
|
Name="NDI_RUNTIME_DIR_V6"
|
|
Type="raw" />
|
|
</Property>
|
|
|
|
<!--
|
|
NDI runtime detection is surfaced at first app launch (App.xaml.cs pops a
|
|
MessageBox with an install link). We deliberately don't block install on
|
|
a missing runtime so admins can stage the app before NDI is rolled out.
|
|
VBScript-based install-time prompts are deprecated in WiX v5 / Windows
|
|
and rewriting in C++ is overkill for a soft warning.
|
|
-->
|
|
|
|
<!--
|
|
Install layout under Program Files\Wild Dragon\TeamsISO.
|
|
-->
|
|
<StandardDirectory Id="ProgramFiles64Folder">
|
|
<Directory Id="ManufacturerFolder" Name="Wild Dragon">
|
|
<Directory Id="INSTALLFOLDER" Name="TeamsISO" />
|
|
</Directory>
|
|
</StandardDirectory>
|
|
|
|
<StandardDirectory Id="ProgramMenuFolder">
|
|
<Directory Id="WildDragonStartMenuFolder" Name="Wild Dragon" />
|
|
</StandardDirectory>
|
|
|
|
<!--
|
|
Files: harvested from the publish output dir at build time.
|
|
WiX v5 understands <Files Include="..."> with glob patterns and
|
|
synthesizes one Component per file with stable GUIDs.
|
|
-->
|
|
<ComponentGroup Id="ApplicationFiles" Directory="INSTALLFOLDER">
|
|
<Files Include="$(var.PublishDir)**" />
|
|
</ComponentGroup>
|
|
|
|
<!--
|
|
Start Menu and Desktop shortcuts — direct .exe targets.
|
|
|
|
Don't wrap the Target in runas.exe /trustlevel:0x20000 (or anything
|
|
else that demotes the spawned process). The SAFER-restricted token
|
|
breaks .NET 8 WPF apphost startup: the process appears alive with
|
|
a window, but no managed code past BAML parse executes. Verified
|
|
empirically 2026-05-16 — letting TeamsISO inherit the launching
|
|
token (medium or high integrity, doesn't matter) is the correct
|
|
behavior. NDI discovery works fine at either integrity level.
|
|
-->
|
|
<ComponentGroup Id="Shortcuts" Directory="WildDragonStartMenuFolder">
|
|
<Component Id="StartMenuShortcut" Guid="*">
|
|
<Shortcut Id="StartMenuTeamsISO"
|
|
Name="TeamsISO"
|
|
Description="Per-Participant NDI ISO Controller for Microsoft Teams"
|
|
Target="[INSTALLFOLDER]TeamsISO.exe"
|
|
WorkingDirectory="INSTALLFOLDER"
|
|
Icon="TeamsISOIcon" />
|
|
<!-- Required by ICE64: Start Menu folder must be cleaned on uninstall. -->
|
|
<RemoveFolder Id="RemoveWildDragonStartMenuFolder"
|
|
Directory="WildDragonStartMenuFolder"
|
|
On="uninstall" />
|
|
<RegistryValue Root="HKCU"
|
|
Key="Software\Wild Dragon\TeamsISO"
|
|
Name="StartMenuShortcut"
|
|
Type="integer"
|
|
Value="1"
|
|
KeyPath="yes" />
|
|
</Component>
|
|
</ComponentGroup>
|
|
|
|
<StandardDirectory Id="DesktopFolder" />
|
|
<ComponentGroup Id="DesktopShortcut" Directory="DesktopFolder">
|
|
<Component Id="DesktopShortcutComponent" Guid="*">
|
|
<Shortcut Id="DesktopTeamsISO"
|
|
Name="TeamsISO"
|
|
Description="Per-Participant NDI ISO Controller for Microsoft Teams"
|
|
Target="[INSTALLFOLDER]TeamsISO.exe"
|
|
WorkingDirectory="INSTALLFOLDER"
|
|
Icon="TeamsISOIcon" />
|
|
<RegistryValue Root="HKCU"
|
|
Key="Software\Wild Dragon\TeamsISO"
|
|
Name="DesktopShortcut"
|
|
Type="integer"
|
|
Value="1"
|
|
KeyPath="yes" />
|
|
</Component>
|
|
</ComponentGroup>
|
|
|
|
<!--
|
|
ARP icon registry entry. Optional — the MSI auto-fills most ARP
|
|
fields from the Package element. We only need to point at the
|
|
executable for the ARP icon.
|
|
-->
|
|
<ComponentGroup Id="ArpEntry" Directory="INSTALLFOLDER">
|
|
<Component Id="ArpIconRegistry" Guid="*">
|
|
<RegistryValue Root="HKLM"
|
|
Key="Software\Wild Dragon\TeamsISO"
|
|
Name="InstallPath"
|
|
Type="string"
|
|
Value="[INSTALLFOLDER]"
|
|
KeyPath="yes" />
|
|
</Component>
|
|
</ComponentGroup>
|
|
|
|
</Package>
|
|
</Wix>
|