All checks were successful
build-and-push / build (push) Successful in 32s
- Project.ClientDomain 필드, MailNote(프로젝트 구성원 공동 메모) 모델
- internal/mailsync: 서비스계정+도메인위임으로 팀 메일함을 도메인 검색·집계(stdlib만, push 패턴 재사용)
· GOOGLE_SA_CREDENTIALS_FILE 미설정 시 비활성(graceful)
- GET /projects/{id}/mails (3분 캐시), GET/PUT /projects/{id}/mail-notes
- fix: handlePatchProject map-key Updates가 camelCase 멀티워드 필드(consultingType·
scopeText·pmEmail·clientDomain·날짜)를 컬럼에 못 맞춰 저장 실패하던 버그 → snakeKeys 변환
Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
40 lines
1.3 KiB
Go
40 lines
1.3 KiB
Go
// Package models defines the GORM models for spin. Each domain slice adds its
|
|
// own file (member.go, attendance.go, project.go, incentive.go, accounting.go);
|
|
// this file holds the shared Base type and the AutoMigrate registry.
|
|
package models
|
|
|
|
import (
|
|
"github.com/google/uuid"
|
|
"gorm.io/gorm"
|
|
)
|
|
|
|
// Base provides a string UUID primary key populated in a BeforeCreate hook.
|
|
type Base struct {
|
|
ID string `gorm:"primaryKey" json:"id"`
|
|
}
|
|
|
|
func (b *Base) ensureID() {
|
|
if b.ID == "" {
|
|
b.ID = uuid.NewString()
|
|
}
|
|
}
|
|
|
|
// All returns every model for AutoMigrate. Each slice appends its models here.
|
|
func All() []interface{} {
|
|
return []interface{}{
|
|
// slice 1 — members / org
|
|
&Member{}, &Department{}, &AuditLog{}, &Notification{}, &WorkStatusEvent{}, &Device{},
|
|
// slice 2 — attendance / leave
|
|
&Attendance{}, &LeaveRequest{}, &OvertimeRequest{}, &WorkPolicy{}, &LeaveBalance{},
|
|
// slice 3 — projects
|
|
&Company{}, &Product{}, &Version{}, &Project{}, &ProjectMember{},
|
|
&ClientContact{}, &ProjectTask{}, &TaskComment{}, &MailNote{}, &Contract{}, &ContractFile{}, &PaymentSplit{},
|
|
// slice 4 — incentive
|
|
&IncentiveConfig{}, &PaymentStage{}, &UserIncentive{}, &QuarterlySettlement{},
|
|
// slice 5 — accounting
|
|
&Account{}, &Transaction{}, &TaxRecord{},
|
|
}
|
|
}
|
|
|
|
var _ = gorm.ErrRecordNotFound // keep gorm imported for slice files
|