Skip to Content
🚀 Welcome to Humansoft Open API Documentation

Approve Work Cycle Change

อนุมัติหรือปฏิเสธเอกสารเปลี่ยนกะการทำงาน รองรับการอนุมัติแบบหลายขั้นตอน (Multi-level Approval)

ใช้ API นี้เพื่ออนุมัติ ปฏิเสธ หรือยกเลิกเอกสารเปลี่ยนกะ เมื่ออนุมัติขั้นสุดท้ายระบบจะเปลี่ยนกะให้พนักงานอัตโนมัติ

Endpoint

POST /api/v1/open-apis/work-cycle-change/approve

สิทธิ์ที่ต้องการ: API Key ต้องมีสิทธิ์ ข้อมูลการยื่นเอกสาร (document:manage)

Request Parameters

Required Parameters

ParameterTypeRequiredDescriptionExample
work_cycle_change_idstringYesรหัสเอกสารเปลี่ยนกะ (Base64)MjAyNjA0MzBXQzAwMDAwMDAx
employee_codestringYesรหัสพนักงานเจ้าของเอกสารEMP001
approve_flagstringYesสถานะการอนุมัติ (02-08)02
authorize_idstringYesรหัสผู้อนุมัติ (Base64)MjAyNjA0MzBVU0VSMDAwMDAx

หา authorize_id ได้อย่างไร: รับค่าจาก Get Employee Data Filter โดยใช้ path_action=get-user พร้อม employee_code ของผู้ทำรายการ — ใช้ค่า user_id ที่ได้กลับมาเป็น authorize_id

Optional Parameters

ParameterTypeDefaultDescription
approve_remarkstring""หมายเหตุ (บังคับสำหรับการปฏิเสธ)
authorize_linestring | boolean""เช็คสายอนุมัติตามลำดับ (true/false)
extra_roundstring"N"งวดพิเศษ (Y/N)
no_hr_permissionbooleanfalseระงับสิทธิพิเศษ HR

Option Values for approve_flag

ค่าสถานะ (TH)สถานะ (EN)การทำงาน
02อนุมัติApprovedอนุมัติขั้นสุดท้าย — ระบบจะเปลี่ยนกะให้พนักงานอัตโนมัติ
03ไม่อนุมัติNot Approvedปฏิเสธเอกสาร
04หัวหน้าอนุมัติขั้นที่ 1Manager Approved Step 1ส่งต่อไปยังขั้นตอนถัดไป
05ยกเลิกCancelledยกเลิก/ถอนคืนเอกสาร
06หัวหน้าอนุมัติขั้นที่ 2Manager Approved Step 2ส่งต่อไปยังขั้นตอนถัดไป
07หัวหน้าอนุมัติขั้นที่ 3Manager Approved Step 3ส่งต่อไปยังขั้นตอนถัดไป
08หัวหน้าอนุมัติขั้นที่ 4Manager Approved Step 4ส่งต่อไปยังขั้นตอนถัดไป

authorize_line — เมื่อส่ง true ผู้ใช้ที่เป็น HR จะต้องผ่านกระบวนการอนุมัติตามลำดับเหมือนพนักงานทั่วไป (ไม่ bypass สายอนุมัติ)

no_hr_permission — เมื่อส่ง true ระบบจะระงับสิทธิพิเศษ HR ทำให้ต้องตรวจสอบกฎอย่างเคร่งครัด (เช่น cut-off date)

Request Body Example

{ "work_cycle_change_id": "MjAyNjA0MzBXQzAwMDAwMDAx", "employee_code": "EMP001", "approve_flag": "02", "authorize_id": "MjAyNjA0MzBVU0VSMDAwMDAx", "approve_remark": "อนุมัติเปลี่ยนกะ" }

Response Format

Success Response (HTTP 200)

{ "code": 200, "message": "สำเร็จ", "payload": { "work_cycle_change_id": "20260430WC00000001", "employee_code": "EMP001", "approve_flag": "02", "approve_remark": "อนุมัติเปลี่ยนกะ", "approved_at": "2026-04-30 10:30:00" } }

Error Response - Validation Failed (HTTP 400)

{ "code": 400, "message": "Validation failed", "errors": [ "Missing required parameter: 'authorize_id'", "'approve_flag' must be 02-08" ] }

Error Response - Remark Required for Rejection (HTTP 400)

{ "code": 400, "message": "Validation failed", "errors": [ "'approve_remark' is required when approve_flag is '03'" ] }

Error Response - Document Not Found (HTTP 400)

{ "code": 400, "message": "Document not found" }

Error Response - Overtime Exists (HTTP 400)

{ "code": 400, "message": "Overtime exists" }

Error Response - Salary Period Closed (HTTP 400)

{ "code": 400, "message": "ไม่สำเร็จ", "error": "ไม่สามารถบันทึกได้ งวดเงินเดือนปิดแล้ว" }

Error Response - Cut-off Date Exceeded (HTTP 400)

{ "code": 400, "message": "ไม่สำเร็จ", "error": "เกินวันที่ cut-off แล้ว" }

Response Fields

