Adaxes installation guide

All Adaxes components (Adaxes service, Web interface, Administration console, etc.) are installed using a single installation package. You can install all components on a single computer or install different components on different computers. If you are going to install Adaxes components on different computers, install Adaxes service first because you will need to specify the network location of the Adaxes service to install other components.

Also, you can set up Adaxes as a multi-server deployment with several Adaxes service instances that share common configuration – for high availability and fault tolerance.

Prerequisites

  • To install Adaxes, the computer must be joined to an Active Directory domain.

    If you plan to manage only Microsoft Entra domains via Adaxes, you still have to install Adaxes on a domain-joined computer. It can be any Active Directory domain, even a placeholder domain created purely for management purposes.

  • All Adaxes components require Microsoft .NET Framework 4.8 or higher.

Hardware requirements

Component Hardware requirements
Adaxes service
  • CPU: 2 GHz or higher recommended
  • RAM: 2 GB or more recommended
  • HDD: 3 GB or more recommended. See details below.
Administration console
  • CPU: 1.6 GHz or higher recommended
  • RAM: 1 GB or more recommended. See details below.
Web interface
  • CPU: 2 GHz or higher recommended
  • RAM: 1 GB or more recommended
REST API
  • CPU: 2 GHz or higher recommended
  • RAM: 1 GB or more recommended

Log records stored in the SQLite database on the computer where Adaxes service is installed may take a significant amount of disk space. This amount depends on the average number of recorded events per day and the log record retention period, which is 30 days by default. It is recommended to allocate at least 1 GB for each month worth of log records.

Each registered Exchange Online organization requires an extra 50MB of RAM. An Exchange Online organization is either a Microsoft Entra domain with Exchange Online, or a Microsoft 365 tenant with Exchange Online. In MSP scenarios, where Adaxes is used to manage Exchange Online organizations of multiple customers, this additional RAM requirement can become significant.

Generally, hardware requirements depend on Adaxes configuration complexity and the number of managed objects. The more complicated your configuration is and the more objects you manage, the more processing power and RAM is recommended to allocate to the computer where Adaxes will be installed.

Software requirements

Component Supported operating systems
Adaxes service
  • Windows 8 and higher
  • Windows Server 2012 R2 and higher
Administration console
  • Windows 7 and higher
  • Windows Server 2008 R2 and higher
Web interface
  • Windows 7 and higher
  • Windows Server 2008 R2 and higher
REST API
  • Windows 7 and higher
  • Windows Server 2008 R2 and higher
PowerShell module
  • Windows 8 and higher
  • Windows Server 2012 and higher
SPML Web service
  • Windows 7 and higher
  • Windows Server 2008 R2 and higher

It's highly recommended to install Web interface, REST API, and SPML Web service on server editions of Windows. IIS has a limitation on the number of simultaneous connections on workstations. The connection limit can be reached with only two or three concurrent connections to any of these components.

Additional software

Some of the Adaxes components require additional software to be installed. All the software is installed automatically during Adaxes installation. The additional software components are listed on the Ready to Install page right before the installation process starts.

Adaxes component Additional software installed
Adaxes service Microsoft AD LDS
Web interface Microsoft IIS
REST API Microsoft IIS
SPML Web service Microsoft IIS

After Adaxes is uninstalled, the additional software components installed automatically remain in the system.

Installation

As a best practice, it is not recommended to install the Adaxes service on a domain controller because you will not be able to install it unless you select the built-in Administrator account as the Adaxes service account.

