Skip to Content
🚀 Welcome to Humansoft Open API Documentation

Update OT

แก้ไขคำขอ OT ที่มีอยู่

ใช้ API นี้เพื่อแก้ไขรายละเอียดคำขอ OT เช่น เวลาเริ่มต้น/สิ้นสุด ประเภท OT หรือรายละเอียด

Endpoint

POST /api/v1/open-apis/overtime/update

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

Request Parameters

Required Parameters

ParameterTypeRequiredDescriptionExample
ot_work_idstringYesID ของคำขอที่ต้องการแก้ไขT1QwMDEyMw==
employee_codestringYesรหัสพนักงานเจ้าของเอกสารEMP001
ot_work_dtstringYesวันที่ทำ OT (YYYY-MM-DD)2026-01-16
ot_work_start_hourstringYesเวลาเริ่มต้น (YYYY-MM-DD HH:mm:ss)2026-01-16 18:00:00
ot_work_end_hourstringYesเวลาสิ้นสุด (YYYY-MM-DD HH:mm:ss)2026-01-16 22:00:00
ot_work_flag_lvstringYesประเภท OT รองรับทั้งรูปแบบตัวเลข (01-08) หรือ string format (OT_1_0-OT_7_0)02 หรือ OT_1_5

Optional Parameters

ParameterTypeRequiredDescriptionExample
ot_work_descstringNoรายละเอียด/เหตุผลแก้ไขเวลา OT
image_contentstringNoไฟล์แนบในรูปแบบ Base64 (สำหรับอัพเดทเอกสารประกอบ)data:image/jpeg;base64,/9j/4AAQ...
authorize_idstringNoID ผู้ทำรายการ (Base64)MjAyNjA0MzBVU0VSMDAwMDAx

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

Request Body Example

{ "ot_work_id": "T1QwMDEyMw==", "employee_code": "EMP001", "ot_work_dt": "2026-01-16", "ot_work_start_hour": "2026-01-16 18:00:00", "ot_work_end_hour": "2026-01-16 22:00:00", "ot_work_flag_lv": "03", "ot_work_desc": "แก้ไข: ทำงานโปรเจกต์พิเศษ" }

Response Format

Success Response (HTTP 200)

{ "code": 200, "message": "สำเร็จ", "payload": { "ot_work_id": "T1QwMDEyMw==", "employee_id": "RU1QMDAx", "employee_code": "EMP001", "ot_work_dt": "2026-01-16", "ot_work_start_hour": "2026-01-16 18:00:00", "ot_work_end_hour": "2026-01-16 22:00:00", "ot_work_time": 4.0, "ot_work_flag_lv": "03", "ot_work_desc": "แก้ไข: ทำงานโปรเจกต์พิเศษ", "approve_flag": "01", "updated_at": "2026-01-13 14:30:00" } }

Error Response - Not Found (HTTP 400)

{ "code": 400, "message": "ไม่สำเร็จ", "error": "OT work record not found" }

Error Response - Already Approved (HTTP 400)

{ "code": 400, "message": "ไม่สำเร็จ", "error": "ไม่สามารถแก้ไขได้ คำขออนุมัติแล้ว" }

Error Response - Salary Period Closed (HTTP 400)

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

Response Fields

FieldTypeDescription
ot_work_idstringID ของคำขอที่แก้ไข
employee_idstringID ของพนักงาน
employee_codestringรหัสพนักงาน
ot_work_dtstringวันที่ทำ OT
ot_work_start_hourdatetimeเวลาเริ่มต้น
ot_work_end_hourdatetimeเวลาสิ้นสุด
ot_work_timenumberจำนวนชั่วโมง OT
ot_work_flag_lvstringประเภท OT
ot_work_descstringรายละเอียดงาน OT
approve_flagstringสถานะการอนุมัติ
updated_atdatetimeวันเวลาที่อัพเดทเอกสาร

Code Examples

curl -X POST "https://openapi.humansoft.co.th/api/v1/open-apis/overtime/update" \ -H "Ocp-Apim-Subscription-Key: YOUR_API_KEY" \ -H "Content-Type: application/json" \ -d '{ "ot_work_id": "T1QwMDEyMw==", "employee_code": "EMP001", "ot_work_dt": "2026-01-16", "ot_work_start_hour": "2026-01-16 18:00:00", "ot_work_end_hour": "2026-01-16 22:00:00", "ot_work_flag_lv": "03", "ot_work_desc": "แก้ไข: ทำงานโปรเจกต์พิเศษ" }'