FieldTypeDescription
work_cycle_change_idstringรหัสเอกสารเปลี่ยนกะ
employee_codestringรหัสพนักงานเจ้าของเอกสาร
approve_flagstringสถานะการอนุมัติ
approve_remarkstringหมายเหตุการอนุมัติ
approved_atstringวันเวลาที่อนุมัติ (YYYY-MM-DD HH:MM:SS)

Code Examples

curl -X POST "https://openapi.humansoft.co.th/api/v1/open-apis/work-cycle-change/approve" \ -H "Ocp-Apim-Subscription-Key: YOUR_API_KEY" \ -H "Content-Type: application/json" \ -d '{ "work_cycle_change_id": "MjAyNjA0MzBXQzAwMDAwMDAx", "employee_code": "EMP001", "approve_flag": "02", "authorize_id": "MjAyNjA0MzBVU0VSMDAwMDAx", "approve_remark": "อนุมัติเปลี่ยนกะ" }'

Validation Rules

ParameterValidationError Message
work_cycle_change_idต้องระบุและเป็น stringMissing required parameter: 'work_cycle_change_id'
employee_codeต้องระบุและเป็น stringMissing required parameter: 'employee_code'
approve_flagต้องระบุและเป็น 02-08'approve_flag' must be 02-08
authorize_idต้องระบุและเป็น stringMissing required parameter: 'authorize_id'
approve_remarkบังคับเมื่อ approve_flag = 03 (ปฏิเสธ)'approve_remark' is required when approve_flag is '03'
work_cycle_change_idต้องมีอยู่ในระบบDocument not found

Business Rules

ข้อจำกัดการอนุมัติ:

  • ระบบคำนวณขั้นตอนถัดไปอัตโนมัติตามสายการอนุมัติที่กำหนด
  • เมื่ออนุมัติขั้นสุดท้าย (approve_flag = 02) ระบบจะเปลี่ยนกะให้พนักงานอัตโนมัติ
  • การปฏิเสธ (approve_flag = 03) ต้องระบุ approve_remark เสมอ
  • ไม่สามารถอนุมัติได้หากมีเอกสาร OT ในวันเดียวกัน
  • ต้องไม่อยู่ในงวดเงินเดือน งวด OT หรืองวด worktime ที่ปิดแล้ว ยกเว้นเข้าเงื่อนไข extra_round
  • HR สามารถข้ามการตรวจสอบ cut-off date ได้ (ยกเว้น no_hr_permission = true)
  • ระบบจะส่งการแจ้งเตือนอัตโนมัติ

Error Handling

ErrorCauseSolution
Missing required parameter: 'work_cycle_change_id'ไม่ได้ส่ง work_cycle_change_idตรวจสอบ request body
Missing required parameter: 'authorize_id'ไม่ได้ส่ง authorize_idตรวจสอบ request body
'approve_flag' must be 02-08ค่า approve_flag ไม่ถูกต้องใช้ค่า 02-08 ตามตาราง Option Values
'approve_remark' is required when approve_flag is '03'ปฏิเสธโดยไม่ระบุหมายเหตุส่ง approve_remark เมื่อ approve_flag = 03
Document not foundไม่พบเอกสารตรวจสอบ work_cycle_change_id
Overtime existsมีเอกสาร OT ในวันเดียวกันตรวจสอบเอกสาร OT ของพนักงานในวันนั้น
ไม่สามารถบันทึกได้ งวดเงินเดือนปิดแล้วงวดเงินเดือนปิดแล้วเลือกเอกสารในงวดที่เปิดอยู่
เกินวันที่ cut-off แล้วเกินวัน cut-offติดต่อ HR หรือส่ง no_hr_permission = false

Notes

Use Cases

  1. หัวหน้าอนุมัติคำขอ - อนุมัติเอกสารเปลี่ยนกะของพนักงานในสายงาน
  2. HR อนุมัติหรือปฏิเสธเอกสาร - อนุมัติหรือปฏิเสธเอกสารในฐานะ HR
  3. อนุมัติแบบหลายขั้นตอน - ส่ง approve_flag = 04-08 เพื่ออนุมัติในแต่ละขั้นตอน
  4. ยกเลิกเอกสาร - ส่ง approve_flag = 05 เพื่อยกเลิก/ถอนคืนเอกสาร

Approval Flow

  • 04 -> 06 -> 07 -> 08 -> 02 (ตามสายการอนุมัติที่กำหนด)
  • ระบบจะคำนวณขั้นตอนถัดไปอัตโนมัติ ไม่จำเป็นต้องส่ง approve_flag ถัดไปเอง
  • หากเป็นขั้นตอนสุดท้าย ระบบจะเปลี่ยนสถานะเป็น 02 (Approved) อัตโนมัติ และเปลี่ยนกะให้พนักงานทันที

HR Special Permission

  • โดยปกติ HR สามารถข้ามการตรวจสอบ cut-off date ได้
  • หากต้องการให้ HR ปฏิบัติตามกฎเดียวกับพนักงานทั่วไป ให้ส่ง authorize_line = true และ/หรือ no_hr_permission = true
Last updated on