Follow the steps below to install Adaxes:

  1. Log on to the operating system using an Active Directory domain account that has local administrator permissions on the computer.

  2. Launch the Adaxes installation package (.msi). Alternatively, install Adaxes from the command line.

  3. Read the information provided on the Welcome screen and click Next.

  4. Accept the license agreement and click Next.

  5. Select Adaxes components you want to install and click Next.

     If you selected the Adaxes service component
    • On the Adaxes service account page, specify the credentials of the user account under which the Adaxes service will run.

      Service account permissions

      The Adaxes service account should have the rights necessary to publish and unpublish the Adaxes service in Active Directory (create/delete service connection points). For information on how to grant the permissions, see Grant permissions to publish Adaxes service.

      If you are going to use this account to manage your domain, it should also have the necessary permissions to perform operations in the domain. For details, see Permissions required by Adaxes.

      Log on as a service right

      Since Adaxes service uses the service account to log on to the system, the Log on as service right will be granted to the account during the installation. However, this right can get revoked by a domain-based Group Policy. In this case, you will need to explicitly grant the Log on as a service right to the Adaxes service account in a domain-based Group Policy. For details, see How do I grant Log on as a service right.

      Access this computer from the network right

      Default Windows security settings grant the Access this computer from the network right to every user on every workstation and server. If you modified the default right assignment on the computer where Adaxes service is installed, you need to explicitly grant the Access this computer from the network right to the Adaxes service account in a domain-based Group Policy. For details, see How do I grant Access this computer from the network right.

    • Click Next.

    • On the Adaxes service configuration page, to achieve fault tolerance and load balancing, you can join the new Adaxes service to an existing Adaxes configuration set. For more details, see Multi-server deployment.

      To join the Adaxes service to a configuration set, select the Shared configuration option, specify the DNS host name of any Adaxes service from the configuration set, and then provide the credentials of the service account of any Adaxes service contained in the set.

    • Click Next.

    • On the Ready to install page, you can specify whether to open the Windows Firewall port that is used for communication between Adaxes clients (e.g. Adaxes Administration console or Adaxes Web interface) and the Adaxes service. If the Open port 54782 in Windows Firewall option is selected, an inbound rule for the TCP port 54782 will be added to Windows Firewall. If you uninstall Adaxes, the rule will be deleted automatically.

     If you selected the Web interface component
    • On the Web interface configuration page, configure IIS web site parameters for the Web interface and Web interface configurator.

      Available Web interfaces

      The list of Web interfaces available on a specific web server is determined by the configuration of each Web interface. For example, if you don't want the Web interface for administrators to be available from outside, you can disable it on all web servers located in the DMZ. For more details, see Disable a Web interface on specific web servers.

    • Click Next.

    • On the Adaxes service for Web interface page, specify the DNS host name of the Adaxes service the Web interface will connect to. The step is only available if you install the Adaxes service and Web interface components separately. When both components are installed simultaneously, Web interface will connect to the Adaxes service installed during the current installation.

      If the Adaxes service shares its configuration with other Adaxes services, the Web interface will connect to the nearest available Adaxes service contained in the configuration set.

    • Click Next.

     If you selected the REST API component
    • On the REST API configuration page, configure IIS web site parameters for REST API and click Next.

    • On the Adaxes service for REST API page, specify the DNS host name of the Adaxes service REST API will connect to. The step is only available if you install the Adaxes service and REST API components separately. When both components are installed simultaneously, REST API will connect to the Adaxes service installed during the current installation.

      If the Adaxes service shares its configuration with other Adaxes services, REST API will connect to the nearest available Adaxes service contained in the configuration set.

    • Click Next.

     If you selected the SPML Web service component
    • On the SPML service configuration page, configure IIS parameters for the SPML web service and click Next.

    • On the AD access for SPML Web service page, specify how you want Adaxes SPML Provider to access Active Directory. The page is only available if you install the Adaxes service and SPML Web service components separately. When both components are installed simultaneously, SPML Provider will use the Adaxes service installed during the current installation.

      Adaxes SPML Provider can access Active Directory directly or via an Adaxes service. Accessing Active Directory via Adaxes allows you to benefit from the Adaxes features like business rules, security roles, and property patterns.

      If SPML Provider connects to Active Directory through an Adaxes service and the service shares its configuration with other Adaxes services, SPML Provider will connect to the nearest available Adaxes service in the configuration set.

    • Click Next.

     If you didn't select any of the Adaxes components

    Only Adaxes ADSI provider will be installed.

    Adaxes ADSI Provider is an API layer that lets you use ADSI interfaces to connect to and communicate with Adaxes service. You can use the ADSI Provider in custom client applications, standalone scripts, and scripts executed by business rules, scheduled tasks, and custom commands.

  6. On the Ready to install page, click Install.

Depending on the features you've selected, additional components can be installed on the system. For details, see Additional software.

Post-installation tasks

If you are installing Adaxes for the first time or installing it on a new computer, you need to perform post-installation steps.

Multi-server deployment

You can set up multiple Adaxes services that share common configuration (managed domains, security roles, business rules, scheduled tasks, Web interface configuration, etc.).

