10
votes

I have msi and wants to check whether vsto run-time is installed on target machine, I have used launch condition through VS2008 in my msi but it only redirect user to vendor's website. I just want to install the prerequisite if it is not installed on machine and want the prerequisite to be installed during the msi is running. It can be summarized as:

When msi is running:

  1. It must check whether the prerequisite is installed if yes then resume the installation
  2. If not then install the prerequisite first and then resume the msi installation

I searched and find many solution like single package executable, vb script in custom action, but requirement is not to ship anything with the installer neither the exe is acceptable :(

I have orca installed but dont have much knowledge to customizing msi using Orca

Your help is appreciated.. Thanks in advance...

4

4 Answers

4
votes

WIX is one of the most powerful (and free) tools for creating Windows installers. There's an end-to-end article I wrote a while ago on Creating a localized Windows Installer & bootstrapper, which may help.

You can enforce prerequisites by defining conditions in the WIX file, for example.

<Condition Message="[ProductName] requires the Microsoft .NET Framework 4 Client Profile">
    Installed Or NETFRAMEWORK40CLIENT
</Condition>

However to install the prerequisite, you will need a boostrapper (EXE).

The article above shows how to use dotNetInstaller to create managed EXEs, which check and install these prerequisites before executing the embedded MSI at the end. You can of course also just chain a load of MSIs together as well, it's really flexible.

I believe WIX also has a tool called Burn which was meant to be released in 3.5, I haven't used it, but it also provides bootstrap functionality.

Orca isn't really used for compling MSIs, it's just useful for debugging and digging around inside.

3
votes

You cannot run multiple .msi packages simultaneously so if a pre-req is .msi-based, it won't work. (Remember that many .msi-based packages are wrapped in .exes.)

3
votes

Since an EXE bootstrapper is not acceptable, there is only one solution:

  • store the prerequisite installers in Binary table of your MSI
  • create some custom actions which extract them from this table and launch them
  • schedule them in InstallUISequence, for example right before Progress dialog
  • use searches to detect if the prerequisites are installed or not
  • condition your custom actions with the search results

Basically, you need to launch them during the installation UI. It may not work if the custom actions run during InstallExecuteSequence.

This is not supported by Visual Studio, but some commercial setup authoring tools have direct support for it. If you want a free solution you can use WiX, but you will need to write the custom actions yourself.

1
votes

As you may already know, the setup.exe file that Visual Studio generates for you can install many prerequisites. However, your question states that you must ship only an MSI file, so the setup.exe isn't going to help.

Instead, you can create your own program to install the prerequisite(s). Include the program in the install, so that it will bundled into the MSI for you, then set up a custom action to run it at install time. You can even set a flag in the installer so that the program will not actually be installed on the target machine - instead it will just be bundled into the MSI and made available to the installer.

If you are already installing .NET-based code, the solution is even easier: Add a project installer class to your existing code, then set a custom action to run the installer class. Note, however, that this approach will not work if the prerequisite you wish to install is the .NET runtime itself.