Skip to content

Get employee

employees.retrieve(employee_id) -> EmployeeRetrieveResponse { data }
GET/v1/employees/{employee_id}

Retrieves detailed information for a specific employee by ID. Returns employee details including personal information, employment status, and payroll deductions from the most recent statement period. Deductions reflect a snapshot of the current period and are replaced when a new statement is generated.

ParametersExpand Collapse
employee_id: String

Unique employee identifier (empl_*)

ReturnsExpand Collapse
class EmployeeRetrieveResponse { data }

Response containing a single employee resource.

data: Employee { id, created_at, date_of_birth, 15 more }
id: String

Unique employee identifier with ‘empl_’ prefix

created_at: Time

Timestamp when the employee was created

formatdate-time
date_of_birth: Date

Date of birth (YYYY-MM-DD)

formatdate
deductions: Array[{ benefit_name, deduction_amount_in_cents, deduction_category, 4 more}]

Payroll deductions from the most recent statement period. Replaced when a new statement is generated.

benefit_name: String

Name of the benefit plan

deduction_amount_in_cents: Integer

Employee deduction amount in cents

deduction_category: String

Deduction category (reserved for future use)

frequency: :weekly | :bi_weekly | :semi_monthly | :monthly
  • weekly - Weekly
  • bi_weekly - Bi Weekly
  • semi_monthly - Semi Monthly
  • monthly - Monthly
One of the following:
:weekly
:bi_weekly
:semi_monthly
:monthly
period_end_date: Date

Period end date (YYYY-MM-DD)

formatdate
period_start_date: Date

Period start date (YYYY-MM-DD)

formatdate
tax_classification: :Unknown | :"Pre-tax" | :"Post-tax"
  • Unknown - Unknown
  • Pre-tax - Pre Tax
  • Post-tax - Post Tax
One of the following:
:Unknown
:"Pre-tax"
:"Post-tax"
email: String

Email address

formatemail
first_name: String

Employee’s legal first name

last_name: String

Employee’s legal last name

member_id: String

Unique member identifier with ‘mbr_’ prefix

status: String

Employee status (active or terminated)

updated_at: Time

Timestamp when the employee was last updated

formatdate-time
address: { address_line_1, city, state, 2 more}

Employee’s residential address

address_line_1: String

Primary street address

city: String

City name

state: String

Two-letter state code (e.g., CA, NY)

zipcode: String

ZIP code (5 or 9 digit)

address_line_2: String

Secondary street address (apt, suite, etc.)

employee_class: EmployeeClass
  • Full Time - Full Time
  • Part Time - Part Time
  • Temporary - Temporary
  • Intern - Intern
  • Seasonal - Seasonal
  • Individual Contractor - Individual Contractor
One of the following:
:"Full Time"
:"Part Time"
:Temporary
:Intern
:Seasonal
:"Individual Contractor"
gender: String

Gender identity, if provided

hire_date: Date

Employee’s hire date with the employer

formatdate
phone: String

Phone number (10-digit US domestic string)

reference_id: String

Partner-assigned reference ID for the employee

suffix: String

Name suffix (e.g., Jr., Sr., III)

termination_date: Date

Employee’s termination date, if terminated

formatdate

Get employee

require "vitable_connect"

vitable_connect = VitableConnect::Client.new(
  api_key: "My API Key",
  environment: "environment_1" # defaults to "production"
)

employee = vitable_connect.employees.retrieve("empl_abc123def456")

puts(employee)
{
  "data": {
    "id": "empl_abc123",
    "member_id": "mbr_xyz789",
    "reference_id": "partner-ee-001",
    "first_name": "John",
    "last_name": "Doe",
    "suffix": null,
    "email": "john.doe@example.com",
    "date_of_birth": "1985-06-15",
    "gender": null,
    "phone": "4155551234",
    "employee_class": "Full Time",
    "status": "active",
    "hire_date": "2023-01-15",
    "termination_date": null,
    "address": {
      "address_line_1": "456 Oak Avenue",
      "address_line_2": "Apt 2B",
      "city": "San Francisco",
      "state": "CA",
      "zipcode": "94102"
    },
    "deductions": [
      {
        "deduction_category": null,
        "deduction_amount_in_cents": 5000,
        "tax_classification": "pre_tax",
        "frequency": "monthly",
        "benefit_name": "Gold PPO Plan",
        "period_start_date": "2025-01-01",
        "period_end_date": "2025-01-31"
      }
    ],
    "created_at": "2023-01-15T09:00:00Z",
    "updated_at": "2024-06-01T14:30:00Z"
  }
}
Returns Examples
{
  "data": {
    "id": "empl_abc123",
    "member_id": "mbr_xyz789",
    "reference_id": "partner-ee-001",
    "first_name": "John",
    "last_name": "Doe",
    "suffix": null,
    "email": "john.doe@example.com",
    "date_of_birth": "1985-06-15",
    "gender": null,
    "phone": "4155551234",
    "employee_class": "Full Time",
    "status": "active",
    "hire_date": "2023-01-15",
    "termination_date": null,
    "address": {
      "address_line_1": "456 Oak Avenue",
      "address_line_2": "Apt 2B",
      "city": "San Francisco",
      "state": "CA",
      "zipcode": "94102"
    },
    "deductions": [
      {
        "deduction_category": null,
        "deduction_amount_in_cents": 5000,
        "tax_classification": "pre_tax",
        "frequency": "monthly",
        "benefit_name": "Gold PPO Plan",
        "period_start_date": "2025-01-01",
        "period_end_date": "2025-01-31"
      }
    ],
    "created_at": "2023-01-15T09:00:00Z",
    "updated_at": "2024-06-01T14:30:00Z"
  }
}