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
+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
}