In a multi-server environment, if one of the Adaxes services goes down, users are automatically redirected to the nearest service available. It enables fault tolerance and provides a more efficient load distribution on your system.

Adaxes services that share common configuration form a logical grouping called a configuration set. When the configuration of an Adaxes service is modified, the configuration of other services in the set becomes inconsistent with the most up-to-date configuration. As the changes get replicated through the configuration set, all service configurations become identical once again. Adaxes uses a type of replication called multi-master replication.

Consider a multi-server deployment if you have a geographically distributed environment, there is a heavy load on your Adaxes service, or you want to achieve extra availability and improve the failover.

To set up a multi-server configuration:

  1. Install the first instance of Adaxes service. This will create a configuration set with only one Adaxes service.

  2. During the installation of subsequent instances of Adaxes service, join each new service to the configuration set.

     How to join a new service to a configuration set
    1. On the Adaxes service configuration page of the installation wizard, select the Shared configuration option.

    2. Specify the DNS host name of any Adaxes service from the configuration set.

    3. Provide the credentials of the service account of any Adaxes service contained in the set.

    To join a new service from another domain to a configuration set, the domains must have two-way trust relationships.

Log record database in a multi-server deployment

By default, Adaxes log records are stored in an SQLite database located on the computer where the Adaxes service is running. Since SQLite databases are not replicated, each instance of Adaxes service will have access to its own log records only.

In a multi-server environment, it is highly recommended to use Microsoft SQL Server as an external database for log records. In such a configuration, all records will be merged in a single database and each Adaxes service will have access to all log records generated within the configuration set.

For instructions on how to configure Adaxes to use an external database for logging, see Enable logging to an external MS SQL database.

Deploying Web interface to a web farm

You can install Adaxes Web interface in a web farm if you want to share the web-site traffic across multiple servers, improve site availability, and balance load among sites.

Since Adaxes Web interface requires all client requests to be routed to the same web server during a client session, you need to configure load balancing to map a client to a Web interface. The load balancing algorithm must be applied only for the very first request from the client. From that point on, all subsequent requests from the same client must be routed to the same Web interface for the duration of the client session.

To install Adaxes Web interface in a web farm:

  1. Install Adaxes Web interface on each web server in the web farm.

     Command line
    Web interface
    msiexec /quiet /i "<path_to_package>\adaxes.msi" \
        ADDLOCAL=AppWebUIFeature \
        ADMWEBSERVICECONFIGSET="<configSetId>"
    
    Web interface and web interface configurator
    msiexec /quiet /i "<path_to_package>\adaxes.msi" \
        ADDLOCAL=AppWebUIFeature,AppConfigWebUIFeature \
        ADMWEBSERVICECONFIGSET="<configSetId>"
    

    Specify the identifier of an Adaxes service configuration set as the value of the ADMWEBSERVICECONFIGSET parameter. For details, see Get the configuration set ID.

  2. Configure client affinity for the web farm. For example:

     Application Request Routing Module {id=app-request-routing}
    1. Launch Internet Information Services (IIS) Manager.

    2. Select the server farm and double-click Server Affinity.

    3. Enable the Client affinity option and click Apply.

     F5 BIG-IP Local Traffic Manager (LTM) {id=f5-big-ip}
    1. Go to the F5 BIG-IP LTM configuration page.

    2. Expand Local Traffic in the navigation panel and select Profiles.

    3. Open the Persistence tab and then click Create.

    4. In the General Properties section type the desired name of the profile you are creating.

    5. Select Source Address Affinity in the Persistence type drop-down list.

    6. Customize other settings of the profile according to your requirements and click Finished.

    7. Open the virtual server(s) that hosts Adaxes Web Interface and open its Resources tab.

    8. In the Default Persistence Profile drop-down list, select the name of the persistence profile you have created.

    9. Save the changes.

     Citrix NetScaler {id=citrix-netscaler}
    1. Go to the Citrix NetScaler VPX configuration page.

    2. Navigate to Traffic Management > Load Balancing > Virtual Servers.

    3. Select the virtual server you use for load balancing and click Edit.

    4. In the Persistence list, select the SOURCEIP option.

    5. Save the changes.

Exposing Web interface to the Internet

