Files
sam-api/app/Http/Requests/V1/ExpectedExpense/StoreExpectedExpenseRequest.php
kent 1f5539db32 feat: I-1 미지급비용 관리 API 개발
- ExpectedExpense 모델 및 마이그레이션 생성
- ExpectedExpenseService 구현 (CRUD, 일괄삭제, 지급일 변경, 요약)
- ExpectedExpenseController REST API 구현
- FormRequest 검증 클래스 3개 생성
- Swagger API 문서 작성
- 라우트 추가 (8개 엔드포인트)

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-26 13:23:07 +09:00

59 lines
2.2 KiB
PHP

<?php
namespace App\Http\Requests\V1\ExpectedExpense;
use Illuminate\Foundation\Http\FormRequest;
class StoreExpectedExpenseRequest extends FormRequest
{
public function authorize(): bool
{
return true;
}
public function rules(): array
{
return [
'expected_payment_date' => ['required', 'date'],
'settlement_date' => ['nullable', 'date'],
'transaction_type' => ['required', 'string', 'in:purchase,advance,suspense,rent,salary,insurance,tax,utilities,other'],
'amount' => ['required', 'numeric', 'min:0'],
'client_id' => ['nullable', 'integer', 'exists:clients,id'],
'client_name' => ['nullable', 'string', 'max:100'],
'bank_account_id' => ['nullable', 'integer', 'exists:bank_accounts,id'],
'account_code' => ['nullable', 'string', 'max:50'],
'payment_status' => ['nullable', 'string', 'in:pending,partial,paid,overdue'],
'approval_status' => ['nullable', 'string', 'in:none,pending,approved,rejected'],
'description' => ['nullable', 'string', 'max:1000'],
];
}
public function messages(): array
{
return [
'expected_payment_date.required' => __('validation.required', ['attribute' => '예상 지급일']),
'transaction_type.required' => __('validation.required', ['attribute' => '거래유형']),
'transaction_type.in' => __('validation.in', ['attribute' => '거래유형']),
'amount.required' => __('validation.required', ['attribute' => '금액']),
'amount.min' => __('validation.min.numeric', ['attribute' => '금액', 'min' => 0]),
];
}
public function attributes(): array
{
return [
'expected_payment_date' => '예상 지급일',
'settlement_date' => '결제일',
'transaction_type' => '거래유형',
'amount' => '금액',
'client_id' => '거래처',
'client_name' => '거래처명',
'bank_account_id' => '계좌',
'account_code' => '계정과목',
'payment_status' => '지급상태',
'approval_status' => '결재상태',
'description' => '적요',
];
}
}