Configure Windows Authentication for the SOAP API
- Create a domain service account.
The IIS application pool for the LogRhythm SOAP API must be granted permissions in the LogRhythm databases to validate the Windows user’s permissions. The preferred method is to create a domain account for this purpose in Active Directory. Alternatively, you can use the default IIS ApplicationPoolIdentity and grant the web server services (<domain>\<hostname>$) permission in the databases, but this is not as secure.
- Enable Kerberos delegation in Active Directory.
- Using the Active Directory Users and Computers snap-in, find the web server’s computer account.
- Open the properties for the Computer and click the Delegation tab.
- Select Trust this computer for delegation to any service (Kerberos only).
- If you want to use constrained delegation (the “specified services only” option), first complete this setup and verify Kerberos authentication is working correctly from a client application. Then reconfigure Delegation with a restricted set of services.
- Configure the IIS Application Pool to use the new domain service account.
- On the LogRhythm SOAP API server, open the Internet Information Services (IIS) Manager.
- Select Application Pools.
- Open the Advanced Settings for the LogRhythmAppPool.
- Open the Identity dialog. Select Custom Account and enter the account name and password for the service account.
- Verify Windows Authentication is enabled in IIS.
- On the LogRhythm SOAP API server, open the Internet Information Services (IIS) Manager.
- Select the LogRhythm Web Site.
- In the Features view, open Authentication.Anonymous Authentication, Basic Authentication, and Windows Authentication should be enabled. Other methods should be disabled.
- Select Windows Authentication, and then select Providers. Negotiate should be at the top of the list.
- Select Windows Authentication and then select Advanced Settings. Enable Kernel-mode authentication should be selected.
- Configure SQL Server for Kerberos authentication.
- On each LogRhythm XM, PM or DPX, run SQL Server Configuration Manager.
- Select SQL Server Services.
- For the SQL Server service, note the service account listed under Log On As.
- Do one of the following:
- If the SQL Server service account is NT AUTHORITY\LOCALSERVICE, configure it to use NT AUTHORITY\NETWORKSERVICE.
A database restart is required. Shut down all LogRhythm services before you restart the database.
- If the SQL Server service account is LocalSystem or NT AUTHORITY\NETWORKSERVICE (preferred), then the Kerberos Service Principal Names (SPN) should be registered automatically when SQL Server starts.
- If the SQL Server service account is a domain account, then the Service Principal Names must be registered manually. As a domain administrator, execute the following commands for each XM, PM, or DPX.
The SPN values need to be registered for each LogRhythm appliance your application may be querying. Alternatively, you can also run the SQL Server Service on each LogRhythm appliance with the SPN <sql service account>.
setspn -S MSSQLSvc/<fully qualified domain name>:1433 <domain>\<sql service account>
setspn -S MSSQLSvc /<host name>:1433 <domain>\<sql service account>
- If the SQL Server service account is NT AUTHORITY\LOCALSERVICE, configure it to use NT AUTHORITY\NETWORKSERVICE.
- Grant the web server service account permissions in the LogRhythmEMDB.
- On the LogRhythm XM or PM, run SQL Server Management Studio.
- Open server / Security / Logins and create a New Login.
- Enter or select the web server service account created in Step 1.
- On the User Mapping page, select the LogRhythmEMDB and select the LogRhythmRestrictedAnalyst role.
- Configure the client.
- The Windows Communication Foundation (WCF) client application must be configured to enable delegation of credentials.
- In the client’s web.config, define an endpoint behavior for all the service references that use Windows Authentication and add the following behavior for delegation.
<behaviors>
<endpointBehaviors>
<behavior name ="DelegateBehavior">
<clientCredentials>
<windows allowedImpersonationLevel ="Delegation"/>
</clientCredentials>
</behavior>
</endpointBehaviors>
</behaviors>
<client>
<endpoint
address="https://webserver/LogRhythm.API/Services/LogQueryServiceWindowsAuth.svc"
binding="basicHttpBinding"
bindingConfiguration="LogQueryServiceWindowsAuth_LogQueryService"
contract="LogQueryService.LogQueryService"
name="LogQueryServiceWindowsAuth_LogQueryService"
behaviorConfiguration="DelegateBehavior"/>
</client>
- You can also specify the delegation in your .NET client code, following the instantiation of the LogRhythm service you are using:
<LogRhythmClient>.ClientCredentials.Windows.AllowedImpersonationLevel = System.Security.Principal.TokenImpersonationLevel.Delegation;
If you did not already complete the following two steps when you installed the SOAP API, you must do so now.
Configure the IIS Application Pool to Use the Service Account