To make Adaxes Web interface and Administration console available from the outside of your network, they can be installed in the DMZ (also known as perimeter network or extranet).

Web interface can be exposed to the Internet to allow users to self-reset their password or search the directory when they are not on the internal network (e.g. users working from home, users on business trips, external users). If you install Adaxes Administration console on a computer in the DMZ, administrators will be able to connect to the computer using Remote Desktop and manage Adaxes from outside the internal network.

To make Adaxes components available from the Internet:

  1. Install a read-only domain controller (RODC) in the DMZ.

    Adaxes Web interface and Administration console can be installed only on a computer that is joined to an Active Directory domain. Since DMZ is usually a highly restricted piece of network, it is recommended to use read-only domain controllers. RODCs provide a one-way replication from your internal network to the DMZ and thus decrease the risks when a DMZ machine gets compromised. For details on how to deploy RODCs in the DMZ, see Active Directory Domain Services in the Perimeter Network.

  2. Open port 54782 in the firewall.

    By default, Adaxes Web interface and Adaxes Administration console use the 54782 port for communication with the Adaxes service. If you need to use a different port, you can change it after the installation.

     How
    • Open the folder where Adaxes service is installed. By default, it is C:\Program Files\Softerra\Adaxes 3\Service.

    • Open the Softerra.Adaxes.Service.exe.config file with a text editor.

    • Locate the configuration\system.runtime.remoting\application\channels\channel XML element.

    • Change the value of the port parameter.

      <configuration>
          ...
          <system.runtime.remoting>
              <customErrors mode="Off" />
              <application>
                  <channels>
                      <channel ref="tcp" port="54782" priority="2" secure="true">
      
    • Repeat the above steps for each Adaxes service in the configuration set if you have a multi-server environment.

  3. Configure which Web interfaces will be available in the DMZ. For example, if you don't want the Web Interface for administrators and help desk to be available from outside, you can allow them only on the web servers located inside your local network. For more details, see Disable Web interface on specific web servers.

If you do not want to install a read-only domain controller and Adaxes Web interface in the DMZ, but still need to make the Web interface accessible from outside, you can use an application delivery controller (e.g. Citrix NetScaler, Nginx, CloudFlare, etc.). For example, the controller can be placed in the DMZ to accept requests from outside and pass them to the Adaxes Web interface installed in your local network.

Uninstallation

Configuration backup

Before uninstalling Adaxes service, you may want to back up Adaxes configuration, or it will be permanently lost after uninstalling the last instance of Adaxes service in the configuration set.

To uninstall Adaxes:

  1. If you want to uninstall the Adaxes service component, make sure that the service is running. This is necessary to correctly unregister the service from your system (remove the service connection points and clean up the configuration set metadata).

  2. Open Add or Remove Programs and select Softerra Adaxes.

  3. Click Remove and follow the steps provided.

Upgrade

To avoid any compatibility issues, it is recommended to upgrade all Adaxes components (e.g. Adaxes service, Administration console, Web interface) to the same version. This is particularly important when upgrading to Adaxes 2023, as its components are completely incompatible with components from older versions.

Before upgrading, make sure that your license key can be used with the latest version of Adaxes. For details, see Check for updates.

Have your license key (license.admlic) at hand, as you will need to reactivate your license right after the upgrade.

Upgrade single-server configuration

If you have a single Adaxes service that doesn't share common configuration with any other Adaxes services, you need to back up your configuration, upgrade to the latest version, and then restore the configuration.

To upgrade, perform the following steps:

  1. Back up the Adaxes configuration.

  2. Uninstall the old version of Adaxes.

  3. If you have Adaxes 2017.2 and older, you need to do an intermediate update to Adaxes 2021.1. Otherwise, skip this step.

     Upgrade from Adaxes 2017.2 and older
    1. Download and install Adaxes 2021.1.

    2. Restore the Adaxes configuration.

    3. Navigate to the folder where Adaxes Web interface is installed. By default, the folder is C:\Program Files\Softerra\Adaxes 3\Web Interface.

    4. Migrate the old configuration of your Web interface using the Softerra.Adaxes.Web.Migration.UI.exe tool.

    5. Back up the Adaxes configuration once again.

    6. Uninstall Adaxes 2021.1.

  4. Install the latest version.

  5. Restore the Adaxes configuration.

  6. Activate your license key.

