Skip to Content
🚀 Welcome to Humansoft Open API Documentation

Get Leave List

ดึงรายการคำขอลาตามเงื่อนไขที่กำหนด พร้อมรองรับการ filter และ pagination

ใช้ API นี้เพื่อดึงรายการคำขอลา ติดตามสถานะการอนุมัติ หรือสร้างรายงานสรุป

Endpoint

GET /api/v1/open-apis/time-leave/get-list

Request Parameters

Required Parameters

ParameterTypeRequiredDescriptionExample
start_datestringYesวันที่เริ่มต้น (YYYY-MM-DD)2026-01-01
end_datestringYesวันที่สิ้นสุด (YYYY-MM-DD)2026-01-31

Optional Parameters

ParameterTypeRequiredDescriptionExample
approve_flagstringNoสถานะการอนุมัติ (01, 02, 03)01
absence_flag_lvstringNoประเภทการลา (absence-01 หรือ 01)absence-01
keywordstringNoคำค้นหา (ชื่อ, รหัสพนักงาน)สมชาย
branch_idstringNoID สาขาQlIwMDE=
department_idstringNoID แผนกREVQMDE=
sort_bystringNoเรียงตาม fieldeffective_hour
sort_orderstringNoลำดับการเรียง (ASC, DESC)DESC
_PAGEnumberNoหน้าที่ต้องการ1
_NUMBER_PER_PAGEnumberNoจำนวนรายการต่อหน้า (1-1000)20

Approve Flag Values

ValueStatusDescription
01Pendingรออนุมัติทั้งหมด (รวม 04-08)
02Approvedอนุมัติแล้ว
03Not Approvedไม่อนุมัติ

Sort By Options

  • effective_hour - เวลาเริ่มต้นการลา (default)
  • employee_code - รหัสพนักงาน
  • approve_flag - สถานะการอนุมัติ
  • created - วันที่สร้าง
  • absence_day - จำนวนวันลา

Response Format

Success Response (HTTP 200)

{ "code": 200, "message": "สำเร็จ", "payload": [ { "time_leave_id": "VExWMDAxMjM=", "employee_code": "EMP001", "employee_name": "สมชาย", "employee_last_name": "ใจดี", "employee_nickname": "ชาย", "employee_name_en": "Somchai", "employee_last_name_en": "Jaidee", "employee_nickname_en": "Chai", "absence_flag_lv": "absence-01", "absence_flag_name": "ลาป่วย", "absence_flag_name_en": "Sick Leave", "effective_dt": "2026-01-15", "expire_dt": "2026-01-15", "effective_hour": "2026-01-15 08:00:00", "expire_hour": "2026-01-15 17:00:00", "absence_day": 1.0, "absence_sum_time": 8.0, "time_leave_desc": "ไม่สบาย มีไข้", "approve_flag": "01", "approve_status": "Pending", "approve_id": "QVBQMDAxMjM=", "approve_upd": "2026-01-13 10:30:00", "approve_remark": "", "created": "2026-01-13 09:00:00", "created_by": "EMP001", "last_upd": "2026-01-13 10:30:00", "last_upd_by": "EMP001" } ], "_PAGINATION": { "_TOTAL_RECORDS": 25, "_PAGE": 1, "_NUMBER_PER_PAGE": 20 } }

Success Response - No Data (HTTP 200)

{ "code": 200, "message": "สำเร็จ", "payload": [], "_PAGINATION": { "_TOTAL_RECORDS": 0, "_PAGE": 1, "_NUMBER_PER_PAGE": 0 } }

Error Response (HTTP 400)

{ "code": 400, "message": "ไม่สำเร็จ", "errors": [ "Missing required parameter: 'start_date'", "'end_date' must be in format YYYY-MM-DD" ] }

Response Fields

