Submit OT
ยื่นคำขอ OT ใหม่
ใช้ API นี้เพื่อสร้างคำขอ OT ใหม่ ระบบจะตรวจสอบข้อมูลและส่งเข้าสู่ขั้นตอนการอนุมัติอัตโนมัติ
Endpoint
POST /api/v1/open-apis/overtime/submitRequest Parameters
Required Parameters
| Parameter | Type | Required | Description | Example |
|---|---|---|---|---|
employee_code | string | Yes | รหัสพนักงาน | EMP001 |
ot_work_dt | string | Yes | วันที่ทำ OT (YYYY-MM-DD) | 2026-01-15 |
ot_work_start_hour | string | Yes | เวลาเริ่มต้น (YYYY-MM-DD HH:mm:ss) | 2026-01-15 18:00:00 |
ot_work_end_hour | string | Yes | เวลาสิ้นสุด (YYYY-MM-DD HH:mm:ss) | 2026-01-15 21:00:00 |
ot_work_type_lv | string | Yes | ประเภท OT (01-08) | 02 |
Optional Parameters
| Parameter | Type | Required | Description | Example |
|---|---|---|---|---|
ot_work_desc | string | No | รายละเอียด/เหตุผล | ทำงานเพิ่มเติมตามโปรเจค |
Request Body Example
{
"employee_code": "EMP001",
"ot_work_dt": "2026-01-15",
"ot_work_start_hour": "2026-01-15 18:00:00",
"ot_work_end_hour": "2026-01-15 21:00:00",
"ot_work_type_lv": "02",
"ot_work_desc": "ทำงานเพิ่มเติมตามโปรเจค"
}Response Format
Success Response (HTTP 200)
{
"code": 200,
"message": "สำเร็จ",
"payload": {
"ot_work_id": "T1QwMDEyMw==",
"employee_code": "EMP001",
"ot_work_dt": "2026-01-15",
"ot_work_start_hour": "2026-01-15 18:00:00",
"ot_work_end_hour": "2026-01-15 21:00:00",
"ot_work_type_lv": "02",
"ot_work_hour": "3.00",
"approve_flag": "01",
"created": "2026-01-13 09:00:00"
}
}Error Response - Validation Failed (HTTP 400)
{
"code": 400,
"message": "Validation failed",
"errors": [
"Missing required parameter: 'employee_code'",
"'ot_work_dt' must be in Y-m-d format"
]
}Error Response - Employee Not Found (HTTP 400)
{
"code": 400,
"message": "ไม่สำเร็จ",
"error": "Employee not found: EMP999"
}Error Response - OT Type Not Enabled (HTTP 400)
{
"code": 400,
"message": "ไม่สำเร็จ",
"error": "OT type '05' is not enabled for this company"
}Error Response - Salary Period Closed (HTTP 400)
{
"code": 400,
"message": "ไม่สำเร็จ",
"error": "ไม่สามารถบันทึกได้ งวดเงินเดือนปิดแล้ว"
}Response Fields
| Field | Type | Description |
|---|---|---|
ot_work_id | string | ID ของคำขอที่สร้าง |
employee_code | string | รหัสพนักงาน |
ot_work_dt | string | วันที่ทำ OT |
ot_work_start_hour | datetime | เวลาเริ่มต้น |
ot_work_end_hour | datetime | เวลาสิ้นสุด |
ot_work_type_lv | string | ประเภท OT |
ot_work_hour | string | จำนวนชั่วโมง OT |
approve_flag | string | สถานะการอนุมัติ |
created | datetime | วันเวลาที่สร้าง |
Code Examples
cURL
curl -X POST "https://openapi.humansoft.co.th/api/v1/open-apis/overtime/submit" \
-H "Ocp-Apim-Subscription-Key: YOUR_API_KEY" \
-H "Content-Type: application/json" \
-d '{
"employee_code": "EMP001",
"ot_work_dt": "2026-01-15",
"ot_work_start_hour": "2026-01-15 18:00:00",
"ot_work_end_hour": "2026-01-15 21:00:00",
"ot_work_type_lv": "02",
"ot_work_desc": "ทำงานเพิ่มเติมตามโปรเจค"
}'Validation Rules
| Parameter | Validation | Error Message |
|---|---|---|
employee_code | ต้องระบุและเป็น string | 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_type_lv | ต้องระบุและเป็น 01-08 | 'ot_work_type_lv' must be one of: 01, 02, 03, 04, 05, 06, 07, 08 |
Business Rules
ข้อจำกัดการยื่นคำขอ:
- ไม่สามารถยื่นคำขอในงวดเงินเดือนที่ปิดแล้ว
- เวลาสิ้นสุดต้องมากกว่าเวลาเริ่มต้น
- ประเภท OT ต้องเปิดใช้งานในบริษัท
- ต้องตรวจสอบว่าพนักงานมีอยู่ในระบบ
- ระบบจะคำนวณชั่วโมง OT อัตโนมัติจากเวลาเริ่มต้นและสิ้นสุด
Side Effects
เมื่อสร้างคำขอสำเร็จ ระบบจะ:
- Calculate OT Hours - คำนวณชั่วโมง OT
- Set Initial Status - ตั้งสถานะเป็น Pending (01)
- Create Notification - แจ้งเตือนผู้อนุมัติ
- Create Feed - สร้าง feed สำหรับพนักงาน
Error Handling
| Error | Cause | Solution |
|---|---|---|
Missing required parameter: 'employee_code' | ไม่ได้ส่ง employee_code | ตรวจสอบ request body |
Employee not found: XXX | ไม่พบพนักงาน | ตรวจสอบ employee_code |
OT type 'XX' is not enabled for this company | ประเภท OT ไม่เปิดใช้ | ใช้ Get OT Types ดูประเภทที่ใช้ได้ |
ไม่สามารถบันทึกได้ งวดเงินเดือนปิดแล้ว | งวดเงินเดือนปิดแล้ว | เลือกวันที่ในงวดที่เปิดอยู่ |
'ot_work_end_hour' must be after 'ot_work_start_hour' | เวลาไม่ถูกต้อง | ตรวจสอบเวลาเริ่มต้น/สิ้นสุด |
Notes
Use Cases
- พนักงานยื่นคำขอ OT - สร้างคำขอผ่าน Self-service
- HR สร้างคำขอแทน - สร้างคำขอให้พนักงานที่ไม่มี access
- Batch Submit - สร้างคำขอหลายรายการพร้อมกัน
Time Format
ot_work_dtใช้รูปแบบYYYY-MM-DDเช่น2026-01-15ot_work_start_hourและot_work_end_hourใช้รูปแบบYYYY-MM-DD HH:mm:ssเช่น2026-01-15 18:00:00
Related APIs
- Get OT Types - ดึงรายการประเภท OT
- Get OT List - ดึงรายการคำขอ OT
- Update OT - แก้ไขคำขอ OT
- Delete OT - ลบคำขอ OT
Last updated on