Files
sam-manage/app/Http/Controllers/HR/BusinessIncomePaymentController.php
김보곤 3fc4c10593 feat: [payroll] 개발서버 슈퍼관리자 급여관리 접근 허용
- 운영서버: 기존 3인(이의찬, 전진선, 김보곤)만 접근 가능 (변경 없음)
- 개발서버/로컬: 슈퍼관리자도 급여관리 전체 접근 가능 (조회+수정)
- 적용 대상: 급여관리, 사업소득자 임금대장, 연봉 정보
2026-03-11 20:44:26 +09:00

58 lines
1.9 KiB
PHP

<?php
namespace App\Http\Controllers\HR;
use App\Http\Controllers\Controller;
use App\Services\HR\BusinessIncomePaymentService;
use Illuminate\Contracts\View\View;
use Illuminate\Http\Request;
use Illuminate\Http\Response;
class BusinessIncomePaymentController extends Controller
{
private const ALLOWED_PAYROLL_USERS = ['이의찬', '전진선', '김보곤'];
public function __construct(
private BusinessIncomePaymentService $service
) {}
/**
* 사업소득자 임금대장 페이지
*/
public function index(Request $request): View|Response
{
if ($request->header('HX-Request')) {
return response('', 200)->header('HX-Redirect', route('hr.business-income-payments.index'));
}
$isAllowedUser = in_array(auth()->user()->name, self::ALLOWED_PAYROLL_USERS);
$isDevSuperAdmin = ! app()->environment('production') && auth()->user()->isSuperAdmin();
if (! $isAllowedUser && ! $isDevSuperAdmin) {
return view('hr.payrolls.restricted');
}
$year = $request->integer('year') ?: now()->year;
$month = $request->integer('month') ?: now()->month;
$earners = $this->service->getActiveEarners();
$payments = $this->service->getPayments($year, $month);
$stats = $this->service->getMonthlyStats($year, $month);
$earnersForJs = $earners->map(fn ($e) => [
'user_id' => $e->user_id,
'business_name' => $e->business_name ?? ($e->user?->name ?? ''),
'user_name' => $e->user?->name ?? '',
'business_reg_number' => $e->business_registration_number ?? '',
])->values();
return view('hr.business-income-payments.index', [
'payments' => $payments,
'earnersForJs' => $earnersForJs,
'stats' => $stats,
'year' => $year,
'month' => $month,
]);
}
}