initial server implementation

This commit is contained in:
2026-05-31 17:35:41 -05:00
parent 686f54af64
commit 16cb057670
106 changed files with 102494 additions and 4 deletions
+14
View File
@@ -0,0 +1,14 @@
package database
import (
"time"
"gorm.io/gorm"
)
type Base struct {
ID uint `gorm:"primarykey"`
CreatedAt time.Time
UpdatedAt time.Time
DeletedAt gorm.DeletedAt `gorm:"index"`
}
+51
View File
@@ -0,0 +1,51 @@
package database
import (
"fmt"
"gorm.io/driver/postgres"
"gorm.io/driver/sqlite"
"gorm.io/gorm"
)
func Migrate(db *gorm.DB) error {
if err := db.AutoMigrate(&User{}, &Role{}); err != nil {
return fmt.Errorf("auto-migrate: %w", err)
}
defaultRoles := []Role{
{Name: "superadmin"},
{Name: "admin"},
{Name: "editor"},
{Name: "author"},
{Name: "viewer"},
}
for _, r := range defaultRoles {
if err := db.FirstOrCreate(&r, Role{Name: r.Name}).Error; err != nil {
return fmt.Errorf("seed role %q: %w", r.Name, err)
}
}
return nil
}
func NewDB(driver, dsn string) (*gorm.DB, error) {
var dialector gorm.Dialector
switch driver {
case "sqlite":
dialector = sqlite.Open(dsn)
case "postgres":
dialector = postgres.Open(dsn)
default:
return nil, fmt.Errorf("unsupported database driver: %s", driver)
}
db, err := gorm.Open(dialector, &gorm.Config{})
if err != nil {
return nil, fmt.Errorf("failed to open database: %w", err)
}
return db, nil
}
+27
View File
@@ -0,0 +1,27 @@
package database
type UserStatus uint8
const (
UserStatusPending UserStatus = iota
UserStatusActive
UserStatusSuspended
UserStatusInactive
)
type User struct {
Base
Name string
Email string
PasswordHash string
Roles []Role `gorm:"many2many:user_roles"`
}
type Role struct {
Base
Name string
Domain string
Description string
}