Upgrade multi-server configuration

If you have multiple Adaxes services sharing common configuration, you need to reinstall them one after another by performing the following steps:

  1. Uninstall the old version of Adaxes service.

  2. Install the latest version. During the installation, join the new Adaxes service to your configuration set.

 Upgrade from Adaxes 2017.2 and older

To upgrade from 2017.2 and older, you need to do an intermediate upgrade of one Adaxes service instance to Adaxes 2021.1, and then upgrade all instances to the latest version.

  1. Back up the Adaxes configuration.

  2. Uninstall one Adaxes service instance from your configuration set.

  3. Download and install Adaxes 2021.1. During the installation, join the new instance to your configuration set.

  4. On the computer where you have just installed Adaxes 2021.1:

    • Restore the Adaxes configuration.

    • Migrate the old configuration of your Web interface using the Softerra.Adaxes.Web.Migration.UI.exe tool. The tool is located in the folder where Adaxes Web interface is installed, which is C:\Program Files\Softerra\Adaxes 3\Web Interface by default.

  5. Upgrade all Adaxes services one by one by following the standard two-step multi-server upgrade process described above. The 2021.1 service should be reinstalled last.

Moving Adaxes service to another computer

If you need to move a 2020.1 or older Adaxes service instance to another computer, you need to transfer pending approval requests.

How do I

 How do I install Adaxes from the command line {id=install-from-command-line}

To install Adaxes from the command line, use the msiexec command and specify what Adaxes components you want to install via the ADDLOCAL parameter. For example, the following command will install only the Adaxes ADSI provider.

msiexec /quiet /i "<path_to_package>\adaxes.msi" ^
    ADDLOCAL=AdaxesFeature

Here's a list of all Adaxes components. Note that some components require you to specify mandatory parameters detailed below.

Component name Description
AdaxesFeature Adaxes ADSI provider
ServiceFeature Adaxes service
AdminConsoleFeature Administration console
AppWebUIFeature Web interface
AppConfigWebUIFeature Web interface configurator
RestApiFeature REST API
SpmlFeature SPML web service
PowerShellFeature PowerShell module

It is not necessary to explicitly include the ADSI provider component unless it is the only component you are installing.

Details

Adaxes service

New configuration
msiexec /quiet /i "<path_to_package>\adaxes.msi" ^
    ADDLOCAL=ServiceFeature ^
        ADMCFGTYPE=0 ^
        OPENADAXESPORTINFIREWALL=1 ^
        ADMADMINNAME="<username>" ^
        ADMADMINPWD="<password>" ^
        ADMSERVICEADMINSID="<SID>" ^
        ADLDSPORT="<port>"
Shared configuration
msiexec /quiet /i "<path_to_package>\adaxes.msi" ^
    ADDLOCAL=ServiceFeature ^
        ADMCFGTYPE=1 ^
        OPENADAXESPORTINFIREWALL=1 ^
        ADMADMINNAME="<username>" ^
        ADMADMINPWD="<password>" ^
        ADMSERVICEADMINSID="<SID>" ^
        ADLDSPORT="<port>" ^
    BACKENDREPLICAADDRESS="<hostname>:<port>" ^
        ADMREPLACCNAME="<username>" ^
        ADMREPLACCPWD="<password>" ^
    ADAMSCHEMAMASTERSERVER="<hostname>" ^
        ADAMSCHEMAMASTERPORT="<port>"  

You must specify the following parameters, whether you are installing the Adaxes service in a new configuration or a shared one.

  • Parameter name

  • Description

  • ADMCFGTYPE

  • Specify 0 to install the service instance in a new configuration set or specify 1 to add it to an existing set.

  • OPENADAXESPORTINFIREWALL

  • Specify 1 to add an inbound rule for the TCP port 54782 to Windows Firewall. The port is used for communication between Adaxes clients and Adaxes service.

  • ADMADMINNAME

  • The username of the account that will be used as the Adaxes service account.

  • ADMADMINPWD

  • The password of the account that will be used as the Adaxes service account.

  • ADMSERVICEADMINSID

  • The SID of the account that will be used as the Adaxes service account.

  • ADLDSPORT

  • The Adaxes backend (AD LDS) port. The port must be unused and must fall within the 1025-65535 range. This parameter is optional. If you don't include it, the port will be automatically selected by the Adaxes installer.

