Soffid 3 Reference guide

Reference Guide Soffid 3

🔎 Overview

Introduction

The Soffid 3 reference guide wants to present all the functionality contained in version 3 of the Soffid Console, explaining the functionality of all the screens and the functionality of each of them.

The documentation is organized as the options menu of Soffid Console, to try to facilitate access and comprehension of the information.

For each screen we try to define the following attributes:

Functionality

Self-service portal

Soffid Console provides the Self-Service Portal, where the end-users can consult or change their credentials, request new permissions or access to applications, manage their profile, or launch applications. All from a single point of entry. 

Another purpose of the Self-Service Portal is to reduce the workload of the IT department, as well as improve the overall security of the IT system. 

My tasks
My applications
My request
Process search
My accounts
My OTP devices
My certificates and FIDO tokens

Global settings

Global settings refer to configuration options or preferences that apply to the entire system. These settings are typically established by administrators or developers and are used to define the behavior and functionality of the system.

Tenant
Plugins
Look &Feel
Soffid parameters
User Type
Group Type
Metadata
Configuration wizard
Export settings & objects
Import settings & objects


Security settings

Authorizations
Authentication
Password policies
Configure PAM sessions
PAM Rules
PAM Policies


Resources management

Users
Groups
Accounts
Roles
Informations Systems
Role assignment rules
Segregation of Duties
Networks
Hosts
Printers
Mail Domains
Mail List
Application access tree
Password vault
Custom objects
Network discovery

Integration engine

Smart engine settings
Agents
Synchronization servers
Account naming rules
Attribute translation tables
Soffid Objects
Sample scripts
Utility classes

Monitoring and reporting

Sync server monitoring
Scheduled task
Scheduled jobs
Audit
Access logs
Sessions
Console log

Privileged accounts dashboard
Search in PAM recordings


Self service portal

Self service portal

Introduction to Self Service Portal

What is Self-Service Portal?

Soffid Console provides the Self-Service Portal, where the end-users can consult or change their credentials, request new permissions or access to applications, manage their profile, or launch applications. All from a single point of entry. 

Another purpose of the Self-Service Portal is to reduce the workload of the IT department, as well as improve the overall security of the IT system. 

Soffid allows administrator users to configure access to the different options depending on the end-users roles defined to use Soffid. In this way, end-users will be able to access the Self-Service Portal to manage their own requirements always depending on the defined business processes.

Screen overview

image-1679411674517.png


Brief description of each option

My tasks

My tasks display all the tasks in which the user is involved, like a supervisor, manager, o person how has to approve or deny that task. 

Visit My Task page

My request

My requests display all the processes or workflows that the user will be able to run, and the option allows the user to consult the status of the requests.

The Query request status displays all the processes that the user has initiated and allows the user to consult all the information about the workflow.

Visit My Request page

That functionality allows to users search for processes initiated or requested by themselves. Here the users will be able to consult all the information related to the processes and their status and if there are any pending tasks to be completed. If there are pending tasks, the user will be able to browse the task and manage it.

Administrator users will be able to consult all the information about all the processes which have been executed by any user.

My Applications

My applications display all the corporate applications and third-party applications as well to which the user has permission to connect. Those applications have to be configured into Soffid Console

The password vault folder will be displayed as well. In this folder, the users will be able to find the shared accounts on the Soffid vault folder and will be able to save their personal accounts.

Visit My Applications page

My Accounts

My Accounts display all the personal user accounts registered into Soffid Console and with which the user will log into the target system.

Visit My Accounts page

My authentication

My OTP devices

My OTP devices display all the OTP devices configured by the user and allow to the user config new ones.

Visit My OTP devices page

My certificates and FIDO tokens

My certificates and FIDO token display all the configured certificates and allow to the user config new ones.

Visit  My certificates and FIDO tokens page

My Profile

My Profile allows to end-users config their own profile, update the user info and preferences, change the password, and recovery questions.

Visit My Profile page


Self service portal

My tasks

Description

Displays the task in which the user is involved like a supervisor, manager, o person how has to approve or deny that tasks.

My task provides information about the process, the task, the start and due date and the asigned user. By clicking a record, it will be shown de task details and to perform actions will be allowed.

Manual tasks are assigned to named users, groups or roles.  Whatever strategy is followed, each one of the assigned users will see that task at their tasks page. 

You can differentiate tasks by their highlighted style:

The purpose of My tasks as a part of Self Service Portal is to reduce the workload of IT department, as well as improve overall security of IT system. Soffid console is concerned about task delegation and workflow management. 

Screen overview

Custom attributes

My Task List

Task detail

Task

Shows information about the job done in this task. This information depends on the process launched.

Action Logs

The action logs tab shows basic information about the process and a list with the summary of all the successive phases through which the task has passed.

Attachments

Displays the documents attached to the task, in some cases, files are attached to the tasks.

Allows you to download those documents and to verify any digital signature attached to them. Some tasks even allow the user to upload documents.

Comments

Displays the comments list added during the business process execution. Displays the comments list added during the task execution providing information about the user who wrote the comment, the date and time of that writing, and the comment that was writed.

Actions

My task query actions

Reload

This action reload the task list with the current data.

Download CSV File

This action allows you to  download a csv file with the list of all tasks. You can open the hamburger icon and Download CSV File.

Open task

By clicking on a record, the task detail will be shown.

My task detail actions

Close

Allows you to closes the task window,  you can add new comments and those will be saved.

Take ownership

Enables the user to self-assign the task to authorize or deny it.

Schedule

Allows you to schedule the task execution.

Delegate

Allows you to to reassign the task to another user, who will must approve or deny it.

Approve

Allows you to authorize the task. When you authorize a task all defined operations for this task will be performed.

Reject

Allows you to deny the task. When you deny a task none defined operations for this task will be performed.




Self service portal

My issues

Description

Soffid provides a tool to manage all issues and allows you to perform the operations available for each type of task. The actions to be performed will depend on each kind of task.

Screen overview

image-1690443317730.png

Standard attributes

Actions

Issues query action

Download CSV file Allows you to download a CSV file with the issue data.

Add or remove columns

Allows you to show and hide columns in the table. You can also set the order in which the columns will be displayed. The selected columns and order will be saved for the next time Soffid displays the page. 

Issue detail

Close Allows you to quit without applying any changes.
Acknowledge

Allows you to check as Acknowledged

Solve issue

Allows you to mark as solved the issue.

Send custom email Allows you to send a custom email to one recipient.
Add Comments Allows you to add comments to the Action logs.
account-created
💻 Image

image-1691073560305.png

Unlock account If you click this option, Soffil will unlock the account.

Look affected accounts

 If you click this option, Soffil will lock affected accounts. 

Disable user

If you click this option, Soffid will disable the user.

disconnected-system
💻 Image

image-1691505347878.png

discovered-host
💻 Image

image-1695972298817.png

discovered-system
💻 Image


duplicated-user
💻 Image

image-1691406809609.png

Mege users

If you click this option, Soffid will allow you to merge the identities by selecting the data of each of them.

💻 Image


image-1691406880979.png


failed-job
💻 Image

image-1691073883011.png

enabled-account-on-disabled-user
💻 Image

image-1695972326375.png

Unlock account If you click this option, Soffil will unlock the account.

Look affected accounts

 If you click this option, Soffil will lock affected accounts. 

global-failed-login
💻 Image

image-1691074786904.png

integration-errors
💻 Image

image-1691074818620.png

locked-account
💻 Image

image-1691412483843.png

Unlock account If you click this option, Soffil will unlock the account.

Look affected accounts

 If you click this option, Soffil will lock affected accounts. 

Disable user

If you click this option, Soffid will disable the user.

Lock affected host

If you click this option, Soffid will lock the affected host.

Unlock host

If you click this option, Soffid will unlock the host.

login-different-country
💻 Image

image-1696239831327.png

Unlock account If you click this option, Soffil will unlock the account.

Look affected accounts

 If you click this option, Soffil will lock affected accounts. 

Disable user

If you click this option, Soffid will disable the user.

Lock affected host

If you click this option, Soffid will lock the affected host.

Unlock host

If you click this option, Soffid will unlock the host.

login-from-new-device
💻 Image

image-1691074846496.png

Unlock account If you click this option, Soffil will unlock the account.

Look affected accounts

 If you click this option, Soffil will lock affected accounts. 

Disable user

If you click this option, Soffid will disable the user.

Lock affected host

If you click this option, Soffid will lock the affected host.

Unlock host

If you click this option, Soffid will unlock the host.

login-not-recognized
💻 Image

image-1691074918985.png

Unlock account If you click this option, Soffil will unlock the account.

Look affected accounts

 If you click this option, Soffil will lock affected accounts. 

Disable user

If you click this option, Soffid will disable the user.

Lock affected host

If you click this option, Soffid will lock the affected host.

Unlock host

If you click this option, Soffid will unlock the host.

otp-failures
💻 Image

image-1691074948199.png

Unlock account If you click this option, Soffil will unlock the account.

Look affected accounts

 If you click this option, Soffil will lock affected accounts. 

Disable user

If you click this option, Soffid will disable the user.

Lock affected host

If you click this option, Soffid will lock the affected host.

Unlock host

If you click this option, Soffid will unlock the host.

pam-violation
💻 Image

image-1691404894434.png

Unlock account If you click this option, Soffil will unlock the account.

Look affected accounts

 If you click this option, Soffil will lock affected accounts. 

Disable user

If you click this option, Soffid will disable the user.

Lock affected host

If you click this option, Soffid will lock the affected host.

Unlock host

If you click this option, Soffid will unlock the host.

password-changed
💻 Image


permissions-granted
💻 Image

image-1691075044973.png

Unlock account If you click this option, Soffil will unlock the account.

Look affected accounts

 If you click this option, Soffil will lock affected accounts. 

Disable user

If you click this option, Soffid will disable the user.

risk-increase
💻 Image

image-1691678367280.png

Unlock account If you click this option, Soffil will unlock the account.

Look affected accounts

 If you click this option, Soffil will lock affected accounts. 

Disable user

If you click this option, Soffid will disable the user.

robot-login
💻 Image

image-1696240262391.png

Unlock account If you click this option, Soffil will unlock the account.

Look affected accounts

 If you click this option, Soffil will lock affected accounts. 

Disable user

If you click this option, Soffid will disable the user.

Lock affected host

If you click this option, Soffid will lock the affected host.

Unlock host

If you click this option, Soffid will unlock the host.

security-exception
💻 Image

image-1691140940313.png

Disable user

If you click this option, Soffid will disable the user.


Self service portal

My applications

Description

My application is a part of a Soffid Self-service portal that allows end-users to start corporate applications and third party applications. Also,  the end-user can view and use the shared accounts available for the user defined on the Password vault.

Applications

That option shows to each user, all the Corporate and Third party Applications to which the user can connect and the applications with public access. These applications have to be configured on the Application Access Tree option by an administrator user.

For more information you can visit the Application access tree page.

Password Vault

My Applications option shows the PasswordVault folder. On the vault folder you can find two kind of folders, one a personal folder and other a shared folder

Inside the personal folder, you can create your own accounts, those accounts will not be shared with any other user. The shared folders could be used or managed by the owner/manager/SSO users.

For more information you can visit the Password vault page.

image-1711093098167.png

Self service portal

My requests

Description

Soffid provides a complete workflow engine that allows you to incorporate business processes or define new business processes as needed. End-users with the appropriate permissions will be able to request these processes. You can visit Self service portal examples page for more information.

My request screen allows to users: on the one hand, consult the processes they have executed and view the process details and status, Query request status; on the other hand, they will be able to execute the processes for which they have been assigned the proper permissions.

More information about process and workflows on BPM Editor Book


Screen overview

image-1638529831157.png

Query request status

Description

Displays a table with all the processes performed by the end-user. The end-user can consult processes detail and perform actions depending on the user permissions. You can visit Self service portal examples page for more information.

Custom attributes

To view all the attributes of one process, you can access Process attributes to consult the custom attributes. Be in mind, the processes have custom attributes depending on the business process definition.

Actions

The operations to be performed depend on the user permission and the business processes defined with the workflow engine.

You can find documentation about the business processes on BPM Editor Book.

Query request status actions

Reload

Allows you to reload the processes list with updated data.

Download CSV file

Allows you to download a CSV file with all the information of the processes list.

Query Filters

Allows you to filter data in each column of the table.

Process actions

The actions to perform to each process, depend on the business process definition and the user permissions.

You can find more information about the most commons process actions if you go to Process detail actions


Self service portal

Process Search

Description

A process is a series of actions, connected by transitions. An action could be either an automatic action or a manual task.

Soffid console is concerned about task delegation and workflow management. Any user is able to create new processes or any user can be assigned as an actor for a task belonging to a process.

Process Search page allows users to search process by different criteria, to view the process details and to perform the proper actions depending on the user roles.

In order to view a task, a security constraint must be accomplished. The user must have granted the observer or administrator role on the specific project version or has been assigned as a potential actor of it at some time.

Screen overview

Custom attributes

Search attributes

The search can be performed by setting certain parameters, which are as follows:

Process attributes

Each process has commons attributes and specific attributes depending on the business process definition.

You can find documentation about the business processes on BPM Editor Book

Commons process attributes
Other process information

Actions

Process query actions

Actions to be performed on the process list:

Search

Allows you to query the processes with the indicated parameters.

Download CSV file

Allows you to download a CSV file with the list of processes. You can open the hamburger icon and Download CSV File.

Table Filters

Allows you to filter data in each column of the table.

Process detail actions

Each process has a specific action defined on the business process definition.

You can find documentation about the business processes on BPM Editor Book

The most commons actions are below:

Close

Allows you to close the process detail page and return to the previous page.

Reload

Allows you to reload all process data with the updated data.

Take ownership

Allows you to take the ownership to approve o deny the process.

Approve

Allows you to approve the process and perform the actions defined for that process.

Deny

Allows you to reject the process.

Work in progress actions

Edit task

Allows you to edit a task by clicking on the record. When you click the task, you will browse to the task detail and it will be allowed to perform actions defined to users with the proper permissions.

Attachments

Download

Allows you to download the available attached files.




Self service portal

My accounts

Description

My Account is a part of Soffid's self-service portal that allows end-users to access and manage their personal accounts. That option displays to each user, all their personal accounts and allows to set and query the password of each account.

image-1711093182201.png

Standard user attributes

Actions

Set password

Allows you to set a new password for this account. That change will apply to different target systems.

The new password must comply with the password policies definied.

Query password

Allows you to query and copy the password and the user name.

Download CSV file

Allows you to download a CSV file with all the information about your accounts. 


Self service portal

My OTP devices

Description

My OTP devices are part of a Soffid Self-service portal that allows end-users to access their OTP devices configured.

That option display to each user, all their OTP devices and also allows you to manage those and add new OTP devices.

This option will only be available if the OTP addon is installed in the Soffid console. Visit the Two factor authentication book for more information

Screen overview

Standard attributes

Actions

Add

Allows you to add a new OTP device. To add new OTP devices you need to click the add button (+), then Soffid will display a new wizard to config the OTP devices. First of all, you need to select the OTP device Type, once the type is selected, you need to fill in the required fields, which depend on the Type selected. If you select an Event-based or Time-based HMAC Token, you will need to scan the QR code and write the PIN. Finally, you must Apply changes.

Delete

Allows you to delete one or more OTP devices. To delete OTP devices first select the devices, then click on the subtract button (-), then Soffid will ask you to confirm or cancel the operation.




Self service portal

My certificates and FIDO tokens

Description

My certificates and FIDO tokens are part of a Soffid Self-service portal that allows end-users to access their OTP devices configured.

That option displays to each user, all their certificates and FIDO tokens and allows also to manage those and add new certificates and FIDO tokens.

Screen overview

image-1679412364922.png

Standard attributes

Actions

Add

Allows you to add new certificates and FIDO tokens. To add new ones you need to click the add button (+), and then Soffid will display a new wizard to configure the certificates and FIDO tokens.

First of all, you need to select the Type, once the type is selected, you need to follow the required steps which depend on the Type selected. 

Delete

Allows you to delete one or more certificates and FIDO tokens. To delete certificates or FIDO tokens first you must select the certificate or FIDO token, then click on the subtract button (-), then Soffid will ask you to confirm or cancel the operation.




Self service portal

My Profile

Description

My Profile is a part of a Soffid Self-service portal that allows to end-users config their own profile, update the user info and preferences, change their password, and recover questions.

To display My Profile page you need to click on the config icon and then click My Profile on the options menu. Then Soffid displays a new window that will allow end users to configure their profiles.

Screen overview

Basic tab

image-1639403202766.png

Change password

image-1665042716560.png

Authorizations tab

image-1639407277195.png

Application consents tab

image-1639407292133.png

Standard attributes

Basic

User Info

For more info about password recovery, you can visit the Password recovery questions page.

Preferences

Authorizations

Display a list with the user authorizations. 

Application consents

Displays a list of all the user's consents given, and the user can see all of them. Users can remove the consent at any time as well.

When the user connects to a new application, the IdP will indicate which data will be shared with this application. That information is defined in the Attribute sharing policies page of the Federation.

For more info about password recovery, you can visit the Attribute sharing policies page.


Global settings

Global settings

Tenants

Definition

Soffid 3 is multi tenant. This means that one can configure many differente tenants to manage disjoints groups of identities and applications. 

Each Soffid object, including applications, systems, roles, users, and accounts are bound to a single tenant. 

Of course, there is a special tenant named master. Master tenant administrators can jump to any other tenant with administration privileges.

Soffid recommends connecting directly to the specific tenant to configure it correctly. You have more information about this topic in the Tenant access section.

Screen overview

Tenant properties

Actions

The following actions can be performed on tenants:

Export a tenant

The process will generate a compressed file with all the information contained in the Tenant. It includes even the connectors configurations, mappings and global settings.

Import a tenant

The user can upload the previously exported tenant. The process will restore all the information contained in the Tenant, including connectors configurations, mappings and global settings.If the Tenant already exists, the process will not replace it. A new tenant will be created with a new name. If you want to replace the existing tenant, remove it before uploading the tenant export file.

Log into a tenant

If you have permission to log into a different tenant, you can use this option to access to it. This option is not intended for normal usage, but for administrative purposes

Tenant access

Option 1

When users are connecting to Soffid console, the master tenant is displayed by default. In order to directly connect to any tenant, a DNS entry with the tenant name must be added to your DNS server.

For instance, if you have deployed a Soffid console with the DNS name soffid.mycompany.com, the DNS name test1.soffid.mycompany.com will be used to access to the test1 tenant.

Note that you must configure the hostName Soffid parameter in the master with your DNS name

image-1651502621836.png

Option 2

You can also configure the login page using the soffid.auth.showTenant Soffid parameter. If the parameter value is true, Soffid will display a new box in the login page to write the tenant name to login.

image-1650618939472.png

image-1650618974134.png





Global settings

Plugins

Definition

Soffid provides you additional functionality that allows installing addons and server plugins. There are two main types of addons: system connectors and console addons.

You can download existing addons and plugins developed by Soffid by visiting http://download.soffid.com/download  or http://download.soffid.com/download/enterprise  if you have a Soffid user with authorization.

Addons and plugins can be developed using Addon Development Guide. 

An addon or plugin, must be upload into a Master tenant, the other tenant will inherit these installed addons and plugins.

System connectors

Also referred as plugins, there are little pieces of software able to manage identities on some type of systems. They can be generic plugins (SQL or LDAP plugins) or custom specific plugins.

The system connector is configured when the administrator creates an agent. An agent can be viewed as a configured instance of a plugin.

In order to upgrade existing (running) plugins, the synchronization server that hosts this plugin must be restarted from the system monitoring screen.

Console addons

Add important features to Soffid console. A console addon can contain common classes, data models, transactional services, web services, and web interfaces.

In order to apply addon changes, the console must be restarted. It can be restarted from this page by clicking on the restart console button.

From the addon management screen, you will be able to upload and upgrade server plugins, as well and enable or disable them.

Screen overview

  1. Tenants
  2. Agents: is used to configure a system connector.

Standard attributes

Actions

Plugins query actions

Add new

Allows you to upload and install a new plugin or addon. You can choose that option on the hamburger menu or click the add button (+).

You must pick a file, that file has to be a valid add-on or plugin. Once the file is selected, it will be uploaded automatically. Then, you must restart the Sync server or Console depending on the uploaded plugin

Delete

Allows you to delete one or more plugins or addons, you must select one or more records from the list and click the button with the subtraction symbol (-).

To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

Restart Console

Allows you to restart the console to apply addon changes. That operation will be mandatory when you load an addon.

Download CSV file

Allows you to download a CSV file with all the information about plugins and addons.

Plugins detail actions

Apply changes Allows you to update the plugin. Only Enabled attribute can be modified. Once you apply changes, the plugin details page will be closed.
Save Allows you to update the plugin. Only Enabled attribute can be modified.
Delete

Allows you to delete and desinstall a specific plugin. To delete a plugin, you can click on the hamburger icon and then click the delete button (trash icon).

Soffid will ask you for confirmation to perform that action, you could confirm or cancel the operation.

Undo Allows you to undo any changes.


Global settings

Look & feel

Definition

Soffid's Look & feel page allows you to adjust the Console styles to your organization.

In this configuration page, the customization of three sections is allowed:

Some changes may require updating the browser several times because some items are in the browser's cache.

Overview

image-1669823122561.png

Actions

Reset values

Allows you to return to the default Soffid values.

Confirm changes

Allows you to apply the changes made.

Pick a file

Allows you to pick a file to load. The file must have a specific configuration

Global settings

Soffid parameters

Definition

Soffid allows you to customize the configuration of some attributes of the Console, Syncserver, connectors and add-ons.

There are several types of parameters.

If you want to know the Soffid console version check the component.iam-core.version parameter.

image-1711093394363.png

Standard attributes

Actions

Soffid parameters query actions

Add new

Allows you to add a new Soffid parameter. You can choose that option on the hamburger menu or clicking the add button (+).

To add a new parameter it will be mandatory to fill in the required fields.

Delete

Allows you to delete one or more Soffid parameters by selecting one or more records and next clicking the button with the subtraction symbol (-).

To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation. 

Import

Allows you to upload a CSV file with the parameter list to add, update or delete parameters to Soffid.

First, you need to pick up a CSV file, that CSV has to contain a specific configuration. Then you need to check the content to be loaded, it is allowed to choose if you want or not to load a specific attribute. And finally, you need to select the mappings for each column of the CSV file to import the data correctly and to click the Import button.

To delete a parameter, the values of the parameter have to be empty

"Parameter","Network","Value","Description"
"addon.backup.test","","",""

Download CSV file

Allows you to download a csv file with the basic information of all Soffid parameters. 

Soffid parameters detail actions

Apply changes

Allows you to save the data of a new parameter or to update the data of a specific parameter. To save the data it will be mandatory to fill in the required fields.

Delete

Allows you to delete a specific Soffid parameter. To delete a host you can click on the hamburger icon and then click the delete button (trash icon).

Soffid will ask you for confirmation to perform that action, you could confirm or cancel the operation.

Undo

Allows you to quit without applying any changes.

List of parameters sorted by functionality

Console

Parameter
Description

soffid.auth.system

Select the managed system where the account name will be searched on the user login. Defaults to soffid.

soffid.auth.trustedLogin

Set to true to enable the Soffid console to validate passwords on trusted systems. Setting it to false, the password will be validated against internal tables only.

soffid.delegation.disable

Set to true to prevent users to delegate permissions from self service page.

soffid.entitlement.group.holder

Set to optional enables the operator to set a group as the group holder for any entitlement assignment.

Set to always enforce that any entitlement assignment must be bound to a holder group.

Set to none to disable this feature. 

This parameter affects to role holder

soffid.language

Enforce user interface language.

soffid.language.default

Default user interface language (en).

soffid.network.internet

Sets the name for a generic subnet that will hold any host not included on any listed network.

soffid.proxy.trustedIps

Set the IP address of any reverse proxy in front of Soffid servers.
When an incoming request is made from any of these trusted IP addresses, the X-Forwarded-for header is taken as the real source IP of the request. In any other case, the X-Forwarded-for header is ignored.

This parameter can take a list of IP addresses, separated by commas, like the following ones:

  • 127.0.0.1
  • 192.168.120.1, 192.168.120.2

To allow a range of network IPS, one can use the wildcard(*) symbol, as in the following example:

  • 127.0.0.1, 192.168.120.*

Starting with Soffid console 3.3.0, the network-address/bits notation is allowed, as in the following example:

  • 127.0.0.1, 192.168.120.128/25

soffid.propagate.timeout

Timeout in seconds to retry the password validation needed to propagate a managed system notified password change (requires syncserver 1.5.4).

soffid.server.sharedThreads

Number of shared dispatcher threads per synchronization servers (by default 1)

soffid.syslog.server

Hostname or IP address of server hosts SIEM. The SIEM will receive audit information using the syslog protocol.

soffid.task.limit

The maximum number of tasks allowed per transaction. If a simple or complex transaction generates more tasks than specified, these tasks will be kept on hold. Administrators can release them through the monitoring page. (version 2.0+)

soffid.ui.docPath

The path where to store report and workflow documents.

soffid.ui.docServer

URL where is the server to store the files.

soffid.ui.docStrategy

Class responsible for managing report and workflow documents.

soffid.ui.docTempPath

The path where to store temporary files

soffid.ui.docUsername

Username of the doc server.

soffid.ui.docUserPassword

The password of the doc server.

soffid.ui.maxrows

The maximum number of rows to display in searches. The default value is 200 but you can change it.

soffid.ui.timeout

Max time (in milliseconds) a query can take to complete (version 2.0 +).

soffid.ui.wildcarts

Setting the auto value enables the user interface to add wildcards on user queries. Setting it to off disables this feature.

soffid.externalURL

External URL to access to Soffid console.

soffid.kerberos.agent

The name of the Windows server agent so that any incoming Kerberos packets will be authenticated against that domain. 

soffid.pam.search.recordings.timeout

Timeout reached in the query, use the parameter to specify a longer timeout in milliseconds. By default, if you don't config this parameter is 60000 milliseconds.

(version 3.5.18+)

soffid.nameformat

Parameter to configure how to display the users full name. Where:

  • %1$s is the first name.
  • %2$s is the middle name.
  • %3$s  is the last name

For instance:

%2$s %3$s, %1$s  

Syncserver

Parameter
Description
SSOServer This parameter indicates which server acts on the workstations that run SSO. This parameter can have different values for any subnet. So you can define ESSO servers allowed for any subnet.
seycon.https.port Port where synchronization server connects to. This parameter is used by ESSO clients to connect to synchronization servers.
seycon.server.list  Shows where Syncserver and SyncServer backup is installed. When installing the first server synchronization, this parameter is automatically updated. If you want to install a synchronization server backup you must update this parameter manually. Note that proxy synchronization servers are not on this list. See the Soffid installation guide.
soffid.sync.engine.threads

This parameter allows you to configure the number of threads available to run the tasks. If you do not fill this parameter, Soffid will run 1 thread for every 50 systems, but never more than twice the number of CPUs of the server. The value of the parameter must be equal or greater than 1. (Available in Sync Server version 3.5.15+)

 

Mail server

Parameter

Description

mail.host

Host to send electronic mail messages.

mail.from

Recipient address that will be set as the email sender.

mail.transport.protocol

Set to SMTPS to get secure mail. Default value "SMTP" to use plain SMTP protocol.

mail.auth

Set to true if your mail server requires user authentication.

mail.user

Set your email user name if your mail server requires user authentication.

mail.password

Set your email password if your mail server requires user authentication.

mail.port

25 by default, with this parameter a new port can be set.

mail.smtp.sasl.enable

Set to true to enable SASL.

Job notifications

Parameter

Description

soffid.scheduler.error.notify

Users to notify when a scheduled task fails. 

soffid.bpm.error.notify

Users to notify when a BPM task fails.

soffid.bpm.error.retry

Set to true to always retry any failed BPM task.

Syncserver provisioning

Parameter
Description
soffid.server.register

Set to direct value to bypass standard workflow needed for a syncserver to join the syncservers security network. Otherwise, the standard approval workflow will be required(Since syncserver 2.6.0). You also can set it to no-direct


Addons

Federation
Parameter
Description
addon.federation.essoidp

Set the Identity Provider identifier to indicate that this will be the authentication provider.

For more information, you can visit the How to add to ESSO a second factor of authentication page.

Exclude menu options

To exclude default menu options for all users of the Sofid console, the following steps can be followed

1. To exclude some menu options from your Soffid console, you must edit the system.properties file of this console. You can find this file in the following path: /opt/soffid/iam-console-3/conf/

2. Add the soffid.menu.hidden parameter to the system.properties file. The value of this parameter can be the menu options name that you can find in the console.yaml file.

image-1685525691139.png

3. Restart the Soffid console.


Global settings

User Type

Description

User type is the way to categorize users and allows configuring different password policies. Those policies can be more or less restrictive depending on the user's risk. For instance, internal users (automatically created) are different from external ones.

Therefore, this field is very useful for the following cases:

Be in mind that a user always must belong to a User Type.

Overview

image-1669823315792.png

  1. User: each user must be assigned a user type.
  2. Account: the shared or privileged accounts also require having selected a user type to associate it with a password policy

Standard attributes

Actions

User type query

Add new

Allows you to create a new User type. You can choose that option on the hamburger menu or clicking the add button (+).

To add a new User type it will be mandatory to fill in the required fields

Delete

Allows you to remove one or more User type by selecting one or more records and next clicking the button with the subtraction symbol (-).

To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

Import

Allows you to upload a CSV file with the User type list to add or update User types to Soffid.

First, you need to pick up a CSV file, that CSV has to contain a specific configuration. Then you need to check the content to be loaded, it is allowed to choose if you want or not to load a specific attribute. And finally, you need to select the mappings for each column of the CSV file to import the data correctly and to click the Import button.

Download CSV file

Allows you to download a csv file with the basic information of all user types. 

User type detail

Apply changes

Allows you to save the data of a new User type or to update the data of a specific User type. To save the data it will be mandatory to fill in the required fields.

Delete

Allows you to delete the User type. To delete a host you can click on the hamburger icon and then click the delete button (trash icon).

Soffid will ask you for confirmation to perform that action, you could confirm or cancel the operation.

Undo

Allows you to undo any changes made.


Global settings

Group Type

Description

Companies are organized in different business units, departments or workgroups. In Soffid, they all are named as groups. These group can be categorized by a group type.

Group types can be used in the definition of Holder Groups. Some roles can be assigned to a user only through a group enabled for it. When a user no longer belongs to a group, it is not allow assign that role to the user.

A user always belongs to a user type, but groups do not necessarily have to belong a group type.

Related objects

  1. Group
  2. User

Standard attributes

Role holder (and holder group)

In some organizations is necessary to assign roles that affect only a part of the structure, for instance, a department, a division or a country.

The role holder is the role that requires to be assigned to a group, and the holder group is the group that can be assigned role permission.

To configure correctly this functionality you have to apply the next steps:

  1. Create at least one organizational unit with the role holder attribute active (yes).
  2. Assign groups to the organizational unit (with the attribute type of the group).
  3. Also, you can include new custom attributes to this membership relation, go to Metadata page and select the GroupUser to add these attributes.
  4. In the soffid parameters page, create a new parameter named soffid.entitlement.group.holder. It can have one of these three values:
    1. Set to optional enables the operator to set a group as the group holder for any entitlement assignment.
    2. Set to always to enforce that any entitlement assignment must be bound to a holder group.
    3. Set to none to disable this feature

