Microsoft IIS

IIS 8 (Windows Server 2012)

Note

There is a batch script autoconfig.bat in the folder [engineDir]/misc/iis of your engine installation, which installs and configures the IIS automatically on a Windows 2012 Server. If you are setting up a new IIS Server you can use this script instead of following the instructions below.

  1. If your Microsoft Internet Information Server is not running on the same host as the Axon.ivy Engine then copy the integration directory to the host where your IIS is running. All next steps have to be done on the host the IIS is running on.

  2. Allow the user groups Authenticated Users and IUSR to have Full control permission on the integration directory.

    ../../_images/iis-directory-security.png
  3. Install Features

    Note

    Instead of installing the features manually you can run the following command which ensures that all necessary IIS Features are installed:

    PKGMGR.EXE /iu:IIS-WebServerRole;IIS-WebServer;IIS-CommonHttpFeatures;IIS-StaticContent;IIS-DefaultDocument;IIS-DirectoryBrowsing;IIS-HttpErrors;IIS-ApplicationDevelopment;IIS-CGI;IIS-ISAPIExtensions;IIS-ISAPIFilter;IIS-HealthAndDiagnostics;IIS-HttpLogging;IIS-RequestMonitor;IIS-Security;IIS-WindowsAuthentication;IIS-RequestFiltering;IIS-Performance;IIS-HttpCompressionStatic;IIS-WebServerManagementTools;IIS-ManagementScriptingTools;IIS-ManagementService
    

    Open the Server Manager (Start > Server Manager). Select the Web Server (IIS). Validate that under the Role Services the services CGI, ISAPI Extensions and ISAPI Filters are installed. If this is not the case select the menu Add Role Services to install the missing services.

    ../../_images/iis-server-manager.png
  4. Feature delegation

    Note

    The following command automatically sets the feature delegation:

    powershell -ExecutionPolicy unrestricted -ImportSystemModules Set-WebConfiguration //System.webServer/handlers -metadata overrideMode -value Allow -PSPath IIS:/
    

    Open the Internet Information Services (IIS) Manager (Start > Internet Information Services (IIS) Manager). In the Connections pane select the node that represent your machine. In the Feature View open the Feature Delegation entry.

    ../../_images/iis-feature-delegation.png

    Ensure that the Delegation of the Handler Mappings are set to Read/Write. Use the menu Read/Write on the Actions pane to change the Delegation to Read/Write.

    ../../_images/iis-edit-feature-delegation.png
  5. Virtual ivy directory

    Note

    The following commands automatically creates the virtual directory ivy:

    set path=%path%;%windir%\system32\inetsrv
    appcmd.exe add vdir /app.name:"Default Web Site/" /path:/ivy /physicalPath:<replace this with the path to the integration directory>
    

    In the Connections pane navigate to the Web Site you want integrate the Axon.ivy Engine into. Use the context menu Add Virtual Directory … of the Web Site to add a new Virtual Directory. A dialog opens. Configure the Alias of the Virtual Directory with ivy and the Physical path of the Virtual Directory with the path of the integration directory. Click OK to close the dialog and create the Virtual Directory:

    ../../_images/iis-add-virtual-directory.png
  6. Handler Mapping Permissions

    Note

    The following command automatically sets the feature permission for the ivy virtual directory:

    appcmd.exe set config "Default Web Site/ivy" /section:system.webServer/handlers /accessPolicy:Read,Write,Execute
    

    Select the new created Virtual Directory ivy in the Connections pane and open the Handler Mappings entry in the Feature View:

    ../../_images/iis-edit-feature-permission.png

    In the Actions pane select the Edit Feature Permissions … menu:

    ../../_images/iis-handler-mappings.png

    On the Edit Feature Permission dialog select all three permission and click OK:

    ../../_images/iis-add-execute-permission.png
  7. Configure Error Page

    Note

    The following command automatically configures that the detailed error page of the Engine is shown:

    appcmd.exe set config "Default Web Site/ivy" /section:system.webServer/httpErrors /errorMode:Detailed
    

    Tip

    See the web.xml for more information about this configuration.

    Select the new created Virtual Directory ivy in the Connections pane and open the Error Pages entry in the Feature View:

    ../../_images/iis-error-pages-select.png

    Right click and select Edit Feature Settings… or select the same from the Actions pane (in the right hand side)

    ../../_images/iis-error-pages-edit-feature.png

    Select the Detailed errors radio button and click on OK

    ../../_images/iis-error-pages-set-detailed-errors.png
  8. Install ISAPI filter

    Note

    The following command automatically adds the ISAPI Filter:

    appcmd.exe set config /section:isapiFilters /+[@start,name='Tomcat',path='<replace this with the path to the integration directory>\isapi_redirect-1.2.42.dll']
    

    Select the Web Site in the Connections pane and open the ISAPI Filters entry in the Feature View:

    ../../_images/iis-isapi-filter.png

    In the Actions pane select the Add … menu:

    ../../_images/iis-isapi-filter-add.png

    On the Add ISAPI Filter dialog configure the Filter name with Axon.ivy Engine and the Executable with the path of the isapi_redirect-1.2.42.dll located in the integration directory. Click OK to add the ISAPI Filter:

    ../../_images/iis-isapi-filter-add-dialog.png
  9. Change ISAPI filter restriction

    Note

    The following command automatically adds the ISAPI Restriction:

    appcmd.exe set config /section:isapiCgiRestriction /+[@start,description='Tomcat',path='<replace this with the path to the integration directory>\isapi_redirect-1.2.42.dll',allowed='true']
    

    In the Connections pane select the node that represent your machine and open the ISAPI and CGI Restrictions entry in the Features View:

    ../../_images/iis-isapi-restriction.png

    In the Actions pane select the Add … menu:

    ../../_images/iis-isapi-restriction-add.png

    On the Add ISAPI or CGI Restriction dialog configure the ISAPI or CGI path with the path of the isapi_redirect-1.2.42.dll located in the integration directory. As Description use Axon.ivy Engine. Select the Allow extension path to execute check box. Click OK to add the ISAPI or CGI Restriction:

    ../../_images/iis-isapi-restriction-add-dialog.png
  10. If your Microsoft Internet Information Server is not running on the same host as the Axon.ivy Engine or if you have changed the AJP port of the Axon.ivy Engine then open the file worker.properties inside the integration directory in a text editor. Change the following line if you have changed the AJP port to another value than 8009:

    worker.AxonIvyEngine.port=8009
    

    Change the value localhost in the following line to the host where your Axon.ivy Engine is running if your Microsoft Internet Information Server is not running on the same host as the Axon.ivy Engine:

    worker.AxonIvyEngine.host=localhost
    
  11. Update the external base URL as shown in the ivy.webserver.yaml

  12. Check if the integration is working by opening a web browser on the address http://<your host>/ivy/

