This section provides an explanation on how to enable the HTTP protocol for the communication between Orchestrator and the Robots.
It is preferable to use a SAN SSL certificate submitted to a Certificate Authority rather than a self-signed one because no certificate has to be installed on Robot computers in the former case. The SAN SLL certificate issued by the Certificate Authority is trusted by all the computers in the domain.
If the primary Orchestrator machine is registered into an Active Directory that has a local Certificate Authority and an auto-enrollment policy, the user may fill a certificate request, as described in the following procedure.
- Press Windows and R keys, type
certlm.msc, and click OK to open the Certificates snap-in.
- Right-click the Personal node, select All Tasks, then Advanced Operations, and Create Custom Request. Click Next in the Before You Begin window.
- In the Select Certificate Enrollment Policy window, choose Active Directory Enrollment Policy, and click Next.
- In the Custom Request window, pick a certificate template designated for web server use. It should be called Web Server or Web.SAN. If no template is defined, choose (No template) Legacy Key. Then, select PKCS #10 as your request format.
- In the Certificate Information window, click on the Details button corresponding to your request, and then select Properties to open the Certificate Properties window and customize the certificate request.
- Customize the information in the Subject tab as described below:
6.1. In the Subject name section, go to Type, and select Common Name from the drop-down menu. In the Value field, type the fully qualified domain name (FQDN) of the machine, e.g. myhost.domain.local. Then click Add.
6.2. In the Alternative name section, go to Type, and select DNS from the drop-down menu. In the Value field, type the machine's FQDN (the same as in step 6.1.). Then click Add.
6.3. If Orchestrator is installed on multiple nodes, you need to add all these FQDNs, as described in step 6.2. Also add the FQDN of the load balancer.
- Customize the information in the Private Key tab as described below:
7.1. In the Cryptographic Service Provider box, go to Select cryptographic service provider (CSP), and check Microsoft RSA SChannel cryptographic Provider (Encryption).
7.2. In the Key options section, make sure Key Size is set to at least 2048 and Make private key exportable is checked.
7.3. In the Key type section, make sure Key usage is set to Exchange.
- Click OK in the configuration window and Next in the Certificate Information screen.
- In the Where do you want to save your offline request? screen, indicate a file path and file name of your choice, e.g.
C:\Users\YourUser\Documents\sslRequest.req, and select Base 64 as your file format.
- After the Certificate Authority accepts the enrollment request, the certificate is visible in the Personal store.
If the company has a standard procedure/template for obtaining the certificate, the user should refer to that procedure.
For other environments (e.g. without auto-enrollment policy), you may still use this document as reference for the certificate parameters.
If you need to quickly create an SSL certificate for testing purposes only, you may create a self-signed SAN SSL certificate.
Open a PowerShell console as administrator, and issue the following commands. Don’t forget to customize values according to your environment.
$ssc = New-SelfSignedCertificate -FriendlyName "TestingCertificate" -DnsName "loadbalancer.domain.local","node1.domain.local","node2.domain.local" $store = New-Object System.Security.Cryptography.X509Certificates.X509Store( "Root", "LocalMachine") $store.Open("MaxAllowed") $store.Add($ssc) $pass = ConvertTo-SecureString -String "myPass" -Force -AsPlainText Export-PfxCertificate -Cert $ssc -FilePath "C:\temp\testingCertificate.pfx" -Password $pass
The commands above also export the
C:\temp\testingCertificate.pfx file for later use.
In order to make the self-signed certificate available on others machines (secondary Orchestrator nodes / Robot machines), open a PowerShell console as administrator, and issue the following commands.
$pass = ConvertTo-SecureString -String "myPass" -Force -AsPlainText $imported = Import-PfxCertificate -FilePath "C:\temp\testingCertificate.pfx" -CertStoreLocation Cert:\LocalMachine\My\ -Exportable -Password $pass $store = New-Object System.Security.Cryptography.X509Certificates.X509Store( "Root", "LocalMachine") $store.Open("MaxAllowed") $store.Add($imported)
Firefox handles the process a bit differently, as it does not read the certificate information in the Windows store. Rather than installing certificates, it allows you to define exceptions for SSL certificates on particular sites.
When you visit a site which has a certificate error, the warning message in the screenshot below is displayed. The URL you are trying to access is displayed in the blue area. To create an exception to bypass this warning on that specific URL:
- Click the Add Exception button. The Add Security Exception window is displayed.
- In the Add Security Exception window, click Confirm Security Exception to configure this exception locally.
If a particular site redirects to subdomains within itself, you may get multiple security warning prompts with slightly different URLs every time. Add exceptions for those URLs by following the steps above.
In case you encounter problems with using a certificate with
UiPathOrchestrator.msi (during installation or upgrade), here is where you can start your troubleshooting:
From Control Panel:
Open Manage Computer Certificates -> Personal -> Certificates. Identify your certificate and double-click it. In the General tab there should information about its validity.
From a command line, run the following command to diagnose the certificate:
certutil -v -verifystore My <certificateThumbprint>- its summary is at the end of the output.
Note: You can find your certificate's thumbprint in the Details tab described at Step 1.
An internal server error may occur if the certificate does not have the appropriate permissions set. Run the following as Admin to grant the necessary permissions:
import-module WebAdministration $siteName = 'UiPath Orchestrator' $binding = (Get-ChildItem -Path IIS:\SSLBindings | Where Sites -eq $siteName) $certLoc = "cert:\LocalMachine\MY\$($binding.Thumbprint)" $cert = Get-Item $certLoc $keyPath = $env:ProgramData + "\Microsoft\Crypto\RSA\MachineKeys\" $keyName = $cert.PrivateKey.CspKeyContainerInfo.UniqueKeyContainerName $keyFullPath = $keyPath + $keyName $acl = (Get-Item $keyFullPath).GetAccessControl('Access') $permission="IIS_IUSRS","Full","Allow" $accessRule = New-Object -TypeName System.Security.AccessControl.FileSystemAccessRule -ArgumentList $permission $acl.AddAccessRule($accessRule) Set-Acl -Path $keyFullPath -AclObject $acl
Updated 4 days ago