With the documents endpoint files like certificates and other kind of documents can be uploaded for an employee to the Visma Personal File System (Personeelsdossier).
The API supports the following types of documents
certificate (Certificaat)
diploma (Diploma)
career agreement (Loopbaan afspraak)
career mail (Correspondentie loopbaan)
career other (Overige loonbaan documenten)
appraisal Review (Beoordelingsgesprek)
performance Review (Functioneringsgesprek)
As-synchronized file upload
Learning systems can upload files, like certificates, diplomas for individual employees to the Personal File System of Visma Raet. The file upload is an a-synchronized process. After the file is uploaded the consumer will receive a ticket Id, which can be used to monitor the process of the file upload.
Endpoints
The API supports the following type of documents:
API endpoint
Personal file system
endpoint
Document type
Description
learning/v1.0/employees/ {personCode}/documents/certificate
certificaat
Certificaat
learning/v1.1/employees/ {personCode}/documents/certificate
certificaat
Certificaat
learning/v1.1/employees/ {personCode}/documents/diploma
diploma
Diploma
learning/v1.1/employees/ {personCode}/documents/appraisalReview
beoordelingsGesprek
Beoordelingsgesprek
learning/v1.1/employees/ {personCode}/documents/performanceReview
functioneringsGesprek
Functioneringsgesprek
learning/v1.1/employees/ {personCode}/documents/careerAgreement
loopbaanafspraken
Loonbaan afspraken
learning/v1.1/employees/ {personCode}/documents/careerMail
corrLoopbaan
Correnspondentie loopbaan
learning/v1.1/employees/ {personCode}/documents/careerOther
ovLoopbaan
Overige loonbaan documenten
Note:
v1.1 is using Content-Type: multipart/form-data and supports the other document types as well.
v1.0 is using Content-Type: multipart/related and supports only certificates. We are advice you the use the latest version of an endpoint
To upload a document you need to use the POST method. For example POST https://api.youforce.com//learning/v1.1/employees/{personCode}/documents/diploma
for uploading a diploma to the Personal File System of Visma Raet. The endpoint returns a ticketId . The file will be stored in a standard folder for diplomas (see table for the other endpoints)
The API will automatically upload the file to the Personal File System. This is an a-synchronized process with an automatic retry mechanism in case the file systems is not available. The retry mechanism will try to upload the file in a maximum of 6 hours. After this period the file will be rejected with a message. Also if the file is too big (maximum 4 Mb) or isn’t a PDF file, the upload will be rejected.
GET documents/{TicketId}/status Endpoint for getting the status of the file upload. The endpoint will return the status of the file. After the file is processed successfully the status Complete is returned.
Examples
version 1.1 (all document types)
Use POST request with multipart/form-data content type.
Replace the PersonCode in the URL with the Id of the employee
Use the authentication token received from the authentication endpoint
Replace the tenant code with the tenant code of the client
Give the document a proper description
The field validFrom is optional. If it's empty the system date will be used as default
The content-type for the file is application/pdf Other type of files will be rejected by the API. The file size is also limited to a maximum of 4 Mb
Response
Example of the response.
HTTP/1.1 200 Content-Type: application/json { "ticketId": "7ca486f6-c730-4d50-a2ec-31a3a1373366", "description": "Example description", "size": 77491, "tenantId": "4028868", "creationDateTime": "2022-04-01T13:53:30.3985949", "status": "InProgress", "errorMessages": [] }
version 1.0 (certificates only)
Use POST request with multipart/related content type with the first part having metadata in json format and the second one having a file.
Replace the PersonCode in the URL with the Id of the employee
Use the authentication token received from the authentication endpoint
Replace the tenant code with the tenant code of the client
Give the document a proper description
The content-type of the metadata is application/json The content-type for the file is application/pdf Other type of files will be rejected by the API. The file size is also limited to a maximum of 4 Mb
POST https://api.youforce.com/learning/V1.0/api/employees//documents/certificate Authorization: Bearer [YOUR_AUTH_TOKEN] Content-Type: multipart/related; boundary=boundary_not_used_within_file_content --boundary_not_used_within_file_content Content-Type: application/json; charset=UTF-8 { "Description":"YOUR_OWN_DESCRIPTION", "ValidFrom" : "2021-01-01" } --boundary_not_used_within_file_content Content-Type: application/pdf [PDF Content] --boundary_not_used_within_file_content--
Upload status
After the file is posted to the API, the file upload can be followed with the status endpoint. Replace the TicketId in the URL with the ticketId from the previous API call.
GET https://api.youforce.com/learning/v1.0/employees/documents/{{TicketId}}/status
The API will return the status of the file upload. If the API could not upload the file, an error is shown as well.
Response
{ "status": "Complete", "errorMessages": [] }
This document describes the ‘De leerrekening (EduBookers) - Visma Raet Learning API’ - connector. This connector has been built on top of the Visma Raet Learning API.
De Recruitment api heeft de status Controlled Available en is enkel nog beschikbaar in overleg met Visma Raet.
De Recruitment API beschikt over een autorisatie mechanisme waarmee bepaald kan worden tot welke medewerkers en datasets een recruitment systeem toegang heeft.
Het autorisatie mechanisme bestaat uit de volgende onderdelen:
Autorisatie op basis van API scopes Door het activeren van scopes kunnen externe systemen toegang krijgen tot één of meerdere endpoint en dataset. De scopes zijn vooraf door Visma Raet bepaald en omvatten één of meerdere endpoints, dataset en/of acties.
Autorisatie op medewerkers Met behulp van autorisaties filters kan worden bepaald welke medewerkers in de API beschikbaar komen.
Met dit document willen wij u informeren over de mogelijkheden van deze autorisatievormen in de API. Beide autorisatie mechanismes moeten door een consultant ingericht worden.
Autorisatie op basis van API scopes In de Visma developer portal zijn per API één of meerdere scopes gedefinieerd. Door het activeren van deze scope krijgt een extern systeem toegang tot één of meerdere endpoint en/of data set. Binnen de API worden de volgende scopes onderscheiden.
Scope
Omschrijving
Endpoints
Invitation_only
Scope noodzakelijk om de API te kunnen activeren. Tijdens het activering proces wordt de contractafspraken gecontroleerd en vastgelegd. Deze scope geeft nog geen toegang tot enige vorm van data maar is noodzakelijk voor de onboarding van klanten op de API of applicatie
-
Get_Basic
Get basic data zoals medewerker- & organisatiedata
GET persons GET employments GET organizationUnits GET roleAssignments GET jobProfiles
GetPrivateContactDetails
Voegt de privé contactgegevens aan de endpoint Person & Employee, zoals post- en woonadres, telefoonnummer vast & mobiel en het email adres.
GET persons
Dit betreft de volgende gegevens: ADRESGEVENS
Home:
P01014 straatnaam P01016 Huisnummer P01018 Huisnummer toev P01020 Postcode P01022 Plaatsnaam P01024 Land
Postal:
P00365 straatnaam P00367 huisnummer P00368 huisnummer toev P00313 postcode P00308 plaatsnaam P00847 land
TELEFOONNUMMERS Home: P01027 - telefoonnr woonadres
Mobile : P01036 - Telefoonnr mobiel
EMAILADRES
Prive: P01034 - E-mail adres privé
HSS_startWorkflow
Scope voor het starten van workflows voor een nieuwe medewerker, nieuw contract of het wijzigen van een bestaat contract.
POST hires POST Contracts POST Contracts/Adjustments
Uw consultant kan u helpen bij het activeren / deactiveren van deze scopes binnen de API.
Autorisatie op basis van autorisatie filters
De autorisatie filters hebben betrekking op welke medewerkers zichtbaar zijn in de API. Standaard worden altijd alle medewerkers getoond in de API. Bij het activeren van de API kan een consultant filters inrichten zodat maar een beperkte groep medewerkers via de API beschikbaar komen.
Filteren in de API is mogelijk op de volgende Beaufort velden:
P01102- Soort Arbeidsrelatie
P01103- Opdrachtgever
P01104- Instelling
P01110 - Code doelgroep
P05045 - Selectierubriek Recruitment API
Een veel voorkomen filter is bijvoorbeeld op Soort Arbeidsrelatie waarbij alleen eigen medewerkers in het extern systeem opgenomen worden. Maar ook een filter op de combinatie Opdrachtgever / Instelling geeft u de mogelijkheid om de medewerkers van één of meerdere specifieke instellingen in de API op te nemen.
Uw consultant kan u helpen bij het inrichten of wijzigen van de autorisatie filters.