This article explains how to set up the 'write-back' integration between Arbor and SAMpeople, allowing HR data such as employee details, contracts, salaries, and absences to flow from SAMpeople to Arbor. It covers permissions needed, data synchronization, field mapping, and setup instructions, ensuring SAMpeople serve as the single source of truth for HR data.
Permissions
- School: User Accounts: Administer - Approve the API connection
- Integrations: Administer All Integrations - Access the Integrations Administration page to set up the integration in Arbor
If you don't have the permission, you'll need to ask your admin team to give you permission using these instructions.
What is included in the integration?
The integration includes the following areas of Staff HR data:
- Staff/Employee Profile
- Staff/Employee Contract
- Staff/Employee Contract Salary
- Staff/Employee Absence
Data is synced to Arbor immediately after a change is made to one of the above areas in SAMpeople.
Field mapping
In each table, the column on the left shows the SAMpeople entity, and on the right is the Arbor entity.
Employee | Staff or Person |
Firstname | LegalFirstName |
Surname | LegalLastName |
PreferredFirstName | Preferred FirstName |
PreferredSurname | PreferredLastName |
SexId | Gender |
Title | Title |
Ethnicity | Ethnicity |
Religion | Religion |
EmailAddress | |
WorkEmail | WorkEmail (Set EmailAddressType to WORK) |
HomeEmail | HomeEmail (Set EmailAddressType to PERSONAL) |
TelephoneNumber | |
HomeTel | Home Telephone (Set TelephoneNumberTypeto HOME) |
WorkTel | Work Telephone (Set TelephoneNumberTypeto WORK) |
HomeMobile | Home Mobile (Set TelephoneNumberTypeto MOBILE) |
WorkMobile |
Work Mobile (Set TelephoneNumberTypeto WORK_MOBILE) |
PostalAddress + PostAddressOccupancy | |
AddressLine1 | Address1 |
AddressLine2 | Address2 |
Town | PostalTown |
County | County |
Postcode | PostalCode |
N/A | PostalAddressType (Set PostalAddressType to HOME) |
StaffContract | |
Position -> PositionName | ContractName |
Position -> PositionName | ContractReference |
EmployeeContractType -> Description | EmployeeType |
EmployeeContract -> ContractStartDate | Issued Date |
EmployeeContract -> ContractStartDate | Issued Date |
EmployeeContract -> ContractStartDate | Start Date |
EmployeeContract -> ContractEndDate | End Date |
EmployeeContract -> ContractEndDate | Expected End Date |
Employee -> Payroll Number | Payroll Number |
StaffContractPost + Position | |
Position -> PositionName | JobTitle |
EmployeeContract -> ContractStartDate | OfferedDate (contract start date) |
EmployeeContract -> ContractStartDate | AcceptedDate (contract start date) |
EmployeeContract -> ContractStartDate | StartDate |
EmployeeContract -> ContractEndDate | EndDate |
BusinessRole | |
EmployeeContract -> ContractStartDate | StartDate |
StaffContractPostSalary | |
EmployeeContractSalary -> StartDate | StartDate |
EmployeeContractSalary -> EndDate | EndDate |
Calculated field | GrossSalary |
EmployeeContractSalary -> HoursPerWeek | FTEHoursPerWeek |
EmployeeContractSalary -> WeeksPerYear | FTEWeeksPerYear |
EmployeeContractSalary -> PayScaleCode | PayScale |
EmployeeContractSalary -> PayScalePointCode or EmployeeContractSalary -> CustomValue |
PayScaleSpinalPoint or GrossSalary |
StaffAbsence | |
StartDate | StartDateTime |
EndDate | EndDateTime |
AbsenceType -> ExternalId | AbsenceCategory |
IllnessCategory -> ExternalId | SicknessCategory |
Sum of AbsenceDays -> ContractDayPart | WorkingDays |
Sum of AbsenceDays -> ContractDayHours | WorkingHours |
Before setting up the integration
- Check email addresses - Arbor stores email address once per address. If the SP employee in SAMpeople has the same email address for both Work and Home, only the Work email would be added.
- Check Positions - Ensure the Employee Positions in SAMpeople are matched to the Position list in Arbor. If they don't match, data won't be written from SAMpeople into Arbor. See how to manage Positions here : Setting Positions, Position Categories and Census Business Roles for the Workforce Census.
-
Check business roles: - Ensure the Business Role in Arbor links to the Position so staff are assigned a Business Role. If they are not, write back sync will succeed, but the staff member won’t be visible in the current staff list in Arbor. Staff Positions in Arbor can be linked to Business Roles from the same positions page as detailed in the article linked above.
- If you want the SAMpeople integration to automatically assign a business role to staff profiles created by the sync, Staff Positions in Arbor can be linked to Business Roles from the same positions page as detailed in the article linked above.
- If you want to manually assign business roles or permissions in Arbor, new staff won't appear in current staff lists and won't be able to log in until they are given a business role: Adding a Business Role to a member of staff.
- Consider restricting permissions - As Staff profile data and Absence data will be controlled in SAMpeople when the integration is enabled, consider restricting user’s permissions to edit these areas in Arbor. You can do this by removing the permissions associated with a Business Role.
Setting up the integration
- First, ensure you have purchased the integration for use with Arbor. You can purchase this or check this by contacting our Partnership Team (customersales@arbor-education.com)
- Request that the integration is enabled by the FEPS support team, via support@staffabsencemanagement.co.uk or by creating a ticket in the FEPS support system.
- FEPS will send the request to your Arbor site. You can approve the integration from System > Partner Apps (API Users): Setting up and managing 3rd Party API Integrations
Checking for a Successful Write Back
In Arbor, you can check for a successful write back by looking at the Staff Profile and checking that the employee data from SAMpeople has either been added or updated in Arbor.
- To see all staff absence data in Arbor, follow this article: Staff Absences
- Absence data sent to Arbor can then be used to manage staff cover. Follow this article: Manage cover
Using the integration in Arbor
Once enabled in SAMpeople, all existing employees will be linked to the corresponding staff record in Arbor. This creates the Arbor ID in the background which is used as the unique identifier on subsequent edits to this data in SAMpeople.
- Update staff details in SAMpeople and it will automatically pull through to Arbor.
- Absences entered into SAMpeople will be immediately available in Arbor for cover purposes.
Top Tip: The Absence type of Sickness in SAMpeople will write back into the Arbor absence category Sickness Certification Unknown.
It is possible to record staff details in Arbor directly. It isn't possible to disable this, so please advise your staff to update in SAMpeople to ensure data is synced across both systems.
Further Support
Please contact the SAMpeople support team via support@staffabsencemanagement.co.uk or via https://fusioneps.freshdesk.com/.
The SAMpeople team will contact Arbor’s API Support Team directly if needed.
FAQ
With this new write-back integration, SAMpeople is treated as the controlling system for Staff/HR/Salary/Absence data.
No, when configured in write back mode, SAMpeople should be the source of truth for staff absence data. Staff absences recorded in SAMpeople will be synced back to Arbor. Arbor will then automatically generate Staff Cover requests. Alternatively, SAMpeople offers a read integration that reads data from Arbor and into SAMpeople, where Arbor is the source of truth for staff & absence.
The School Workforce Census can be completed in either Arbor or SAMpeople.
Pay Scales need to be updated in both Arbor and SAMpeople.
Data is synced to Arbor immediately after a change is made in SAMpeople.
Comments
Article is closed for comments.