Change context URI /ivy/

You might like to make the Axon.ivy engine accessible under a custom context URI other than /ivy.

  1. Change the context name of Axon.ivy as shown in the ivy.webserver.yaml

    # sample ivy.yaml that configures a different context:
    # so Axon.ivy will be accessible trough <a href="http://localhost/workflow">http://localhost/workflow</a>
    WebServer.IvyContextName: workflow
    
  2. Change the context name of the Microsoft IIS by changing the last line of the uriworkermap.properties configuration file:

    #/ivy/* AxonIvyEngine
    /workflow/*=AxonIvyEngine
    
  3. If you’re using AJP, you will also need to modify the misc/iis/isapi_redirect.properties file:

    extension_uri=/workflow/isapi_redirect.dll
    

Access multiple Axon.ivy Engines through one IIS

Multiple Axon.ivy Engine instances can be accessed through a single IIS server. This is especially useful if multiple Axon.ivy versions must be accessible during a migration phase. The following explanation shows a solution for the scenario, where a legacy Xpert.ivy 3.9 Server and an Axon.ivy 5.x Engine must be accessible through a single IIS host.

  1. Make the newer Axon.ivy Engine accessible through the IIS as if only one engine would be behind the IIS. For detailed instructions follow Microsoft IIS Integration.

    In our scenario the integration directory from the Axon.ivy 5.x Engine was used to make the engine instance accessible under http://localhost/ivy.

  2. The contexts of the Axon.ivy Engines must be unique. By default the context is set to /ivy/. If different versions of ivy engines are accessed from the same IIS host, it’s useful to change the contexts so that it matches the ivy version. For detailed explanation see Change context URI /ivy/

    In our scenario the context URI of the Axon.ivy 5.x Engine was changed to /ivy5/ and the Xpert.ivy 3.9 Server kept his default context /ivy/.

  3. All Axon.ivy Engines, which are accessed from the same IIS, must listen on a different port for AJP communication. Therefore the AJP port must be changed. This can be configured as shown in the ivy.webserver.yaml.

    In our scenario the AJP port of the Axon.ivy 7.x Engine was changed to 8010 and the Xpert.ivy 3.9 Server kept his default AJP port 8009.

    # ivy.yaml with AJP enabled on 8010
    AJP:
        Enabled: true
        Port: 8010
    
  4. The Axon.ivy Engines must be declared in the worker.properties file of the integration directory. It’s important that each worker has a unique name and that they are listed in the worker.list property. In our scenario the worker.properties looks as follows:

    worker.XpertIvyServer3x.type=ajp13
    worker.XpertIvyServer3x.port=8009
    worker.XpertIvyServer3x.host=ivyhostname39
    
    worker.AxonIvyEngine5x.type=ajp13
    worker.AxonIvyEngine5x.port=8010
    worker.AxonIvyEngine5x.host=ivyhostname50
    
    worker.list=XpertIvyServer3x,AxonIvyEngine5x
    
  5. The contexts of the Axon.ivy Engines must be registered in the uriworkermap.properties file of the integration directory. In our scenario we make Axon.ivy 5.x available under http://localhost/ivy5/ and Xpert.ivy 3.9 under http://localhost/ivy. So the uriworkermap.properties file looks as follows:

    /ivy/*=XpertIvyServer3x
    /ivy5/*=AxonIvyEngine5x
    

Single Sign On

Axon.ivy Engine supports single sign on in Windows environments. The following preconditions must be fulfilled for single sign on:

  • The application on the Axon.ivy Engine must use Active Directory Security System

  • The Axon.ivy Engine must be integrated into a Microsoft Internet Information Server (IIS)

IIS 8 (Windows Server 2012)

Note

There is a batch script autoconfigSSO.bat in the folder [engineDir]/misc/iis of your engine installation. This script automatically sets up SSO on a Windows 2012 Server. If you are setting up a new IIS Server you can use this script instead of following the instructions below.

Install Windows Authentication

Note

The following command automatically installs Basic Authentication:

PKGMGR.EXE /iu:IIS-WindowsAuthentication

Open the Server Manager (Start > Server Manager). Select the Web Server (IIS). Validate that under the Role Services the service Window Authentication is installed. If this is not the case select the menu Add Role Services to install the missing service.

../../_images/iis-single-sign-on-feature.png

Deactivate Anonymous Authentication

Note

The following command automatically deactivates the Anonymous Authentication:

set path=%path%;%windir%\system32\inetsrv
appcmd.exe set config "Default Web Site/ivy" -section:system.webServer/security/authentication/anonymousAuthentication /enabled:"False" /commit:apphost

Open the Internet Information Services (IIS) Manager (Start > Internet Information Services (IIS) Manager). In the Connections pane select the ivy Virtual Directory node. In the Feature View open the Authentication entry. Select the Windows Authentication and use the menu Enable in the Actions pane to enable Windows Authentication.

Make sure that all other authentication modes such as Anonymous Authentication or Digest Authentication are disabled, otherwise IIS will use those authentication modes and Single Sign On will not work.

../../_images/iis-single-sign-on-disable.png

Activate Windows Authentication

Note

The following command automatically activates the Windows Authentication:

appcmd.exe set config "Default Web Site/ivy" -section:system.webServer/security/authentication/windowsAuthentication /enabled:"True" /-"providers.[value='Negotiate']" /commit:apphost

Basic Authentication

In the following situations Basic Authentication is required:

  • to use the Axon.ivy Mobile App

  • to provide REST services which require authentication

IIS 8 (Windows Server 2012)

Note

There is a batch script autoconfigBasicAuth.bat in the folder [engineDir]/misc/iis of your engine installation. This script automatically sets up Basic Authentication on a Windows 2012 Server. If you are setting up a new IIS Server you can use this script instead of following the instructions below.

Install Basic Authentication

Note

The following command automatically installs Basic Authentication:

PKGMGR.EXE /iu:IIS-BasicAuthentication

Open the Server Manager (Start > Server Manager). Select the Web Server (IIS). Validate that under the Role Services the service Basic Authentication is installed. If this is not the case select the menu Add Role Services to install the missing service.

../../_images/iis-basic-authentication-feature.png

Activate Basic Authentication

Note

The following command automatically activates the Basic Authentication:

set path=%path%;%windir%\system32\inetsrv
appcmd.exe set config "Default Web Site/ivy" -section:system.webServer/security/authentication/basicAuthentication /enabled:true /commit:apphost

Open the Internet Information Services (IIS) Manager (Start > Internet Information Services (IIS) Manager). In the Connections pane select the ivy Virtual Directory node. In the Feature View open the Authentication entry. Select the Basic Authentication and use the menu Enable in the Actions pane to enable Basic Authentication.

../../_images/iis-basic-authentication-activate.png

Error Handling

If the engine is running behind an IIS web server and an error occurs on the Engine IIS shows its own error page and hides the error page coming from the Engine. This is the default IIS behavior.

The Axon.ivy IIS integration script configures the IIS to show the detailed error page of the Engine (see ‘Errors’ in ivy.yaml). IIS can be reset to its default behavior (e.g. because of security reasons) with the following steps:

  1. Open the IIS manager

  2. Select the virtual directory ivy and on its Features View, double click on Error Pages

  3. Right click and select the Edit Feature Settings… or select the same from the Actions pane (on the right hand side)

  4. Select the “Detailed errors for local requests …” radio button and click OK.