Skip to content

Tools4everBV/HelloID-Conn-Prov-Source-Visma.net-HRM-API

Repository files navigation

HelloID-Conn-Prov-Source-Visma.net-HRM-API

ℹ️ Information
This repository contains the connector and configuration code only. The implementer is responsible to acquire the connection details such as username, password, certificate, etc. You might even need to sign a contract or agreement with the supplier before implementing this connector. Please contact the client's application manager to coordinate the connector requirements.
⚠️ Warning
The latest version of this connector no longer uses the uniqueId. Visma will also no longer generate this uniqueId. We will now use Person Aggregation in HelloID. If you are upgrading an existing implementation, make sure to validate the data and person aggregation.

Versioning

Version Description Date
3.0.0 Release of v3 connector with updated logging and performance and no longer using uniqueId 2023/02/03
2.0.0 Release of v2 connector including support for aggregation, multiple contracts and department manager lookup 2022/11/07
1.1.0 Added support to only import contracts X days in past at most 2022/08/03
1.0.0 Initial release 2021/10/04

Table of contents

Introduction

Visma is an HR System and provides a set of REST API's that allow you to programmatically interact with it's data. The HelloID connector uses the API endpoints listed below.

  • /hrm/employees (Persons & Departments script)
  • /hrm/employees/user-defined-field-histories (Persons script)
  • /hrm/contracts (Persons script, optional)
  • /hrm/contracts/user-defined-field-histories (Persons script)
  • /nl/hrm/metadata/cost-centers (Persons script)
  • /nl/hrm/users (Persons & Departments script)
  • /nl/hrm/metadata/organization-units (Departments script)

Visma.net HRM documentation

Please see the following website about the Visma.net HRM API documentation.

Note: These end-points do return a lot of information. Some of these fields are excluded in the API call. Please be aware that the exclusion is applied correctly and that this does not prevent access to this data (it only limits the data send)

Getting started

By using this connector you will have the ability to retrieve employee and contract data from the Visma.NET HR system.

Scope Configuration within Visma

Before the connector can be used to retrieve employee information, the following scopes need to be enabled and assigned to the connector. If you need help setting the scopes up, please consult your Visma contact.

  • hrmanalytics:nlhrm:exportemployees
  • hrmanalytics:nlhrm:exportcontracts
  • hrmanalytics:nlhrm:exportorganizationunits
  • hrmanalytics:nlhrm:exportmetadata
  • hrmanalytics:nlhrm:exportusers

Note: If one of the scopes is missing, the connector will throw a '401 Unauthorized' exception

Optional:

  • hrmanalytics:nlhrm:exportcontactinformation (to retrieve personal data like private mailaddress)

    Note: make sure to toggle the option IncludePersonalData to include the scope 'hrmanalytics:nlhrm:exportcontactinformation' in the import scripts.

Please see the Visma HRM API documentation for more information on the required scopes per attribute. For the employee attributes, see: NLHrmEmployeeCsvDto

Person Aggregation

By default, for each contract Visma creates a new employee record (with a new employeeID). Therefore, aggregation is needed. We have provided an example for aggregation in the mapping. Please make sure to validate this and the results.

Note: Because aggregation is required, personal data, e.g., birthdate and birthplace are required. Make sure these fields are available.

Cloud agent compatibilty

The HelloID-Conn-Prov-Source-Visma.net-HRM-API connector is created for both Windows PowerShell 5.1 and PowerShell Core. This means that the connector can be executed in both cloud and on-premises using the HelloID agent.

Connection settings

The following settings are required to connect to the API.

Setting Description Mandatory
Client ID The Client ID to connect to the Visma.NET HRM API (created when registering the App in in the Visma Developer portal). Yes
Client Secret The Client Secret to connect to the Visma.NET HRM API (created when registering the App in in the Visma Developer portal). Yes
Tenant ID The Tenant ID to specify to which tenant to connect to the Visma.NET HRM API(available in the Visma Developer portal after the invitation code has been accepted). Yes
Cut Off Days Amount of days expired contracts stay in scope. No
Exclude persons without contracts in HelloID Exclude persons without contracts in HelloID yes/no. No
Toggle debug logging Toggle Debug logging yes/no. When toggled, debug logging will be displayed. When set to true individual actions are logged. This may cause lots of logging, so use with cause No

Contents

Files Description
Configuration.json The configuration settings for the connector
Persons.ps1 Retrieves the person and contract data
Departments.ps1 Retrieves the department data
Mapping.json A basic mapping for both persons and contracts

Remarks

Complexity in how data must be retrieved from the Visma.Net HRM API

The data from Visma must be gathered in five different stages.

  1. Request token
  2. Request a data export (with a valid token)
  3. Check (in a loop) whether or not the export is ready for download.
  4. Download the export
  5. Import the data into HelloID

The third stage (check if the export is ready for download) returns a json object containing the status of the export.

{
    "changeTimestampBefore": null,
    "employeeFileUris": null,
    "status": "InProgress"
}

When the is export is ready, the status changes to Completed. The connector will continously check the status until it has changed to Completed. Now, this works fine on our test environment. However, in a real life environment, there might be a situation where the status won't change to Completed and you end up with an endless loop. We haven't experienced this behavior ourselves but it's good to be aware of it.

Setup the connector

For help setting up a new source connector, please refer to our documentation

Change history

File Version Changes
persons.p1 3.0.0
  • Release of v3 connector with updated logging and performance and no longer using uniqueId
departments.p1 3.0.0
  • Release of v3 connector with updated logging and performance and no longer using uniqueId
persons.p1 2.0.0.0
  • Release of v2 connector including support for aggregation, multiple contracts and department manager lookup
departments.p1 2.0.0.0
  • Release of v2 connector including support for aggregation, multiple contracts and department manager lookup
persons.p1 1.0.0.1
  • Added 'user-defined-fields' for both persons and contracts
  • Updated errorhandling
departments.p1 1.0.0.1
  • Updated errorhandling
persons.p1 1.0.0.0
  • Initial release
departments.p1 1.0.0.0
  • Initial release

Getting help

If you need help, feel free to ask questions on our forum

HelloID Docs

The official HelloID documentation can be found at: https://docs.helloid.com/