Validation Rules

ParameterValidationError Message
ot_work_idต้องระบุและเป็น stringMissing required parameter: 'ot_work_id'
employee_codeต้องระบุMissing required parameter: 'employee_code'
ot_work_dtต้องระบุและรูปแบบ YYYY-MM-DD'ot_work_dt' must be in Y-m-d format
ot_work_start_hourต้องระบุและรูปแบบ YYYY-MM-DD HH:mm:ss'ot_work_start_hour' must be in Y-m-d H:i:s format
ot_work_end_hourต้องระบุและรูปแบบ YYYY-MM-DD HH:mm:ss'ot_work_end_hour' must be in Y-m-d H:i:s format
ot_work_end_hourต้อง > ot_work_start_hour'ot_work_end_hour' must be after 'ot_work_start_hour'
ot_work_flag_lvต้องระบุและรองรับ 01-08 หรือ OT_1_0-OT_7_0'ot_work_flag_lv' must be one of: 01, 02, 03, 04, 05, 06, 07, 08 or OT_1_0, OT_1_5, OT_2_0, OT_3_0, OT_4_0, OT_5_0, OT_6_0, OT_7_0

Business Rules

ข้อจำกัดการแก้ไข:

  • ไม่สามารถแก้ไขคำขอที่อนุมัติแล้ว (approve_flag = 02)
  • ไม่สามารถแก้ไขในงวดเงินเดือนที่ปิดแล้ว
  • ถ้าเปลี่ยนเวลา ระบบจะคำนวณชั่วโมง OT ใหม่
  • ประเภท OT ที่เปลี่ยนต้องเปิดใช้งานในบริษัท

Side Effects

เมื่อแก้ไขคำขอสำเร็จ ระบบจะ:

  1. Recalculate OT Hours - คำนวณชั่วโมง OT ใหม่ (ถ้าเปลี่ยนเวลา)
  2. Update Notification - อัพเดทการแจ้งเตือน
  3. Update Feed - อัพเดท feed สำหรับพนักงาน

Error Handling

ErrorCauseSolution
Missing required parameter: 'ot_work_id'ไม่ได้ส่ง ot_work_idตรวจสอบ request body
OT work record not foundไม่พบคำขอตรวจสอบ ot_work_id
ไม่สามารถแก้ไขได้ คำขออนุมัติแล้วคำขออนุมัติแล้วไม่สามารถแก้ไขได้
ไม่สามารถแก้ไขได้ งวดเงินเดือนปิดแล้วงวดเงินเดือนปิดแล้วติดต่อ HR
OT type 'XX' is not enabled for this companyประเภท OT ไม่เปิดใช้ใช้ Get OT Types ดูประเภทที่ใช้ได้

Notes

Use Cases

  1. แก้ไขเวลา OT - เปลี่ยนเวลาเริ่มต้นหรือสิ้นสุด
  2. เปลี่ยนประเภท OT - เปลี่ยนจาก OT 1.5x เป็น OT 2.0x
  3. เพิ่มรายละเอียด - อัพเดทเหตุผลการทำ OT

Full Update

API นี้ต้องการให้ส่งข้อมูลครบทุก required field — ระบบจะอัพเดทเอกสารเต็มรูปแบบ ไม่รองรับ partial update

OT Types (ประเภท OT)

API รองรับการส่งค่า ot_work_flag_lv ได้ 2 รูปแบบ:

รูปแบบที่ 1: ตัวเลข (Numeric Code)

Codeอัตรา OTคำอธิบาย
011.0xOT อัตราปกติ
021.5xOT อัตรา 1.5 เท่า
032.0xOT อัตรา 2 เท่า
043.0xOT อัตรา 3 เท่า
054.0xOT อัตรา 4 เท่า
065.0xOT อัตรา 5 เท่า
076.0xOT อัตรา 6 เท่า
087.0xOT อัตรา 7 เท่า

รูปแบบที่ 2: String Format

Codeอัตรา OTเทียบเท่ากับ
OT_1_01.0x01
OT_1_51.5x02
OT_2_02.0x03
OT_3_03.0x04
OT_4_04.0x05
OT_5_05.0x06
OT_6_06.0x07
OT_7_07.0x08

ระบบจะแปลง OT_X_X เป็นรหัสตัวเลขอัตโนมัติ เช่น OT_1_502

  • Get OT List - ดึงรายการคำขอ OT
  • Submit OT - ยื่นคำขอ OT ใหม่
  • Delete OT - ลบคำขอ OT
Last updated on