Now you can start to apply this configuration to the users:

Actions

Group type query

Add new

Allows you to create a new Group type. You can choose that option on the hamburger menu or clicking the add button (+).

To add a new Group type it will be mandatory to fill in the required fields

Delete

Allows you to remove one or more Group types by selecting one or more records and next clicking the button with the subtraction symbol (-).

To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

Import

Allows you to upload a CSV file with the Group type list to add or update Group types to Soffid.

First, you need to pick up a CSV file, that CSV has to contain a specific configuration. Then you need to check the content to be loaded, it is allowed to choose if you want or not to load a specific attribute. And finally, you need to select the mappings for each column of the CSV file to import the data correctly and to click the Import button.

Download CSV file

Allows you to download a csv file with the basic information of all groups types. 

Group type detail

Apply changes

Allows you to save the data of a new Group type or to update the data of a specific Group type. To save the data it will be mandatory to fill in the required fields.

Delete

Allows you to delete the Group type. To delete a host you can click on the hamburger icon and then click the delete button (trash icon).

Soffid will ask you for confirmation to perform that action, you could confirm or cancel the operation.

Undo

Allows you to undo any changes made.



Global settings

Metadata

Description

The Metadata functionality allows expanding the Soffid objects, their attributes, and their data types. Also, it allows expanding custom objects.

By default, there is a list of built-in objects, but it is possible to create new custom objects and add new custom attributes to each of them.

It is usual to add custom attributes in the User built-in object to hold additional information.

Each attribute has a data type, it may be a basic type as a String (simple text), integer value, date, or something more complex as a reference to a custom object, or a popup to select a manager. In this way, one can build relationships between objects.

Screen overview

Related objects

Basically, there are two types of metadata objects. The built-in objects are part of the Soffid core and the custom objects as new objects.

built-in objects

The built-in objects are the objects that are part of the Soffid core. It can not be removed, but more custom attributes can be added.

The following objects are Soffid well-known objects that can be customized by means of this screen. All of them are tagged as Built-in objects.

  1. Accounts
  2. Application
  3. Group
  4. Host
  5. Mail List
  6. Role
  7. User

Custom objects

The custom objects are the objects created by the administrator to extend the Soffid underlying data model. All of them are marked as  Built-in type No.

Each custom object type created by the administrator is displayed at the custom objects menu options. Unfortunately, all custom object types share the same icon.

Custom object attributes

For more information, you can visit the Custom Objects page.

Standard attributes

Object attributes

For more information, you can visit the Textual index page.

Attribute metadata