When installing the Adaxes service in a shared configuration, you need to specify an additional set of parameters on top of the base set.

  • Parameter name

  • Description

  • BACKENDREPLICAADDRESS

  • The fully qualified domain name of an Adaxes service instance that you want to share the configuration with, followed by its AD LDS backend port number.

  • ADMREPLACCNAME

  • The username of the Adaxes service account used to run the service instance specified in BACKENDREPLICAADDRESS.

  • ADMREPLACCPWD

  • The password of the Adaxes service account used to run the service instance specified in BACKENDREPLICAADDRESS.

  • ADAMSCHEMAMASTERSERVER

  • The fully qualified domain name of an Adaxes service instance that holds the schema master role.

  • ADAMSCHEMAMASTERPORT

  • The backend port of an Adaxes service instance that holds the schema master role.

Installing Adaxes service in a shared configuration requires you to know the schema master role holder and the AD LDS backend port. It is recommended to obtain these values right before the installation instead of hardcoding them.

 How to find out the backend port and the schema master holder

Execute the following script on any computer in a domain to obtain backend information from every Adaxes service instance installed in that domain.

# Get all Adaxes service connection points.
$filter = @'
(&
    (objectclass=serviceConnectionPoint)
    (keywords=1.3.6.1.4.1.15741.2.3.1)
    (name=Adaxes)
)
'@
$scps = Get-ADObject -Properties keywords -LDAPFilter $filter

$allServicesInfo = @()
foreach ($scp in $scps)
{
    # Extract backend information.
    [string[]]$keywords = $scp.keywords | 
        Where-Object {$_ -ne "1.3.6.1.4.1.15741.2.3.1"}
    try {
        $scpInfo = ConvertFrom-StringData -StringData ($keywords -join "`n")
    }
    catch {
        # Invalid data.
        continue
    }
    $dnsHostname = $scpInfo.'Backend.DnsHostName'
    $backendPort = $scpInfo.'Backend.Port'

    # Find out if service is schema master.
    try {
        $rootDSE = New-Object System.DirectoryServices.DirectoryEntry `
            -ArgumentList "LDAP://$dnsHostname`:$backendPort/RootDSE"
        $schemaDN = $rootDSE.schemaNamingContext.Value
        $schemaObject = New-Object System.DirectoryServices.DirectoryEntry `
            -ArgumentList "LDAP://$dnsHostname`:$backendPort/$schemaDN"
        $fSMORoleOwner = $schemaObject.fSMORoleOwner
        $isSchemaMaster = $fSMORoleOwner.Contains($scpInfo.'Backend.ServerName')
    }
    catch {
        # Service unavailable.
        Write-Host $dnsHostname "is unavailable"
        continue
    }

    # Add service info to output.
    $allServicesInfo += New-Object PSObject -Property @{
        "ConfigurationSetId" = $scpInfo.'Instance.ConfigurationSet'
        "DnsHostName" = $dnsHostname
        "BackendPort" = $backendPort 
        "IsSchemaMaster" = $isSchemaMaster
    }
}

# Output information.
$allServicesInfo | Format-Table `
    -Property DnsHostName,BackendPort,IsSchemaMaster `
    -GroupBy ConfigurationSetId

Other components

The Administration console and the PowerShell module don't require any additional parameters.

Administration console
msiexec /quiet /i "<path_to_package>\adaxes.msi" ^
    ADDLOCAL=AdminConsoleFeature
PowerShell module
msiexec /quiet /i "<path_to_package>\adaxes.msi" ^
    ADDLOCAL=PowerShellFeature

The web interface, web interface configurator, REST API, and the SPML provider require you to specify the identifier of an Adaxes service configuration set to which to connect. For information on how to get it, see Get the configuration set ID.

Web interface
msiexec /quiet /i "<path_to_package>\adaxes.msi" ^
    ADDLOCAL=AppWebUIFeature ^
    ADMWEBSERVICECONFIGSET="<configSetID>"
Web interface configurator
msiexec /quiet /i "<path_to_package>\adaxes.msi" ^
    ADDLOCAL=AppConfigWebUIFeature ^
    ADMWEBSERVICECONFIGSET="<configSetID>"
