Smart.Credential.Retriever
1.0.4
Requires NuGet 3.3 or higher.
dotnet add package Smart.Credential.Retriever --version 1.0.4
NuGet\Install-Package Smart.Credential.Retriever -Version 1.0.4
<PackageReference Include="Smart.Credential.Retriever" Version="1.0.4" />
paket add Smart.Credential.Retriever --version 1.0.4
#r "nuget: Smart.Credential.Retriever, 1.0.4"
// Install Smart.Credential.Retriever as a Cake Addin #addin nuget:?package=Smart.Credential.Retriever&version=1.0.4 // Install Smart.Credential.Retriever as a Cake Tool #tool nuget:?package=Smart.Credential.Retriever&version=1.0.4
Why Do We Need the Smart.Credential.Retriever ?
The Smart.Credential.Retriever workflow is essential in environments where multiple robots access the same application but cannot share the same credentials simultaneously. In many enterprise applications, attempting to use the same credentials for concurrent sessions can result in one or more robots being logged out automatically. This often leads to process failures, as the application detects multiple logins from the same account and terminates conflicting sessions.
Without a solution like this, a credential being used by one robot could unintentionally be assigned to another robot, causing the first robot's session to be forcibly logged out. This creates critical issues, such as:
- Failed automations due to unexpected logouts.
- Inconsistent behavior where robots cannot complete their tasks.
- Increased downtime as processes need to be restarted.
The Smart.Credential.Retriever dynamically manages credential allocation, ensuring that only unused credentials are assigned to robots. By checking the Credential Manager, it prevents the assignment of credentials that are already in use. This guarantees that:
- Each robot operates with a unique and free credential.
- Application session conflicts are avoided.
- Automation processes run smoothly without interruption.
This solution is indispensable for ensuring reliable and uninterrupted robotic process automation (RPA), especially when dealing with applications that enforce strict login policies.
How it Works:
The program entry starts from the GetAvailableCredential workflow is designed to identify and retrieve an available credential asset from a specified Orchestrator folder. It accomplishes this by comparing a list of predefined asset credential names against those currently stored in the Credential Manager, which serves as a cache for the credentials in use.
The Credential Manager is essentially an asset that temporarily stores used credential asset names and job IDs in JSON text format as the value of the asset. Job IDs uniquely identify a running process and can be retrieved using the Get Job activity.
To find an available credential, the workflow iterates through the list of asset names and checks each one to determine if it is currently in use. It selects the first asset name that is absent from the Credential Manager, ensuring that it is not being utilized by any other processes.
Once an available credential asset name is identified, the workflow retrieves the corresponding username and password using a UiPath Get Credential activity. Following this, the job ID and the name of the used credential asset are registered in the Credential Manager. This registration process prevents other robots that reference this program from using the same credential, thereby ensuring that only free and unused assets are selected for operations.
Workflow Steps
This workflow serves as the entry point for the program, where the following actions occur:
Determining the Required Parameters:
- If the variable
sharedOrchestratorFolderName
is not declared, the program defaults to "Shared." - Similarly, if
topLevelOrchestratorFolderName
is not declared, it defaults to "/", representing the top-level tenant folder. - The
CredentialManager
asset is utilized to cache the credentials that are currently in use.
- If the variable
If a
listOfCredentialAssetNamesInSharedFolder
is provided, the program validates the given list in (3). Otherwise, it retrieves the list of credentials from the Orchestrator's shared folder by searching through available assets (4).ValidateListOfCredentialAssetNamesProvided:
- when a
listOfCredentialAssetNamesInSharedFolder
is provided this verifies that each asset name in the list exist in thesharedOrchestratorFolderName
of the ochestrator as a credential.
- when a
GetListOfCredentials:
- when a
listOfCredentialAssetNamesInSharedFolder
is NOT provideded this retrievs all credentials asset names from thesharedOrchestratorFolderName
of the Orchestrator that match a giventagToIdentifyTargetCredentialsWith
and puts them into the 'listOfCredentialAssetNamesInSharedFolder. Alternatively, if no
tagToIdentifyTargetCredentialsWithwas provided its takes all credential assets on the shared ochestrator and puts them into the 'listOfCredentialAssetNamesInSharedFolder
.
- when a
CreateCredentialManagerAssetIfNotExisting:
- This creates a text value asset named
CredentialManager
in thesharedOrchestratorFolderName
of the ochestrator if it does not already exist. - Upon its initial creation, the asset's default value will be a JSON string:
{"CredentialName":"JobId"}
. This format indicates that it will store a JSON object containing the propertiesCredentialName
andJobId
.
- This creates a text value asset named
ReadAndUpdateCredentialManager:
- This generates a
credentialLogConfig
by reading and deserializing the JSON text in theCredentialManager
asset. The generated config is a dictionary (ofString, String
), where theCredentialName
is stored as a string against its correspondingJobId
as a string. - Next, it uses the Orchestrator API to find all jobs that are currently running or pending (active jobs). The active jobs are placed in a list of
JobId
. - Only jobs in the
credentialLogConfig
withJobId
present in the list of activeJobId
are preserved in thecredentialLogConfig
. - The
credentialLogConfig
is serialized back to text and updated as JSON, then saved back to theCredentialManager
asset. - The
credentialLogConfig
is also returned for use in the next steps.
- This generates a
Iterate Asset Names:
- The program iterates through
listOfCredentialAssetNamesInSharedFolder
, checking for its absence in thecredentialLogConfig
. - Upon finding an asset name in
listOfCredentialAssetNamesInSharedFolder
that is not currently in use (i.e., not present incredentialLogConfig
), the program captures its name and exits the loop. - This asset name is stored in
assetNameOfAvailableCredential
.
- The program iterates through
If step (7) successfully returns a credential asset name, then steps (8) and (9) are executed:
GetCredential Activity:
- The
GetCredential
activity is used to retrieve theusername
andpassword
ofassetNameOfAvailableCredential
fromsharedOrchestratorFolderName
.
- The
AddCurrentJobIdToCredentialManager:
- This workflow registers the
JobId
of the current process with the asset name in thecredentialLogConfig
and updates the JSON text in theCredentialManager
asset. - It updates the associated value in the JSON text format. For example, if the job ID is
56sg672628-67126gh1jj2
, the JSON text will be updated to{"CredentialName":"JobId","Credential1":"56sg672628-67126gh1jj2"}
. - This ensures that any subsequent programs accessing this library cannot use
Credential1
while the job ID56sg672628-67126gh1jj2
is still running or pending.
- This workflow registers the
Error Handling:
- If step (7) does not return a credential asset name, the program throws an error.
How To Use In Uipath
After downloading package into your project from the Manage Depencies on your uipath studio
Key Arguments You Need to Supply:
topLevelOchestratorFolderName
- What it is: The name of the top-level folder in Orchestrator.
- Example:
"Company"
Optional
If not declared, it defaults to/
, representing the top-level tenant folder.
sharedOchestratorFolderName
- What it is: The specific folder inside the top-level folder where the credentials are stored.
- Example:
"IT_Credentials"
Optional
If not declared, the program defaults to"Shared"
listOfCredentialAssetNamesInSharedFolder
- What it is: A list of the names of the credentials you want to retrieve from that folder.
- Example:
{"AppCredentials1", "AppCredentials2", "AppCredentials3"}
Optional
If not declared, the program defaults to"Shared"
sharedOchestratorFolderName
- What it is: The specific folder inside the top-level folder where the credentials are stored.
- Example:
"IT_Credentials"
Optional
If not declared, the program defaults to"Shared."
tagToIdentifyTargetCredentialsWith
- What it is: is a phrase within credential names that helps filter and retrieve all credentials containing that phrase. If left blank, the program will select all available credentials without filtering by name. Only use when you have not declared
listOfCredentialAssetNamesInSharedFolder
. - Example:
"WhatsAppCredential"
Optional
Can be left blank If is you are going to let the program determine all credentials asset names from thesharedOrchestratorFolderName
of the Orchestrator.
- What it is: is a phrase within credential names that helps filter and retrieve all credentials containing that phrase. If left blank, the program will select all available credentials without filtering by name. Only use when you have not declared
How to Use These:
- If your folder structure in Orchestrator looks like this:
- Top-level folder:
"Company"
- Shared folder:
"General"
- Credential assets you want to always choose from:
"WhatsAppCredential1"
,"WhatsAppCredential2"
,"WhatsAppCredential3"
- Top-level folder:
You would pass these values as arguments like this:
topLevelOchestratorFolderName
:"Company"
sharedOchestratorFolderName
:"General"
listOfCredentialAssetNamesInSharedFolder
:{"WhatsAppCredential1", "WhatsAppCredential2", "WhatsAppCredential3"}
This is all you need, and the library would return the credentials which are not in use by another process or robot.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net8.0-windows7.0 is compatible. net9.0-windows was computed. |
-
net8.0-windows7.0
- UiPath.Excel.Activities (>= 2.24.0-preview)
- UiPath.Mail.Activities (>= 1.23.11)
- UiPath.System.Activities (>= 24.11.0-preview)
- UiPath.Testing.Activities (>= 24.10.0)
- UiPath.UIAutomation.Activities (>= 24.11.1-preview)
- UiPath.WebAPI.Activities (>= 1.21.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
1.0.4 | 138 | 9/9/2024 |