Files
sam-docs/system/database/tenants.md
권혁성 d4e5f62413 docs: [종합정비] Phase 1 시스템 현황 문서 14개 작성
- system/overview.md: 전체 아키텍처 개요
- system/api-structure.md: API 구조 (220 모델, 1027 엔드포인트, 18 라우트 도메인)
- system/react-structure.md: React 구조 (249 페이지, 612 컴포넌트)
- system/mng-structure.md: MNG 구조 (171 컨트롤러, 436 Blade 뷰)
- system/docker-setup.md: Docker 7 컨테이너 구성
- system/database/README.md + 9개 도메인 스키마 (270+ 테이블)
  - core, hr, sales, production, finance, boards, files, system, erp-analysis

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-27 18:03:13 +09:00

2.9 KiB

테넌트 / 사용자 / 권한 도메인

모델 수: Tenants 56 + Members 4 + Permissions 3 = 63 핵심: 멀티테넌시 기반, 모든 비즈니스 데이터의 기준점


주요 테이블

인증 / 사용자

테이블 모델 역할
users User 시스템 계정 (Sanctum, HasRoles)
user_tenants UserTenant 사용자-테넌트 매핑 (is_active, is_default)
user_roles UserRole 사용자-역할 매핑
user_menu_permissions UserMenuPermission 사용자별 메뉴 권한

테넌트 핵심

테이블 모델 역할
tenants Tenant 조직/회사 마스터
departments Department 부서 (계층 구조, parent_id)
department_user (pivot) 부서-사용자 다대다
tenant_user_profiles TenantUserProfile 테넌트별 직원 프로필
positions Position 직급/직위

테넌트 설정

테이블 모델 역할
tenant_settings TenantSetting 테넌트별 설정값
tenant_field_settings TenantFieldSetting 필드별 설정
tenant_option_groups TenantOptionGroup 옵션 그룹 정의
tenant_option_values TenantOptionValue 옵션 값
tenant_stat_fields TenantStatField 통계 필드 설정

권한 (Spatie Permission)

테이블 모델 역할
permissions Permission 권한 정의
roles Role 역할 정의
permission_overrides PermissionOverride 권한 오버라이드 (다형)

관계 구조

User (1)
  ├─ (N) UserTenant ─→ (1) Tenant
  ├─ (N) UserRole ─→ (1) Role ─→ (N) Permission
  └─ (N) UserMenuPermission

Tenant (1)
  ├─ (N) Department (parent_id → self)
  │   └─ (N:M) User via department_user
  ├─ (N) TenantUserProfile
  │   ├─ → User
  │   └─ → Department
  ├─ (N) TenantSetting
  └─ (N) [모든 BelongsToTenant 모델]

Tenants 하위 비즈니스 모델 (56개)

Tenants 도메인은 조직 내 다양한 비즈니스 기능을 포함:

  • 재무: Payment, Bill, TaxInvoice, JournalEntry, Deposit, Withdrawal 등
  • 인사: Payroll, Attendance, Leave, LeavePolicy, Salary, Loan 등
  • 영업: Sale, Client, ClientGroup, Shipment, Receivables 등
  • 재고: Stock, StockLot, MaterialInput 등
  • 결재: Approval, ApprovalForm, ApprovalLine 등
  • 기타: Calendar, CalendarSchedule, Notification 등

이 모델들의 상세 내용은 각 도메인 문서(finance.md, hr.md, sales.md 등)에서 다룸.


특이사항

  • User는 BelongsToTenant가 아님 (시스템 전역)
  • UserTenant으로 다중 테넌트 소속 지원
  • TenantUserProfile은 테넌트별 직원 정보 (직급, 입사일 등)
  • Department는 self-reference 계층 구조 (parent_id)
  • 권한은 메뉴 기반 RBAC (Spatie Permission + UserMenuPermission)