REST API
msiexec /quiet /i "<path_to_package>\adaxes.msi" ^
    ADDLOCAL=RestApiFeature ^
    RESTAPISERVICECONFIGSET="<configSetID>"
SPML provider
msiexec /quiet /i "<path_to_package>\adaxes.msi" ^
    ADDLOCAL=SpmlFeature ^
    ADMSPMLSERVICECONFIGSET="<configSetID>"
 How do I install Adaxes service with a specific language {id=install-with-specific-language}

By default, the Adaxes service language is automatically selected based on the operating system locale. To install Adaxes service with a specific language, launch the installation package from the command prompt and specify the required language code in the ADMSERVICEINITCULTURE parameter.

msiexec /i "<path_to_package>\adaxes.msi" ADMSERVICEINITCULTURE="en-US"

Possible values:

  • en-US – English
  • fr-FR – French
  • de-DE – German

Adaxes service is available in English, German and French. If a different language is specified, English language will be used.

 How do I grant permissions to publish Adaxes service {id=grant-permissions-to-publish-adaxes-service}

The Adaxes service account should have the permissions necessary to publish and unpublish the Adaxes service in Active Directory (create/delete a Service Connection Point). To grant the permissions:

  1. Open Active Directory Users and Computers on a domain controller.

  2. Connect to the domain of the computer where you want to install Adaxes.

  3. On the View menu, select Advanced Features.

  4. Right-click the computer where you want to install Adaxes, and then click Properties.

  5. On the Security tab, click Add.

  6. Type in the name of the user account whom you want to grant the permissions and click OK.

  7. Select the Allow checkboxes for the Create All Child Objects and Delete All Child Objects permissions.

  8. Click OK.

 How do I grant Log on as a service right {id=grant-logon-as-service}

When Adaxes service is installed on a workstation rather than on a domain controller, the Log on as service right is granted locally on the workstation via the Local Policy settings.

If there is a conflicting domain-based Group Policy Object that grants such a right to other accounts, it will override the Local Policy during Group Policy refresh and will revoke the local right granted during the installation process. As a result, the Adaxes service will no longer be able to start.

In this case, you need to grant the Log on as a service right to the Adaxes service account in a precedent domain-based Group Policy.

  1. Launch the Group Policy Management Console.

  2. Select the precedent Group Policy Object (GPO) effective for the computer where Adaxes service is installed.

  3. Right click the GPO and then click Edit.

  4. Navigate to Computer Configuration / Policies / Windows Settings / Security Settings / Local Policies and click User Rights Assignment.

  5. Add the Adaxes service account to the Log on as a service policy.

 How do I grant Access this computer from the network right {id=grant-network-access}

By default, the Access this computer from the network right is granted to the Administrators, Users, and Backup operators built-in security groups as well as the Everyone computed group on every Windows computer.

If you have a domain-based Group Policy Object that does not include Everyone or Authenticated Users in the security setting for this policy, it will override the default Local Policy on the computer where Adaxes service is installed. As a result, the Adaxes service will not be able to start.

In this case, you need to explicitly grant the Access this computer from the network right right to the Adaxes service account in a precedent domain-based Group Policy.

  1. Launch the Group Policy Management Console.

  2. Select the precedent Group Policy Object (GPO) effective for the computer where Adaxes service is installed.

  3. Right click the GPO and then click Edit.

  4. Navigate to Computer Configuration / Policies / Windows Settings / Security Settings / Local Policies and click User Rights Assignment.

  5. Add the Adaxes service account to the Access this computer from the network policy.

 How do I transfer pending approval requests {id=transfer-pending-approval-requests}

In Adaxes 2020.1 and older, pending approval requests are not replicated. This means you need to manually transfer pending approval requests if you are moving an Adaxes service instance to another computer.

  1. Uninstall the Adaxes service instance which you want to move to another computer.

  2. Install the new Adaxes service instance and join it to your configuration set.

  3. On the computer where the old Adaxes service instance was installed, navigate to the common application data folder used by Adaxes. It is typically located at C:\ProgramData\Softerra\Adaxes 3\.

  4. Copy the AdaxesCommandQueueBackup folder to the computer where you installed the new Adaxes service, preserving the folder structure. If any folder doesn't exist, create it.

In Adaxes 2021.1 and newer, pending approval requests are replicated between Adaxes services, so the above actions are not necessary.