feat : Tenant Scope 추가 - 모델에 해당 유저의 tenant_id 로 자동 매핑 (CommonCode 모델에 추가)

This commit is contained in:
2025-07-25 17:31:08 +09:00
parent 201df48853
commit 94501d5624
5 changed files with 58 additions and 6 deletions

View File

@@ -37,7 +37,7 @@ public function handle(Request $request, Closure $next)
}
if (!$validApiKey) {
return response()->json(['message' => 'Unauthorized. Invalid or missing API key or token'], 401);
return response()->json(['message' => 'Unauthorized. Invalid or missing API key'], 401);
}
// Bearer 인증 (Sanctum)
@@ -46,11 +46,13 @@ public function handle(Request $request, Closure $next)
$accessToken = PersonalAccessToken::findToken($token);
if ($accessToken && $accessToken->tokenable instanceof Member) {
$user = $accessToken->tokenable;
if ($user) {
$request->attributes->set('tenant_id', $user->tn_num);
$request->attributes->set('api_user', $user->mb_num);
}
}
}
if ($user) {
$request->setUserResolver(fn() => $user);
}
$response = $next($request);

View File

@@ -42,4 +42,9 @@ public function company()
return $this->belongsTo(MemberCompany::class, 'tn_num', 'mc_num');
// members.tn_num = member_company.mc_num
}
public function tenant()
{
return $this->belongsTo(Tenant::class, 'tn_num');
}
}

View File

@@ -4,10 +4,10 @@
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\SoftDeletes;
use App\Traits\BelongsToTenant;
class CommonCode extends Model
{
use SoftDeletes;
use SoftDeletes, BelongsToTenant;
protected $table = 'common_codes';

View File

@@ -0,0 +1,32 @@
<?php
namespace App\Models\Scopes;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Scope;
use Illuminate\Http\Request;
class TenantScope implements Scope
{
/**
* Apply the scope to a given Eloquent query builder.
*/
public function apply(Builder $builder, Model $model)
{
// artisan migrate 등은 제외
if (app()->runningInConsole()) return;
// request 헬퍼 사용 → request 인스턴스를 명시적으로 주입받아 사용해야 함
$request = app(Request::class);
$tenantId = $request->attributes->get('tenant_id')
?? $request->header('X-TENANT-ID')
?? auth()->user()?->tenant_id;
if ($tenantId) {
$builder->where($model->getTable().'.tenant_id', $tenantId);
}
}
}

View File

@@ -0,0 +1,13 @@
<?php
namespace App\Traits;
use App\Models\Scopes\TenantScope;
trait BelongsToTenant
{
protected static function bootBelongsToTenant(): void
{
static::addGlobalScope(new TenantScope);
}
}