package model import ( "context" "time" "{{ .PkgName }}/database/table" "github.com/samber/lo" . "github.com/go-jet/jet/v2/postgres" log "github.com/sirupsen/logrus" ) // conds {{- if .SoftDelete }} func (m *{{.PascalTable}}) NotDeleted() Cond { return func(cond BoolExpression) BoolExpression { return cond.AND(table.Posts.DeletedAt.IS_NULL()) } } {{- end}} // funcs func (m *{{.PascalTable}}) log() *log.Entry { return log.WithField("model", "{{.PascalTable}}") } func (m *{{.PascalTable}}) Create(ctx context.Context) error { {{- if .HasCreatedAt}} m.CreatedAt = time.Now() {{- end}} {{- if .HasUpdatedAt}} m.UpdatedAt = time.Now() {{- end}} stmt := table.Medias.INSERT(table.{{.PascalTable}}.MutableColumns).MODEL(m).RETURNING(table.Medias.AllColumns) m.log().WithField("func","Create").Info( stmt.DebugSql()) if err := stmt.QueryContext(ctx, db, m); err != nil { m.log().WithField("func","Create").Errorf("error creating {{.PascalTable}} item: %v", err) return err } m.log().WithField("func","Create").Infof("{{.PascalTable}} item created successfully") return nil } func (m *{{.PascalTable}}) BatchCreate(ctx context.Context, models []*{{.PascalTable}}) error { stmt := table.{{.PascalTable}}.INSERT(table.{{.PascalTable}}.MutableColumns).MODELS(models) m.log().WithField("func", "BatchCreate").Info(stmt.DebugSql()) if _, err := stmt.ExecContext(ctx, db); err != nil { m.log().WithField("func","Create").Errorf("error creating {{.PascalTable}} item: %v", err) return err } m.log().WithField("func", "BatchCreate").Infof("{{.PascalTable}} items created successfully") return nil } {{- if .SoftDelete }} func (m *{{.PascalTable}}) Delete(ctx context.Context) error { stmt := table.{{.PascalTable}}.UPDATE().SET(table.{{.PascalTable}}.DeletedAt.Set(TimestampzT(time.Now()))).WHERE(table.{{.PascalTable}}.ID.EQ(Int(m.ID))) m.log().WithField("func", "SoftDelete").Info(stmt.DebugSql()) if err := stmt.QueryContext(ctx, db, m); err != nil { m.log().WithField("func","SoftDelete").Errorf("error soft deleting {{.PascalTable}} item: %v", err) return err } m.log().WithField("func", "SoftDelete").Infof("{{.PascalTable}} item soft deleted successfully") return nil } // BatchDelete func (m *{{.PascalTable}}) BatchDelete(ctx context.Context, ids []int64) error { condIds := lo.Map(ids, func(id int64, _ int) Expression { return Int64(id) }) stmt := table.{{.PascalTable}}.UPDATE().SET(table.{{.PascalTable}}.DeletedAt.Set(TimestampzT(time.Now()))).WHERE(table.{{.PascalTable}}.ID.IN(condIds...)) m.log().WithField("func", "BatchSoftDelete").Info(stmt.DebugSql()) if err := stmt.QueryContext(ctx, db, m); err != nil { m.log().WithField("func","BatchSoftDelete").Errorf("error soft deleting {{.PascalTable}} items: %v", err) return err } m.log().WithField("func", "BatchSoftDelete").Infof("{{.PascalTable}} items soft deleted successfully") return nil } {{- end}} func (m *{{.PascalTable}}) ForceDelete(ctx context.Context) error { stmt := table.{{.PascalTable}}.DELETE().WHERE(table.{{.PascalTable}}.ID.EQ(Int(m.ID))) m.log().WithField("func", "Delete").Info(stmt.DebugSql()) if _, err := stmt.ExecContext(ctx, db); err != nil { m.log().WithField("func","Delete").Errorf("error deleting {{.PascalTable}} item: %v", err) return err } m.log().WithField("func", "Delete").Infof("{{.PascalTable}} item deleted successfully") return nil } func (m *{{.PascalTable}}) BatchForceDelete(ctx context.Context, ids []int64) error { condIds := lo.Map(ids, func(id int64, _ int) Expression { return Int64(id) }) stmt := table.{{.PascalTable}}.DELETE().WHERE(table.{{.PascalTable}}.ID.IN(condIds...)) m.log().WithField("func", "BatchDelete").Info(stmt.DebugSql()) if _, err := stmt.ExecContext(ctx, db); err != nil { m.log().WithField("func","BatchDelete").Errorf("error deleting {{.PascalTable}} items: %v", err) return err } m.log().WithField("func", "BatchDelete").Infof("{{.PascalTable}} items deleted successfully") return nil } func (m *{{.PascalTable}}) Update(ctx context.Context) error { {{- if .HasUpdatedAt}} m.UpdatedAt = time.Now() {{- end}} stmt := table.{{.PascalTable}}.UPDATE(table.{{.PascalTable}}.MutableColumns.Except({{.CamelTable}}UpdateExcludeColumns...)).SET(m).WHERE(table.{{.PascalTable}}.ID.EQ(Int(m.ID))).RETURNING(table.{{.PascalTable}}.AllColumns) m.log().WithField("func", "Update").Info(stmt.DebugSql()) if err := stmt.QueryContext(ctx, db, m); err != nil { m.log().WithField("func","Update").Errorf("error updating {{.PascalTable}} item: %v", err) return err } m.log().WithField("func", "Update").Infof("{{.PascalTable}} item updated successfully") return nil } // GetByID func (m *{{.PascalTable}}) GetByID(ctx context.Context, id int64, conds ...BoolExpression) (*{{.PascalTable}}, error) { expr := table.{{.PascalTable}}.ID.EQ(Int(m.ID)) if len(conds) > 0 { for _, c := range conds { expr = expr.AND(c) } } stmt := table.{{.PascalTable}}.SELECT(table.{{.PascalTable}}.AllColumns).WHERE(expr) m.log().WithField("func", "GetByID").Info(stmt.DebugSql()) if err := stmt.QueryContext(ctx, db, m); err != nil { m.log().WithField("func","GetByID").Errorf("error getting {{.PascalTable}} item by ID: %v", err) return nil, err } m.log().WithField("func", "GetByID").Infof("{{.PascalTable}} item retrieved successfully") return m, nil } // Count func (m *{{.PascalTable}}) Count(ctx context.Context, conds ...BoolExpression) (int64, error) { cond := Bool(true) if len(conds) > 0 { for _, c := range conds { cond = cond.AND(c) } } tbl := table.{{.PascalTable}} stmt := tbl.SELECT(COUNT(tbl.ID).AS("count")).WHERE(cond) m.log().Infof("sql: %s", stmt.DebugSql()) var count struct { Count int64 } if err := stmt.QueryContext(ctx, db, &count); err != nil { m.log().Errorf("error counting {{.PascalTable}} items: %v", err) return 0, err } return count.Count, nil }