FieldTypeDescription
time_leave_idstringID ของคำขอลา
employee_codestringรหัสพนักงาน
employee_namestringชื่อพนักงาน (ไทย)
employee_last_namestringนามสกุลพนักงาน (ไทย)
employee_nicknamestringชื่อเล่น (ไทย)
employee_name_enstringชื่อพนักงาน (อังกฤษ)
employee_last_name_enstringนามสกุลพนักงาน (อังกฤษ)
employee_nickname_enstringชื่อเล่น (อังกฤษ)
absence_flag_lvstringรหัสประเภทการลา
absence_flag_namestringชื่อประเภทการลา (ไทย)
absence_flag_name_enstringชื่อประเภทการลา (อังกฤษ)
effective_dtstringวันที่เริ่มต้น (YYYY-MM-DD)
expire_dtstringวันที่สิ้นสุด (YYYY-MM-DD)
effective_hourdatetimeเวลาเริ่มต้น
expire_hourdatetimeเวลาสิ้นสุด
absence_daynumberจำนวนวันลา
absence_sum_timenumberจำนวนชั่วโมงลารวม
time_leave_descstringรายละเอียด/เหตุผล
approve_flagstringรหัสสถานะการอนุมัติ
approve_statusstringชื่อสถานะการอนุมัติ
approve_idstringID ผู้อนุมัติ
approve_upddatetimeวันเวลาที่อนุมัติ
approve_remarkstringหมายเหตุการอนุมัติ
createddatetimeวันเวลาที่สร้าง
created_bystringผู้สร้าง
last_upddatetimeวันเวลาที่แก้ไขล่าสุด
last_upd_bystringผู้แก้ไขล่าสุด

Code Examples

curl -X GET "https://openapi.humansoft.co.th/api/v1/open-apis/time-leave/get-list?start_date=2026-01-01&end_date=2026-01-31&approve_flag=01&_NUMBER_PER_PAGE=20" \ -H "Ocp-Apim-Subscription-Key: YOUR_API_KEY"

Validation Rules

ParameterValidationError Message
start_dateต้องระบุและรูปแบบ YYYY-MM-DDMissing required parameter: 'start_date'
end_dateต้องระบุและรูปแบบ YYYY-MM-DDMissing required parameter: 'end_date'
end_dateต้อง >= start_date'end_date' must be greater than or equal to 'start_date'
approve_flagต้องเป็น 01, 02, หรือ 03'approve_flag' must be one of: 01, 02, 03
absence_flag_lvต้องเป็น 01-08 หรือ 10-20'absence_flag_lv' must be 01 to 08 or 10 to 20
_NUMBER_PER_PAGEต้องเป็นตัวเลข 1-1000'_NUMBER_PER_PAGE' must be a number between 1 and 1000

Notes

  • approve_flag = '01' จะดึงรายการที่รออนุมัติทุกระดับ (01, 04-08)
  • absence_flag_lv รองรับทั้งรูปแบบ absence-01 และ 01
  • การค้นหาจะรวมทุกวันที่ที่ช่วงการลาทับซ้อนกับช่วงที่ระบุ

Use Cases

  1. แสดงรายการรออนุมัติ - ใช้ approve_flag=01 เพื่อดึงคำขอที่รออนุมัติ
  2. ค้นหาตามพนักงาน - ใช้ keyword เพื่อค้นหา
  3. รายงานประจำเดือน - ใช้ start_date และ end_date ของเดือนนั้น
  4. Filter ตามแผนก - ใช้ department_id เพื่อกรองตามแผนก
  5. Filter ตามประเภทการลา - ใช้ absence_flag_lv เพื่อกรองตามประเภท

Error Handling

ErrorCauseSolution
Missing required parameter: 'start_date'ไม่ได้ส่ง start_dateตรวจสอบ query parameter
'start_date' must be in format YYYY-MM-DDรูปแบบวันที่ไม่ถูกต้องใช้รูปแบบ YYYY-MM-DD
'end_date' must be greater than or equal to 'start_date'end_date น้อยกว่า start_dateตรวจสอบช่วงวันที่
  • Get Leave Types - ดึงรายการประเภทการลา
  • Submit Leave - ยื่นคำขอลาใหม่
Last updated on