// Sample to enable company name attribute only when the user is of type E (external)
return "E".equals(ownerObject.userType);
// Sample for checking birthDate is greater than 18 years old
c = java.util.Calendar.getInstance();
c.add(-18, c.YEAR);
if (birthDate == null || birthDate.before(c.getTime()) return true;
else return "Birth date should be before "+ new java.text.SimpleDateFormat().format(c.getTime());
// Sample to set contract number attribute to read only if the attribute company is empty
// Place as an on-load trigger in the contract number field
if (ownerObject.attributes.get("company") == null || ownerObject.attributes.get("company").trim().isEmpty())
  inputField.setReadonly(true);
else
  inputField.setReadonly(false);
// Sample trigger to set contract number attribute to read only when the company attribute gets empty
// Place as an on-change trigger in the contract field
contractField = inputFields.get("contractNumber");
if (value == null || value.trim().isEmpty())
  contractField.setReadonly(true);
else
  contractField.setReadonly(false);
contractField.invalidate(); // Redraw contract number field
......
inputFields.get("contractNumber").getValue();

You can access to SCIM Chapter for more information

Actions

Metadata query

Add or remove columns

Allows you to show and hide columns in the table. You can also set the order in which the columns will be displayed. The selected columns and order will be saved for the next time Soffid displays the page. 

Add new

Allows you to add a new metadata object in the system. You can choose that option on the hamburger menu or by clicking the add button (+).

To add a new it is necessary to fill in the required fields. By default, it will has have two mandatory attributes, name and description.

Delete

Allows you to remove one or more metadata objects by selecting one or more records and next clicking the button with the subtraction symbol (-).

To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

Download CSV file

Allows you to download a CSV file with the basic information of all metadata. 

Metadata object detail

Add new

Allows you to add a new attribute metadata. You can choose that option by clicking the add button (+).

Add or remove columns



Allows you to show and hide columns in the table. You can also set the order in which the columns will be displayed. The selected columns and order will be saved for the next time Soffid displays the page. 

Delete

Allows you to delete the metadata object. To delete a host you can click on the hamburger icon and then click the delete button (trash icon).

Soffid will ask you for confirmation to perform that action, you could confirm or cancel the operation.

Set to default

Allows you to set the factory setting. Sometimes, usually after an upgrade, it is advisable to reset the built-in attributes of a built-in object. In that case, the properties of the attribute will be changed to the factory setting ones.

Import

Allows you to upload a CSV file with the attribute metadata to add or update attribute metadata to Soffid.

First, you need to pick up a CSV file, that CSV has to contain a specific configuration. Then you need to check the content to be loaded, it is allowed to choose if you want or not to load a specific attribute. And finally, you need to select the mappings for each column of the CSV file to import the data correctly and click the Import button.

Download CSV file

Allows you to download a CSV file with the basic information of the metadata object. 

Attribute metadata

Delete

Allows you to delete the metadata object. To delete a host you can click on the hamburger icon and then click the delete button (trash icon).

Soffid will ask you for confirmation to perform that action, you could confirm or cancel the operation.

Undo

Allows you to quit without applying any changes made.

Apply changes

Allows you to save the data of a new Metadata object or to update the data of a specific Metadata object. To save the data it will be mandatory to fill in the required fields.


Global settings

User backup configure & restore

Description

On the User backup configure & restore page, you could search, check and restore the user's snapshots.

Main Menu > Administration > Configuration > Global Settings > User backup configure & restore

Screen overview

image-1655374153334.png

Custom attributes

Actions

Backup query actions

Query

Allows you to query users through different search systems, Basic and Advanced.

Download CSV file

Allows you to download a CSV file with the basic information of all backups. 

Configure backup

Allows you to configure the backup parameters.

For more information visit the User backup configure page.

Download

Allows you to download an XML file with the user. You only need to click on the download icon of one of the records and save the file on your computer.

Restore

Allows you to restore one or more users' snapshots.

First of all, you need select one or more snapshots. Second, you need to click the restore button. Then Soffid will run the restore process.


Global settings

Configuration wizard

For more information, you can visit the Configuration wizard book 

Introduction

Soffid provides you a 360° perspective of the identities of your organization employees, providers and customers:

Screen overview

For more information, you can visit the Configuration wizard book 

Global settings

Export settings and objects

Description

Soffid has the functionality that allows you to export configuration, Soffid objects, and objects from target systems in a  ZIP file. Every object or configuration will be downloaded into the ZIP in a binary file. This ZIP file could be imported into another Soffid tenant to be used.

For more information, you can visit the Import settings and objects page.

Once you open the Export settings and objects, you must select the configuration, objects, and target system objects you want to export. Then you only need to click the Generate export file button to download the ZIP that will contain all the previous information selected.

It is not allowed to export the basic configuration and configuration parameters of an agent for security reasons. You must create them manually and make sure you put the same names as in the source system if you are going to import accounts.

Overview

image-1678953057534.png

Configuration

Objects

Target system objects

    Actions

    Generate export file

    By clicking this button, Soffid will generate a ZIP file with the objects and configuration that you have selected and will download it to your computer.

    Global settings

    Import settings and objects

    Description

    Soffid has the functionality that allows you to import configuration, Soffid objects, and objects from target systems from a  ZIP file. This ZIP file must be generated by the export action from another Soffid tenant.

    For more information, you can visit the Export settings and objects page.

    Once you pick the file to import, Soffid will display all the objects and configurations that you can load. You must select the proper objects and settings to import or enable the Load everything option. And finally, you must click the Proceed buttons to launch the import process. Once the process is finished, Soffid will display the result and allows you to download the log file.

    It is not allowed to import the basic configuration and configuration parameters of an agent for security reasons. You must create them manually and make sure you put the same names as in the source system if you are going to import accounts.

    Overview

    image-1679056302858.png

    Configuration

    Objects

    Target system objects

      Actions

      Proceed

      Allows you to start the import process.

      Security settings

      Security settings

      Authorizations

      Definition

      Soffid console provides a granular access control system. That granular control system allows the administrator user to assign granular permissions to roles. Be in mind that some permissions may inherit some other permissions.

      You cannot assign permissions directly to users. Instead, permissions are assigned to roles and roles are assign to users, either directly or through grant inheritance.

      The roles may be created into Soffid application system, but could also be included in any other application system.

      Permissions are grouped into permission scopes. Most scopes are Soffid object types, but there are one special scope named Soffid, that applies to Soffid console web pages.

      Addons can create their own authorizations that automatically will appear at this screen. When a new addon has been installed and applied, the first thing to do use to be assign permissions for this new addon. In fact, administrators won't be able to manage the addon unless the log out and log in to get the newly created permissions.

      The permissions given to roles and the roles given to users are cached by Soffid. In order to reapply permissions, the user should close its session and log-in again

      image-1711094581997.png

      1. Roles
      2. Information system

      Standard attributes

      Actions

      Authorization query action

      Import

      Allows you to upload a CSV file with the authorization data to add or to update the granular control system. If they exist, the values of the CSV file will prevail.

      First, you need to pick up a CSV file, that CSV has to contain a specific configuration. Then you need to check the contents. And finally, you need to select the mappings for each column of the CSV file to import the data correctly and to click the Import button.

      Download CSV file Allows you to download a CSV file with the authorization data.

      Authorization detail actions

      Add new

      Allows you to add a new role to the authorization. You can choose that option clicking the add button (+).

      First, you need to search a role writing the role name on the field, and Soffid will show the values related. Second, you can select one or more roles and accept.

      And finally, you need to apply changes to save the roles added. If you cancel that action, no role will be assigned.

      Delete

      Allows you to delete one or more roles from an authorization.

      To delete one role, you need to click the subtraction symbol (-), located at the end of the row, of the role which you want to delete and then apply changes.

      To delete more than one role, you can select the roles which you want to delete and there click the subtraction symbol (-) and then apply changes.

      It is mandatory apply changes to save the roles deleted.

      Soffid will ask you for confirmation to perform that action, you could confirm or cancel the operation.

      Apply changes Allows you to update the changes made on the authorization.
      Undo Allows you to quit without applying any changes.


      Security settings

      Authentication

      Definition

      Soffid could use different kinds of external authentication sources. These mechanisms could be selectively enabled or disabled.

      Screen overview

      image-1712138266299.png

      Standard attributes

      Global status

      image-1685358837043.png

      image-1685358984524.png

      image-1712138497760.png

      Username and password

      Internal

      External

      Not all the external systems are included, only the ones that have marked the check "Trust password" on the agent. For more information about agents please visit the Agents page.

      Once an agent is configured, Soffid will still use its internal tables to authenticate usernames and passwords.

      If the password entered by the user does not match, the Soffid core will issue a "ValidatePassword" task for each trusted target system. If any of the trusted target systems accepts the password, it will be hashed and stored in Soffid tables and login will be accepted.

      External SAML identity provider 

      It should be noted this feature does not depend on the federation addon. That is a feature included by default in the Soffid smart engine to allow you to include in the authentication flow a mechanism to use a third-party SAML system.

      Finally, download the Soffid Console and load it into your SAML Identity Provider federation.

      If SAML Identity Provider is enabled, as well as username and password, the user will have the chance to select the preferred authentication method. Otherwise, if only SAML is enabled, the user will be automatically redirected to SAML Identity Provider.

      image-1685358871521.png


      Enable LinOTP integration

      Soffid allows you to use an external OTP, LinOTP in this case. If you decide to use LinOTP, Soffid could be configured to request the user to authenticate using a second factor authentication to perform certain actions. In another case, you can use the Soffid OTP.

      If you want to configure the Soffid OTP you could visit Two factor authentication (2FA) chapter.

      Second Factor Authentication configuration

      This section requires to have the LinOTP integration enabled (previous section)

      💻 Example

      Request only the OTP for these pages:

      image-1691657269637.png

      💻 Example

      Request OTP for all pages except those containing menu.zul or otp.zul:

      image-1691736830460.png

      💻 Example

      image-1692278416756.png

      In both configurations, if OTP is required by the user, a popup requesting the token value is raised to write the OTP value.

      Actions

      Download metada

      Allows you to download an XML file with metadata to load it into your SAML Identity Provider federation when you use an External SAML identity provider

      Confirm changes Allows you to save the changes made in the Authentication setup.


      Security settings

      Password policies

      Definition

      Password domain

      Is a logical way of grouping managed systems that are sharing the same password for each account. If the administrator chooses to have the same password for every system, only one password domain should exist. If the administrator chooses to assign a different password for each system, then a password domain should be created for each managed system.

      Password policies

      Password policies allow you to define custom rules that passwords must comply with to enhance system security. For each password domain, Soffid allows you to create different password policies related to user type. It is only possible to define a single password policy for one password domain and one user type. 

      There are two kinds of password policies.

      A password policy will also define how often the password needs to be changed and how many days are allowed to change it.

      Regarding password complexity, you can specify the minimum and the maximum number of lowercase letters, uppercase letters, numbers, and symbols, as well as password length.

      The administrator users can define a regular expression that must match each password. This can be used, for instance, to ensure that the first password is not numeric.

      It is allowed to create a list of forbidden words that cannot be used as passwords.

      image-1641381462597.png

      1. Password domain
      2. User Type

      Standard attributes

      Password Domain

      Password policies

      Actions

      Password policies query actions

      Add new domain

      Allows you to create a new password domain. You can choose that option on the hamburger menu or click the add button (+).To add a new password domain it will be mandatory to fill in the required fields

      Add new password policy

      Allows you to create a new password policy on a specific password domain. Below the father password domain, you can find the button to perform that action. To add a new password policy it will be mandatory to fill in the required fields.

      Password domain detail actions

      Apply changes

      Allows you to save a new password domain or to update the password domain changes. To save the data it will be mandatory to fill in the required fields.

      Delete

      Allows you to delete a password domain. To delete a password domain you can click on the hamburger icon and then click the delete button (trash icon).

      Soffid will ask you for confirmation to perform that action, you could confirm or cancel the operation.

      Undo

      Allows you to quit without applying any changes.

      Password policies detail actions

      Apply changes

      Allows you to create a new password policy or to update password policy changes. To save the data it will be mandatory to fill in the required fields.

      Delete

      Allows you to delete a password policy. To delete a password policy you can click on the hamburger icon and then click the delete button (trash icon).

      Soffid will ask you for confirmation to perform that action, you could confirm or cancel the operation.

      Undo

      Allows you to quit without applying any changes.

      Add word

      Allows you to create a new forbidden word. Those forbidden words may not be used to create a password if they are selected.


      Security settings

      Configure PAM session servers

      Definition

      Soffid provides the functionality that allows you to configure the Jump servers. That option is located on

      Main Menu > Administration > Configure Soffid > Security settings > Configure PAM session servers

      To configure that functionality is mandatory to install PAM following the instructions of the PAM installation page.

      A Jump server is the control point that forces users to log into that system first, then, they could traverse to other servers without having to log in again. The purpose of a jump server is to be the only gateway for access to your infrastructure reducing the size of any potential attack surface.

      Screen overview

      Standard attributes

      Actions

      Add new

      Allows you to add a new configuration of PAM.  You can choose that option by clicking the add button (+).

      You must fill in all the attributes to save a new configuration. 

      Delete

      Allows you to delete one or more configuration PAM registers, you must select one or more records from the list and click the button with the subtraction symbol (-).

      To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Apply chanages

      Allows you to create a new configuration PAM or to update an existing one. To save the data it will be mandatory to fill in the required fields. Also, the password and user name should be correct to connect.

      Undo

      Allows you to quit without applying any changes made.


      Security settings

      PAM Rules

      Definition

      Soffid allows you to define rules to detect commands executed on a server. When a user launches a command defined on a rule, Soffid will detect it.

      To use those rules you need to define the PAM policies. For more information, you can visit the PAM policies page.

      Screen overview

      image-1696499283030.png

      Keyboard example

      image-1696499194127.png

      Screen example

      image-1696499256255.png

      Standard attributes

      Actions

      PAM rules query

      Query

      Allows you to query PAM rules through different search systems, Quick, Basic and Advanced.

      Add or remove columns

      Allows you to show and hide columns in the table.

      Add new

      Allows you to create a new PAM rule. You can choose that option on the hamburger menu or click the add button (+).

      To add a new PAM rule it will be mandatory to fill in the required fields.

      Delete

      Allows you to remove one or more PAM rules by selecting one or more records and next clicking the button with the subtraction symbol (-).

      To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Import

      Allows you to upload a CSV file with the PAM rules list to add or update PAM rules to Soffid.

      First, you need to pick up a CSV file, that CSV has to contain a specific configuration. Then you need to check the content to be loaded, it is allowed to choose if you want or not to load a specific attribute. And finally, you need to select the mappings for each column of the CSV file to import the data correctly and click the Import button.

      Download CSV file

      Allows you to download a CSV file with the PAM rules information.

      PAM rules detail

      Apply changes

      Allows you to create a new configuration PAM rule or to update an existing one. To save the data it will be mandatory to fill in the required fields.

      Undo

      Allows you to quit without applying any changes made.

      Delete

      Allows you to delete a PAM rule. To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.


      Security settings

      PAM Policies

      Definition

      Privileged Access Management (PAM) policies are a set of guidelines and controls that dictate how privileged access is granted, managed, and audited within an organization.

      Soffid allows you to define policies, those policies can be made up of several rules. For each rule, you could select the action to perform when Soffid detects that rule is accomplished.

      To use those policies you need to define how policies will be used by each folder in the password vault. For more information, you can visit the Password Vault page

      Screen overview

      Standard attributes

      When you save the standard attributes of a PAM policy and edit the policy again, the rule list will be shown. Here you can customize the policy depending on the existing rules.

      (*) You can visit the following page for more information about the issues:

      https://bookstack.soffid.com/books/soffid-3-reference-guide/page/issue-policies https://bookstack.soffid.com/link/1153#bkmrk-pam-violation

      Actions

      PAM rules query

      Query

      Allows you to query PAM policies through different search systems, Quick, Basic and Advanced.

      Add or remove columns

      Allows you to show and hide columns in the table.

      Add new

      Allows you to create a new PAM policy. You can choose that option on the hamburger menu or click the add button (+).

      To add a new PAM policy it will be mandatory to fill in the required fields.

      Delete

      Allows you to remove one or more PAM policies by selecting one or more records and next clicking the button with the subtraction symbol (-).

      To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Import

      Allows you to upload a CSV file with the PAM policies list to add or update PAM policies to Soffid.

      First, you need to pick up a CSV file, that CSV has to contain a specific configuration. Then you need to check the content to be loaded, it is allowed to choose if you want or not to load a specific attribute. Finally, you need to select the mappings for each column of the CSV file to import the data correctly and click the Import button.

      Download CSV file

      Allows you to download a CSV file with the PAM policies information.

      PAM rules detail

      Apply changes

      Allows you to create a new configuration PAM policy or to update an existing one. To save the data it will be mandatory to fill in the required fields.

      Undo

      Allows you to quit without applying any changes made.

      Delete

      Allows you to delete a PAM policy. To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.


      Security settings

      Password recovery configuration

      Description

      Soffid provides you the functionality that allows to the users recover their passwords. To do that, the admin user, o a user with the proper roles, must config the the password recovery parameters.

      Screen Overview

      image-1711378217620.png

      Custom attributes

      Actions

      Confirm changes

      Allows you to save the data of password recovery configuration. To save the data it will be mandatory to fill in the required fields.


      Security settings

      OTP settings

      Definition

      The OTP settings allow the administrator users to configure the available OPT options. Soffid provides four different OTP implementations.

      Main Menu > Administration > Configuration > Security settings > OTP settings

      Screen overview

      image-1698996143859.png

      image-1698996183374.png

      Standard attributes

      Email

      To send an email, will be mandatory to fill in the value of the mail.from parameter. You can visit the mail server parameters.

      SMS

      https://www.xxxxxxx.com/cgi-bin/sms/http2sms.cgi?account=sms-bg490971-1&password=XXXXXXt&login=user&from=SOFFID&to=${PHONE}&message=This is your access PIN: ${PIN}&noStop&contentType=application/json&class=0
      "status":100

      The URL and POST data to be sent, the administrator can use some tags that will be replaced by some target user attributes:

      Voice (alternative to SMS)

      The POST data to be sent, the administrator can use some tags that will be replaced by some target user attributes:

      Time based HMAC Token

      Event based HMAC Token

      Security PIN

      Actions

      Confirm changes

      Allows you to save the updates and quit the page.


      Security settings

      XACML Policy Management

      Definition

      The PDP, Policy Decision Point, is in charge of evaluating the defined rules. The Policy Decision Point is essentially a policy compiler. The PDP must verify that the specified rules are within the scope of the rule authors authority. The PDP provides the authorization to the PEP.

      XACML Policy Management

      The policy language is used to describe general access control requirements, and has standard extension points for defining new functions, data types, combining logic, etc. The request/response language lets you form a query to ask whether or not a given action should be allowed, and interpret the result.

      Main Menu > Administration > Configure Soffid > Security settings > XACML Policy Management

      It is possible to import an existing PolicySet into the system. The file to import must be a well-formed XML.

      To know more about XACML, read XACML 2.0 Standard Specification

       


      https://www.oasis-open.org/committees/download.php/2713/Brief_Introduction_to_XACML.html

      Security settings

      XACML PEP configuration

      Description

      The PEP, Policy enforcement point,  is a component of policy-based management, where enforce the policies. It is the component that serves as the gatekeeper to access a digital resource. The PEP gives the PDP, Policy Decision Point, the job of deciding whether or not to authorize the user based on the description of the user's attributes.

      XACML PEP configuration

      Soffid allows you to configure different policies enforcement points, each of then can use a different policy set.

      Main Menu > Administration > Configure Soffid > Security settings > XACML PEP configuration

      Screen

      image-1628231580976.png

       

      Custom attributes

      Custom attributes for each PEP:

      Policies enforcement points

      Web Policy Enforcement Point

      The policy will be enforced when the user open a new Soffid page. Using this PEP you can define the rules to access to Soffid pages.

      SUBJECTS RESOURCES ACTIONS ENVIRONMENTS

      User
      User attributes
      Account
      System
      Role
      Group
      Primary Gorup
      IP Address

      Server URL

      Get

      Put

      Post

      Current Time

      Current Date

      Current DateTime

      Role centric Policy Enforcement Point

      The policy will be enforced when the user login into Soffid. It will calculate the user authorizations as of the permissions that the user has assigned.

      SUBJECTS RESOURCES ACTIONS ENVIRONMENTS

      User
      User attributes
      Account
      System
      Role
      Group
      Primary Gorup
      IP Address

      Soffid  object

      Attributes 

       

       

      create

      update

      delete

      query

      Current Time

      Current Date

      Current DateTime

      Dynamic role Policy Enforcement Point

      The policy will be enforced when the user performs an action to evaluate if the user has or not authorization. The user must have the proper role and comply with the XACML rule.

      You can use that PEP to split the permissions, for instance, a support group can update the permission of a specific group of user, and another support group can update the permissions of another group of users.

      SUBJECTS RESOURCES ACTIONS ENVIRONMENTS

      User
      User attributes
      Account
      System
      Role
      Group
      Primary Gorup
      IP Address

      Soffid  object

      Attributes 

      (*)

       

      create

      update

      delete

      query

      Current Time

      Current Date

      Current DateTime

      (*) It is allowed to use "Attribute Selector" to configure Dynamic role policy,

      External Policy Enforcement Point (https://iam-sync-lab.soffidnetlab:1760//XACML/pep)

      PEP of general purpose. Calling the web service, the clients can made validations and figure out if the users have access.

      SUBJECTS RESOURCES ACTIONS ENVIRONMENTS

      User
      User attributes
      Account
      System
      Role
      Group
      Primary Gorup
      IP Address

      Token

      Method

      Soffid object

      Get

      Put

      Current Time

      Current Date

      Current DateTime

      Password vault Policy Enforcement Point (https://iam-sync-lab.soffidnetlab:1760//XACML/vault)

      The policy will be enforced when the password vault is used.

      SUBJECTS RESOURCES ACTIONS ENVIRONMENTS

      User
      User attributes
      Account
      System
      Role
      Group
      Primary Gorup
      IP Address

      Access level

      Account

      System

      Login

      Vault Folder 

      Server URL

      setPassword

      queryPassword

      queryPasswordBypassPolicy

      launch

       

      Current Time

      Current Date

      Current DateTime

       

       

      Security settings

      Digital certificates

      Definition

      Soffid includes Digital certificate functionality as a security enhancement. You could add new Digital certificates, internal or external. If you select the external certificate, you could add a valid certificate to Soffid; If you select the internal certificate, Soffidl will generate a valid certificate.

      Screen Overview

      Internal

      image-1695885525346.png

      External

      image-1695885507434.png

      Standard attributes

      Internal

      External

      Actions

      Digital certificates query

      Add new

      Allows you to add a new certificate. You can choose that option on the hamburger menu or click the add button (+). To add a new certificate it will be mandatory to fill in the required fields. 

      Delete

      Allows you to remove one or more certificates by selecting one or more records and next clicking the button with the subtraction symbol (-).

      To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Download CSV file

      Allows you to download a CSV file with the digital certificates data.

      New token

      Next

      Allows you to browse the wizard to create a new certificate.

      Apply changes

      Allows you to save the data of a new certificate or to update the data of a specific certificate. To save the data it will be mandatory to fill in the required fields

      Undo

      Allows you to quit without applying any changes.

      Security settings

      Recertification policies

      Description

      Soffid allows you to establish some policies to define the scope of the recertification process.

      Menu option

      Main Menu > Administration > Configuration > Security settings > Recertification policies

      Screen overview

      image-1653572713094.png

      Custom attributes

      (*1) grant object is a com.soffid.iam.api.RoleAccount object.

      Examples

      Some sample scripts for the filters and approval steps are shown below

      Filter

      Return all grants with risk.

      return grant.sodRisk != null 
      	&& grant.sodRisk != es.caib.seycon.ng.comu.SoDRisk.SOD_NA;

      Steps

      account = serviceLocator.getAccountService().findAccountById(grant.accountId);
      StringBuffer sb =  new StringBuffer();
      for (owner : account.ownerUsers) {
        if (sb.length() > 0)
          sb.append(" ");
        
        sb.append(owner);
      }
      if (sb.length() > 0) 
        return sb.toString();
      else 
        return "admin";
      com.soffid.iam.api.Role role = serviceLocator.getApplicationService().findRoleByNameAndSystem(grant.roleName, grant.system);
      StringBuffer sb =  new StringBuffer();
      List owners = role.getAttributes().get("owner");
      if (owners != null) {
      	for (owner : account.ownerUsers) {
          	if (sb.length() > 0)
          		sb.append(" ");
              
              sb.append(owner);
      	}
      }
      
      if (sb.length() == 0) 
      	return "admin";
      else 
      	return sb.toString();

      Mail template

      image-1653470454738.png

      Actions

       Recertification policies query

      Add new

      Allows you to add a new Recertification policy. You can choose that option on the hamburger menu or click the add button (+).

      To add a new it is necessary to fill in the required fields.

      Delete

      Allows you to remove one or moreRecertification policies by selecting one or more records and next clicking the button with the subtraction symbol (-).

      To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Import

      Allows you to upload a CSV file with the Recertification policies to add or update the attribute definition to Soffid.

      First, you need to pick up a CSV file, that CSV has to contain a specific configuration. Then you need to check the content to be loaded, it is allowed to choose if you want or not to load a specific attribute. And finally, you need to select the mappings for each column of the CSV file to import the data correctly and click the Import button.

      Download CSV file

      Allows you to download a CSV file with the basic information of all Recertification policies. 

      Add or remove columns

       Allows you to show and hide columns in the table. You can also set the order in which the columns will be displayed. The selected columns and order will be saved for the next time Soffid displays the page to the user. 

       Recertification policies details

      Apply changes

      Allows you to save the data of a new policy or to update the data of a specific policy and quit. To save the data it will be mandatory to fill in the required fields.

      Save

      Allows you to save the data of a new policy or to update the data of a specific policy. To save the data it will be mandatory to fill in the required fields.

      Delete

      Allows you to remove a specific policy. You can choose that option on the hamburger icon.

      To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Undo

      Allows you to quit without applying any changes. 



      https://download.soffid.com/doc/console/latest/uml/es/caib/seycon/ng/comu/SoDRisk.html

      Security settings

      Issue policies

      Definition

      Soffid has defined automatic events by default. For each of these events, it is possible to define the tasks to be performed and configure them.

      You can find this functionality in the following path:

      Main Menu > Administration > Configuration > Security settings > Issue policies

      The default events are the following;

      Issue Type Description
      account-created

      This issue is created when the Sync Server detects when a new account is created. This may occur after the Reconciliation process has been executed.

      disconnected-system This issue is created when the Sync Server detects that some target system is offline. 
      discovered-host

      This issue is created when the Sync Server detects a new host in the network. This only occurs after the Network Discovery process has been executed.

      discovered-system

      This issue is created when the Sync Server detects a new system in a host. This only occurs after the Network Discovery process has been executed.

      duplicated-user

      This issue is created the system detects that there are duplicate users, or when the task is generated manually from the user management.

      enabled-account-on-disabled-user This issue is created when an enabled account is detected on a disabled user. This may occur after the reconciliation process has been executed.
      failed-job

      This issue is created when the system detects job failures. This may occur by running any scheduled task.

      global-failed-login This issue is created when the number of session start failures exceeds the threshold of 0.8.
      integration-errors This issue is created when the Sync Server detects an integration error between Soffid and an end system. You can check the task in the Monitoring & Reporting.  
      locked-account

      This issue is created when an account has been blocked for exceeding the maximum number of login attempts. You can configure the property Lock after failures in the Password policies settings. Even if it is temporarily locked, the incident will be generated.

      login-different-country

      This issue is created when Soffid detects a new login from a different country. It only works with the Identity Provider and it is necessary to have the geolocation database updated.

      login-from-new-device

      This issue is created when Soffid detects a new login from a new device. It only works with the Identity Provider.

      login-not-recognized This issue is created when Soffid detects a login not recognized (disabled user or user does not exist) in the Soffid Console or in Soffid as an Identity Provider.
      otp-failures This issue is created when an OTP is blocked for exceeding the number of attempts. Currently blocked with 10 unsuccessful attempts.
      pam-violation This issue is created when any of the rules of the PAM are violated. You can define the PAM rules and the PAM policies. Be in mind, that you must check the "Open issue" option in the PAM policies you wish to control.
      password-changed

      This issue is created when a Password change is detected. These changes come from the end system (Active Directory or Soffid OpenLDAP) and Soffid has been notified. The issue is not created if it is the operator or a script that changes the password in Soffid.

      permissions-granted

      This issue is created when it is detected that permissions have been given to a user on the end system. This may occur after the reconciliation process has been executed.

      risk-increase This issue is created when it is detected the risk level of a user is increased. You can configure the risks in the Segregation of Duties option.
      robot-login This issue is created when it is detected is detected that someone who has not passed the CAPTCHA is trying to log in to the Identity Provider.
      security-exception This issue is created when unauthorized access to the console via WebService or admin console occurs.

      Screen Overview

      image-1689689114657.png

      image-1686554911612.png

      1. Roles

      Standard attributes

      Note that it will be necessary to restart the Sync Server when changing the action of an issue.

      Actions

      Issue policies query action

      Download CSV file Allows you to download a CSV file with the issue policies data.

      Issue policy detail

      Add new

      Allows you to add a new action to the issue policy. You can choose the action from the action list. Depending on the selected action, you must fill in different information.

      Once the information will be filled in, you need to close the window and Apply the changes.

      Delete

      Allows you to delete one or more actions from the actions list.

      Apply changes Allows you to update the changes made to the issue policy.
      Undo Allows you to quit without applying any changes.
       


      Resources Management

      Resources Management

      Users

      Description

      The user is the core object of the system. In Soffid, a user means an identity (usually a person). Every user can have a number of accounts spread on different information systems.

      In traditional system management, one can assign roles and permissions to accounts. Then, the administrator uses to grant the account to one single user. In Soffid you can have a global view of permissions assigned to any user. Being the user and the main management object, you have a more clear perspective in terms of operation, security, and end-user engagement.

      It is important to know that dependency rules can be established between systems, so a user with a role or permission in one system will automatically be assigned a role or permission in another system, according to the system policies.

      The administrator can also identify the potential users of shared or system management accounts. These accounts are managed in a slightly different way. See the Accounts and Password Vault pages for more information.

      Sometimes is possible to find that there is any user with duplicated user data. To solve that problem, Soffid provides the merge functionality. That allows you to combine two user records, selecting the proper data to fix that situation.

      Screen overview

      Related objects

      1. Groups
      2. Account
      3. Roles
      4. User Type
      5. Password domains
      6. Audit
      7. Logs 
      8. Workflows

      Standard user attributes

      Basic

      On the basic user tab, you can view all the user attributes. Other attributes can be customized in Soffid.

      Common attributes
      Mail service
      User status
      Organization
      Other
      Audit information

      Groups

      Your company is organized into different business units, departments, or workgroups. In Soffid, they all are named as groups. Some systems, like Active Directory, use groups to control or restrict resource access. A Soffid Group is more like an Active Directory OU.

      On the group tab, you can manage all the groups that the user belongs to. Be in mind that all users have to belong to a Primary Group defined on the Basic user attributes.

      By clicking on a record, Soffid shows group membership details. It is possible to change the group, and the start date and add comments.

      It is also possible to assign a new membership by clicking the button with the add symbol (+), and revoking the group membership from the group details, or by selecting one or more records from the list and clicking the button with the subtraction symbol (-).

      Accounts

      An account is a way a user is presented on a target system.

      On the accounts tab, you can view the accounts that belong to the user that is currently displayed, grouped by password domains. The account can be displayed in black or gray color. The gray color is used to indicate that the account is unmanaged, that is because the agent is disconnected or because the agent is in Read-Only Mode.

      Soffid smart engine will automatically create, disable or remove user accounts depending on the system policies.

      Also, you can manually add a new account for a specific system, rename an existing one, delete it or change its password. You can also see when the password was last set and its expected expiration date. Mind that you cannot change a single account password, as long as any password belongs to a password domain, so each password belonging to the same user and password domain will be changed at a time. When you apply user changes, automatically they will be forwarded to target systems.

      Mind that Soffid smart engine can revert some of your changes if those changes are violating any system policy.

      Each change made at the Soffid console is asynchronously replicated into the managed system. At the accounts tab, the administrator can check when each account was updated last. When the Soffid console notices there the replication process is failing, an exclamation sign will appear next to the account name.

      When the settings for a managed system exclude a user to be replicated, no account will be created for him. In case the user was replicated and due to user attributes changes it should be excluded, its account will be disabled and it will appear with line-through style.

      At the agent configuration screen, the administrator can configure when to create or enable user accounts depending on the user type or the group the user belongs to. When the settings for a managed system exclude a user, no account will be created for him. In case the account exists and due to user attributes changes it should be excluded, its account will be disabled and it will appear with line-through style.

      Regarding automatic account creation, it's important to know that if a user needs an account with a name, based on the user domain configuration, and that such an account already exists as a shared or single user account, this account won't be created or assigned. Nevertheless, if such account already exists as an unmanaged account, this existing account will be assigned to the user along with their role grants.

      By clicking on a record Soffid displays more accurate information about the account. It will be allowed to rename the account, change it, change the account status or delete the account (logic delete). Also, Soffid allows you to query the properties if the account on the target system. Finally, Soffid will display custom attributes defined for the specific agent on the agent "Account metadata"  tab, you can visit the Agent page for more information.

      On the accounts tab, you can check the failed login attempts and if the account has been blocked, it is displayed until how long it has been blocked.

      💻 Image

      image-1698759762332.png

      Roles

      A role is a collection of permissions that can be granted to a user. With these permissions, the user will access to another system and perform some operations.

      On the roles tab, you can assign or revoke roles to any user. Each role needs an account to be applied to. So, if a user has no account on a system and a role on that system is granted, a new account will be created on this system. In case a user has more than one account on a system, you should indicate which of the suitable accounts will be granted the role.

      More and more, when the role should be scoped, the operator must select the right scope for the role. The scope and its allowed values are defined on the application management page.

      By clicking on a record Soffid shows more information about the role, this information can not be updated. On this screen, you can browse through the different roles.

      It is also possible to revoke the role to the user from the entitlement details or by selecting one or more records from the list and clicking the button with the subtraction symbol.

      The roles list shows a column to display when there are risks with the roles assigned to the user. If you click on a record, Soffid will show the entitlement details including the SoD rules with the detail of the risk. 

      For more information about SoD visit the  Segregation of Duties page.

      Additionally, you can download a CSV file with the user's role information, or upload a CSV file to assign or revoke roles to the user.

      Effective Roles

      Hierarchy of permissions assigned to or inherited. 

      This screen details the effective roles of the selected user. 

      Shared accounts

      Accounts that can be used by several users, those accounts can be privileged or shared.

      On the shared account tab, you can see all shared user accounts. You can view information about the system, the account, the date of update, when was the last login, when the password was changed, and the expiration date.

      By clicking on a record, you can browse the share account details page.

      Sessions

      On the sessions tab, you can view sessions opened by the user. Here will be displayed any open ESSO session, showing the host that has created the session and the host where the user is connected from, if applicable. The port number is the TCP/IP port number the ESSO session manager is listening to. It is used by the synchronization server to check for session validity.

      ESSO Integration

      Multi-session attribute: ESSO will prevent any user from having more than one session at a time unless it has the multisession attribute checked.

      If ESSO detects the user trying to log in has an active session, it will do the following job:

      No user with an active flag unchecked will be allowed to log in or use any system managed through ESSO.

      User Processes

      In the user processes tab you can view the business processes in which the user has been managed. It shows information about the process, the status process and when it was initiated and ended.

      NOTE: Mind that this page does not show the business processes the user has acted.

      Pending tasks

      When a user has pending tasks, an icon will be appearing at the right corner. If the status of pending tasks is "Error", the icon will be a highlight alert icon, if the status is "Pending", the icon will be a wifi icon.

      That window displays the most relevant task data, the task name, the agent that manages the task, the status task, and the schedule to will be executed, ... That pending task information is only available in consultation mode. 

      Tokens

      In the Tokens tab, you can manage the user tokens. You can add or delete the users' tokens. Currently, the available options are Certificate and FIDO token.

      Certificate

      If you select the certificate option, you only need to register the certificate description. Then Soffid will read the existing certificates registered into Soffid, at the Digital certificates page, and finally, Soffid will give you a p12 file and a password to install the certificate in the browser.

      If there are no registered certificates, Soffid will not allow you to add new certificate tokens for any user.

      FIDO token

      If you select the FIDO token option, you need to full fill in the following data:

      You can use the Generate secure or insecure link option to send it to users to complete the registration process.

      When you register a FIDO token, this will be displayed on the proper user "My certificates and FIDO tokens" page and it will be available for this user.

      Backups

      The backup functionality is available when the backup addon is loaded in the Soffid Console. By clicking on the Backups tab, Soffid will display all the snapshots available for the user, and you could restore what you need.

      You can also check other available snapshots by clicking on the hamburger icon and a specific option. Those are the options:

      Groups History

      You can check all the group history changes for a specific user, and decide if you want to restore an earlier versión.

      Accounts History

      You can check all the account history changes for a specific user, and decide if you want to restore an earlier versión.

      Roles history

      You can check all the role history changes for a specific user, and decide if you want to restore an earlier versión.

      Mail list history

      You can check all the mail list history changes for a specific user, and decide if you want to restore an earlier version.

      Download CSV file

      Allows you to download a CSV file with the data of all backups.

      OTP devices

      In the OTP devices tab, Soffid displays all the OTP devices configured by this user. For each OTP device, Soffid displays the info about the name, the created date, the last time used, and the status. Soffid allows you to manage all the OTP devices for each user.

      By clicking on a record, Soffid shows OTP device details, including the failed number. It is also possible to change the status.

      💻 Image

      image-1705491017544.png

      This option will only be available if the OTP addon is installed in the Soffid console.

      Issues

      In the Issues tab, Soffid displays all the issues in which the user is involved. If you click one issue, Soffid will display the issue detail and will allow you to perform any available operation if you have the proper permissions to do that.

      This option will only be available in Soffid >= 3.5.x

      For more information, you can visit the Issue page.

      Actions

      Users query actions

      Query

      Allows you to query users through different search systems, Quick, Basic and Advanced.

      Add or remove columns

      Allows you to show and hide columns in the table. You can also set the order in which the columns will be displayed. The selected columns and order will be saved for the next time Soffid displays the page to the user. 

      Add new

      Allows you to add a new user in the system. You can choose that option on the hamburger menu or click the add button (+). To add a new user it will be mandatory to fill in the required fields

      Delete

      Allows you to remove one or more users by selecting one or more records and next clicking the button with the subtraction symbol (-).To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Import

      Allows you to upload a CSV file with the user list to add or update users to Soffid. First, you need to pick up a CSV file, that CSV has to contain a specific configuration. Then you need to check the content to be loaded, it is allowed to choose if you want or not to load a specific attribute. And finally, you need to select the mappings for each column of the CSV file to import the data correctly and click the Import button.

      Download CSV file

      Allows you to download a CSV file with the basic information of all users. 

      Bulk actions

      Allows massive operations to be performed on all system users.  With that operation, updates can be made to any of the user's parameters. First of all, you must select the records that you want to update, once you have selected them, you must choose the bulk action on the hamburger icon. For more information visit the Bulk action page.

      Merge

      Allows you to merge two or more identities when you identify that is necessary.

      First of all, you must select the identities to merge. Second, you need to click the hamburger icon and select the merge action. Then Soffid will display a window where you can choose if you want to merge right now, if you want to create an issue, or if you want to quit without applying any changes.

      image-1686725988764.png

      • If you select Solve now, Soffid will display a new window where you can choose the correct value for each standard and custom parameter. Finally, you need to apply changes to save the updates, or back to cancel that action.

      image-1686727576483.png

      • If you select Create issue,  Soffid will create an issue that you could check the issues page for more information.

      image-1686727159064.png

      User detail actions

      Apply changes

      Allows you to save the data of a new user or to update the data of a specific user. To save the data it will be mandatory to fill in the required fields.

      When you apply changes, automatically they will be forwarded to target systems.

      Delete

      Allows you to remove a specific user. You can choose that option on the hamburger icon.

      To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Undo

      Allows you to quit without applying any changes. 

      Audit

      Browse to the Audit page and display all the detailed actions performed over the user. It is allowed to filter the information displayed and also to download a CSV file with the audit information.

      Access logs

      Browse to the Logs page and display all the detailed logs about the user actions. It is allowed to filter the information displayed and also to download a CSV file with the logs information.

      Propagates the changes

      Allows you to propagate the user changes to the repository systems configured. It is only necessary when the task engine mode is configured as Manual, visit the smart engine setting page for more information.

      Refresh

      Allows you to refresh all the user information.

      Groups actions

      Group query actions

      Assign

      Allows you to add a new group membership. You can choose that option on the hamburger menu or click the add button (+).

      Then you need to select a group the user will belong to it.  Next, you need to define, if it is necessary the membership properties. And finally, you need to apply changes.

      Delete

      Allows you to delete group membership. You can select one or more groups and next click the button with the subtraction symbol (-). 

      To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Group detail actions

      Apply changes

      Allows you to save the updates of the group.

      Undo

      Allows you to quit without applying any changes. 

      Delete

      Allows you to delete a group membership.

      To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Accounts actions

      Accounts query actions

      Change password

      Allows you to change the password for a domain. The password can be generated automatically, or you can set the password. If you choose the set password option, you can check if the user must or not change the password on first use.


      image-1668586613654.png


      It will be mandatory the password complies with the Password policies defined for the domain.

      New Account

      Allows you to add a new account for a user and a specific target system. 

      First of all, you need to select the target system, then Soffid will show the target system name and the account name. The account name could be updated, but always with an account name which no be already in use on the target system. Then you need to choose the account status and finally, you can set the system properties. That properties depend on the target system and do not be mandatory.

      Accounts detail actions

      Delete

      Allows you to delete an account for a specific user. To delete the account first, you need to click the account, and Soffid will show a form with the account data. Then you need to click the hamburger icon and select the delete action. To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Show actual account properties

      Allows you to query the account properties on the target system.

      Apply changes

      Allows you to save the updates of the account.

      Undo

      Allows you to quit without applying any changes. 

      Roles actions

      Roles query actions

      Assign

      Allows you to assign a new role to the user. You can choose that option on the hamburger menu or click the add button (+).

      Then you need to select a role from the role list. If it is necessary, the next step will be to set the scope. Then you need to check and fill in the membership properties. And finally, apply changes.

      Revoke

      Allows you to revoke one by one or to revoke some roles at the same time. 

      To revoke some roles at the same time, you need to select the roles, and then click the button with the subtraction symbol (-). 

      To revoke one role, you can click the role, and then Soffid will show a form with the details. Then you can click the delete button (trash icon). 

      Soffid will ask you for confirmation to perform that action, you could confirm or cancel the operation. 

      Import

      Allows you to upload a CSV file with the role list to assign permission.

      First, you need to pick up a CSV file, that CSV has to contain a specific configuration. Then you need to check the content to be loaded, it is allowed to choose if you want or not to load a specific attribute. And finally, you need to select the mappings for each column of the CSV file to import the data correctly and click the Import button.

      Download CSV file

      Allows you to download a CSV file with all the information about user roles. 

      Role detail action

      Assign

      Allows you to assign a new role to the user. You can choose that option on the hamburger menu or click the add button (+).

      Then you need to select a role from the role list. If it is necessary, the next step will be to set the scope. Then you need to check and fill in the membership properties. And finally, apply changes.

      Revoke

      Allows you to revoke a role. 

      To revoke one role, you can click the role, and then Soffid will show a form with the details. Then you can click the delete button (trash icon). 

      Soffid will ask you for confirmation to perform that action, you could confirm or cancel the operation. 

      Sessions actions

      Download CSV file

      Allows you to download a CSV file with all the information about sessions. 

      User processes 

      Query 

      Allows you to query the process info by browsing the process page.

      OTP devices action

      Add

      Allows you to add a new OTP device. To add a new OTP device you need to click the add button (+), then Soffid will display a wizard to config the OTP device. First of all, you need select the OTP device Type and then Apply changes.

      Delete

      Allows you to delete one or more OTP devices for a specific user. To delete OTP devices first select the devices, then click on the subtract button (-), then Soffid will ask you to confirm or cancel the operation.

      Change Status

      Allows you to change the OTP device status. First of all, you need to click the proper OTP device, then change the status, and finally close the window.

      Issues

      Query 

      Allows you to query the issues info by browsing the process page.

      Display Issue

      By clicking one Issue, Soffid will display the issue detail will allow you to perform any available operation if you have the proper permissions to do that

      Resources Management

      Groups

      Description

      Groups are a convenient way to apply policies to a collection of users. Groups allow administrator users to specify permission for multiple users in a quick and easy way. Groups are managed in a hierarchical way. A user can belong to a group, and that user will be assigned the roles of this group and all the roles that this group inherits from its parent.

      Companies are organized in different business units, departments, or workgroups. In Soffid, they all are named as groups. Some systems, like Active Directory, use the groups to control or restrict access to resources. A Soffid Group is more like an Active Directory OU.

      Screen overview

      image-1655287747709.png

      Related objects

      1. User
      2. Roles

      Standard attributes

      Basic

      On the basic group tab, you can view all the group attributes. It is allowed to add new groups, and update or delete existing groups.

      💻 Image

      image-1698651182916.png

      Users

      Administrator users can manage the users who belong to the group. These users will have assigned all the permissions granted to that group and permissions inherited from its parent.  

      On the user's tab, you can add new users to the group by clicking the button with the add symbol (+), you must select the user to add, and select the membership properties.

      It is also allowed to delete one or more users from a specific group, you can do it from the group membership details or by selecting one or more records from the list and clicking the button with the subtraction symbol (-).

      Additionally, you can download a CSV file with the user's information and you can also upload a CSV file to add new users or update existing users.

      Granted roles

      Administrator users can manage the permissions to a group, this is the way to establish an access policy to a collection of users. The users who belong to a group will inherit all the permissions granted of that group.

      On the granted roles tab, you can assign or revoke roles to the group. To assign a new role, you must click the button with the add symbol (+), then select the role,  in some cases specify the scope, and finally set membership properties. To revoke role, you can do it from the group membership detail or by selecting one or more records from the list and clicking the button with the subtraction symbol (-).

      Additionally, you can download a CSV file with the granted roles information and you can also upload a CSV file to assign roles, modify or delete assigning roles.

      Managers

      On the tab Managers, Soffid displays the Roles with Domain group for the specific Information System and the proper authorization. Here you could grant the role to one or more users. You could grant the role on the Role page and on the User page as well and the information will be displayed on the managers tab.

      Be in mind, to query the information about the roles and users on the managers tab, it will be mandatory to give authorization to query users, you must add the role to the authorization (user:query). You can visit the Authorization page.

      Actions

      Group query actions


      Query

      Allows you to query groups through different search systems, Quick, Basic and Advanced.

      Add or remove columns 

      Allows you to show and hide columns in the table.

      Historical view

      Allows you to check all the group's historical data. If you click this option, Soffid will display a new modal window to manage the historical view. 

      Add new

      Allows you to add a new group in the system. You can choose that option on the hamburger menu or clicking the add button (+).

      To add a new group it will be mandatory to fill in the required fields

      Add child group

      Allows you to add a child to a specific group. You can choose that option below the father group.

      To add a child it is necessary to fill in the required fields

      Import

      Allows you to upload a CSV file with the group list to add or update groups to Soffid.

      First, you need to pick up a CSV file, that CSV has to contain a specific configuration. Then you need to check the content to be loaded, it is allowed to choose if you want or not to load a specific attribute. And finally, you need to select the mappings for each column of the CSV file to import the data correctly and to click the Import button.

      Download CSV file

      Allows you to download a csv file with the basic information of all groups. 

      Historical view

      Switch to current view

      Allows you to come back to the current data view.

      Apply changes

      Once you have pickup the proper date at the date component, you can apply changes and Soffid will display all the group data at the selected date time.

      Then you can browse the Groups tree and check the information

      Undo

      Allows you to quit without applying any changes.

      Group detail actions

      Apply changes

      Allows you to save the data of a new group or to update the data of a specific group. To save the data it will be mandatory to fill in the required fields

      Delete

      Allows you to remove a specific group. To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Undo

      Allows you to quit without applying any changes.

      Users

      Add or remove columns

      Allows you to show and hide columns in the table.

      Add new

      Allows you to add new user to a group.

      Fist of all, you need to select the user. Then you need to set the system properties. And finally you need to apply changes.

      Remove

      Allows you to delete one by one or to delete some users at the same time from a group .  

      To delete some users at the same time, you need to select the users, and then click the button with the subtraction symbol (-). 

      To delete one user, you can click the user, and then Soffid will display a form with the details. Then you can click the delete button (trash icon). 

      Soffid will ask you for confirmation to perform that action, you could confirm or cancel the operation. 

      Import

      Allows you to upload a CSV file with the user list to add to the group.

      First, you need to pick up a CSV file, that CSV has to contain a specific configuration. Then you need to check the content to be loaded, it is allowed to choose if you want or not to load a specific attribute. And finally, you need to select the mappings for each column of the CSV file to import the data correctly and to click the Import button.

      Download CSV file

      Allows you to download a CSV file with all the information about users. 

      Granted roles

      Add or remove columns

      Allows you to show and hide columns in the table. 

      Assign role

      Allows you to assign a role to the group. You can choose that option on the hamburger menu or click the add button (+).

      Then you need to select a role from the role list. If it is necessary, the next step will be to set the scope. Then you need to check and fill in the membership properties. And finally, apply changes.

      Revoke role

      Allows you to revoke one by one or to revoke some roles at the same time.

      To revoke some roles at the same time, you need to select the roles, and then click the button with the subtraction symbol (-).

      To revoke one role, you can click the role, and then Soffid will show a form with the details. Then you can click the delete button (trash icon).

      Soffid will ask you for confirmation to perform that action, you could confirm or cancel the operation.

      Import

      Allows you to upload a CSV file with the role list to assign permission.

      First, you need to pick up a CSV file, that CSV has to contain a specific configuration. Then you need to check the content to be loaded, it is allowed to choose if you want or not to load a specific attribute. And finally, you need to select the mappings for each column of the CSV file to import the data correctly and click the Import button.

      Download CSV file

      Allows you to download a CSV file with all the information about roles assigned to the group. 

      Managers

      Grant <ROLE_NAME> role

      Allows you to grant the role, <ROLE_NAME>, to one or more users. You need to click on the "Grant <ROLE_NAME> role", under the role you want to grant. Then, Soffid will display a modal window that allows you to search for the users. Here you are able to write the user name and select it to grant the role.

      Finally, you need to accept by clicking on the "Accept" button.

      If you click on the "Cancel" button, no changes will be applied.


      Resources Management

      Accounts

      Description

      An account is the way an user is presented on a target system.  There can be user accounts as well as system-purpose accounts.

      An account belongs to a system and that account can have specific permissions assigned to it. An account must have defined the account type, that is if the account is a single user, privileged, shared, or unmanaged.

      The password policy is also mandatory to create an account. That password policy determines the conditions that the password must meet.

      It is allowed to set a password for an account, which can be a generated password by the system, or a password set by the administrator user. That password must comply with the password policies defined. When the account is unmanaged, if the password change, it will not be sent to the target system.

      The account can be displayed in black or gray color. The gray color is used to indicate that the account is unmanaged, that is because the agent is disconnected or because the agent is in Read-Only Mode.

      Screen overview

      image-1665046375035.png

      Related objects

      An account is related, in Soffid, to other objects:

      1. User: users related to this account.
      2. Groups: groups to which the account belongs.
      3. Roles: the permissions that this account has associated with the system in which it is used. They can be assigned or revoked by users with administrator privileges.
      4. System: the environment in which that account is used (AD, Exchange, etc).

      Standard attributes

      Basic

      On the basic account tab, you can view all the account attributes. It is allowed to add new accounts,  update or delete existing accounts and other options.

      Commons attributes

      image-1695656685251.png

      Owners, Managers, and SSO users

      Specify the list of users authorized to use this account. For accounts of type "single user", only one user can be specified. Other accounts can have more than one user. The users that can use this account can be specified either directly, by entering the user name, or indirectly, by entering a group or role name. At the latest, any user having that group or role will automatically be entitled to use this account.

      There are three access levels for each account and user:

      image-1695656706123.png

      Password vault

      image-1695656753816.png

      Launch properties

      Defines the properties to connect to the target system.

      image-1695656777606.png

      Audit information
      System properties

      Roles

      A role is a collection of permissions that can be granted.

      On the roles tab, you can view the roles assigned to the account, it is shown information about the role name, description, application or start (and, if proceed, end) date of the role assignment. 

      You can also assign roles to the account, you can click the add symbol (+), select the role that you want to assign, depending on the role you must fill the scope, and finally set memberships properties.

      It is also possible to revoke roles to the account from the entitlement details or by selecting one or more records from the list and clicking the button with the subtraction symbol (-). 

      By clicking on a record, it is shown the detail  role assignment information.

      Additionally, you can download a CSV file with the roles information and you can also upload a CSV file to assign or revoke roles.

      Effective roles

      Hierarchy of permissions assigned to or inherited. 

      This screen details the effective roles for the selected account.

      Actions

      Account query actions

      Query

      Allows you to query accounts through different search systems, Quick, Basic and Advanced.

      Add or remove columns

      Allows you to show and hide columns in the table. You can also set the order in which the columns will be displayed. The selected columns and order will be saved for the next time Soffid displays the page to the user.

      Add new

      Allows you to add a new account in the system. You can choose that option on the hamburger icon or click the add button (+).To add a new account it will be mandatory to fill in the required fields

      Delete

      Allows you to remove one or more accounts by selecting one or more records and next clicking the button with the subtraction symbol (-).To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Download CSV file

      Allows you to download a CSV file with the basic information of all accounts. 

      Bulk actions

      Allows massive operations to be performed on all system accounts.  With that operation, updates can be made to any of the account's parameters. First of all, you must select the records that you want to update, once you have selected them, you must choose the bulk action on the hamburger icon. For more information visit the Bulk action page.

      Account detail actions

      Apply changes

      Allows you to save the data of a new account or to update the data of a specific account. To save the data it will be mandatory to fill in the required fields

      Delete

      Allow you to remove the account. You can choose that option on the hamburger icon

      To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Undo

      Allows you to quit without applying any changes.

      Set password

      Allows you to set a new password to the account.

      The password can be generated automatically, or you can set the password. The user use this password the first time, 

      It will be mandatory the password complies with the Password policies defined for the domain.

      If an account is unmanaged, the password will not be sent to the target system.

      Show actual account properties

      Display the account attributes at the target system. To perform that action, Soffid needs to connect with the target system and get the account attributes that will be shown.

      Roles

      Assign Role

      Allows you to assign a new role to the account. You can choose that option on the hamburger menu or click the add button (+).

      Then you need to select a role from the role list. If it is necessary, the next step will be to set the scope. Then you need to check and fill in the membership properties. And finally, apply changes.

      Revoke Role

      Allows you to revoke one by one or to revoke some roles at the same time.

      To revoke some roles at the same time, you need to select the roles, and then click the button with the subtraction symbol (-).

      To revoke one role, you can click the role, and then Soffid will show a form with the details. Then you can click the delete button (trash icon).

      Soffid will ask you for confirmation to perform that action, you could confirm or cancel the operation.

      Import

      Allows you to upload a CSV file with the role list to assign permission.

      First, you need to pick up a CSV file, that CSV has to contain a specific configuration. Then you need to check the content to be loaded, it is allowed to choose if you want or not load a specific attribute. And finally, you need to select the mappings for each column of the CSV file to import the data correctly and to click the Import button.

      Download CSV file

      Allows you to download a CSV file with all the information about account roles. 



      Resources Management

      Roles

      Description

      Soffid allows you to create roles to specify permissions that can be assigned to a user, a group, or an account. These permissions determine what operations are allowed on a resource. You can use roles to delegate access to users, applications, or services. The main goal is to achieve optimal security administration.

      Roles can be defined at different levels:

      When needed, generic roles can be created. When such a role is granted to any user, it is converted into a specific role by specifying an organization unit, information system, or a specific value. So, for instance, a generic emergency coordinator role can be created. The master emergency coordinator will have this role granted for the whole organization, while a remote office emergency coordinator will have this role granted for his single unit.

      Screen overview

      image-1698682539184.png

      1. User
      2. Groups
      3. Information System

      Standard attributes

      Role detail

      More information about workflows on the BPM Editor Book.

      Granted roles

      On the granted roles tab, you can assign the privileges of this role to another role in another system.

      To assign privileges you must click the button with the add symbol (+), then select the target role, finish, and apply changes. With this operation, all the permissions of this will be assigned to the target role.

      If you want to revoke permissions,  you must select one or more records from the list and click the button with the subtraction symbol (-). 

      In addition, you can check the preview changes, it display information about the action, the user or account, and the role or domain, and you can apply them.

      Grantee roles

      On the grantee roles tab, you can assign the privileges of a role of any other system to this role.

      To assign privileges you must click the button with the add symbol (+), then select the source role, finish, and apply changes. With this operation, all the permissions of the source role will be assigned to this role.

      If you want to revoke permissions,  you must select one or more records from the list and click the button with the subtraction symbol (-). 

      In addition, you can check the preview changes, it display information about the action, the user or account, and the role or domain, and you can apply them.

      Grantee groups

      On the grantee groups tab, you can assign the privileges from a specific group to this role, or revoke the privileges.

      To assign privileges you must click the button with the add symbol (+), then select the group, finish, and apply changes. With this operation, all the permissions of this group will be assigned to the role.

      If you want to revoke permissions,  you must select one or more records from the list and click the button with the subtraction symbol (-). 

      In addition, you can check the preview changes, it display information about the action, the user or account, and the role or domain, and you can apply them.

      Users

      On the users tab, you can assign or revoke roles. To assign a role you must click the button with the add symbol (+) and choose one or more users, fill the scope when it is mandatory, and set membership properties. Each role needs an account to be applied to, so, if a user has no account on a system and a role on that system is granted, a new account will be created on this system. In case a user has more than one account on a system, you should indicate which of the suitable accounts will be granted the role.

      It is also possible to revoke roles to the user from the entitlement details or by selecting one or more records from the list and clicking the button with the subtraction symbol.

      The users with the role assigned by rules will be displayed with different colors. Soffid does not allow to revoke roles, on that page, that were assigned by rules. 

      Additionally, you can download a CSV file with the basic users data.

      Role assignment rules

      You can consult the Role assignment rules related to this role.

      For more information, you can visit the Role assignment rules page.

       

      Actions

      Roles query

      Query

      Allows you to query roles through different search systems, Quick, Basic and Advanced.

      Add or remove columns

      Allows you to show and hide columns in the table.

      Add new

      Allows you to add a new role in the system. You can choose that option on the hamburger menu or click the add button (+).

      To add a new role it will be mandatory to fill in the required fields

      Delete

      Allows you to remove one or more roles by selecting one or more records and next clicking the button with the subtraction symbol (-).

      To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Import

      Allows you to upload a CSV file with the role list to add or update roles to Soffid.

      First, you need to pick up a CSV file, that CSV has to contain a specific configuration. Then you need to check the content to be loaded, it is allowed to choose if you want or not to load a specific attribute. And finally, you need to select the mappings for each column of the CSV file to import the data correctly and to click the Import button.

      Download CSV file

      Allows you to download a csv file with the basic roles data.

      Roles detail

      Apply changes

      Allows you to save the data of a new role or to update the data of a specific role. To save the data it will be mandatory to fill in the required fields

      Delete

      Allows you to delete a role. You can choose that option on the trash icon.

      To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Undo

      Allows you to quit without applying any changes.

      Preview changes

      Shows the pending changes on users or accounts.  Soffid shows the information about the user or accounts, the action and de Role.

      Apply now (changes)

      Allows you to apply the pending changes.

      Granted roles

      Apply changes

      Allows you to update the data changes.

      Add

      Allows you to add a new granted role. To add a granted role, first you need to click the  add button (+). Second, you need to write or search for a role. Once you have selected the role, if it is necessary, the next step will be to set the scope. Then, you need to finish the process. And finally, you need to apply changes.

      Delete

      Allows you to delete one or more granted roles.

      To delete one, you can select the record and click the button with the subtraction symbol (-) or the trash button located at the end of the row.

      To delete more at the same time, you need to select the records and then click the button with the subtraction symbol (-).

      To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      And finally, you need to apply changes.

      Preview changes

      To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Apply now (changes)

      Allows you to apply the pending changes.

      Grantee roles

      Apply changes

      Allows you to update the data changes.

      Add

      Allows you to add a new grantee role. To add a grantee role, first you need to click the add button (+). Second, you need to write or search for a role. Once you have selected the role, if it is necessary, the next step will be to set the source scope and the scope. Then, you need to finish the process. And finally, you need to apply changes.

      Delete

      Allows you to delete one or more grantee roles.

      To delete one, you can select the record and click the button with the subtraction symbol (-) or the trash button located at the end of the row.

      To delete more at the same time, you need to select the records and then click the button with the subtraction symbol (-).

      To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      And finally, you need to apply changes.

      Preview changes

      To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Apply now (changes)

      Allows you to apply the pending changes.

      Grantee groups 

      Apply changes

      Allows you to update the data changes.

      Add

      Allows you to add a new grantee group. To add a grantee group, first you need to click the  add button (+). Second, you need to write or search for a group. Once you have selected the group, if it is necessary, the next step will be to set the scope. Then, you need to finish the process. And finally, you need to apply changes.

      Delete

      Allows you to delete one or more grantee groups.

      To delete one, you can select the record and click the button with the subtraction symbol (-) or the trash button located at the end of the row.

      To delete more at the same time, you need to select the records and then click the button with the subtraction symbol (-).

      To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      And finally, you need to apply changes.

      Preview changes

      To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Apply now (changes)

      Allows you to apply the pending changes.

      Users

      Add or remove columns

      Allows you to show and hide columns in the table.

      Add

      Allows you to add users or accounts to assign the role. To add users or accounts, fist of all, you need to click the add button (+) or the "Add new" action  located on the hamburger icon. Second, you need to search the users and/or accounts and select the users and/or accounts you want to add. Once you have selected the users and/or accounts, if it is necessary, the next step will be to set the scope. Then you need to fill in the membership properties and finish the process. Finally, you need to apply changes.

      Delete

      Allows you to delete one or more users and/or accounts, that is, Soffid will revoke the role.

      To delete one, you can select the record and click the button with the subtraction symbol (-) or the trash button located at the end of the row.

      To delete more at the same time, you need to select the records and then click the button with the subtraction symbol (-).

      To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      And finally, you need to apply changes.

      Preview changes

      To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Apply now (changes)

      Allows you to apply the pending changes.

      Download CSV file

      Allows you to download a CSV file with all the information about users. 


      Resources Management

      Information systems

      Description

      Information systems are the systems that Soffid will protect granting and revoking roles. Each role and entry point is bound to an information system.

      The information system can be created hierarchically. These information systems are managed in a tree structure. 

      Soffid allows you to categorize the information systems to facilitate the management, the available categories are Application, Container and Business. That categories are for information purposes only.

      The permission can be granted by using workflows.  You can access to Workflows page for more information.

      1. Users
      2. Role

      Custom attributes

      Basics

      Role Scopes (Domain)

      Role scope or domains are properties that can be assigned to some entitlements, limiting the scope of that entitlement. This can be used to limit, for instance, the maximum amount allowed for a money transfer, or the commercial zones to manage.

      On this tab, you can add new domains, you must click the button with the add symbol and fill the information about the new domain. You can also delete a domain or update the domain information.

      Other operations allowed are to download a CSV file with the domain data and toOther operations allowed are to download a CSV file with the domain data and to upload a CSV file to add new domains, or update existed domains to add new domains, or update existing domains

      Roles

      A role is a collection of permissions that determine what operations a user or a group of users can perform on that information system.

      On the roles tab is allowed to create, update and delete roles. The effective privileges bound to each role are managed from each application.

      To add a new role you must click the button with the add symbol (+) and fill all the role data.

      You can update a specific role by clicking on the right record, making and applying changes.

      It is also possible to delete roles from the role details or by selecting one or more records from the list and clicking the button with the subtraction symbol (-). 

      Additionally you can download a CSV file with the roles information and you can also upload a CSV file to add new roles, or modify existing roles.

      Users

      On the user's tab, Soffid displays all the user with granted roles for this information system.

      It is allowed to download a CSV file with all the user data.

      Actions

      Information system query

      Query

      Allows to query groups through different search systems, Quick, Basic and Advanced.

      Add or remove columns

      Allows to show and hide columns in the table.

      Add new

      Allows to create a new information system. You can choose that option on the hamburger menu or clicking the add button (+).

      To add a new information system it will be mandatory to fill in the required fields

      Add child information system

      Allows to add a child to a specific information system. You can choose that option below the father information system.

      To add a child it is necessary to fill in the required fields

      Import

      Allows you to upload a CSV file with the information system list to add or update information systems to Soffid.

      First, you need to pick up a CSV file, that CSV has to contain a specific configuration. Then you need to check the content to be loaded, it is allowed to choose if you want or not load a specific attribute. And finally, you need to select the mappings for each column of the CSV file to import the data correctly and to click the Import button.

      Download CSV file

      Allows to download a csv file with the basic information of all information systems. 

      Information system detail actions

      Apply changes

      Allows you to save the data of a new information system or to update the data of a specific information system. To save the data it will be mandatory to fill in the required fields

      Delete

      Allows you to remove a specific information system. To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Undo

      Allows you to quit without applying any changes.

      Role scopes actions

      Add domain

      Allows you to add a new domain to limit the scope. You can choose that option on the hamburger menu or clicking the add button (+).

      To add a new domain it will be mandatory to fill in the required fields

      Import

      Allows you to upload a CSV file with the domain list to add or update domains to Soffid.

      First, you need to pick up a CSV file, that CSV has to contain a specific configuration. Then you need to check the content to be loaded, it is allowed to choose if you want or not to load a specific attribute. And finally, you need to select the mappings for each column of the CSV file to import the data correctly and to click the Import button.

      Download CSV file

      Allows you to download a CSV file with all the information about domains. 

      Roles actions

      Add or remove columns

      Allows you to show and hide columns in the table.

      Add new

      Allows you to create a new role for that information system. You can choose that option on the hamburger menu or clicking the add button (+).

      To add a new role it will be mandatory to fill in the required fields

      Delete

      Allows you to delete one by one or to delete some roles at the same time from an information system .  

      To delete some roles at the same time, you need to select the roles, and then click the button with the subtraction symbol (-). 

      To delete one role, you can click the users, and then Soffid will show a form with the details. Then you can click the delete button (trash icon). 

      Soffid will ask you for confirmation to perform that action, you could confirm or cancel the operation. 

      Import

      Allows you to upload a CSV file with the roles list to add to the information system.

      First, you need to pick up a CSV file, that CSV has to contain a specific configuration. Then you need to check the content to be loaded, it is allowed to choose if you want or not to load a specific attribute. And finally, you need to select the mappings for each column of the CSV file to import the data correctly and to click the Import button.

      Download CSV file

      Allows to download a csv file with the basic role data

      In addition for each role you can perform the specific operations defined on the Role page

      Users actions

      Download CSV file

      Allows to download a CSV file with all the information about users. 


      Resources Management

      Role assignment rules

      Description

      Soffid console provides an option that allows you to customize policies to assign or revoke roles automatically to specific users. To assign or revoke roles, the users must comply with the defined requirements.

      That option allows you to Preview changes before to Apply changes, to verify that the actions to be performed are the correct ones. 

      To Apply now the Role assignment rule, it is mandatory to have previously saved any changes made in the customization of the role assignment rule using the Apply changes button.

      The rule evaluation is performed asynchronously.

      When a user is updated, no matter from where, Soffid will launch the role assignment rules defined.

      image-1661337836100.png

      1. User
      2. Roles
      Custom attributes

      Role detail

      Roles to apply when rule expression returns true

      The roles result will be a Role list, or RoleAccount list, or String list. 

      Actions

      Role assignment rules query action

      Add new

      Allows you to add a new role assignment rule in the system. You can choose that option on the hamburger menu or clicking the add button (+).To add a new role assignment rule it will be mandatory to fill in the required fields

      Delete

      Allows you to remove one or more role assignment rule by selecting one or more records and next clicking the button with the subtraction symbol (-).To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Import

      Allows you to upload a CSV file with the role assignment rule list to add or update role assignment rules to Soffid.First, you need to pick up a CSV file, that CSV has to contain a specific configuration. Then you need to check the content to be loaded, it is allowed to choose if you want or not to load a specific attribute. And finally, you need to select the mappings for each column of the CSV file to import the data correctly and to click the Import button.

      Download CSV file

      Allows you to download a CSV file with the basic information of all role assignment rule. 

      Role assignment rules detail action

      Apply changes

      Allows you to save the changes made on the rule specification, or to save a new rule.

      Undo

      Allows you to undo any changes made on the rule, except the roles added or deleted to the role list.

      Add new role

      Allows you to add a role to be applied with the rule.

      Preview changes

      Displays a list with the changes that would be applied with that rule definition.

      Apply now

      Allows you to launch the role assignment rule process. When users comply with the rule specification, their roles will be updated.


      Resources Management

      Segregation of Duties (SoD)

      Description

      The segregation of duties (SoD) is a fundamental element of internal controls, defined to prevent error and fraud. Segregation of duties ensure that at least two individuals are responsible for the separate parts of any task.

      For each user, the roles tab displays the list of roles assigned to the user and the possible risks. If you click on a role record, Soffid will show the entitlement details including the SoD rules with the detail of the risk. 

      1. Information Systems
      2. Roles
      Custom attributes

      Actions

      Segregation of Duties query actions

      Query

      Allows you to query Segregation of Duties through different search systems, Basic and Advanced.

      Add new

      Allows you to add a new Segregation of Duties in the system. You can choose that option on the hamburger menu or click the add button (+).

      To add a new Segregation of Duties it will be mandatory to fill in the required fields

      Delete

      Allows you to remove one or more Segregation of Duties by selecting one or more records and next clicking the button with the subtraction symbol (-).

      To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Download CSV file

      Allows you to download a CSV file with the basic Segregation of Duties data.

      Segregation of Duties detailed actions

      Apply changes

      Allows you to save the data of a new role or to update the data of a specific role. To save the data it will be mandatory to fill in the required fields

      Delete

      Allows you to delete a Segregation of Duties. You can choose that option on the trash icon.

      To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Undo

      Allows you to quit without applying any changes.

      Add new role Allows you to add a new role to the Role list. You can add a role by clicking the add button (+), then Soffid will show a form to search and select one or more roles. Finally, you need to click the apply changes button and the roles will be added to the role list.
      Delete role

      Allows you to delete one or more roles from the role list. You can select one or more roles and then click the button with the subtraction symbol (-). The roles will be deleted from the role list without Soffid asking for confirmation.


      Resources Management

      Networks

      Description

      Operators can define the subnets that compose the internal network, in order to manage the IP address space. The main goal is to manage a limited resource as the IP address is.

      Soffid supports both static and dynamic IP assignments. Anyway, static IP management does not exclude the use of DHCP o BOOTP protocols in order to get them.

      Screen overview

      image-1706091595138.png

      Custom attributes

      Basics

      On the network group tab, you can view all the network attributes. It is allowed to add new networks,  update or delete existing networks.

      Access control

      In order to delegate the management of IP addresses in this network range, the Access Control List allows to select which users, groups or roles will be allowed to manage it.

      Each Access Control List Entry has the following attributes:

      To add a new access control you can click the button with the add symbol (+), you have to select the grantee type (user, group or role), then you have to choose an user, group or role depending on the grantee selected, and finally set the acces level and the mask and apply the changes.

      If you want to delete access controls,  you must select one or more records from the list and clicking the button with the subtraction symbol (-). 

      Actions

      Networks query

      Query

      Allows you to query networks through different search systems, Quick, Basic and Advanced.

      Add or remove columns

      Allows you to show and hide columns in the table.

      Add new

      Allows you to create a new network. You can choose that option on the hamburger menu or clicking the add button (+).

      To add a new network it will be mandatory to fill in the required fields

      Delete

      Allows you to remove one or more networks by selecting one or more records and next clicking the button with the subtraction symbol (-).

      To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Import

      Allows you to upload a CSV file with the network list to add or update networks to Soffid.

      First, you need to pick up a CSV file, that CSV has to contain a specific configuration. Then you need to check the content to be loaded, it is allowed to choose if you want or not to load a specific attribute. And finally, you need to select the mappings for each column of the CSV file to import the data correctly and to click the Import button.

      Download CSV file

      Allows you to download a csv file with the networks information.

      Networks detail

      Apply changes

      Allows you to save the data of a new network or to update the data of a specific network. To save the data it will be mandatory to fill in the required fields

      Undo

      Allows you to quit without applying any changes.

      Access control

      Add new

      Allows you to create a new access control. You can choose that option on the hamburger menu or clicking the add button (+).

      First,  you will select the Grantee type, which could be a role, a user or a group. Second, you will select the Grantee, it will depend on the Grantee type selected. Then, you will fill in the access level. And finally you will apply changes.

      Delete

      Allows you to remove one or more access controls by selecting one or more records and next clicking the button with the subtraction symbol (-).

      To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Import

      Allows you to upload a CSV file with the access control list to add or update access controls to Soffid.

      First, you need to pick up a CSV file, that CSV has to contain a specific configuration. Then you need to check the content to be loaded, it is allowed to choose if you want or not to load a specific attribute. And finally, you need to select the mappings for each column of the CSV file to import the data correctly and to click the Import button.

      Download CSV file

      Allows you to download a csv file with the basic access controls data.

      Restrict ESSO login

      Allows you to restrict the access to the workstations of this network.


      Resources Management

      Hosts

      Description

      The host screen lets the administrator manage a static IP address assigned to any host. Dynamic IP addresses are automatically managed by Soffid ESSO.

      Screen overview

      image-1713881557353.png

      1. Network
      2. Operating systems
      Custom attributes

      Basics

      On the basic host tab, you can view all the host attributes. It is allowed to add new host,  update or delete existing hosts.

      Access Control

      On the access control tab, you can delegate the host management.

      If you add a user authorization, you will allow the user to execute any task as a local administrator on this server or workstation. This feature requires the Soffid ESSO to be installed in the target host.

      To add a user authorization you can click the button with the add symbol (+), then select the user and expiration date, and finally apply changes.

      It is also allowed to delete one or more user authorizations, you can do it from the entitlement details or by selecting one or more records from the list and clicking the button with the subtraction symbol (-).

      Additionally, you can download a CSV file with the access control data and you can also upload a CSV file to add user authorizations, and modify or delete user authorizations.

      You also can view the administrator password.

      Sessions

      On the sessions tab, you can view the information about the last connection of a user to this host. Shows data about the user, server, client, port used and date of connection.

      You can download a CSV file with the user sessions data.

      Actions

      Host query

      Query

      Allows you to query host through different search systems, Quick, Basic and Advanced.

      Add or remove columns

      Allows you to show and hide columns in the table.

      Add new

      Allows you to create a new host. You can choose that option on the hamburger menu or by clicking the add button (+).

      To add a new host it will be mandatory to fill in the required fields

      Delete

      Allows you to remove one or more hosts by selecting one or more records and next clicking the button with the subtraction symbol (-).

      To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Import

      Allows you to upload a CSV file with the host list to add or update hosts to Soffid.

      First, you need to pick up a CSV file, that CSV has to contain a specific configuration. Then you need to check the content to be loaded, it is allowed to choose if you want or not to load a specific attribute. And finally, you need to select the mappings for each column of the CSV file to import the data correctly and click the Import button.

      Download CSV file

      Allows you to download a csv file with the hosts information.

      Operating systems

      This option allows you to manage the Operating Systems. You can add new, update, or delete OS

      Host detail

      Apply changes

      Allows you to save the data of a new host or to update the data of a specific host. To save the data it will be mandatory to fill in the required fields.

      Delete

      Allows you to delete the host. To delete a host you can click on the hamburger icon and then click the delete button (trash icon).

      Soffid will ask you for confirmation to perform that action, you could confirm or cancel the operation.

      Undo

      Allows you to quit without applying any changes.

      Assign free IP Address

      Allows you to assign a free IP address. You can find that option by clicking on the hamburger icon.

      View password

      Will show the administrator password if it is available.

      Access control

      Add new

      Allows you to create a new access control. You can choose that option on the hamburger menu or clicking the add button (+).

      First,  you will select the user and the expiration date of that authorization. Finally you need to apply changes.

      Delete

      Allows you to remove one or more access controls by selecting one or more records and next clicking the button with the subtraction symbol (-).

      To delete one access control, you can click the access control, and then Soffid will show a form with the details. Then you can click the delete button (trash icon).

      To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Import

      Allows you to upload a CSV file with the access control list to add or update access controls to Soffid.

      First, you need to pick up a CSV file, that CSV has to contain a specific configuration. Then you need to check the content to be loaded, it is allowed to choose if you want or not to load a specific attribute. And finally, you need to select the mappings for each column of the CSV file to import the data correctly and to click the Import button.

      Download CSV file

      Allows you to download a csv file with the access control information

      View password

      Will show the administrator password if it is available.

      Sessions

      Download CSV file

      Allows you to download a csv file with the sessions information


      Resources Management

      Printers

      Description

      Soffid lets administrator users manage system printers. A printer must always be attached to a host. A network attached printer is composed of a host (network print server) and a printer (printer queue).

      Printers can be assigned to specific users or to user groups. The effective assignment can be done on session startup by using a Single Sign On client script. To do that, it is necessary to add a script on a Login entry point with type x-mazinger-script.

      1. Hosts
      2. Users
      3. Groups
      Standard attributes 

      Actions

      Printer query

      Query

      Allows you to query printers through different search systems, Quick, Basic and Advanced.

      Add or remove columns

      Allows you to show and hide columns in the table.

      Add new

      Allows you to create a new printer. You can choose that option on the hamburger menu or clicking the add button (+).

      To add a new printer it will be mandatory to fill in the required fields

      Delete

      Allows you to remove one or more printers by selecting one or more records and next clicking the button with the subtraction symbol (-).

      To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Import

      Allows you to upload a CSV file with the printer list to add or update printers to Soffid.

      First, you need to pick up a CSV file, that CSV has to contain a specific configuration. Then you need to check the content to be loaded, it is allowed to choose if you want or not to load a specific attribute. And finally, you need to select the mappings for each column of the CSV file to import the data correctly and to click the Import button.

      Download CSV file

      Allows you to download a csv file with the basic information of all printers. 

      Printer detail

      Add new

      Allows you to create a new printer. You can choose that option on the hamburger menu or clicking the add button (+).

      To add a new printer it will be mandatory to fill in the required fields and apply changes.

      Delete

      Allows you to remove one printer. You can find that option by clicking on the hamburger icon.

      To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Undo

      Allows you to quit without applying any changes.


      Resources Management

      Mail Domains

      Description

      The mail domains identify each single mail domain that is going to be managed. If a mail domain is marked as obsolete, it won't be assigned to a user anymore.

      Custom attributes

      Actions

      Mail Domains query

      Add new

      Allows you to create a new mail domain. You can choose that option on the hamburger menu or clicking the add button (+).

      To add a new mail domain it will be mandatory to fill in the required fields

      Delete

      Allows you to remove one or more mail domains by selecting one or more records and next clicking the button with the subtraction symbol (-).

      To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Import

      Allows you to upload a CSV file with the mail domain list to add or update mail domains to Soffid.

      First, you need to pick up a CSV file, that CSV has to contain a specific configuration. Then you need to check the content to be loaded, it is allowed to choose if you want or not to load a specific attribute. And finally, you need to select the mappings for each column of the CSV file to import the data correctly and to click the Import button.

      Download CSV file

      Allows you to download a CSV file with the mail domains information.

      Mail Domain detail

      Apply changes

      Allows you to save the data of a new mail domain or to update the data of a specific mail domain. To save the data it will be mandatory to fill in the required fields.

      Delete

      Allows you to delete the mail domain.

      To delete a mail domain can click on the hamburger icon and then click the delete button (trash icon).

      Soffid will ask you for confirmation to perform that action, you could confirm or cancel the operation.

      Undo

      Allows you to undo the changes made.


      Resources Management

      Mail List

      Description

      The mail lists identify addresses that are going to be delivered to one or more users, just as distribution mail lists do.

      Standard attributes

      Actions

      Mail List query

      Query

      Allows you to query mail list through different search systems, Quick, Basic and Advanced.

      Add or remove columns

      Allows you to show and hide columns in the table.

      Add new

      Allows you to create a new mail list. You can choose that option on the hamburger menu or clicking the add button (+).

      To add a new mail list it will be mandatory to fill in the required fields

      Delete

      Allows you to remove one or more mail domains by selecting one or more records and next clicking the button with the subtraction symbol (-).

      To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Import

      Allows you to upload a CSV file with the "mail list" list to add or update mail lists to Soffid.

      First, you need to pick up a CSV file, that CSV has to contain a specific configuration. Then you need to check the content to be loaded, it is allowed to choose if you want or not to load a specific attribute. And finally, you need to select the mappings for each column of the CSV file to import the data correctly and to click the Import button.

      Download CSV file

      Allows you to download a csv file with the mail domains information.

      Mail List detail

      Apply changes

      Allows you to save the data of a new mail list or to update the data of a specific mail list. To save the data it will be mandatory to fill in the required fields.

      Delete

      Allows you to delete the mail list.

      To delete a mail list can click on the hamburger icon and then click the delete button (trash icon).

      Soffid will ask you for confirmation to perform that action, you could confirm or cancel the operation.

      Undo

      Allows you to quit without applying any changes.


      Resources Management

      Application access tree

      Description

      The entry points could be to connect to information systems defined on Soffid, or to connect to other applications. These applications can be Web applications or Native applications. Each information systems can have one or more application entry points.

      The entry points are managed in a tree structure, that allows creating new menus and new application access.

      Each member of the tree can be tied to a list of users, account groups, or roles. Also, you can choose if the application menu entry will be visible or not by unauthorized users.

      After logging on to a managed workstation, the system will apply such restrictions and will update the Windows or Linux start menu.

      Each application entry point will have different execution methods for fully managed workstations, loosely managed workstations, or external devices. Each of them can be a web browser URL or a javascript piece.

      Each application entry point can have a single sign on rule. Those roles are fully explained in the ESSO reference guide. For more information, you can visit the ESSO chapter.

      The defined entry points allow to final users open applications from the self service portal. For more information can visit My Applications page.

      Screen overview

      1. Information system
      2. User
      3. Group
      4. Role
      5. Account

      Standard attributes

      Basics

      Authorizations

      Allows you to grant access permissions to users, groups, roles, or accounts. 

      To give authorization it is necessary, first of all, to select the grantee type, then to choose the user, group, role, or account, and finally choose the access level. The access level allows two options:

      Executions

      Allows Administrator users to configure the entry point access. It is only available to entry points with the option Menu not selected.

      There are three options to configure the executions. Administrator users can configure one or more:

      For each execution option it is possible to configure the following parameters: 

      ESSO

      Allows you to customize a script to define a pattern to detect when an application is used and how to inject the credentials.

      For more information, you can visit the ESSO chapter.

      Actions

      Application query

      💻 Image

      image-1714027900339.png

      Query Allows to query the entry points through different search systems, Quick, Basic and Advanced.
      Create new entry

      Allows you to add a new entry point.

      To create a new entry point you can click the Create new entry button, then Soffid will display a new window to fill in the entry point data.

      To add a new entry point it will be mandatory to fill in the required fields.

      Application detail

      💻 Image

      image-1709803473292.png

      Apply changes

      Allows you to save the data of a new entry point or to update the data of a specific entry point. To save the data it will be mandatory to fill in the required fields.

      Delete

      Allows you to delete the entry point.

      To delete an entry point, you can click the hamburger icon and then click the delete button (trash icon). Soffid will ask you for confirmation to perform that action, you could confirm or cancel the operation.

      Undo

      Allows you to quit without applying any changes made.

      Authorizations
      💻 Image

      image-1709803621569.png

      Add new

      Allows you to add a new authorization. You can choose that option on the hamburger menu or by clicking the add button (+).

      💻 Image

      image-1709886443334.png

      First,  you will select the Grantee type, which could be a role, a user, an account, or a group. Second, you will select the Grantee, it will depend on the Grantee type selected. Then, you will fill in the access level. And finally, you will apply changes.

      Executions
      💻 Image

      image-1709806446004.png

      Apply Changes Allows you to save the execution configuration.
      Delete Allows you to delete the execution configuration.
      ESSO
      💻 Image

      image-1709807010309.png

      Validate Allows you to validate and save the script.


      Resources Management

      Password vault

      Description

      Soffid provides a protected storage, to save and manage accounts for multiple applications, that is the Password vault. Here you can save the accounts and passwords to access to critical systems and to your applications as well. Password vault allows you to handle the access control list to these accounts. Sometimes these accounts can be used by a specific user or a set of users.

      The accounts are organized in folders depending on the permissión, and the criticality level, .... These accounts can be system accounts or user accounts.

      The Password vault exposes a subset of accounts to some users. These accounts are available through the Self-services portal. You can visit My applications page for more information.

      When a privileged account is being config, it will be able to assign a workflow or approval process to request in order to use that account. For more information visit the link How to apply policies

      Users can be authorized to manage their own personal accounts, sso:manageAccounts. For more info visit the Authorizations page.

      Folders

      In the password vault, two kinds of folders are used: personal folders and shared folders, which depend on the Owners configuration you define.

      On one hand, each user has their own personal folder. Inside this folder, the user can create accounts. That account will not be shared with any other user.

      On the other hand, the shared folders could be used or managed by the owner/manager/SSO users.

      Accounts

      Soffid allows you to create new accounts on a specific folder on the password vault page, to add a new account will be mandatory to fill in some attributes, like System, name, and login name. You can consult the existing accounts related to a folder. For each account, you can update or delete the account, view and set a password.

      Also, you can create accounts on the Account page and assign the appropriate vault folder.

      Soffid allows administrator users to configure a workflow to request permissions when a user try to change the password of a privileged account in the password vault. That process can be defined with the BPM Editor as an Account reservation type. For more information you can visit the BPM Editor book.

      Overview

      1. Accounts

      Standard attributes

      Folder attributes

      Accounts attributes

      Actions Tab

      This tab shows the read-only attributes of the user account:

      Also, this tab allows you to launch the connection to the target system, view the password, set the password to launch the connection, and unlock the use of that account. All those options depend on the account definition and user privileges.

      Basics Tab

      This tab displais all the account attributes and allows you to update the account configuration.

      Visit the Account page to view more information about the standard attributes of an account.

      Actions

      Folders query actions

      Query

      Allows you to query folders through, only Quick search is available.

      Add new

      Allows you to create a new folder. You can choose that option on the hamburger menu or by clicking the add button (+).

      To add a new folder it will be mandatory to fill in the required fields.

      A folder needs to have, at less, an owner to manage it.

      Folder actions

      Apply changes

      Allows you to save a new folder or update an existing folder. To save the data it will be mandatory to fill in the required fields. Be in mind that is important to indicate who are the owners of the folder.

      Undo

      Allows you to quit without saving any change made.

      Delete

      Allows you to delete a folder if you have the right permissions. To delete a folder you can click on the hamburger icon and then click the delete button (trash icon). Soffid will ask you for confirmation to perform that action, you could confirm or cancel the operation.

      Account actions

      Apply changes

      Allows you to save a new account. To save the data it will be mandatory to fill in the required fields. Be in mind that is important to indicate who are the owners of the folder. If the account exists on the system, you can assign the vault folder to the account window.

      Undo

      Allows you to quit without saving any change made.

      Delete

      Allows you to delete an account from a folder if you have the right permissions. To delete a host you can click on the hamburger icon and then click the delete button (trash icon). Soffid will ask you for confirmation to perform that action, you could confirm or cancel the operation.

      Set password

      Allows you to set a password to access to the account.


      How to apply policies

      Soffid allows you to define policies and rules to apply to a specific folder or a set of folders. To do that is needed to install the XACML  addon and configure the proper policies and rules. 

      Also, you can config a workflow or approval process to request in order to use accounts saved on a folder.

      It is mandatory to enable the Password Vault PEP and populate the information about the XACML policy set and the version which applies.

      Example 

      XACML PEP config

      It is mandatory to enable the Password Vault PEP and populate the information about the XACML policy set and the version which applies.

      Password Vault:

      image-1627909636077.png

      XACML PEP config:

      image-1627903193056.png

      XACML Policy Management

      You need to configure the access to the folder "VaultFolder", that folder can contain other folders and accounts. It will be mandatory to config the access list, who are the owners, managers, and so on. You need to know if you need to config the control access list by accounts, by folders, or both.

      image-1627904759237.png

      For instance, the policies you need to implement are the following:

      1. Only users between 6:00 and 18:00 could use the accounts inside the "demoFolder".

      image-1627909569093.png

      image-1627909585789.png

      2.- User "bob" never could use the accounts of demoFolder.

      image-1627909447400.png

      image-1627909485850.png

      3. Users with result permits, need the authorization to use the accounts.

      You need to config the workflow that will be called, to config you need to include the bpm obligation on the policy. Also, you can include a message to the user, or other obligations. 

      image-1627909874242.png




      Visit the XACML Book for more information.

      Visit the BPM Editor Book for more information.



      Resources Management

      Custom objects

      Description

      The custom objects are the objects created by the administrator to extend the Soffid underlying data model. You can visit the Metadata page for more information.

      This option allows administrator users to provide objects with content.

      1. Object Type: objects created by the administrator.

      Standard attributes

      Every single custom object could have specified attributes defined by the administrator users when they create the object type.

      Actions

      Custom object query

      Query

      Allows you to query custom object through different search systems, Quick, Basic and Advanced.

      Add or remove columns

      Allows you to show and hide columns in the table.

      Add new

      Allows you to create a new custom object. You can choose that option on the hamburger menu or clicking the add button (+).

      To add a new custom object it will be mandatory to fill in the required fields

      Delete

      Allows you to remove one or more custom objects by selecting one or more records and next clicking the button with the subtraction symbol (-).

      To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Import

      Allows you to upload a CSV file with the custom object list to add or update custom objects to Soffid.

      First, you need to pick up a CSV file, that CSV has to contain a specific configuration. Then you need to check the content to be loaded, it is allowed to choose if you want or not to load a specific attribute. And finally, you need to select the mappings for each column of the CSV file to import the data correctly and to click the Import button.

      Download CSV file

      Allows you to download a csv file with the custom objects information.

      Custom object detail


      Apply changes

      Allows you to save the data of a new custom object or to update the data of a specific custom object. To save the data it will be mandatory to fill in the required fields

      Undo

      Allows you to undo  any changes made

      Delete

      Allows you to remove a custom object.  You can choose that option on the trash icon.

      To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.


      Integration Engine

      Integration Engine

      Smart engine settings

      Description

      The administrator users can decide the engine mechanism for the synchronization task, i.e. when the tasks are created and sent to external systems.

      Screen overview

      image-1710860385281.png

      Standard attributes

      1. Task engine mode:  allows you to select the synchronization mode. There are three available options: 
        • Read only: it is the option by default in the Soffid installation.  No task is synchronized to external systems.
        • Manual: only selected synchronization tasks are performed. You could synchronize manually a user, check the "Propagates the changes" action on the Users page. Or also synchronize a whole target system, check the Agents page. 
        • Automatic:  each change is automatically send to target systems.
      2. Tasks limit per transaction: if a single transaction creates more than this number of tasks, tasks will be held until Soffid administrator releases them. The administrator could check them in the  Sync server monitoring page.
      3. Scripting language: Soffid allows you to create scripts and you can choose the scripting language:
        • Beanshell
        • Javascript
        • Autodetected

      Soffid offers a set of sample scripts. You can find examples visiting the Sample scripts page.

      Additionally, in the initial configuration of the container, we can configure the SOFFID_TRUSTED_SCRIPTS environment variable to allow the use of insecure classes.  You can find this information visiting the Installing IAM Console page.

      Tips

      Use the task engine mode for these scenarios:
      Tasks limit per transaction:

      Actions

      Confirm changes Allows you to update the engine settings.
      Undo Allows you to cancel the changes made and not confirmed.


      Integration Engine

      Agents

      Description

      Soffid agents are the tool that allows the connection between the Soffid console and the target systems. To establish the connection with target systems, Soffid provides a large number of connectors that will be able to set up into the Soffid console.

      You could see the complete list of Synchronization Server Connectors

      Soffid administrator has the chance to easily customize attribute mappings for some connectors addons, without having to code it using Java. Soffid provides a graphical interface to perform attribute mapping.

      An agent will appear disabled when this agent won't have a server assigned. Bear in mind to select the “Disabled” flag on Server URL criteria when you will query if you want to search for disabled, but defined agents.

      Related objects

      1. Synchronization server
      2. Account naming rules
      3. User type
      4. Password policies

      Standard attributes

      Basic

      When uploading authoritative data for identities from a managed system, firstly, users will be created in Soffid as indicated in the attribute mapping, and secondly, accounts will be created for the managed systems only if the agent option "Manual account creation" is not checked and only for User Types indicate.

      Connector parameters

      The custom attributes depend on the used plugin. 

      Here you will find all the information needed about the available Soffid connectors to integrate external managed systems.

      1. AWS Connector
      2. CSV Connector
      3. Google Apps Connector
      4. JSON REST Web Services Connector
      5. LDAP Connector
      6. Oracle Connector
      7. Oracle EBS Connector
      8. SAP Connector
      9. SCIM Connector
      10. Shell Connector
      11. SQL Connector
      12. Windows Connector
      13. Zarafa Connector
      14. SQL Server Connector

      Integration flows

      Some connector addons have associated integration workflows. On the Integration flows tab you can view the integration flows related to the agent. You also can view in detail the workflows and test them. 

      Attribute mapping

      The attribute mapping tab only appears when the agent allows such customization. Soffid administrators have the chance to easily customize attribute mappings without having to code them using Java. The administrator users can select system objects and the Soffid objects related, manage their attributes, and make either inbound and outbound attribute mappings.

      There is an action that creates all the default mapping depending on the agent connector type. That option creates automatically system objects with their attributes and properties, you can select them by clicking on the hamburger icon and then the Create default mapping option. Once created the default mapping, those can be customized as required. 

      Properties

      Some agents require to configure some custom attributes in their properties section.

      These properties are specific for each type of connector. You could see all these properties by visiting each connector type page.

      Methods

      This option is only available on some types of connectors. It is used to define methods that can be called using the defined properties.

      Attributes

      Each object mapping defines an agent object name and one bound Soffid object type.

      The left hand side attributes are managed system attributes, so they are agent dependent that is being configured. The right side attributes are Soffid attributes and must be selected from an existing list. 

      It is allowed to use bean Shell expression in the source when the mapping is one-way.

      System attributes

      A configuration agent must define object types that can be created on it. Each object mapping defines an agent object name and needs bound Soffid object type.

      At this column, the system's attribute name will be displayed.

      Directions

      At the center column, an arrow will show the direction of the information flows.

      When the information flows from the system (left) to Soffid (right), the left column name can be replaced by a bean shell expression. This expression will be evaluated on the system object prior to uploading it to Soffid.

      When the information flows from Soffid (right) to the managed system (left), the right column can contain a bean shell expression that will be evaluated prior to provisioning the user.

      Here are some examples:

      System attribute Direction Soffid attribute Meaning

      cn

      <=>

      accountName

      The account name is the CN attribute of the LDAP

      departmentNumber

      <=

      for (group: secondaryGroups) {
        if  (group.get("name").equals(primaryGroup)) {
          return group.get("description");
        }
      }
      return null;

      Assigns the group description of the primary group to the departmentNumber attribute

      baseDN

      =>

      "ou="+primaryGroup+",dc=soffid,dc=org"

      Assigns the base dn of the user to the proper organization unit that is below dc=soffd,dc=org.

      Soffid attributes

      You can consult the list of Soffid attributes:

      When evaluating any expression, either the system or soffid attributes are available as script variables. Moreover, the following variables are available:

      Variable Content

      serverService

      Server API that enables an easy object query [ Search the link "Public API Module" or "Data & Service model" ]

      serviceLocator

      Spring Singleton that gets access to any published service bean. Only available on the main syncserver

      remoteServiceLocator

      Singleton that gets access to any remotely published service bean.

      THIS

      HashMap that contains any soffid or system managed attribute. It can be used when the attribute name is not a valid java identifier.

      dispatcherService

      Service that allows the script to get or update information in the target system.

      Test

      For the definition of an object, you can check the system attributes defined, in both the final system and in Soffid.

      1. First of all, you need to click the Test button, then Soffid will display a text field and some buttons to perform new actions.

      2. Secondly, the text field must be filled in with the appropriate data. It can be a user, an account, a group or another system object. It depends on the system object you are checking.

      3. Then, you can choose the action to perform.

      Text expression: allows you to test a system object.

      Synchronize now: this allows you to synchronize the data object to the target system.

      Fetch system raw data: brings the data of an object from a target system.

      Fetch Soffid object: brings the data of a specific system object with processed data to update into Soffid

      Triggers

      It is allowed to define BeanShell scripts that will be triggered when data is loaded into the target system (outgoing triggers). 

      The trigger result will be a boolean value, true to continue or false to stop.

      A configuration agent can configure triggers related to the operation to be performed. There are different trigger type, that determines the specific moment at which the script will be triggered.

      Triggers can be used to validate or perform a specific action just before performing an operation or just after performing an operation on target objects. 

      To access Soffid data, you can use source{"attributeName"}, which recovers the value of the attributeName. That object will be Soffid format.

      Also, you can use newObject{"attributeName"} to create the new value or oldObject{"attributeName"} to get the old value of the target system, those objects will be target system format.

      Trigger

      preInsert

      It will be triggered just before the insert action. It will be used to validate or prevent the insert action, and also to prepare objects or actions when a new object will be inserted

      preUpdate

      It will be triggered just before the update action. It will be used to validate or prevent update an object.

      preDelete

      It will be triggered just before the delete action. It will be used to validate or prevent delete an object.

      postInsert

      It will be triggered just after the insert action. It will be used to trigger or prevent an action.

      postUpdate

      It will be triggered just after the update action. It will be used to trigger or prevent an action.

      postDelete

      It will be triggered just after the delete action. It will be used to trigger or prevent an action.

      preSetPassword

      It will be triggered just after the set password action. It will be used to trigger or prevent an action.

      postSetPassword

      It will be triggered just after the set password action. It will be used to trigger or prevent an action.

      Example 1

      Get the attribute company option 1:

      company = source{"attributes"}{"company"};

      Get the attribute company option 2

      userName = source{"userName"};
      attributes = serviceLocator.getUserService().findUserAttributes(userName);
      company = attributes.get("company");
      Example 2
      role = serviceLocator.getAplicacioService ().findRoleByNameAndSystem ( "Domain Users", "AcitveDirectory");
      rg = new java.util.HashMap();
      rg.put ("grantedRoleId", role.getId ());
      
      list = new java.util.LinkedList ();
      list.add (rg);
      newObject{"ownedRoles"} = list;
      
      return newObject{"name"} != null
      Example 3
      if (oldObject.get("userPrincipalName") != null)   {
      	newObject.remove("userPrincipalName");   
          newObject.put("groupType", oldObject{"groupType"});
      }

      For more examples, you can visit the Incoming Triggers examples page.

      Load triggers

      On the Load trigger tab, it is allowed to set up a specific configuration for the agent and define BeanShell scripts that will be triggered when data is loaded into Soffid (incoming triggers).

      To add a new trigger, it is mandatory first of all, to select a Soffid object on which the action will be performed. Then to select the trigger, that determines the moment at which the script will be triggered. Finally, define the BeanShell script that will be executed. The available objects are the following:

      Triggers can be used to validate or perform a specific action just before performing an operation or just after performing an operation into Soffid objects. The trigger result will be a boolean value, true to continue or false to stop.

      In a Load Trigger, it is not possible to access to mapping definitions configured on the attribute mapping tab. It will be necessary to use newObject{"attributeName"} to get the new value, or oldObject{"attributeName"} to get the old value. Those objects will be in Soffid format.

      For more info about the Soffid format, you can visit the Soffid Objects page.

      Trigger

      preInsert

      It will be triggered just before the insert action. It will be used to validate or prevent the insert action.

      preUpdate

      It will be triggered just before the update action. It will be used to validate or prevent update an object.

      preDelete

      It will be triggered just before the delete action. It will be used to validate or prevent delete an object.

      postInsert

      It will be triggered just after the insert action. It will be used to trigger or prevent an action.

      postUpdate

      It will be triggered just after the update action. It will be used to trigger or prevent an action.

      postDelete

      It will be triggered just after the delete action. It will be used to trigger or prevent an action.

      Example 1
      userName = newObject {"userName"};
      system = "ActiveDirectory";
      
      accounts = serviceLocator.getAccountService()
        .findAccountByJsonQuery("(system eq \"" + system + "\") AND name eq \"" + userName + "\" AND (type eq \"I\")");
      .....
      user = serviceLocator.getUserService().findUserByUserName(userName);
      .......
      Example 2
      ...........
      if (isFound) {
        newObject{"id-indicator"} = "1";
      } else {
        if (contFalse > 0) {
          newObject{"id-indicator"} = "0"; 
        } else if (contNull > 0) {
          newObject{"id-indicator"} =  null;
        } 
      } 
      

      For more examples, you can visit the Outgoing Triggers examples page.

      Massive actions

      Provisioning all users on to managed systems

      One of the main features of identity and access management (IAM) is automated user provisioning.  User provisioning is the process that ensures the users are created, with proper permissions, updated, disabled, or deleted on to managed systems.

      All managed systems must have an agent configuration, which will determine the way to perform the provisioning.

      Soffid shows information about the last time that the option was run and a report with the details. You can access the report by clicking the verification icon (✓).

      Propagate groups to agent

      This option allows pushing to the managed system all the defined groups in Soffid. 

      Soffid shows information about the last time that option was run and a report with the details. You can access the report by clicking the verification icon (✓).

      Reconcile (load target system objects)

      The main purpose of reconciling process is to provide a mechanism to ensure that all users are aligned on the specific roles and responsibilities. Reconcile process discovers new, changed, deleted, or orphaned accounts to determine user access privileges.

      Not every system connector has the capabilities needed to execute the reconcile process.

      When "Read only" property, in Basic parameters, is checked (selected value is Yes), the reconcile process only considers unmanaged accounts. 

      Soffid shows information about the last time that the option was run and a report with the details. You can access the report by clicking the verification icon (✓).

      Load authoritative data for identities and groups

      Identities use to live on authoritative identity sources and they do in Soffid as well. Each identity may have any number of accounts on each managed system.

      When "Authoritative identity source" is checked (option selected is Yes) Soffid will show the option that allows the load authoritative data for identities and groups. 

      That option performs the operations to load data of groups and data of identities from the managed system into Soffid,  following the rules configured in the agent.

      Soffid shows information about the last time that the option was run and a report with the details. You can access to the report by clicking the verification icon (✓).

      Also, Soffid creates a parameter on the Soffid parameters page, with information about the version of the data. If you need to perform the load authoritative action, it will be mandatory to delete this parameter before perform the action.

      Generate target system potential impact

      That option allows you to generate a report with all the potential changes that would be performed on the managed system with the current agent configuration

      If that option was performed previously, Soffid will show information about the last time that the option was run and the report with the potential impact. You can access the report by clicking the verification icon (✓).

      Account metadata

      Agents allow you to create additional data, on the "Account metadata" tab, to customize the accounts created for that agent. This additional information will be loaded with the agent's information, or calculated as defined in the mappings.
      The additional data can be used in both mappings and triggers.

      To get the Account Metadata value, or to put value, you need to use accountAttributes{"ATT_NAME"}

      Standard attributes

      Example 1

      Into the attribute mappings save the value of account metadata:

      varX <= accountAttributes{"att_name"}
      Example 2

      Get the value from the attribute account metadata to use it into a trigger

      strValue = source.get("attributes").get("att_name");
      if (strValue != null) {
      	.....
      	.....
      } else {
      	.....
          .....
      }

      Actions

      Agents query actions

      Query

      Allows you to query roles through different search systems, Basic and Advanced.

      Add new

      Allows you to add a new agent to the system. You can choose that option on the hamburger menu or click the add button (+).

      To add a new role it will be mandatory to fill in the required fields

      Delete

      Allows you to remove one or more agents by selecting one or more records and next clicking the button with the subtraction symbol (-).

      To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Download CSV file

      Allows you to download a CSV file with the basic information of all agents. 

      Agent detail actions

      Apply changes

      Allows you to create a new agent or update an existing agent. To save the data it will be mandatory to fill in the required fields

      Preview changes

      When there are some changes to be applied (when the configuration agent is updated), you can check them with this option. If you click this button, Soffid will display a new window with the list of users to be updated.

      Apply now

      When the configuration agent is updated, this button will be displayed. If you click this option the update action will be performed. The progress bar will be displayed during the execution of the process. 

      This action is performed asynchronously.

      Delete

      Allows you to delete a specific agent. You can choose that option on the trash icon.

      To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Undo

      Allows you to quit without applying any changes made.

      Import

      Allows you to upload an XML file with the attribute mapping data. This option deletes previous attribute mappings and creates new attribute mapping.

      Export

      Allows you to export an XML file with attribute mappings.

      Create default mapping

      Allows you to create automatically default mappings for the specific Type selected.

      Test

      Check if there is a connection to the target system.

      Integration flows

      Open flow

      Opens a window with the workflow.

      Test

      Allows you to test the workflow.

      Attribute mapping

      Apply changes/Save

      Allows you to update the agent with the changes made on Attribute mappings.

      Add System Objects

      Allows you to add a new system object based on a Soffid object. You need to click the button with the add symbol (+) located at the end of the row of System Objects. Once you click the button, Soffid adds new fields to the form to add new attributes, properties, and/or Triggers depending on the agent type.

      It is mandatory to apply changes by clicking the diskette button to update the agent.

      Delete System Objects

      Allows you to delete a system object. You need to click the button with the subtraction symbol (-) located at the end of the row system object which you want to delete.

      It is mandatory to apply changes by clicking the diskette button to update the agent.

      Add Property

      Allows you to add properties to a specific system object. You need to click the button with the add symbol (+) located at the end of the row of Properties. Once you click the button, Soffid adds new fields to the form to add the property.

      It is mandatory to apply changes by clicking the diskette button to update the agent.

      Delete Property

      Allows you to delete properties from a specific system object. You need to click the button with the subtraction symbol (-) located at the end of the row property which you want to delete.

      It is mandatory to apply changes by clicking the diskette button to update the agent.

      Add System attribute

      Allows you to add attribute mappings to a specific system object. You need to click the button with the add symbol (+) located at the end of the row of the System attribute. Once you click the button, Soffid adds new fields to the form to add the attribute.

      It is mandatory to apply changes by clicking the diskette button to update the agent.

      Detele System attribute

      Allows you to delete attribute mappings of a specific system object. You need to click the button with the subtraction symbol (-) located at the end of the row System attribute which you want to delete.

      It is mandatory to apply changes by clicking the diskette button to update the agent.

      Test expression

      Allows you to test a system object. When you click that option, Soffid will show you new fields and operations to test the system attribute config.

      Synchronize now

      Allows you to synchronize a specific system object to the target system.

      Fetch system raw data

      Brings the data of a specific system object from a target system.

      Fetch Soffid object

      Brings the data of a specific system object with processed data to update into Soffid

      Add Trigger

      Allows you to add a trigger to a specific system object that will be executed when data is loaded into a target system. You need to click the button with the add symbol (+) located at the end of the row of Trigger. Once you click the button, Soffid adds new fields to the form to add the trigger.

      It is mandatory to apply changes by clicking the diskette button to update the agent.

      Delete Trigger

      Allows you to delete a trigger of a specific system object. You need to click the button with the subtraction symbol (-) located at the end of the row Trigger which you want to delete.

      It is mandatory to apply changes by clicking the diskette button to update the agent.

      Load triggers

      Apply changes

      Allows you to update the Load trigger data with the changes made on the Load Trigger

      Add Trigger

      Allows you to add a trigger that will be executed when data is loaded into Soffid.

      You need to click the button with the add symbol (+) located at the end of the row. Once you click the button, Soffid adds new fields to the form to add the trigger. Then you need to select the Object and the type of trigger and write the customized script.

      Finally, you need to apply changes to update the agent.

      Delete Trigger

      Allows you to delete a trigger. You need to click the button with the subtraction symbol (-) located at the end of the row which you want to delete.

      It is mandatory to apply changes by clicking the diskette button to update the agent.

      Massive actions

      Provisioning all users on to managed systems

      Run the process to ensure the users are created, with proper permissions, updated, disabled, or deleted on to managed systems.

      Propagate groups to agent

      Run the process to push all the groups of Soffid into the managed system.

      Reconcile (load target system objects)

      Run the process to discover new, changed, deleted, or orphaned accounts to determine user access privileges.

      Load authoritative data for identities and groups

      Run the process to load data of groups and data of identities from the managed system into Soffid

      Generate target system potential impact

      Generate a report with all the potential changes that would be performed on the managed system.

      Account metadata

      Add account metadata

      Allows you to update the agent with the changes made on metadata.

      Add account metadata

      Allows you to add account metadata. You need to click the button with the add symbol (+) located at the end of the row. Once you click the button, Soffid shows you an empty form to fill in with the new account metadata.

      Finally, you need to apply changes.

      Delete account metadata

      Allows you to delete one account metadata. First, you need to click on the account metadata which you want to delete. Then Soffid shows a form with the detailed account metadata. On the hamburger icon of that form, you can find the delete action. 

      In this case, Soffid will not ask you for confirmation to delete.



      Scripting

      In the agent's configuration, it may be possible to use scripting to include logic in the attribute mappings and in the trigger scripts.

      In the attribute mapping, if you use a script on one side, it will be mandatory to a single direction to the other side:

      Below, an easy script to send a full name to the system:

      system attribute <= return firstName + lastName;

      Below, a more complex script to create the main domain if it doesn't exist in Soffid:

      String mailDomain = null;
      if (email != void && email != null && email.contains("@")) {
          String[] mailTokens = email.split("@");
          mailDomain = mailTokens[1];
      }
      com.soffid.iam.service.MailListsService service = com.soffid.iam.ServiceLocator.instance().getMailListsService();
      com.soffid.iam.api.MailDomain domain = service.findMailDomainByName(mailDomain);
      if (domain==null) {
          domain = new com.soffid.iam.api.MailDomain();
          domain.setCode(mailDomain);
          domain.setDescription(mailDomain);
          domain.setObsolete(new Boolean(false));
          domain = service.create(domain);
      }
      return mailDomain;
       
      => mailDomain

      You could find a set of sample scripts: Sample scripts

      You could find a link with the SCIM Query Language used in some methods as findUserByJsonQuery("query"). You can visit the SCIM chapter.

      Below you could find a set of custom utility classes: Utility classes


      More information

      Password synchronization

      The passwords a user has on an agent will be synchronized with any other "single user account" the user has on this agent. Shared accounts will never get their password synchronized.

      Password in an agent will be also synchronized with any other account the user has on other agents that are sharing the same password domain.

      The password change can be produced by an operator using the Soffid console, the user itself using the Soffid Self Service portal, or a timed automatic task. Furthermore, some managed systems can forward their password to Soffid in order to get them synchronized. In order to accept these password changes coming from managed systems, the trusted passwords box must be checked for the source agent.

      Mind that this is the flow for normal user passwords. Temporary passwords generated by the Soffid console will only be sent to agents marked as trusted. Agents not checked as trusted will have a random new password instead. Later, when the user changes the password on Soffid or any trusted system, the new password will be notified to Soffid by the managed system, and every agent on the same password domain will actually get the new password.

      Agents account management

      The agent configuration sets the way accounts are created and disabled.

      Whenever a user is modified, the following rules will be applied to check if the user should have or not an account on this agent:

      1. The user type is checked against valid user types.
      2. If there is a business unit or group bound to the agent, the user membership will be assessed.
      3. If the role based box is checked, the system will verify if the user has any role or entitlement assigned to this agent.

      If the user does not apply for any of the conditions, every account the user has at this agent will be changed to Disabled status.

      If the user verifies every one of the conditions, the user can have an account on this agent. Every account the user has at this agent will be changed to Enabled status.

      Unless the "Manual account creation" is checked, if the user can have an account on this agent, but it has no one, the account creation method will be invoked. To create it, Soffid will search for the user domain bound to this agent and will follow its configuration. If the user domain is configured with a script, this script will be executed and the result value will be accepted as the new account name. Mind that if the script returns a null value, no account can be created. 

      If the returning value from the script clashes with an existing account, the existing account will remain unchanged, unless the existing account is marked as an unmanaged account. In such a case, the account will be changed from an unmanaged state to a single user.


      Operational

      Monitoring

      After the agent configuration you could check on the monitoring page if the service is running in the Synchronization Server, please go to:

      Main Menu > Administration > Monitoring and reporting > Syscserver monitoring

      Tasks

      Authoritative

      If you are checked "Authorized identity source", an automatic task to load identities from the managed system to Soffid is available, please go to:

      Main Menu > Administration > Monitoring and reporting > Scheduled tasks

      And you will something like "Import authoritative data from <AGENT_NAME>".

      image-1659012997074.png

      You can also run the Authoritative load from the Massive actions tab in the Agent

      image-1659013094703.png

      Reconcile

      If you are configured the "Attribute Mapping" tab with some of our objects: "user, account, role, group or grant", an automatic task to synchronize these objects from the managed system to Soffid is available, please go to:

      Main Menu > Administration > Monitoring and reporting > Scheduled tasks

      And you will do something like "Reconcile all accounts from <AGENT_NAME>".

      image-1659013025873.png

      You can also run the Reconcile from the Massive actions tab in the Agent

      image-1659013126808.png

      Synchronization

      Regarding the synchronization of the objects, there are two possible options:




      Integration Engine

      Synchronization servers

      Description

      Sync server is the engine responsible for connecting Soffid with data sources or managed systems.

      Soffid allows you to configure different synchronization servers. These synchronization servers are installed and configurated using command line tool. 

      More information about how to install sync server on the Installation chapter. Here you can find information on how to install a sync server in different environments.

      Whenever an action is performed on any Soffid object, a synchronization task is created in Soffid database.

      Initially, most of the tasks should be forwarded to every managed system connector. The specific system connector will be responsible for applying (or ignoring) the task to the managed system.

      The normal synchronization server flow for a task is as follows:

      1. Engine timely reads pending tasks table (SC_TASQUE). To avoid two sync servers to process the same task, the column TAS_SERVER is updated to reflect the actual server that is processing it.

      2. Engine manage tasks priorities and updates the task queue. Engine keeps track of one task queue for each managed system connector.

      Soffid allows you to configure the parameter soffid.sync.engine.threads with the number of threads available to run the tasks.

      For more information about this parameter you can visit the Soffid Parameter page.

      3. Engine has created some execution threads to forward each task to the specific connector class. During this process, dispatcher can decide to reject (mark as done) the task without forwarding it.

      4. The specific connector class gets additional information about the task from core services.

      5. Task is removed from database when every dispatcher has done it.

      This architecture and its optimized engine allow Soffid to achieve great performance.

      Screen overview

      image-1641823484543.png


      image-1641823523641.png

      Standard attributes

      If you change the Java Options of an existing Syncserver, you will need to restart the Syncserver.  You can visit the Sync server monitoring page for more information about how to restat the Syncserver.

      If you are working on Soffid Console version 2.x to change the capacity you need to edit the iam-console.vmoptions file and change the -Xmx attribute.

      Actions

      Synchronization server query

      Download CSV file

      Allows you to download a CSV file with the  information of all synchronization servers. 

      Synchronization server detail

      Apply changes Allows you to save the synchronization server data and quit.
      Save Allows you to save the synchronization server data
      Undo Allows you to undo the changes to quit without save them.
      Delete

      To delete a sync server you can click on the hamburger icon and then click the delete button (trash icon).

      Soffid will ask you for confirmation to perform that action, you could confirm or cancel the operation.


      Integration Engine

      Account naming rules

      Definition

      Account naming rules define how to generate account names to connect with final systems. The normal case is the account name will be the same as the user name, in other cases, here you could define the customized account name rules.

      When you are configuring an agent, you have to indicate the user domain which will be used to create new accounts, that user domain refers to the Account naming rules defined on the Soffid console. You can visit the Agents page for more information.

      Standard attributes


      Create account condition

      The create account condition enables or prevents the creation of the account.

      Available objects
      user User object: Details
      attributes User attributes map
      groups

      The groups that the user belongs to.

      It's composed of a java map. The key is the group name, and the value is the Group object

      groupsList

      The groups that the user belongs to.

      It's composed of a java list of Group objects

      serviceLocator Helper to get access to Soffid microservices
      userDomain User domain object
      system Target system object
      Expected result
      boolean Return true if the account can be created
      Examples

      Only users with mail address in soffid.com can have an account:

      "soffid.com".equals(user.mailDomain)



      Account name Script

      The create account script computes the name to assign to the user account. If the script returns null, the account is not going to be created.

      Available objects
      user User object: Details
      attributes User attributes map
      groups

      The groups that the user belongs to.

      It's composed of a java map. The key is the group name, and the value is the Group object

      groupsList

      The groups that the user belongs to.

      It's composed of a java list of Group objects

      serviceLocator Helper to get access to Soffid microservices
      userDomain User domain object
      system Target system object
      Expected result
      String Return the account name to use
      Example
      // Uses the email address as the account name
      user.shortName+"@"+user.mailDomain

      Actions

      Account naming rules query

      Add new

      Allows you to add a new account naming rule in the system. To add a new agent it is necessary to fill in the required fields.

      Delete

      Allows you to remove one or more agents by selecting one or more records on the list.

      Export

      Allows you to export a CSV file with the account naming rules configuration.

      Import

      Allows you to upload a CSV file with the account naming rules configuration to add new rules to the system.

      First, you need to pick up a CSV file, that CSV has to contain a specific configuration. Then you need to check the contents. And finally, you need to select the mappings for each column of the CSV file to import the data correctly and click the Import button.

      Account naming rules detail

      Apply changes

      Allows you to save new account naming rules or to save an updated account naming rule.

      Undo

      Allows you to undo any changes made.

      Delete

      Allows you to remove one account naming rule.


      Integration Engine

      Attribute translation tables

      Definition

      Soffid provides an easy to use mechanism to translate references or external codes into internal codes. For example, the HHRR application could be using a diferent coding scheme for business units.

      To deal with this data mismatch, users can extend the data model, or can either use translation tables. This screen allows the user to create and maintain such tables. This tables can also be downloaded or uploaded as CSV files, enable the import of data contained into spreadsheets.

      Usage of translation table is bound, but not restricted to, attribute translation expressions, by using trigger scripts, through the use of serverService interface

      Standard attributes

      Column 1 to 5 meaning is user defined. Usage of translation table is bound, but not restricted to, attribute translation expressions, through the use of serverService interface.

      Actions

      Query

      Allows to query groups through different search systems, Quick, Basic and Advanced.

      Add new

      Allows you to add a new attribute translation table. That option adds a new row on the table to fill in the data. It will be mandatory to apply changes to save the data.

      Delete

      Allows you to remove one or more agents by selecting one or more records on the list. Or delete one by one.

      Import

      Allows you to upload a CSV file with the attribute translation table data to add to the system.

      First, you need to pick up a CSV file, that CSV has to contain a specific configuration. Then you need to check the contents. And finally, you need to select the mappings for each column of the CSV file to import the data correctly and to click the Import button.

      Download CSV file

      Allows you to download a CSV file with the information of all attribute translation tables.

      Apply changes

      Allows you to save new attribute translation tables or to save updated attribute translation tables.

      Undo

      Allows you to undo any changes made.


      Integration Engine

      Soffid Objects


      You can consult the list of Soffid attributes:

      1. User Object
      2. Account Object
      3. Group Object
      4. Role Object
      5. Grant Object
      6. Maillist Object
      7. Membership Object
      8. dispatcherService
      9. Authoritative change object

      User object

      A user objects are maps that hold the information belonging to a single user account.

      Attribute
      Type
      Description
      id Long user id
      accountId Long account id
      accountName String account name
      system String managed system (agent) name
      accountDescription String account description
      active Boolean true if user is active
      accountDisabled Boolean true if account is diabled
      mailAlias String blank separated mails
      userName String user name
      primaryGroup String user's primary group name
      comments String user's comments
      createdOn Date user creation date
      modifiedOn Date user last modification date
      mailDomain Date user mail domain ( email right side of @)
      fullName String user full name
      shortName String user mail name (email left side of @)
      firstName String user first name
      lastName String user last name
      lastName2 String user second last name (when applicable)
      mailServer String mail server host name
      homeServer String home drive server host name
      profileServer String roaming profile server host name
      phone String user's phone number
      userType String user type
      createdBy String user name creator of this user
      modifiedBy String user name modifier of this user
      secondaryGroups List<Map<String,Object>>

      list of groups the user belongs to, including primary group

      The attributes of the inner map are described later

      attributes Map<String,String> additional user attributes
      grantedRoles List<Map<String,Object>> list of grants directly granted to the user
      allGrantedRoles List<Map<String,Object>> list of grants directly on indirectly granted to the user
      granted List<String> list of role names and group names directly granted to the user
      allGranted List<String> list of role names and group names directly or indirectly granted to the user

      Account object

      An account object holds the information belonging to an account.

      Attribute
      Type
      Description
      accountDescription String account description
      accountDisabled Boolean true if account is diabled
      accountId Long account id
      accountName String account name
      allGranted List<String> list of role names directly or indirectly granted to the user
      allGrantedRoles List<Map<String,Object>> list of grants directly on indirectly granted to the user
      attributes Map<String,String> additional account attributes
      granted List<String> list of role names directly granted to the user
      grantedRoles List<Map<String,Object>> list of grants directly granted to the user
      lastLogin Calendar lastLogin
      lastPasswordUpdate Calendar lastPasswordUpdate
      lastUpdate Calendar lastUpdate
      passwordExpiration Calendar passwordExpiration
      passwordPolicy String password policy
      system String managed system (agent) name
      type AccountType "U"=user, "S"=shared, "P"=privileged, "I=ignored

      Group object

      An group object holds the information belonging to a group.

      Attribute
      Type
      Description
      groupId Long group id
      name String group name
      description String group description
      parent String parent group name
      server String home server host name
      disabled boolean true if the group is disabled
      accountingGroup String group accounting information
      type String group type
      driveLetter String home server letter to connect to
      users List<Map<String,Object>> list of users belonging to this group
      userNames List<String> list of user names belonging to this group
      allUsers List<Map<String,Object>> list of users directly or indirectly belonging to this group
      allUserNames List<String> list of user names either directly or indirectly grantee of this role
      grantedRoles List<Map<String,Object>> list of roles granted to this group
      grantedRoleNames List<String> list of role names granted to this group

      Role object

      An role object holds the information belonging to a role.

      Attribute
      Type
      Description
      roleId Long role id
      system String managed system (agent) name
      name String role name
      application String application system name
      category String role category
      passwordProtected boolean true if role should be password protected (where applicable)
      description String Role description
      wfmanaged boolean true if role should be displayed in self service requests
      domain String custom domain for this role: Use com.soffid.iam.api.DomainType constants or configured custom domain
      ownedRoles List<Map<String,Object>> list of roles granted to this one
      ownerRoles List<Map<String,Object>> list of roles grantee of this one
      ownerGroups List<Map<String,Object>> list of groups grantee of this role
      grantedAccountNames List<String> list of account names directly grantee of this role
      grantedAccounts List<Map<String,Object>> list of users directly grantee of this role
      allGrantedAccountNames List<String> list of account names either directly or indirectly grantee of this role
      allGrantedAccounts List<Map<String,Object>> list of users either directly or indirectly grantee of this role
      attributes Map<String,Object> role's custom attributes

      Grant object

      Grant, grantedRole & allGrantedRoles

      The objects grant, grantedRole and allGrantedRoles are used to assing roles to accounts and roles.

      Attribute
      Type
      Description
      domainValue String grant value (if any)
      grantedRole String granted role name
      grantedRoleId Long granted role id
      grantedRoleObject role object granted role
      grantedRoleSystem String granted role managed system (agent) name
      id Long grant id
      ownerAccount String grantee account name
      ownerAccountObject account object grantee account
      ownerGroup String grantee group name
      ownerRoleId String grantee role id
      ownerRoleName String grantee role name
      ownerSystem String grantee account or role managed system name
      ownerUser String grantee user name

      Examples

      Grant

      Example to map a grant object (assign a role to an account):

      System attribute
      Direction
      Soffid attribute
      role_name => grantedRole
      account_name => ownerAccount
      GrantedRole

      Example to map a grantedRole object (assign a role as a child of another role):

      System attribute
      Direction
      Soffid attribute
      role_name => grantedRole
      parent_role_name => ownerRoleName
      AllGrantedRoles

      Example to map a allGrantedRoles object in a holderGroup (assign a role to an account in a specific group):

      System attribute
      Direction
      Soffid attribute
      role_name => grantedRole
      parent_role_name => ownerRoleName
      group_code => domainValue
      group_code => holderGroup
      userName => ownerUser

      Maillist object


      Attribute
      Type
      Description
      id Long internal mail list id
      name String mail list name ( the initial part, before the @ sign)
      domain String mail list domain ( the remaining part after the @ sign)
      system String managed system (agent) name
      description String mail list description
      users String array user names that are bound to this mail list
      groups String array group names thta are subscribed to this mai list
      roles String array role names that grant access to this mail list
      lists String array Nested mail lists
      explodedUsers String array Names of the users that should be subscribed to this mail list, including the users that should be subscribed due to group or role membership
      explodedUserAddresses String array Mail addresses of any exploded User

      Membership object

      A membership object contains the user account information as well as the group the user belongs to.

      Attribute
      Type
      Description
      userName String User name
      user Map<String,Object> user object
      groupName String Group name
      group Map<String,Object> group object
      attributes Map<String,Object> Membership custom attributes

      dispatcherService

      dispatcherService is an object available from agents' attribute translation rules.

      This object contains four methods:

      method name
      parameters
      result type
      comments
      soffidToSystem ExtensibleObject soffidObject ExtensibleObject

      Uses attribute translation tables to transform a soffid object to a target system object.

      Mind to fill-in objectType property to use the proper object mapping

      systemToSoffid ExtensibleObject systemObject ExtensibleObject

      Uses attribute translation tables to transform a target system object to a Soffid object.

      Mind to fill-in objectType property to use the proper object mapping

      search ExtensibleObject exampleObject ExtensibleObject

      Uses the exampleObject to perform a query by example on the target system. If the object exists on the target system, it is returned.

      Mind to fill-in objectType property with the desired system object type

      invoke

      String verb

      String action

      Map parameters

      List of Map

      This method allows arbitrary executions on the target system, but it semantics can change depending on the connector used.

      For instance, it can be used to perform a GET on the target system in REST connector, can issue an LDAP query on ActiveDirectory connector, can execute a SELECT sentence on a SQL connector, or can execute an operating system command in Shell connector.

      The results are returned as a list of objects (map).

      Examples

      Snippet to query the sys_id attribute for a grant owner
      System.out.println("Searching id for "+ownerRoleName);
      com.soffid.iam.sync.intf.ExtensibleObject eo = new com.soffid.iam.sync.intf.ExtensibleObject();
      eo.setObjectType("ROLE");
      eo{"name"} = ownerRoleName;
      eo = dispatcherService.search(eo);
      System.out.println("FOUND "+eo{"sys_id"});
      return eo{"sys_id"};
      Snippet that performs a REST query to get group to role assignments in ServiceNow
      list = dispatcherService.invoke ("GET",
        "https://arxusdev.service-now.com/api/now/table/sys_group_has_role?sysparm_exclude_reference_link=true&amp;sysparm_display_value=all&amp;sysparm_fields=role%2Cgroup&amp;sysparm_query=group="+sys_id,
        null).
        get(0).get("result")
        
      r = new java.util.LinkedList();
      for ( d: list)
      {
        grant = new java.util.HashMap();
        grant{"grantedRole"} = d.get("role").get("display_value");
        grant{"grantedRoleSystem"} = "ServiceNow";
        grant{"ownerRoleName"} = name;
        grant{"ownerSystem"} = "ServiceNow";
        r.add  (grant);
      }
      return r;
      Snippet of invoke usage on a relational database
      // Table ITREPRT
      role = source{"granted"}.size() == 0 ? "" : source{"granted"}.get(0);
      System.out.println ("************** ROLE "+role);
      args = new java.util.HashMap();
      args.put("user", source{"accountName"}.toUpperCase());
      if (role.equals ("Receptores PR") || role.equals("Jefes_Personal")) {
        r = dispatcherService.invoke("select", "* from ITREPRT where IDUSER=:user", args);
        if (r.size() == 0) {
          dispatcherService.invoke("insert", "into ITREPRT(IDUSER,NOMECO) values (:user, 1)", args);
        } 
      } else {
        dispatcherService.invoke("delete", "from ITREPRT where IDUSER=:user", args);
      }
      // TABLE MRGEUCT
      cc = source{"attributes"}{"dominio"};
      if ( source{"userType"} .equals ("T")) {
        cc = source{"userName"}.substring(1); 
      }
      while (cc != null && cc.startsWith("0")) cc = cc.substring(1);
      System.out.println ("************** COST CENTER "+cc);
      if (cc != null && ! cc.trim().isEmpty())
      {
        args = new java.util.HashMap();
        args.put("user", source{"accountName"}.toUpperCase());
        args.put("cc", cc);
        r = dispatcherService.invoke("SELECT", "* from MRGEUCT where IDUSER=:user and MOARPR=:cc", args);
        if (r.size() == 0) {
          dispatcherService.invoke("INSERT", "into MRGEUCT(MOARPR,CENTRA, IDUSER, NOTIFI ) "+
                                   "values ('II', :cc, :user, 'S')", args);
          dispatcherService.invoke("INSERT", "into MRGEUCT(MOARPR,CENTRA, IDUSER, NOTIFI ) "+
                                   "values ('BM', :cc, :user, 'S')", args);
          dispatcherService.invoke("DELETE", "FROM MRGEUCT WHERE CENTRA!=:cc AND IDUSER=:user", args);
        } 
      }
      return true;

      Authoritative change object

      A user objects are maps that hold the information belonging to a single user account

      Attribute
      Type
      Description
      id Long user id
      accountId Long account id
      accountName String account name
      system String managed system (agent) name
      accountDescription String account description
      active Boolean true if user is active
      accountDisabled Boolean true if account is diabled
      mailAlias String blank separated mails
      userName String user name
      primaryGroup String user's primary group name
      comments String user's comments
      createdOn Date user creation date
      modifiedOn Date user last modification date
      mailDomain Date user mail domain ( email right side of @)
      fullName String user full name
      shortName String user mail name (email left side of @)
      firstName String user first name
      lastName String user last name
      lastName2 String user second last name (when applicable)
      mailServer String mail server host name
      homeServer String home drive server host name
      profileServer String roaming profile server host name
      phone String user's phone number
      userType String user type
      createdBy String user name creator of this user
      modifiedBy String user name modifier of this user
      secondaryGroups List<Map<String,Object>>

      list of groups the user belongs to, including primary group

      The attributes of the inner map are described in the link

      secondariGroups2 List<Map<String,Object>>

      list of user memberships, excluding primary group

      The attributes of the inner map are described link

      attributes Map<String,String> additional user attributes
      grantedRoles List<Map<String,Object>> list of grants directly granted to the user
      allGrantedRoles List<Map<String,Object>> list of grants directly on indirectly granted to the user
      granted List<String> list of role names and group names directly granted to the user
      allGranted List<String> list of role names and group names directly or indirectly granted to the user
      Integration Engine

      Sample scripts

       

      Note that Soffid supports different scripting languages, you can configure it in the Smart engine settings screen.

      Additionally, in the initial configuration of the container, we can configure the SOFFID_TRUSTED_SCRIPTS environment variable to allow the use of insecure classes.  You can find this information visiting the Installing IAM Console page.

      Table of contents

      1. Agent scripts
      2. Identity scripts
      3. Account scripts
      4. Role scripts



      Agent scripts

      User full name

      return firstName + lastName;

      Create mainDomain if it doesn't exit

      String mailDomain = null;
      if (email != void && email != null && email.contains("@")) {
          String[] mailTokens = email.split("@");
          mailDomain = mailTokens[1];
      }
      com.soffid.iam.service.MailListsService service = com.soffid.iam.ServiceLocator.instance().getMailListsService();
      com.soffid.iam.api.MailDomain domain = service.findMailDomainByName(mailDomain);
      if (domain==null) {
          domain = new com.soffid.iam.api.MailDomain();
          domain.setCode(mailDomain);
          domain.setDescription(mailDomain);
          domain.setObsolete(new Boolean(false));
          domain = service.create(domain);
      }
      return mailDomain;

      Recover active agents

      llistaAgents =  serviceLocator.getDispatcherService().findAllActiveDispatchers();
      for(agent:llistaAgents) {
        out.println("Nom: " + agent.name);
        out.println("Class Name: " + agent.className + "\n");
      }

      Show by a user the agents that have associates

      llistaUsuaris = serviceLocator.getUserService().findUserByJsonQuery("userName eq \"Ivan\" ");
      for(usuari:llistaUsuaris) {
        out.println("Usuario: " + usuari.userName);
         
         llisstacuentas = serviceLocator.getAccountService().findAccountByJsonQuery("users.user.userName eq \""+usuari.userName+"\" ");
         
        for(cuenta:llisstacuentas){
          out.print("   Cuenta : " + cuenta.name);
          out.println("   ID: " + cuenta.id);
          llistaRole = serviceLocator.getApplicationService().findRoleAccountByAccount(cuenta.id);
           
          for(role:llistaRole){
            out.print("      Role: " + role.roleName + "\n");
            out.println("          Aplicacion: " + role.informationSystemName);
            out.println("             Agente: " + role.system);
          }
        }
      }

      Identity scripts

      Recover a user for userName

      u = serviceLocator.getUserService().findUserByUserName("Ivan");
      out.print("Usuari: " + u.firstName);

      Recover a users from a Jquery

      llistaUsuari = serviceLocator.getUserService().findUserByJsonQuery("firstName sw \"A\" AND lastName sw \"V\" ");
      for (usuari:llistaUsuari){ 
          out.println("Usuari: " + usuari.userName);
      }

      Print some attributes

      u = serviceLocator.getUserService().findUserByUserName("02");
      out.println("UserName: " + u.userName);
      out.println("Name: " + u.firstName);
      out.println("LastName: " + u.lastName);

      Print by user the email

      u = serviceLocator.getUserService().findUserByUserName("02");
      out.print("Email: " + u.shortName + "@" + u.mailDomain);

      Print by user some additional data

      llistaDadesUsuari = serviceLocator.getUserService().findUserDataByUserName("18008366X");
      for(dadaUsuari:llistaDadesUsuari){
        out.println("Atributs " + dadaUsuari.attribute + " = " + dadaUsuari.value);
      }

      Create a new identity

       try {
       newUser = new com.soffid.iam.api.User();
      //Instanciar un nuevo objeto de tipo usuario
        
       newUser.userName = "IvanVis"; //Faltan 6 parametres
       newUser.firstName = "Ivannn";
       newUser.lastName = "Visarttt";
       newUser.userType = "I";
       newUser.profileServer = "null" ;
       newUser.homeServer = "null" ;
       newUser.mailServer = "null" ;
       newUser.primaryGroup = "world";
       newUser.active = true;
        
       serviceLocator.getUserService().create(newUser);
      }catch(Exception e){
       e.printStackTrace(out);
      }

      Update an identity

      u = serviceLocator.getUserService().findUserByUserName("Ivan");
      u.firstName = "Ivaaan1";
      u = serviceLocator.getUserService().update(u);
      out.print(u.firstName);
      out.print(u.userName);

      Delete an identity

      try {
        u = serviceLocator.getUserService().findUserByUserName("02");
        serviceLocator.getUserService().delete(u);
      } catch(Exception e) {
          e.printStackTrace(out);
      }

      Account scripts

      Recover accounts of user

      la = serviceLocator.getAccountService().findAccountByJsonQuery("users.user.userName eq \"02\" ");
      for(a:la) {
        out.println("Cuenta: " + a.name);
        out.println("ID: " + a.id);
        out.println("System: " + a.system + "\n");
      }

      Remove attribute values of a metadata

      public void removeUnAttributeValues(String attribute, String system) {
        la = serviceLocator.getAccountService().findAccountByJsonQuery("system eq \""+system+"\"");
        for (a : la) {
          laa = serviceLocator.getAccountService().getAccountAttributes(a);
          for (aa : laa) {
            if (aa.attribute.equals(attribute)) {
              if (aa.value!=null) {
                out.print("accountName: "+accountName+", attribute.value: "+aa.value);
                serviceLocator.getAccountService().removeAccountAttribute(aa);
                out.println(" ---> removed");
              }
            }
          }
        }
      }
      removeUnAttributeValues("manager","OSCM");

      Role scripts

      Recover roles of a user

      user = serviceLocator.getUserService().findUserByUserName("Ivan");
      out.println("Usuari: " + user.userName + "\n");
      rolsUser = serviceLocator.getUserService().findUserRolesHierachyByUserName(user.userName);
      for(listrRolsUser:rolsUser){
        out.println("Nombre: " + listrRolsUser.name);
        out.println("Descripcion: " + listrRolsUser.description);
        out.println();
      }

      Print the associated roles for each account

      llistaUsuaris = serviceLocator.getUserService().findUserByJsonQuery("userName eq \"Ivan\" ");
      for(usuari:llistaUsuaris){
         
         llisstacuentas = serviceLocator.getAccountService().findAccountByJsonQuery("users.user.userName eq \""+usuari.userName+"\" ");
         
        for(cuenta:llisstacuentas){
          out.print("   Cuenta : " + cuenta.name);
          llistaRole = serviceLocator.getApplicationService().findRoleAccountByAccount(cuenta.id);
           
          for(role:llistaRole){
            out.print("      Role: " + role.roleName + "\n");
          }
        }
      }

      Print for an account the roles and applications for each of them

      llistaUsuaris = serviceLocator.getUserService().findUserByJsonQuery("userName eq \"Ivan\" ");
      for(usuari:llistaUsuaris){
         
         llisstacuentas = serviceLocator.getAccountService().findAccountByJsonQuery("users.user.userName eq \""+usuari.userName+"\" ");
         
        for(cuenta:llisstacuentas){
          out.print("   Cuenta : " + cuenta.name);
          out.println("   ID: " + cuenta.id);
          llistaRole = serviceLocator.getApplicationService().findRoleAccountByAccount(cuenta.id);
           
          for(role:llistaRole){
            out.print("      Role: " + role.roleName + "\n");
            out.println("          Aplicacion: " + role.informationSystemName);
          }
        }
      }

      Print the roles associated with each account

      usuCuenta = serviceLocator.getUserService().findUserByJsonQuery("");
      for(listaUsuCuenta:usuCuenta) {
         
          out.println("Usuario: " + listaUsuCuenta.userName);
          out.println("Nombre: " + listaUsuCuenta.firstName);
         
          rolsUser = serviceLocator.getUserService().findUserRolesHierachyByUserName(listaUsuCuenta.userName);
           
          for(listaRolsUser:rolsUser){
            out.println("Nombre del Rol: " + listaRolsUser.name);
            out.println("Descripcion: " + listaRolsUser.description);
            out.println();
          }
        }
      }

      Create a new role

      try {
        newRol = new com.soffid.iam.api.Role();
        newRol.name = "Rol_New_Script";
        newRol.description = "Rol Script";
        newRol.informationSystemName = "SOFFID";
        newRol.system = "APLICACION01";
        serviceLocator.getApplicationService().create(newRol);
         
      } catch(Exception e){
          e.printStackTrace(out);
      }

      Update a role

      editRole = serviceLocator.getApplicationService().findRoleByJsonQuery("name eq \"Rol editado por script\" and informationSystemName eq \"APLICACION01\" ");
      for (role:editRole){
         
        out.println(role.name);
        role.name = "ROL01";
         
        role = serviceLocator.getApplicationService().update(role);
        out.print(role.name);
      }

      Delete a role

      try {
        editRole = serviceLocator.getApplicationService().findRoleById(232734);
        serviceLocator.getApplicationService().delete(editRole);
      } catch(Exception e){
          e.printStackTrace(out);
      }

      List the roles of an application

      list = serviceLocator.getApplicationService().findRoleByJsonQuery("informationSystemName eq \"SOFFID\"");
      for (role : list) {
        out.println(role.name);
      }


      Integration Engine

      Utility classes

      Crypt

      Crypt allows to encrypt text with different algorithms and verify the resulting hash.

      To use this class: com.soffid.iam.crypt.Crypt

      All methods are static:

      hash(String algorithm, String text) -> String
      pBKDF2Sha256(String text, String utf8Salt, int iterations) -> String
      pBKDF2Sha256(String text, byte []salt, int iterations) -> String
      pBKDF2Sha1(String text, String utf8Salt, int iterations) -> String
      pBKDF2Sha1(String text, byte []salt, int iterations) -> String
      genSaltBytes() -> byte[] // 8 bytes
      genSaltBytes(int size) -> byte[]
      genSalt() -> String // 8 bytes
      genSalt(int size) -> String
      verify(String algorithm, String text, String hash) -> boolean
      

      The algorithms allowed are:

      One example:

      String myText = "abcd";
      String myAlgorithm = "bcrypt";
      String myHash = com.soffid.iam.crypt.Crypt.hash(myAlgorithm, myText);
      boolean isVerified = com.soffid.iam.crypt.Crypt.verify(myAlgorithm, myText, myHash);
      if (isVerified) {
          return myHash;
      } else {
          return null;
      }

      CalendarConverter

      CalendarConverter allows to covert Calendar into String.

      To use this class: com.soffid.iam.json.CalendarConverter

      The methods (non static):

      toString(Calendar instance) -> String
      fromString(final String text) -> Calendar

      One example:

      out.println(new com.soffid.iam.json.CalendarConverter().toString(date));


      Integration Engine

      Network discovery

      Description

      The Network discovery tool will be in charge to scan the networks to find the hosts and retrieve information about user accounts. Network discovery can detect system accounts as well.

      First of all, you need to create the networks that you want to scan. Visit the Networks page for more information. Then, on the Network discovery page, you need to configure for each network, the accounts and passwords of potential administrators to connect to the host and retrieve the information. And finally, you need to start the process execution or you can schedule the execution of the network discovery task.

      The operating system of machines can be Windows or Linux and it is not necessary to install any additional software on those machines. 

      Once the machines and accounts, both user and system, have been discovered, the critical accounts must be located in the password vault. You can visit the Password vault page for more information.

      Screen overview

      Standard attributes

      Network attributes

      Basic 

      Those attributes are readOnly, you can update them on the Networks page.

      💻 Image

      image-1705573373643.png

      Server

      Accounts to probe

      When you register a new account, that will be created as an unmanaged account. 

      Schedule

      For each value of month, day, hour, minute, or day of the week:

      Current execution

      Last execution

      Previous executions

      List the information about the previous executions:

      Machine attributes

      💻 Image

      image-1705661256378.png

      Actions

      Network discovery query

      Add new account repository

      Allows you to create a new agent.

      You must select the System type and the login name and password. When the agent is created, if the connection is successful, the reconciliation process will be executed.

      💻 Image

      image-1701426264500.png

      Agent definition

      Allows you to browse to the agent definition.

      Accounts

      Allows you to browse the accounts page and the accounts, which belong to this system, will be displayed

      Add new entry point

      Allows you to create a new entry point. 

      You must select the Entry point type and the pale to locate it. Once the entry point is created, you can connect to the target system. Bear in mind, that if you need to create an account to connect, when you set the password to this account, the system (agent) must be in No ReadOnly mode.

      💻 Image

      image-1701426470540.png

      Entry point definition

      Allows you to browse to the entry point definition.

      Network discovery detail

      Apply changes

      Allows you to save the data of network detail. To save the data it will be mandatory to fill in the required fields.

      Undo

      Allows you to undo any changes made.

      Accounts to probe
      Add

      Allows you to add a new administrator potential account to connect to the machines of the network.  To add a new account, first of all, you need to click the add button (+) and close the accounts to probe list. Then you will need to choose if you want to add an existing account or register a new account.


      save the data of a new network or update the data of a specific network. To save the data it will be mandatory to fill in the required fields

      Delete

      Allows you to delete one or more accounts of the accounts to probe. You need to select one or more records and next click the button with the subtraction symbol (-).


      Schedule 

      Start now

      Allows you to launch the task execution.

      Previous execution

       Logs

      Allows you to download the log files of previous executions.

      Machine

       Delete

      Allows you to delete the machine and the PAM connectors for the device. Soffid will display a message to confirm the deletion process.

      Tools

      Tools

      Clear redundant roles

      Description

      A high level profile can contain or grant application permissions. On the other side, application permissions can contain or grant low level permissions. All of them are referred to generally as roles.

      Some users could have been granted both high level profiles and application permissions or low level permissions.

      In that case, low level roles can be removed from the Soffid database, as they are inherited through role inheritance rules.

      This tool identifies any low level roles granted to users at the same time that its owner high level role, and removes them.

      Screen overview


      1. Roles
      2. User

      Actions

      Introduction

      A brief description of this process.

      Next

      Allows you to browse to the Filter roles step.

      Filter roles

      Allows you to filter a subset of roles to apply the process.

      Undo

      Allows you to return to the previous step without applying any changes.

      Next

      Once you search for the proper Roles, you can click the Next button to browse to the Preview result step.

      Preview result

      Displays a list with the subset filtered of roles.

      Undo

      Allows you to return to the previous step without applying any changes.

      Next

      Allows you to run the Clear redundant roles process to the subset of roles & accounts there are in the list.

      Tools

      Disable inactive users

      Description

      Probably there are some users that do not need access to any information system. Using this tool you will be able to identify them and act upon them.

      The process is a two step process:

      1. Filter out the universe of users to analyze.
      2. Select the actions to perform on these users.

      The available actions are the following:

      It's usual to initially use this tool for only a subset of your users.
      For instance, you can send a message when the password is reaching the expiration date, disable the user when no login has been made in the last 90 days or completely remove its accounts when the identity has been disabled for 30 days.

      Screen overview

      * Send an email message: Send To: #{userName} #{attributes.manager} issuers@soffid.com

      1. User

      Actions

      Introduction

      A brief description of this process.

      Next

      Allows you to browse to the Filter roles step.

      Filter users

      Allows you to filter a subset of users to apply the process

      Undo

      Allows you to return to the previous step without applying any changes.

      Next

      Once you search for the proper Users, you can click the Next button to browse to the Criteria result step.

      Criteria

      Allows you to establish the action to perform on these users.

      Undo

      Allows you to return to the previous step without applying any changes.

      Next

      Once you search for the proper Users, you can click the Next button to browse to the Criteria result step.

      Preview result

      Displays a list with the subset filtered of users.

      Undo

      Allows you to return to the previous step without applying any changes.

      Next

      Allows you to run the process to the subset of users there are in the list.

      Tools

      Disable inactive accounts

      Description

      Probably there are some accounts that are no longer used. Using this tool you will be able to identify them and act upon them.

      The process is a two step process:

      1. Filter out the universe of accounts to analyze.
      2. Select the actions to perform on that accounts.

      The available actions are the following:

      It's usual to initially use this tool for only a subset of your accounts.
      For instance, you can send a message when the password is reaching the expiration date, disable the account when no login has been made in the last 90 days or completely remove it when the account has been disabled for 30 days

      Screen overview

      * Send an email message: Send To: #{userName} #{attributes.manager} issuers@soffid.com

      1. Account

      Actions

      Introduction

      A brief description of this process.

      Next

      Allows you to browse to the Filter roles step.

      Filter accounts

      Allows you to filter a subset of accounts to apply the process

      Undo

      Allows you to return to the previous step without applying any changes.

      Next

      Once you search for the proper Accounts, you can click the Next button to browse to the Criteria result step.

      Criteria

      Allows you to establish the action to perform on these accounts.

      Undo

      Allows you to return to the previous step without applying any changes.

      Next

      Once you search for the proper Accounts, you can click the Next button to browse to the Criteria result step.

      Preview result

      Displays a list with the subset filtered of accounts.

      Undo

      Allows you to return to the previous step without applying any changes.

      Next

      Allows you to run the process to the subset of accounts there are in the list.

      Tools

      Role mining

      Description

      Soffid’s role mining feature applies data mining technology to create business profiles based upon current application permissions in order to minimize the number of roles to be managed and maintained with the relevant cost saving.

      In this context, Soffid allows the administrator to select different role management strategies:

      Once you configure the role mining strategy, you will run the Role mining process (Scheduled task)

      Screen overview

      Custom attributes

      Scope

      Parameters

      Results

      Reports

      Actions

      Role mining query actions

      Query

      Allows you to query the role mining process through different search systems, Basic and Advanced.

      Add or remove columns

      Allows you to show and hide columns in the table. You can also set the order in which the columns will be displayed. The selected columns and order will be saved the next time Soffid displays the page. 

      Add new

      Allows you to add a new role mining process in the system. You can choose that option on the hamburger menu or by clicking the add button (+). 

      Delete

      Allows you to remove one or more role mining processes by selecting one or more records and next clicking the button with the subtraction symbol (-). To perform that action, Soffid will ask you for confirmation, you could confirm or cancel the operation.

      Download CSV file

      Allows you to download a CSV file with the basic information of all role mining processes. 

      Merge

      Allows you to merge two identities when you identify that is necessary.

      First of all, you need select two identities. Second, you need to click the hamburger icon and select the merge action. Then Soffid will display a window where you need to select the correct value for each standard and custom parameter. Finally, you need to apply changes to save the updates, or back to cancel that action.

      Role mining scope

      Save

      Allows you to save the scope defined. It will be mandatory to select some groups and information systems before continuing. When the role mining process is created, the default status will be Preparation.

      Add Groups

      Allows you to add new groups to be evaluated. You need to click the add groups button (+) and search the proper groups, then click the Add group button.

      Add Applications

      Allows you to add new applications to be evaluated. You need to click the add application button (+) and search the proper groups, then click the Add application button.

      Undo

      Allows you to quit without applying any changes. 

      Next

      Allows you to browse to the Parameter step. It will be mandatory to select some groups and information systems before continuing.

      Parameters

      Start

      If you click the start button, Soffid will change the process status to Scheduled.

      Undo

      Allows you to quit without applying any changes. 

      Result

      Next

      If you click the Next button, Soffid will browse to the Reports tab.

      Undo

      Allows you to quit without applying any changes. 

      Reports

      Download

      Allows you to download a report with the permissions matrix.

      Apply changes

      If you click the Apply changes button, Soffid will make the changes in the roles of users and entitlements.

      Undo

      Allows you to quit without applying any changes. 

      Monitoring and reporting

      Monitoring and reporting

      Sync server monitoring

      Description

      Soffid provides a monitoring functionality to consult all the information of the different agents and the status of each one of them and the amount of tasks assigned. Consequently, it allows diagnosing possible incidents in a quick and easy way.

      This option allows you to manage all the options related to the tasks created according to the configuration of each of the agents.

      Sync server

      Shows a list with the URL of all the sync servers that you have configured and the options to perform for every sync server.

      Agent Status

      The graph of agent status shows the number of agents connected (green light) and the number of agents disconnected (red light). By clicking on the captions you can select if you want to show only the connected agents, only the disconnected agents, or both agents.

      💻 Image

      image-1710860571986.png

      View Agents

      Allows you to access a new window with the information of every single agent. That page shows a list with the information about Agent, Number of the pending tasks, the Status, and the URL of the agent.

      If you click one of the agents, Soffid will display all the pending tasks for that agent. If you click on one pending task, you can view the details of that task and you could perform the actions available for that depending on your permissions.

      💻 Image

      image-1710860669782.png

      View Tasks

      Displays a matrix with all the agents configured, all the tasks, and the status of the task for each agent. You can reload the matrix with the updated tasks.

      The available status for a task are: 

      If you click on one error task, Soffid will display the details of that task, the basic data, and the specific data about Execution time, Error message, Scheduled and Log detail, and Soffid will allow you to perform the available actions. If you click on one pending task, you can perform the available actions.

      💻 Image

      image-1710860692532.png

      Get log

      Allows you to download the Sync Server log file.

      Stats

      Displays the performance (tasks per minute) graph of the synchronization servers.

      💻 Image

      image-1710918775742.png

      Restart server

      Allows you to restart the synchronization server that hosts any agent. Soffis will ask for your confirmation before performing that action. If you confirm, the server will be restarted.

      Additional information

      Display the additional information of Soffid

      💻 Image

      image-1710918843860.png

      Tasks

      Active tasks

      Displays a graph with information about the tasks pending to be performed on the different systems.

      Tasks by server

      Displays a graph with information about the tasks for each server.

      View Agents

      Displays a view with a list of agent tasks, regardless of which synchronization server they are running on.

      Not scheduled tasks

      Displays a view with a list not scheduled tasks. At that view, you can cancel and release the held tasks

      💻 Image

      image-1710918988780.png

      Screen overview

      image-1698999287005.png

      Related objects

      1. Agents
      2. Synchronization Servers
      3. Tasks
      Actions

      Agent actions

      Get log

      Soffid displays the log trace.

      Reset Allows you to restart the synchronization server that hosts any agent. Soffis will ask for your confirmation before performing that action.

      Tasks actions

      Cancel task

      Allows you to cancel a specific task. Soffid will ask for your confirmation, if you confirm, that task will be canceled.

      Prioritize Allows you to release a specific task. Soffid will ask for your confirmation, if you confirm, that task will be executed. 


      Monitoring and reporting

      Scheduled tasks

      Description

      Schedule tasks display all the automatic tasks defined on Soffid, the scheduling of each task, and information about the last execution. Also, allows administrator users to update the execution of that tasks using a cron pattern and init the execution.

      Screen overview

      Scheduled tasks list

      image-1676892983234.png

      Schedule task detail

      image-1676893027236.png

      Standard attributes

      Schedule

      For each value of month, day, hour, minute, or day of the week:

      Current execution

      Last execution

      Previous executions

      List with the information about the previous executions:

      Actions

      Scheduled tasks query actions

      Add or remove columns

      Allows you to show and hide columns in the table.

      Download CSV file

      Allows you to download a CSV file with the scheduled tasks.

      Scheduled Task detail actions

      Apply changes

      Allows you to save the data of scheduled tasks. To save the data it will be mandatory to fill in the required fields.

      Start now

      Allows you to launch the task execution.

      Undo

      Allows you to undo any changes made.

      Logs

      Allows you to download the log file.


      Monitoring and reporting

      Scheduled jobs

      Description

      Schedule jobs display all the asynchronous tasks generated for the workflows engine. When a job is finished, it will disappear from that list.

      Standard attributes

      Actions

      Scheduled jobs query actions

      Add or remove columns

      Allows you to show and hide columns in the table.

      Download CSV file

      Allows you to download a CSV file with the information of the scheduled jobs.

      Scheduled Task detail actions

      Resume

      Allows you to resume the task

      Hold

      Allows you to retain the task.

      Close

      Allows you to close the window without perform any action.


      Monitoring and reporting

      Audit

      Description

      The audit trail page allows you to query for audit records. Each action done at the Soffid console will be reported.

      Here you have a list of common Advanced searches, you only have to copy, paste and search, e.g.

      // User changes trace
      calendar ge "2020-01-01T00:00:00.000+01:00" AND user co "admin"
       
      // User actions trace
      calendar ge "2020-01-01T00:00:00.000+01:00" AND author co "admin"
       
      // Soffid accounts
      calendar ge "2020-01-01T00:00:00.000+01:00" AND user co "admin" AND database co "soffid"
       
      // Created accounts
      calendar ge "2020-01-01T00:00:00.000+01:00" AND action co "C" AND object co "SC_ACCOUN"
       
      // Removed objects
      calendar ge "2020-01-01T00:00:00.000+01:00" AND action co "D" AND object co "SC_ACCOUN"
      
      Screen overview

      image-1679557370520.png

      Custom attributes

      Actions

      Query Allows you to query accounts through different search systems, Quick and Advanced.
      Add or remove columns Allows you to show and hide columns in the table.
      Download CSV file Allows you to download a csv file with the information of audit records. 


      Monitoring and reporting

      Access logs

      Description

      The access log page allows querying all the information about the opened sessions. 

      Note that any session that was active during the specified date will be shown, even when it started before of finished after that date.

      Screen overview
      Custom attributes

      Actions

      Query Allows you to query accounts through different search systems, Quick and Advanced.
      Add or remove columns Allows to show and hide columns in the table.
      Download CSV file Allows to download a CSV file with the information of access logs. 
      Monitoring and reporting

      Sessions

      Description

      The sessions page displays the current open sessions made with ESSO, WSSO or PAM for which the user is the owner. 

      This functionality allows the owner users, with appropriate privileges, to open and view online a session opened by another user. It also allows them to interact if necessary.

      Screen overview
      Custom attributes

      Actions

      Add or remove columns Allows to show and hide columns in the table.
      Download CSV file Allows to download a CSV file with the information of access logs. 


      Monitoring and reporting

      Console log

      Description

      That option allows you to look up server logs from the console. The logs are created on the server filesystem.

      Screen Overview

      image-1679557650561.png

      Actions

      Download  Allows you to download the log file 
      Monitoring and reporting

      Privileged accounts dashboard

      Description

      Soffid provides a monitoring functionality to consult all the information about the different Jump servers installed and configured.

      The displayed info is the following:

      Screen overview

      image-1629183744388.png


      To activate this view you will need to enable the Feed statistic tables task on the  Scheduled tasks page.

      Monitoring and reporting

      Search in PAM recordings

      Description

      Soffid provides the functionality that allows searching for information about the PAM recording sessions.

      That option is located on Main Menu > Administration > Monitoring and reporting > Search in PAM recordings

      First of all, to query the PAM recording, you could apply some filters to refine your search. Then, when you click the Search button, Soffid will show you all the recording sessions that comply with the criteria specified.

      If you click on one record, Soffid will show you a new page with all the data about the session and the recorded video. If you query with a typed keys filter, a bookmark with the minute and second will show, and it will allow you to go directly to that point and view the action.

      Screen overview

      Standard attributes

      Actions

      Download CSV file

      Allows you to download a CSV file with the PAM recording information.

      Search

      Allows you to query the PAM recording by applying some filters.

      View recording

      Allows you to view the recording. You need to click on the record of the PAM recording that you want to view, then Soffid will show you a new page with all the information about the session and the recording video.



      Monitoring and reporting

      Issues

      Definition

      Soffid provides a tool to manage all issues and allows you to perform the operations available for each type of task. The actions to be performed will depend on each kind of task.

      You can find this functionality in the following path:

      Main Menu > Administration > Monitoring and reporting > Issues

      Screen Overview

      Issues

      image-1691074240103.png

      1. User
      2. Accounts

      Standard attributes

      Actions

      Issues query action

      Download CSV file Allows you to download a CSV file with the issue data.

      Add or remove columns

      Allows you to show and hide columns in the table. You can also set the order in which the columns will be displayed. The selected columns and order will be saved for the next time Soffid displays the page. 

      Issue detail

      Close Allows you to quit without applying any changes.
      Acknowledge

      Allows you to check as Acknowledged

      Solve issue

      Allows you to mark as solved the issue.

      Send custom email Allows you to send a custom email to one recipient.
      Add Comments Allows you to add comments to the Action logs.
      account-created
      💻 Image

      image-1691073560305.png

      Unlock account If you click this option, Soffil will unlock the account.

      Look affected accounts

       If you click this option, Soffil will lock affected accounts. 

      Disable user

      If you click this option, Soffid will disable the user.

      disconnected-system
      💻 Image

      image-1691505347878.png

      discovered-host
      💻 Image

      image-1695972298817.png

      discovered-system
      💻 Image


      duplicated-user
      💻 Image

      image-1691406809609.png

      Mege users

      If you click this option, Soffid will allow you to merge the identities by selecting the data of each of them.

      💻 Image


      image-1691406880979.png


      failed-job
      💻 Image

      image-1691073883011.png

      enabled-account-on-disabled-user
      💻 Image

      image-1695972326375.png

      Unlock account If you click this option, Soffil will unlock the account.

      Look affected accounts

       If you click this option, Soffil will lock affected accounts. 

      global-failed-login
      💻 Image

      image-1691074786904.png

      integration-errors
      💻 Image

      image-1691074818620.png

      locked-account
      💻 Image

      image-1691412483843.png

      Unlock account If you click this option, Soffil will unlock the account.

      Look affected accounts

       If you click this option, Soffil will lock affected accounts. 

      Disable user

      If you click this option, Soffid will disable the user.

      Lock affected host

      If you click this option, Soffid will lock the affected host.

      Unlock host

      If you click this option, Soffid will unlock the host.

      login-different-country
      💻 Image

      image-1696239831327.png

      Unlock account If you click this option, Soffil will unlock the account.

      Look affected accounts

       If you click this option, Soffil will lock affected accounts. 

      Disable user

      If you click this option, Soffid will disable the user.

      Lock affected host

      If you click this option, Soffid will lock the affected host.

      Unlock host

      If you click this option, Soffid will unlock the host.

      login-from-new-device
      💻 Image

      image-1691074846496.png

      Unlock account If you click this option, Soffil will unlock the account.

      Look affected accounts

       If you click this option, Soffil will lock affected accounts. 

      Disable user

      If you click this option, Soffid will disable the user.

      Lock affected host

      If you click this option, Soffid will lock the affected host.

      Unlock host

      If you click this option, Soffid will unlock the host.

      login-not-recognized
      💻 Image

      image-1691074918985.png

      Unlock account If you click this option, Soffil will unlock the account.

      Look affected accounts

       If you click this option, Soffil will lock affected accounts. 

      Disable user

      If you click this option, Soffid will disable the user.

      Lock affected host

      If you click this option, Soffid will lock the affected host.

      Unlock host

      If you click this option, Soffid will unlock the host.

      otp-failures
      💻 Image

      image-1691074948199.png

      Unlock account If you click this option, Soffil will unlock the account.

      Look affected accounts

       If you click this option, Soffil will lock affected accounts. 

      Disable user

      If you click this option, Soffid will disable the user.

      Lock affected host

      If you click this option, Soffid will lock the affected host.

      Unlock host

      If you click this option, Soffid will unlock the host.

      pam-violation
      💻 Image

      image-1691404894434.png

      Unlock account If you click this option, Soffil will unlock the account.

      Look affected accounts

       If you click this option, Soffil will lock affected accounts. 

      Disable user

      If you click this option, Soffid will disable the user.

      Lock affected host

      If you click this option, Soffid will lock the affected host.

      Unlock host

      If you click this option, Soffid will unlock the host.

      password-changed
      💻 Image


      permissions-granted
      💻 Image

      image-1691075044973.png

      Unlock account If you click this option, Soffil will unlock the account.

      Look affected accounts

       If you click this option, Soffil will lock affected accounts. 

      Disable user

      If you click this option, Soffid will disable the user.

      risk-increase
      💻 Image

      image-1691678367280.png

      Unlock account If you click this option, Soffil will unlock the account.

      Look affected accounts

       If you click this option, Soffil will lock affected accounts. 

      Disable user

      If you click this option, Soffid will disable the user.

      robot-login
      💻 Image

      image-1696240262391.png

      Unlock account If you click this option, Soffil will unlock the account.

      Look affected accounts

       If you click this option, Soffil will lock affected accounts. 

      Disable user

      If you click this option, Soffid will disable the user.

      Lock affected host

      If you click this option, Soffid will lock the affected host.

      Unlock host

      If you click this option, Soffid will unlock the host.

      security-exception
      💻 Image

      image-1691140940313.png

      Disable user

      If you click this option, Soffid will disable the user.

      Common actions

      Common actions

      Search Types

      Description

      Throughout the Soffid you will be able to perform searches on the different objects that make up the application.

      You will be able to search in the system by applying different ways of searching. 

      Quick

      This option allows a quick search by fields that have been defined in the application metadata. You can find metadata configuration on Global Settings > Metadata

      You only have to type in the field provided for this purpose and press enter or click on the magnifying glass, then Soffid will display the list with the objects that complain the criteria typed. 

      You can include some characters "," "." and "/" as word separators in the search text.

      Example

      image-1661348367582.png

      image-1661348697785.png

      image-1661348429835.png

      Basic

      This is the default option. It provides some default search criteria and other criteria can be added from the add criteria option. These criteria will depend on the entity or object on which the search is being performed.

      Remember, each criteria will be added to the previous ones. Each search criterion will have different search forms depending on the type of data in the particular field. For instance, a text field provides four different options to search, "Contains", "Start with", "End with" and "Equals", a date field provides the date "Since" and date "Until".

      Soffid allows you to and criteria by clicking on the Add criteria button, then Soffid will display a list with all the criteria available and allows you to select to add a new one. To delete criteria you only have to click on the Equis icon (x) of the criteria you want to remove and automatically Soffid will remove the criteria and run the search without the removed criteria.

      The criteria depend on the object list where you are working, so for instance the criteria are not the same for the user's list and the group's list.

      Example

      image-1643789138188.png

      Advanced

      This option allows an advanced search system using the SCIM standard. You can type the query to search the info using the SCIM standard. 

      You can access to SCIM Book for more information

      Example 1

      image-1643790290701.png

      Example 2

      image-1698651911950.png

      Common actions

      Column Selector

      Description

      Throughout the Soffid Console, we can find a large number of list-type components. These lists are used to display the corresponding objects data in each case, for instance users, accounts, ...

      This component allows you to add or remove columns, but also allows you to sort by the name of the columns to display them in the list. Be in mind, the columns are the attributes of an object (an user, or an account...).
      It is easy to use, once you click on the hamburger icon and the Add or remove columns option, Soffid will display a window with the available columns for the object, then just drag and drop them in the order you want and click on the Apply changes button. Once you Applu changes, Soffid will display the list with the attributes in the order you defined.

      Example

      image-1643788432028.png

      Common actions

      Download CSV file & Import

      Download CSV file

      Soffid allows you to download all data objects displayed in tables in a CSV file. 

      You can access to Download CSV file option  through the hamburger icon from most of the components of the table type.

      Import

      Soffid allows you to upload a CSV file with the data list to add, update or delete information to the data table. The operations that can be performed with the data import depend on the table on which the process is being performed.

      You can access to Import option through the hamburger icon from most of the components of the table type.

      To import data from a CSV file, first of all it will be to pick the file to import. Once the file has been selected, the data will be displayed to check contents. If the content is correct, then it is allowed to set up the mappings for each CSV file column, "Don't load" option is available. Finally it is allowed to perform the import process.

      When the import process finishes, Soffid will show a message with the result of the process execution.


      Common actions

      Bulk actions

      Description

      Allows massive operations to be performed on the selected records. With that operation, updates can be made to any of the object parameters.

      You can access this option through the hamburger icon from a few of the components of the table type, like users list or accounts list.

      1. First of all, you need to select the records that you want to update from the list, once you have selected them, you must choose the bulk action on the hamburguer icon.

      2. Then Soffid display a modal where you can select one by one the attributes that will be updated.

      The fist dropdown list displays the attributes of the object, for instance, the user attributes.

      The second dropdown list displays the operation to be performed on the selected attribute. The operation can be change the value or clear the value,  and if it is neccesary the new value.

      The type of the third field will depend on the attribute type selected previously.

      3. Soffid shows a confirmation message with the number of records that will be updated. Finally, you can choose apply or come back. If you apply the changes, the attributes of the seleccted records will be updated


      Common actions

      Issue Actions

      Actions

      Issues query action

      Download CSV file Allows you to download a CSV file with the issue data.

      Add or remove columns

      Allows you to show and hide columns in the table. You can also set the order in which the columns will be displayed. The selected columns and order will be saved for the next time Soffid displays the page. 

      Issue detail

      Close Allows you to quit without applying any changes.
      Acknowledge

      Allows you to check as Acknowledged

      Solve issue

      Allows you to mark as solved the issue.

      Send custom email Allows you to send a custom email to one recipient.
      Add Comments Allows you to add comments to the Action logs.
      account-created
      💻 Image

      image-1691073560305.png

      Unlock account If you click this option, Soffil will unlock the account.

      Look affected accounts

       If you click this option, Soffil will lock affected accounts. 

      Disable user

      If you click this option, Soffid will disable the user.

      disconnected-system
      💻 Image

      image-1691505347878.png

      discovered-host
      💻 Image

      image-1695972298817.png

      discovered-system
      💻 Image


      duplicated-user
      💻 Image

      image-1691406809609.png

      Mege users

      If you click this option, Soffid will allow you to merge the identities by selecting the data of each of them.

      💻 Image


      image-1691406880979.png


      failed-job
      💻 Image

      image-1691073883011.png

      enabled-account-on-disabled-user
      💻 Image

      image-1695972326375.png

      Unlock account If you click this option, Soffil will unlock the account.

      Look affected accounts

       If you click this option, Soffil will lock affected accounts. 

      global-failed-login
      💻 Image

      image-1691074786904.png

      integration-errors
      💻 Image

      image-1691074818620.png

      locked-account
      💻 Image

      image-1691412483843.png

      Unlock account If you click this option, Soffil will unlock the account.

      Look affected accounts

       If you click this option, Soffil will lock affected accounts. 

      Disable user

      If you click this option, Soffid will disable the user.

      Lock affected host

      If you click this option, Soffid will lock the affected host.

      Unlock host

      If you click this option, Soffid will unlock the host.

      login-different-country
      💻 Image

      image-1696239831327.png

      Unlock account If you click this option, Soffil will unlock the account.

      Look affected accounts

       If you click this option, Soffil will lock affected accounts. 

      Disable user

      If you click this option, Soffid will disable the user.

      Lock affected host

      If you click this option, Soffid will lock the affected host.

      Unlock host

      If you click this option, Soffid will unlock the host.

      login-from-new-device
      💻 Image

      image-1691074846496.png

      Unlock account If you click this option, Soffil will unlock the account.

      Look affected accounts

       If you click this option, Soffil will lock affected accounts. 

      Disable user

      If you click this option, Soffid will disable the user.

      Lock affected host

      If you click this option, Soffid will lock the affected host.

      Unlock host

      If you click this option, Soffid will unlock the host.

      login-not-recognized
      💻 Image

      image-1691074918985.png

      Unlock account If you click this option, Soffil will unlock the account.

      Look affected accounts

       If you click this option, Soffil will lock affected accounts. 

      Disable user

      If you click this option, Soffid will disable the user.

      Lock affected host

      If you click this option, Soffid will lock the affected host.

      Unlock host

      If you click this option, Soffid will unlock the host.

      otp-failures
      💻 Image

      image-1691074948199.png

      Unlock account If you click this option, Soffil will unlock the account.

      Look affected accounts

       If you click this option, Soffil will lock affected accounts. 

      Disable user

      If you click this option, Soffid will disable the user.

      Lock affected host

      If you click this option, Soffid will lock the affected host.

      Unlock host

      If you click this option, Soffid will unlock the host.

      pam-violation
      💻 Image

      image-1691404894434.png

      Unlock account If you click this option, Soffil will unlock the account.

      Look affected accounts

       If you click this option, Soffil will lock affected accounts. 

      Disable user

      If you click this option, Soffid will disable the user.

      Lock affected host

      If you click this option, Soffid will lock the affected host.

      Unlock host

      If you click this option, Soffid will unlock the host.

      password-changed
      💻 Image


      permissions-granted
      💻 Image

      image-1691075044973.png

      Unlock account If you click this option, Soffil will unlock the account.

      Look affected accounts

       If you click this option, Soffil will lock affected accounts. 

      Disable user

      If you click this option, Soffid will disable the user.

      risk-increase
      💻 Image

      image-1691678367280.png

      Unlock account If you click this option, Soffil will unlock the account.

      Look affected accounts

       If you click this option, Soffil will lock affected accounts. 

      Disable user

      If you click this option, Soffid will disable the user.

      robot-login
      💻 Image

      image-1696240262391.png

      Unlock account If you click this option, Soffil will unlock the account.

      Look affected accounts

       If you click this option, Soffil will lock affected accounts. 

      Disable user

      If you click this option, Soffid will disable the user.

      Lock affected host

      If you click this option, Soffid will lock the affected host.

      Unlock host

      If you click this option, Soffid will unlock the host.

      security-exception
      💻 Image

      image-1691140940313.png

      Disable user

      If you click this option, Soffid will disable the user.

      Textual Index

      Textual Index

      Textual Index

      Introduction 

      A textual index is a data structure used in database systems to facilitate efficient search and retrieval of text-based information. It is designed to handle large volumes of textual data and provide quick access to relevant documents or records based on specified search criteria.

      When a search query is performed on a database with a textual index, the index is queried to identify relevant documents or records that match the search terms. The index provides information about the location and relevance of the documents, which enables the database system to retrieve and present the results in a timely manner.

      Textual indexes play a crucial role in enabling efficient search and retrieval of textual information in databases, making them an essential component in applications that handle large volumes of textual data, such as search engines, content management systems, and document repositories.

      Soffid incorporates the textual index from version 3.5 using the Apache Lucene library

      Index  configuration

      Soffid allows you to configure the objects you want to use in the textual index. To do this, you must select the proper object from the metadata page and enable the option "Use textual index". Once you enable this option, the textual index will be applied to the attributes of this object that have been included in the quick search.

      Notice, from the user interface, it is not interpreted as a Lucene expression.

      Example

      1. Enable the "Use textual index" on the User object and save the changes.

      image-1685696054716.png

      2. Check the attributes included in the quick search.

      image-1685696008734.png


      How does the user interface search work?

      Once you have configured the textual index for a specific object, Soffid will apply it when you use Quick Search on this object.

      Example 1

      1. If you search for users using the text "frankin", then Soffid will display all the users whose userName, firstName, lastName, or middleName match, to some degree, with the typed text following the textual index rules.

      image-1696848303441.png

      2. If you include the attribute manager in the quick search:

      image-1685699018153.png

      3. And search for "frankin",  then Soffid will display all the users whose userName, firstName, lastName, middleName, or manager match with the typed text following the textual index rules.

      image-1696848348203.png

      Example 2

      1. If you search for users using the text "manager:frank"  Soffid will display all users whose manager matches the text "frank".

      image-1696848389213.png

      Notice the difference by searching "manager:frank?":

      image-1696848612113.png

      And by searching "manager:frank*": 

      image-1696848651863.png

      And also by searching "manager:fr*"

      image-1696848449297.png

      Example 3

      1. If you search for users using the text "userName:frank*"  Soffid will display all users whose user name matches the text "frank" followed by any other text.

      image-1696849446243.png

      Notice the difference by searching the text "userName:frank?":

      image-1696849467816.png

      Example 4

      1. If you search for users using the text "frank" plus the wildcard "?", Soffid will display all users whose userName, firstName, lastName, middleName, or manager match the typed text as long as it has variation in the characters where the wildcard has been used.

      image-1696848705925.png

      Notice the difference by searching "fran?"

      image-1696848750498.png

      How does the SCIM interface search work?

      1. First of all, you must install the SCIM addon in Soffid.

      For more information, you can visit the How to install SCIM in Soffid? page.

      2. Then, you can use any REST client to test and consume our SCIM REST web service.

      For more information, you can visit the Testing tool page.

      3. Finally, you can start to use the SCIM interface search by using Lucene syntaxis

      Lucene syntaxis 

      Please browse the standard specifications in this link: https://bookstack.soffid.com/books/soffid-3-reference-guide/page/lucene-query-parser-syntax

      Term Modifiers

      Lucene supports modifying query terms to provide a wide range of search options.  Here are the most common ones: 

      Wildcard Searches

      To perform a single character wildcard search use the "?" symbol.

      To perform a multiple character wildcard search use the "*" symbol.

      Regular Expression Searches Lucene supports regular expression searches matching a pattern between forward slashes "/"
      Fuzzy Searches

      To do a fuzzy search use the tilde, "~", symbol at the end of a Single word Term

      Soffid Console <= 3.4 version

      ~0.8: stricter search

      ~0.1: more lax search

      Soffid Console > 3.4 version

      An additional (optional) parameter can specify the maximum number of edits allowed. The value is between 0 and 2.

      Range Searches Range Queries allow one to match documents whose field(s) values are between the lower and upper bound specified by the Range Query
      Boosting a Term To boost a term use the caret, "^", symbol with a boost factor (a number) at the end of the term you are searching. The higher the boost factor, the more relevant the term will be.

      Boolean Operators

      OR The OR operator links two terms and finds a matching document if either of the terms exist in a document. This is equivalent to a union using sets
      AND The AND operator matches documents where both terms exist anywhere in the text of a single document. This is equivalent to an intersection using sets. 
      + The "+" or required operator requires that the term after the "+" symbol exist somewhere in a the field of a single document.
      NOT The NOT operator excludes documents that contain the term after NOT. This is equivalent to a difference using sets. 
      - The "-" or prohibit operator excludes documents that contain the term after the "-" symbol.

      Escaping Special Characters

      Lucene supports escaping special characters that are part of the query syntax.

      The current list of special characters are + - && || ! ( ) { } [ ] ^ " ~ * ? : \ /

      Examples

      Example 1

      1. Use the wildcard search

      1.1. *

      Request

      GET http://<domain>/webservice/scim2/v1/User?textFilter=fran*

      Response 200 OK

      {
          "schemas": [
              "urn:ietf:params:scim:api:messages:2.0:ListResponse"
          ],
          "totalResults": 4,
          "startIndex": 1,
          "Resources": [
              {
                  "lastName": "Franklin",
                  "createdByUser": "ActiveDirectory",
                  "fullName": "Rosalind Franklin",
                  "active": true,
                  "userName": "rfranklin",
                  "mailAlias": "",
                  "firstName": "Rosalind",
                  "createdDate": "2023-08-08 14:26:14",
                  "multiSession": true,
                  "meta": {
                      "location": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/2862",
                      "links": {
                          "roleAccounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/RoleAccount?filter=userCode+eq+'rfranklin'+and+enabled+eq+true",
                          "groupUsers": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/GroupUser?filter=user+eq+'rfranklin'+and+disabled+eq+false",
                          "accounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Account?filter=type+eq+U+and+users.user.userName+eq+'rfranklin'",
                          "issues": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Issue?filter=user.userName+eq+'rfranklin'",
                          "effectiveGrants": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/2862/effectiveGrants"
                      },
                      "resourceType": "User"
                  },
                  "modifiedByUser": "ActiveDirectory",
                  "schemas": [
                      "urn:soffid:com.soffid.iam.api.User"
                  ],
                  "modifiedDate": "2023-08-08 14:26:14",
                  "attributes": {},
                  "id": 2862,
                  "userType": "I",
                  "primaryGroupDescription": "scientist",
                  "primaryGroup": "scientist"
              },
              {
                  "lastName": "Franklin",
                  "createdByUser": "ActiveDirectory",
                  "fullName": "Aretha Franklin",
                  "active": true,
                  "userName": "aretha",
                  "mailAlias": "",
                  "firstName": "Aretha",
                  "createdDate": "2023-09-06 13:12:54",
                  "multiSession": true,
                  "meta": {
                      "location": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/276397",
                      "links": {
                          "roleAccounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/RoleAccount?filter=userCode+eq+'aretha'+and+enabled+eq+true",
                          "groupUsers": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/GroupUser?filter=user+eq+'aretha'+and+disabled+eq+false",
                          "accounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Account?filter=type+eq+U+and+users.user.userName+eq+'aretha'",
                          "issues": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Issue?filter=user.userName+eq+'aretha'",
                          "effectiveGrants": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/276397/effectiveGrants"
                      },
                      "resourceType": "User"
                  },
                  "modifiedByUser": "ActiveDirectory",
                  "schemas": [
                      "urn:soffid:com.soffid.iam.api.User"
                  ],
                  "modifiedDate": "2023-09-06 13:12:54",
                  "attributes": {},
                  "id": 276397,
                  "userType": "I",
                  "primaryGroupDescription": "World",
                  "primaryGroup": "world"
              },
              {
                  "lastName": "Sinatra",
                  "createdByUser": "ActiveDirectory",
                  "fullName": "Frank Sinatra",
                  "active": true,
                  "userName": "frank",
                  "mailAlias": "",
                  "firstName": "Frank",
                  "createdDate": "2023-09-06 13:12:54",
                  "multiSession": true,
                  "meta": {
                      "location": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/276435",
                      "links": {
                          "roleAccounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/RoleAccount?filter=userCode+eq+'frank'+and+enabled+eq+true",
                          "groupUsers": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/GroupUser?filter=user+eq+'frank'+and+disabled+eq+false",
                          "accounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Account?filter=type+eq+U+and+users.user.userName+eq+'frank'",
                          "issues": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Issue?filter=user.userName+eq+'frank'",
                          "effectiveGrants": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/276435/effectiveGrants"
                      },
                      "resourceType": "User"
                  },
                  "modifiedByUser": "ActiveDirectory",
                  "schemas": [
                      "urn:soffid:com.soffid.iam.api.User"
                  ],
                  "modifiedDate": "2023-09-06 13:12:55",
                  "attributes": {},
                  "id": 276435,
                  "userType": "I",
                  "primaryGroupDescription": "Music",
                  "primaryGroup": "Music"
              },
              {
                  "lastName": "Sherwood",
                  "createdByUser": "pgarcia",
                  "fullName": "Frank Sherwood",
                  "active": true,
                  "userName": "franks",
                  "mailAlias": "",
                  "firstName": "Frank",
                  "createdDate": "2023-10-05 15:32:40",
                  "multiSession": false,
                  "meta": {
                      "location": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/432644",
                      "links": {
                          "roleAccounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/RoleAccount?filter=userCode+eq+'franks'+and+enabled+eq+true",
                          "groupUsers": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/GroupUser?filter=user+eq+'franks'+and+disabled+eq+false",
                          "accounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Account?filter=type+eq+U+and+users.user.userName+eq+'franks'",
                          "issues": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Issue?filter=user.userName+eq+'franks'",
                          "effectiveGrants": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/432644/effectiveGrants"
                      },
                      "resourceType": "User"
                  },
                  "modifiedByUser": "pgarcia",
                  "schemas": [
                      "urn:soffid:com.soffid.iam.api.User"
                  ],
                  "modifiedDate": "2023-10-05 15:32:40",
                  "attributes": {},
                  "id": 432644,
                  "userType": "I",
                  "primaryGroupDescription": "scientist",
                  "primaryGroup": "scientist"
              }
          ]
      }

      1.2. ?

      Request 

      http://<domain>/webservice/scim2/v1/User?textFilter=fran?

      Response 200 OK

      {
          "schemas": [
              "urn:ietf:params:scim:api:messages:2.0:ListResponse"
          ],
          "totalResults": 2,
          "startIndex": 1,
          "Resources": [
              {
                  "lastName": "Sinatra",
                  "createdByUser": "ActiveDirectory",
                  "fullName": "Frank Sinatra",
                  "active": true,
                  "userName": "frank",
                  "mailAlias": "",
                  "firstName": "Frank",
                  "createdDate": "2023-09-06 13:12:54",
                  "multiSession": true,
                  "meta": {
                      "location": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/276435",
                      "links": {
                          "roleAccounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/RoleAccount?filter=userCode+eq+'frank'+and+enabled+eq+true",
                          "groupUsers": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/GroupUser?filter=user+eq+'frank'+and+disabled+eq+false",
                          "accounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Account?filter=type+eq+U+and+users.user.userName+eq+'frank'",
                          "issues": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Issue?filter=user.userName+eq+'frank'",
                          "effectiveGrants": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/276435/effectiveGrants"
                      },
                      "resourceType": "User"
                  },
                  "modifiedByUser": "ActiveDirectory",
                  "schemas": [
                      "urn:soffid:com.soffid.iam.api.User"
                  ],
                  "modifiedDate": "2023-09-06 13:12:55",
                  "attributes": {},
                  "id": 276435,
                  "userType": "I",
                  "primaryGroupDescription": "Music",
                  "primaryGroup": "Music"
              },
              {
                  "lastName": "Sherwood",
                  "createdByUser": "pgarcia",
                  "fullName": "Frank Sherwood",
                  "active": true,
                  "userName": "franks",
                  "mailAlias": "",
                  "firstName": "Frank",
                  "createdDate": "2023-10-05 15:32:40",
                  "multiSession": false,
                  "meta": {
                      "location": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/432644",
                      "links": {
                          "roleAccounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/RoleAccount?filter=userCode+eq+'franks'+and+enabled+eq+true",
                          "groupUsers": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/GroupUser?filter=user+eq+'franks'+and+disabled+eq+false",
                          "accounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Account?filter=type+eq+U+and+users.user.userName+eq+'franks'",
                          "issues": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Issue?filter=user.userName+eq+'franks'",
                          "effectiveGrants": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/432644/effectiveGrants"
                      },
                      "resourceType": "User"
                  },
                  "modifiedByUser": "pgarcia",
                  "schemas": [
                      "urn:soffid:com.soffid.iam.api.User"
                  ],
                  "modifiedDate": "2023-10-05 15:32:40",
                  "attributes": {},
                  "id": 432644,
                  "userType": "I",
                  "primaryGroupDescription": "scientist",
                  "primaryGroup": "scientist"
              }
          ]
      }
      Example 2

      1. Use the wildcard search in a specific attribute

      Request 

      GET http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User?textFilter=userName:frank

      Response 200 OK

      {
          "schemas": [
              "urn:ietf:params:scim:api:messages:2.0:ListResponse"
          ],
          "totalResults": 1,
          "startIndex": 1,
          "Resources": [
              {
                  "lastName": "Sinatra",
                  "profileServer": "Void host",
                  "createdByUser": "admin",
                  "fullName": "Frankaaa Sinatra",
                  "active": true,
                  "userName": "frank",
                  "mailAlias": "",
                  "mailServer": "Void host",
                  "firstName": "Frankaaa",
                  "emailAddress": "pgarcia@soffid.com",
                  "mailDomain": "soffid.com",
                  "createdDate": "2023-06-02 07:41:47",
                  "multiSession": false,
                  "meta": {
                      "location": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/3910",
                      "links": {
                          "roleAccounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/RoleAccount?filter=userCode+eq+'frank'+and+enabled+eq+true",
                          "groupUsers": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/GroupUser?filter=user+eq+'frank'+and+disabled+eq+false",
                          "accounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Account?filter=type+eq+U+and+users.user.userName+eq+'frank'",
                          "effectiveGrants": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/3910/effectiveGrants"
                      },
                      "resourceType": "User"
                  },
                  "modifiedByUser": "admin",
                  "schemas": [
                      "urn:soffid:com.soffid.iam.api.User"
                  ],
                  "modifiedDate": "2023-06-02 07:41:47",
                  "attributes": {
                      "picture": "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"
                  },
                  "id": 3910,
                  "userType": "I",
                  "homeServer": "Void host",
                  "shortName": "pgarcia",
                  "primaryGroupDescription": "Music",
                  "primaryGroup": "Music"
              }
          ]
      }
      Example 3

      1. Use the Fuzzy Searches

      Request

      GET http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User?textFilter=fran~

      Response 200 OK

      {
          "schemas": [
              "urn:ietf:params:scim:api:messages:2.0:ListResponse"
          ],
          "totalResults": 2,
          "startIndex": 1,
          "Resources": [
              {
                  "lastName": "Sinatra",
                  "createdByUser": "ActiveDirectory",
                  "fullName": "Frank Sinatra",
                  "active": true,
                  "userName": "frank",
                  "mailAlias": "",
                  "firstName": "Frank",
                  "createdDate": "2023-09-06 13:12:54",
                  "multiSession": true,
                  "meta": {
                      "location": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/276435",
                      "links": {
                          "roleAccounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/RoleAccount?filter=userCode+eq+'frank'+and+enabled+eq+true",
                          "groupUsers": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/GroupUser?filter=user+eq+'frank'+and+disabled+eq+false",
                          "accounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Account?filter=type+eq+U+and+users.user.userName+eq+'frank'",
                          "issues": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Issue?filter=user.userName+eq+'frank'",
                          "effectiveGrants": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/276435/effectiveGrants"
                      },
                      "resourceType": "User"
                  },
                  "modifiedByUser": "ActiveDirectory",
                  "schemas": [
                      "urn:soffid:com.soffid.iam.api.User"
                  ],
                  "modifiedDate": "2023-09-06 13:12:55",
                  "attributes": {},
                  "id": 276435,
                  "userType": "I",
                  "primaryGroupDescription": "Music",
                  "primaryGroup": "Music"
              },
              {
                  "lastName": "Sherwood",
                  "createdByUser": "pgarcia",
                  "fullName": "Frank Sherwood",
                  "active": true,
                  "userName": "franks",
                  "mailAlias": "",
                  "firstName": "Frank",
                  "createdDate": "2023-10-05 15:32:40",
                  "multiSession": false,
                  "meta": {
                      "location": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/432644",
                      "links": {
                          "roleAccounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/RoleAccount?filter=userCode+eq+'franks'+and+enabled+eq+true",
                          "groupUsers": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/GroupUser?filter=user+eq+'franks'+and+disabled+eq+false",
                          "accounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Account?filter=type+eq+U+and+users.user.userName+eq+'franks'",
                          "issues": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Issue?filter=user.userName+eq+'franks'",
                          "effectiveGrants": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/432644/effectiveGrants"
                      },
                      "resourceType": "User"
                  },
                  "modifiedByUser": "pgarcia",
                  "schemas": [
                      "urn:soffid:com.soffid.iam.api.User"
                  ],
                  "modifiedDate": "2023-10-05 15:32:40",
                  "attributes": {},
                  "id": 432644,
                  "userType": "I",
                  "primaryGroupDescription": "scientist",
                  "primaryGroup": "scientist"
              }
          ]
      }

      2. Use the Fuzzy Searches: specify the maximum number of edits allowed

      Request

      GET http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User?textFilter=frankl~2

      Response 200 OK

      {
          "schemas": [
              "urn:ietf:params:scim:api:messages:2.0:ListResponse"
          ],
          "totalResults": 4,
          "startIndex": 1,
          "Resources": [
              {
                  "lastName": "Franklin",
                  "createdByUser": "ActiveDirectory",
                  "fullName": "Rosalind Franklin",
                  "active": true,
                  "userName": "rfranklin",
                  "mailAlias": "",
                  "firstName": "Rosalind",
                  "createdDate": "2023-08-08 14:26:14",
                  "multiSession": true,
                  "meta": {
                      "location": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/2862",
                      "links": {
                          "roleAccounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/RoleAccount?filter=userCode+eq+'rfranklin'+and+enabled+eq+true",
                          "groupUsers": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/GroupUser?filter=user+eq+'rfranklin'+and+disabled+eq+false",
                          "accounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Account?filter=type+eq+U+and+users.user.userName+eq+'rfranklin'",
                          "issues": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Issue?filter=user.userName+eq+'rfranklin'",
                          "effectiveGrants": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/2862/effectiveGrants"
                      },
                      "resourceType": "User"
                  },
                  "modifiedByUser": "ActiveDirectory",
                  "schemas": [
                      "urn:soffid:com.soffid.iam.api.User"
                  ],
                  "modifiedDate": "2023-08-08 14:26:14",
                  "attributes": {},
                  "id": 2862,
                  "userType": "I",
                  "primaryGroupDescription": "scientist",
                  "primaryGroup": "scientist"
              },
              {
                  "lastName": "Franklin",
                  "createdByUser": "ActiveDirectory",
                  "fullName": "Aretha Franklin",
                  "active": true,
                  "userName": "aretha",
                  "mailAlias": "",
                  "firstName": "Aretha",
                  "createdDate": "2023-09-06 13:12:54",
                  "multiSession": true,
                  "meta": {
                      "location": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/276397",
                      "links": {
                          "roleAccounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/RoleAccount?filter=userCode+eq+'aretha'+and+enabled+eq+true",
                          "groupUsers": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/GroupUser?filter=user+eq+'aretha'+and+disabled+eq+false",
                          "accounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Account?filter=type+eq+U+and+users.user.userName+eq+'aretha'",
                          "issues": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Issue?filter=user.userName+eq+'aretha'",
                          "effectiveGrants": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/276397/effectiveGrants"
                      },
                      "resourceType": "User"
                  },
                  "modifiedByUser": "ActiveDirectory",
                  "schemas": [
                      "urn:soffid:com.soffid.iam.api.User"
                  ],
                  "modifiedDate": "2023-09-06 13:12:54",
                  "attributes": {},
                  "id": 276397,
                  "userType": "I",
                  "primaryGroupDescription": "World",
                  "primaryGroup": "world"
              },
              {
                  "lastName": "Sinatra",
                  "createdByUser": "ActiveDirectory",
                  "fullName": "Frank Sinatra",
                  "active": true,
                  "userName": "frank",
                  "mailAlias": "",
                  "firstName": "Frank",
                  "createdDate": "2023-09-06 13:12:54",
                  "multiSession": true,
                  "meta": {
                      "location": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/276435",
                      "links": {
                          "roleAccounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/RoleAccount?filter=userCode+eq+'frank'+and+enabled+eq+true",
                          "groupUsers": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/GroupUser?filter=user+eq+'frank'+and+disabled+eq+false",
                          "accounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Account?filter=type+eq+U+and+users.user.userName+eq+'frank'",
                          "issues": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Issue?filter=user.userName+eq+'frank'",
                          "effectiveGrants": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/276435/effectiveGrants"
                      },
                      "resourceType": "User"
                  },
                  "modifiedByUser": "ActiveDirectory",
                  "schemas": [
                      "urn:soffid:com.soffid.iam.api.User"
                  ],
                  "modifiedDate": "2023-09-06 13:12:55",
                  "attributes": {},
                  "id": 276435,
                  "userType": "I",
                  "primaryGroupDescription": "Music",
                  "primaryGroup": "Music"
              },
              {
                  "lastName": "Sherwood",
                  "createdByUser": "pgarcia",
                  "fullName": "Frank Sherwood",
                  "active": true,
                  "userName": "franks",
                  "mailAlias": "",
                  "firstName": "Frank",
                  "createdDate": "2023-10-05 15:32:40",
                  "multiSession": false,
                  "meta": {
                      "location": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/432644",
                      "links": {
                          "roleAccounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/RoleAccount?filter=userCode+eq+'franks'+and+enabled+eq+true",
                          "groupUsers": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/GroupUser?filter=user+eq+'franks'+and+disabled+eq+false",
                          "accounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Account?filter=type+eq+U+and+users.user.userName+eq+'franks'",
                          "issues": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Issue?filter=user.userName+eq+'franks'",
                          "effectiveGrants": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/432644/effectiveGrants"
                      },
                      "resourceType": "User"
                  },
                  "modifiedByUser": "pgarcia",
                  "schemas": [
                      "urn:soffid:com.soffid.iam.api.User"
                  ],
                  "modifiedDate": "2023-10-05 15:32:40",
                  "attributes": {},
                  "id": 432644,
                  "userType": "I",
                  "primaryGroupDescription": "scientist",
                  "primaryGroup": "scientist"
              }
          ]
      }
      Example 4

      1. Use the boolean operator AND

      Request

      GET http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User?textFilter=fran~ AND Sinatra

      Response 200 OK

      {
          "schemas": [
              "urn:ietf:params:scim:api:messages:2.0:ListResponse"
          ],
          "totalResults": 1,
          "startIndex": 1,
          "Resources": [
              {
                  "lastName": "Sinatra",
                  "profileServer": "Void host",
                  "createdByUser": "admin",
                  "fullName": "Frankaaa Sinatra",
                  "active": true,
                  "userName": "frank",
                  "mailAlias": "",
                  "mailServer": "Void host",
                  "firstName": "Frankaaa",
                  "emailAddress": "pgarcia@soffid.com",
                  "mailDomain": "soffid.com",
                  "createdDate": "2023-06-02 07:41:47",
                  "multiSession": false,
                  "meta": {
                      "location": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/3910",
                      "links": {
                          "roleAccounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/RoleAccount?filter=userCode+eq+'frank'+and+enabled+eq+true",
                          "groupUsers": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/GroupUser?filter=user+eq+'frank'+and+disabled+eq+false",
                          "accounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Account?filter=type+eq+U+and+users.user.userName+eq+'frank'",
                          "effectiveGrants": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/3910/effectiveGrants"
                      },
                      "resourceType": "User"
                  },
                  "modifiedByUser": "admin",
                  "schemas": [
                      "urn:soffid:com.soffid.iam.api.User"
                  ],
                  "modifiedDate": "2023-06-02 07:41:47",
                  "attributes": {
                      "picture": "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"
                  },
                  "id": 3910,
                  "userType": "I",
                  "homeServer": "Void host",
                  "shortName": "pgarcia",
                  "primaryGroupDescription": "Music",
                  "primaryGroup": "Music"
              }
          ]
      }

      2. Use the boolean operator +

      Request

      GET http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User?textFilter=fran~ +bacall

      Response 200 OK

      {
          "schemas": [
              "urn:ietf:params:scim:api:messages:2.0:ListResponse"
          ],
          "totalResults": 3,
          "startIndex": 1,
          "Resources": [
              {
                  "lastName": "Bacall",
                  "createdByUser": "ActiveDirectory",
                  "fullName": "Lauren Bacall",
                  "active": true,
                  "userName": "lbacall",
                  "mailAlias": "",
                  "firstName": "Lauren",
                  "createdDate": "2023-08-08 14:26:14",
                  "multiSession": true,
                  "meta": {
                      "location": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/2844",
                      "links": {
                          "roleAccounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/RoleAccount?filter=userCode+eq+'lbacall'+and+enabled+eq+true",
                          "groupUsers": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/GroupUser?filter=user+eq+'lbacall'+and+disabled+eq+false",
                          "accounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Account?filter=type+eq+U+and+users.user.userName+eq+'lbacall'",
                          "issues": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Issue?filter=user.userName+eq+'lbacall'",
                          "effectiveGrants": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/2844/effectiveGrants"
                      },
                      "resourceType": "User"
                  },
                  "modifiedByUser": "pgarcia",
                  "schemas": [
                      "urn:soffid:com.soffid.iam.api.User"
                  ],
                  "modifiedDate": "2023-08-22 17:34:07",
                  "attributes": {},
                  "id": 2844,
                  "userType": "I",
                  "primaryGroupDescription": "Music",
                  "primaryGroup": "Music"
              },
              {
                  "lastName": "Sinatra",
                  "createdByUser": "ActiveDirectory",
                  "fullName": "Frank Sinatra",
                  "active": true,
                  "userName": "frank",
                  "mailAlias": "",
                  "firstName": "Frank",
                  "createdDate": "2023-09-06 13:12:54",
                  "multiSession": true,
                  "meta": {
                      "location": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/276435",
                      "links": {
                          "roleAccounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/RoleAccount?filter=userCode+eq+'frank'+and+enabled+eq+true",
                          "groupUsers": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/GroupUser?filter=user+eq+'frank'+and+disabled+eq+false",
                          "accounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Account?filter=type+eq+U+and+users.user.userName+eq+'frank'",
                          "issues": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Issue?filter=user.userName+eq+'frank'",
                          "effectiveGrants": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/276435/effectiveGrants"
                      },
                      "resourceType": "User"
                  },
                  "modifiedByUser": "ActiveDirectory",
                  "schemas": [
                      "urn:soffid:com.soffid.iam.api.User"
                  ],
                  "modifiedDate": "2023-09-06 13:12:55",
                  "attributes": {},
                  "id": 276435,
                  "userType": "I",
                  "primaryGroupDescription": "Music",
                  "primaryGroup": "Music"
              },
              {
                  "lastName": "Sherwood",
                  "createdByUser": "pgarcia",
                  "fullName": "Frank Sherwood",
                  "active": true,
                  "userName": "franks",
                  "mailAlias": "",
                  "firstName": "Frank",
                  "createdDate": "2023-10-05 15:32:40",
                  "multiSession": false,
                  "meta": {
                      "location": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/432644",
                      "links": {
                          "roleAccounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/RoleAccount?filter=userCode+eq+'franks'+and+enabled+eq+true",
                          "groupUsers": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/GroupUser?filter=user+eq+'franks'+and+disabled+eq+false",
                          "accounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Account?filter=type+eq+U+and+users.user.userName+eq+'franks'",
                          "issues": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Issue?filter=user.userName+eq+'franks'",
                          "effectiveGrants": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/432644/effectiveGrants"
                      },
                      "resourceType": "User"
                  },
                  "modifiedByUser": "pgarcia",
                  "schemas": [
                      "urn:soffid:com.soffid.iam.api.User"
                  ],
                  "modifiedDate": "2023-10-05 15:32:40",
                  "attributes": {},
                  "id": 432644,
                  "userType": "I",
                  "primaryGroupDescription": "scientist",
                  "primaryGroup": "scientist"
              }
          ]
      }

      3. Use the boolean operator -

      Request

      GET http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User?textFilter=fran~ -Sherwood

      Response 200 OK

      {
          "schemas": [
              "urn:ietf:params:scim:api:messages:2.0:ListResponse"
          ],
          "totalResults": 1,
          "startIndex": 1,
          "Resources": [
              {
                  "lastName": "Sinatra",
                  "createdByUser": "ActiveDirectory",
                  "fullName": "Frank Sinatra",
                  "active": true,
                  "userName": "frank",
                  "mailAlias": "",
                  "firstName": "Frank",
                  "createdDate": "2023-09-06 13:12:54",
                  "multiSession": true,
                  "meta": {
                      "location": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/276435",
                      "links": {
                          "roleAccounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/RoleAccount?filter=userCode+eq+'frank'+and+enabled+eq+true",
                          "groupUsers": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/GroupUser?filter=user+eq+'frank'+and+disabled+eq+false",
                          "accounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Account?filter=type+eq+U+and+users.user.userName+eq+'frank'",
                          "issues": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Issue?filter=user.userName+eq+'frank'",
                          "effectiveGrants": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/276435/effectiveGrants"
                      },
                      "resourceType": "User"
                  },
                  "modifiedByUser": "ActiveDirectory",
                  "schemas": [
                      "urn:soffid:com.soffid.iam.api.User"
                  ],
                  "modifiedDate": "2023-09-06 13:12:55",
                  "attributes": {},
                  "id": 276435,
                  "userType": "I",
                  "primaryGroupDescription": "Music",
                  "primaryGroup": "Music"
              }
          ]
      }
      Example 5

      1. U

      Request 

      GET 
      http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User?textFilter=(firstName:aretha OR firstName:Rosalind) 
      AND lastName:Franklin AND birthDate:1979-01-01

      Response 200 OK

      {
          "schemas": [
              "urn:ietf:params:scim:api:messages:2.0:ListResponse"
          ],
          "totalResults": 2,
          "startIndex": 1,
          "Resources": [
              {
                  "lastName": "Franklin",
                  "createdByUser": "ActiveDirectory",
                  "fullName": "Aretha Franklin",
                  "active": true,
                  "userName": "aretha",
                  "mailAlias": "",
                  "firstName": "Aretha",
                  "createdDate": "2023-09-06 13:12:54",
                  "multiSession": true,
                  "meta": {
                      "location": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/276397",
                      "links": {
                          "roleAccounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/RoleAccount?filter=userCode+eq+'aretha'+and+enabled+eq+true",
                          "groupUsers": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/GroupUser?filter=user+eq+'aretha'+and+disabled+eq+false",
                          "accounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Account?filter=type+eq+U+and+users.user.userName+eq+'aretha'",
                          "issues": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Issue?filter=user.userName+eq+'aretha'",
                          "effectiveGrants": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/276397/effectiveGrants"
                      },
                      "resourceType": "User"
                  },
                  "modifiedByUser": "pgarcia",
                  "schemas": [
                      "urn:soffid:com.soffid.iam.api.User"
                  ],
                  "modifiedDate": "2023-10-05 16:02:40",
                  "attributes": {
                      "birthDate": "1979-01-01 00:00:00"
                  },
                  "id": 276397,
                  "userType": "I",
                  "primaryGroupDescription": "World",
                  "primaryGroup": "world"
              },
              {
                  "lastName": "Franklin",
                  "createdByUser": "ActiveDirectory",
                  "fullName": "Rosalind Franklin",
                  "active": true,
                  "userName": "rfranklin",
                  "mailAlias": "",
                  "firstName": "Rosalind",
                  "createdDate": "2023-08-08 14:26:14",
                  "multiSession": true,
                  "meta": {
                      "location": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/2862",
                      "links": {
                          "roleAccounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/RoleAccount?filter=userCode+eq+'rfranklin'+and+enabled+eq+true",
                          "groupUsers": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/GroupUser?filter=user+eq+'rfranklin'+and+disabled+eq+false",
                          "accounts": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Account?filter=type+eq+U+and+users.user.userName+eq+'rfranklin'",
                          "issues": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/Issue?filter=user.userName+eq+'rfranklin'",
                          "effectiveGrants": "http://soffid.35x.lab:8089/soffid/webservice/scim2/v1/User/2862/effectiveGrants"
                      },
                      "resourceType": "User"
                  },
                  "modifiedByUser": "pgarcia",
                  "schemas": [
                      "urn:soffid:com.soffid.iam.api.User"
                  ],
                  "modifiedDate": "2023-10-05 16:03:02",
                  "attributes": {
                      "birthDate": "1979-01-01 00:00:00"
                  },
                  "id": 2862,
                  "userType": "I",
                  "primaryGroupDescription": "scientist",
                  "primaryGroup": "scientist"
              }
          ]
      }
      Textual Index

      Operation

      Operation

      The Lucene index information is stored in files arranged in a folder structure. This folder structure is replicated in every Soffid Console and every Sync Server and also is saved in the database.

      In case an instance (Docker, Kubernetes, or stand-alone) detects an inconsistency, the information will be overwritten with the database data.

      When you update an object, marked as the textual index, a task will be created. The soffid agent will execute this task and the Sync Server will update the database tables related to the textual index.

      Folder structure

      The folder structure is the following:

      Example

      1. Here you are the folder structure for the Soffid Console

      image-1685703071647.png

      image-1685703042391.png

      2. And the folder structure for the Sync Server

      image-1685703728067.png

      image-1685703757514.png

      Database 

      The database tables involved:

      Example

      1. The database structure

      image-1685703851111.png

      image-1685703952720.png

      soffid agent

      You can check the soffid agent status by visiting the Sync Server monitoring page:

      Main Menu > Administration > Monitoring and reporting > Sync server monitoring

      Example

      1. A soffid agent pending task:

      image-1685702576648.png

      Step-by-step

      Example 1

      1. You update one user's data and save the changes.

      image-1685711742292.png

      2. New tasks are created and executed.

      image-1685713884201.png

      3. Then Sync Server indexes the updated text and places the index file.

      image-1685712476037.png

      4. Then Sync Server and updates the database table SC_LUNIND by upgrading the LIP_TIMSTA field of the User object or by creating a new record if it did not previously exist.

      image-1685712562684.png

      5. When the following search will be performed, the very first thing to do is check the database file. If it is necessary update the file system and finally perform the search.

      Example 2

      1. The task engine mode is Read only

      image-1685713356805.png

      2. You update one user's data and save the changes.

      image-1685711742292.png


      3. A new task is created and executed

      image-1685711822595.png

      4. Then Sync Server indexes the updated text and places the index file.

      5. Then Sync Server and updates the database table SC_LUNIND by upgrading the LIP_TIMSTA field of the User object or by creating a new record if it did not previously exist.

      6. When the following search will be performed, the very first thing to do is check the database file. If it is necessary update the file system and finally perform the search.

      Textual Index

      Lucene - Query Parser Syntax

      Overview

      Although Lucene provides the ability to create your own queries through its API, it also provides a rich query language through the Query Parser, a lexer which interprets a string into a Lucene Query using JavaCC.

      Generally, the query parser syntax may change from release to release. This page describes the syntax as of the current release. If you are using a different version of Lucene, please consult the copy of docs/queryparsersyntax.html that was distributed with the version you are using.

      Before choosing to use the provided Query Parser, please consider the following:

      1. If you are programmatically generating a query string and then parsing it with the query parser then you should seriously consider building your queries directly with the query API. In other words, the query parser is designed for human-entered text, not for program-generated text.
      2. Untokenized fields are best added directly to queries, and not through the query parser. If a field's values are generated programmatically by the application, then so should query clauses for this field. An analyzer, which the query parser uses, is designed to convert human-entered text to terms. Program-generated values, like dates, keywords, etc., should be consistently program-generated.
      3. In a query form, fields which are general text should use the query parser. All others, such as date ranges, keywords, etc. are better added directly through the query API. A field with a limit set of values, that can be specified with a pull-down menu should not be added to a query string which is subsequently parsed, but rather added as a TermQuery clause.

      https://lucene.apache.org/core/9_6_0/queryparser/org/apache/lucene/queryparser/classic/package-summary.html#Overview

      Terms

      A query is broken up into terms and operators. There are two types of terms: Single Terms and Phrases.

      A Single Term is a single word such as "test" or "hello".

      A Phrase is a group of words surrounded by double quotes such as "hello dolly".

      Multiple terms can be combined together with Boolean operators to form a more complex query (see below).

      Note: The analyzer used to create the index will be used on the terms and phrases in the query string. So it is important to choose an analyzer that will not interfere with the terms used in the query string.

      Fields

      Lucene supports fielded data. When performing a search you can either specify a field, or use the default field. The field names and default field is implementation specific.

      You can search any field by typing the field name followed by a colon ":" and then the term you are looking for.

      As an example, let's assume a Lucene index contains two fields, title and text and text is the default field. If you want to find the document entitled "The Right Way" which contains the text "don't go this way", you can enter:

      title:"The Right Way" AND text:go

      or

      title:"The Right Way" AND go

      Since text is the default field, the field indicator is not required.

      Note: The field is only valid for the term that it directly precedes, so the query

      title:The Right Way

      Will only find "The" in the title field. It will find "Right" and "Way" in the default field (in this case the text field).

      Term Modifiers

      Lucene supports modifying query terms to provide a wide range of searching options. 

      Wildcard Searches

      Lucene supports single and multiple character wildcard searches within single terms (not within phrase queries).

      To perform a single character wildcard search use the "?" symbol.

      To perform a multiple character wildcard search use the "*" symbol.

      The single character wildcard search looks for terms that match that with the single character replaced. For example, to search for "text" or "test" you can use the search:

      te?t

      Multiple character wildcard searches looks for 0 or more characters. For example, to search for test, tests or tester, you can use the search:

      test*

      You can also use the wildcard searches in the middle of a term.

      te*t

      Note: You cannot use a * or ? symbol as the first character of a search. 

      Regular Expression Searches

      Lucene supports regular expression searches matching a pattern between forward slashes "/". The syntax may change across releases, but the current supported syntax is documented in the RegExp class. For example to find documents containing "moat" or "boat":

      /[mb]oat/

      Fuzzy Searches

      Lucene supports fuzzy searches based on Damerau-Levenshtein Distance. To do a fuzzy search use the tilde, "~", symbol at the end of a Single word Term. For example to search for a term similar in spelling to "roam" use the fuzzy search:

      roam~

      This search will find terms like foam and roams.

      An additional (optional) parameter can specify the maximum number of edits allowed. The value is between 0 and 2, For example:

      roam~1

      The default that is used if the parameter is not given is 2 edit distances.

      Previously, a floating point value was allowed here. This syntax is considered deprecated and will be removed in Lucene 5.0 

      Proximity Searches

      Lucene supports finding words are a within a specific distance away. To do a proximity search use the tilde, "~", symbol at the end of a Phrase. For example to search for a "apache" and "jakarta" within 10 words of each other in a document use the search:

      "jakarta apache"~10

      Range Searches

      Range Queries allow one to match documents whose field(s) values are between the lower and upper bound specified by the Range Query. Range Queries can be inclusive or exclusive of the upper and lower bounds. Sorting is done lexicographically.

      mod_date:[20020101 TO 20030101]

      This will find documents whose mod_date fields have values between 20020101 and 20030101, inclusive. Note that Range Queries are not reserved for date fields. You could also use range queries with non-date fields:

      title:{Aida TO Carmen}

      This will find all documents whose titles are between Aida and Carmen, but not including Aida and Carmen.

      Inclusive range queries are denoted by square brackets. Exclusive range queries are denoted by curly brackets. 

      Boosting a Term

      Lucene provides the relevance level of matching documents based on the terms found. To boost a term use the caret, "^", symbol with a boost factor (a number) at the end of the term you are searching. The higher the boost factor, the more relevant the term will be.

      Boosting allows you to control the relevance of a document by boosting its term. For example, if you are searching for

      jakarta apache

      and you want the term "jakarta" to be more relevant boost it using the ^ symbol along with the boost factor next to the term. You would type:

      jakarta^4 apache

      This will make documents with the term jakarta appear more relevant. You can also boost Phrase Terms as in the example:

      "jakarta apache"^4 "Apache Lucene"

      By default, the boost factor is 1. Although the boost factor must be positive, it can be less than 1 (e.g. 0.2)

      Boolean Operators

      Boolean operators allow terms to be combined through logic operators. Lucene supports AND, "+", OR, NOT and "-" as Boolean operators(Note: Boolean operators must be ALL CAPS). 

      OR

      The OR operator is the default conjunction operator. This means that if there is no Boolean operator between two terms, the OR operator is used. The OR operator links two terms and finds a matching document if either of the terms exist in a document. This is equivalent to a union using sets. The symbol || can be used in place of the word OR.

      To search for documents that contain either "jakarta apache" or just "jakarta" use the query:

      "jakarta apache" jakarta

      or

      "jakarta apache" OR jakarta

      AND

      The AND operator matches documents where both terms exist anywhere in the text of a single document. This is equivalent to an intersection using sets. The symbol && can be used in place of the word AND.

      To search for documents that contain "jakarta apache" and "Apache Lucene" use the query:

      "jakarta apache" AND "Apache Lucene"

      +

      The "+" or required operator requires that the term after the "+" symbol exist somewhere in a the field of a single document.

      To search for documents that must contain "jakarta" and may contain "lucene" use the query:

      +jakarta lucene

      NOT

      The NOT operator excludes documents that contain the term after NOT. This is equivalent to a difference using sets. The symbol ! can be used in place of the word NOT.

      To search for documents that contain "jakarta apache" but not "Apache Lucene" use the query:

      "jakarta apache" NOT "Apache Lucene"

      Note: The NOT operator cannot be used with just one term. For example, the following search will return no results:

      NOT "jakarta apache"

      -

      The "-" or prohibit operator excludes documents that contain the term after the "-" symbol.

      To search for documents that contain "jakarta apache" but not "Apache Lucene" use the query:

      "jakarta apache" -"Apache Lucene"

      Grouping

      Lucene supports using parentheses to group clauses to form sub queries. This can be very useful if you want to control the boolean logic for a query.

      To search for either "jakarta" or "apache" and "website" use the query:

      (jakarta OR apache) AND website

      This eliminates any confusion and makes sure you that website must exist and either term jakarta or apache may exist.

      Field Grouping

      Lucene supports using parentheses to group multiple clauses to a single field.

      To search for a title that contains both the word "return" and the phrase "pink panther" use the query:

      title:(+return +"pink panther")

      Escaping Special Characters

      Lucene supports escaping special characters that are part of the query syntax. The current list special characters are

      + - && || ! ( ) { } [ ] ^ " ~ * ? : \ /

      To escape these character use the \ before the character. For example to search for (1+1):2 use the query:

      \(1\+1\)\:2


      Interface Summary
      Interface Description
      QueryParserConstants
      Token literal values and constants.


      Class Summary
      Class Description
      MultiFieldQueryParser
      A QueryParser which constructs queries to search multiple fields.
      QueryParser
      This class is generated by JavaCC.
      QueryParserBase
      This class is overridden by QueryParser in QueryParser.jj and acts to separate the majority of the Java code from the .jj grammar file.
      QueryParserTokenManager
      Token Manager.
      Token
      Describes the input token stream.
      Enum Summary
      Enum Description
      QueryParser.Operator
      The default operator for parsing queries.
      Exception Summary
      Exception Description
      ParseException
      This exception is thrown when parse errors are encountered.
      Error Summary
      Error Description
      TokenMgrError
      Token Manager Error.