package libhelper import ( "fmt" pl "simrs-vx/pkg/logger" "strings" "unicode" "github.com/jackc/pgx/v5/pgconn" "gorm.io/gorm" ) func SearchCodeOrName(search string, tx *gorm.DB) *gorm.DB { if search != "" { tx = tx.Where("\"Code\" ILIKE ? OR \"Name\" ILIKE ?", "%"+search+"%", "%"+search+"%") } return tx } func Sort(sort string, tx *gorm.DB) *gorm.DB { if sort == "" { return tx } pairs := strings.Split(sort, ",") for _, pair := range pairs { parts := strings.Split(strings.TrimSpace(pair), ":") if len(parts) != 2 { continue // skip invalid format } field := strings.TrimSpace(parts[0]) direction := strings.ToUpper(strings.TrimSpace(parts[1])) if direction != "ASC" && direction != "DESC" { continue } field = normalizeColumnName(field) tx = tx.Order(fmt.Sprintf("\"%s\" %s", field, direction)) } return tx } func normalizeColumnName(input string) string { if input == "" { return input } input = strings.ReplaceAll(input, "-", "_") runes := []rune(input) var out []rune upperNext := true for _, r := range runes { if r == '_' { out = append(out, r) upperNext = true continue } if upperNext { out = append(out, unicode.ToUpper(r)) upperNext = false } else { out = append(out, r) } } return string(out) } func HandleCreateError(input any, event *pl.Event, err error) error { e, ok := err.(*pgconn.PgError) if !ok { // fallback if it's not a pg error event.Status = "failed" event.ErrInfo = pl.ErrorInfo{ Code: "data-create-fail", Detail: fmt.Sprintf("Database insert failed: %s", err.Error()), Raw: err, } return pl.SetLogError(event, input) } switch e.Code { case "23505": // unique_violation event.Status = "failed" event.ErrInfo = pl.ErrorInfo{ Code: "data-create-duplicate", Detail: fmt.Sprintf("Duplicate value violates unique constraint: %s", e.ConstraintName), Raw: err, } return pl.SetLogError(event, input) case "23503": // foreign_key_violation event.Status = "failed" event.ErrInfo = pl.ErrorInfo{ Code: "data-create-fkViolation", Detail: fmt.Sprintf("Foreign key constraint '%s' violated. Please check related record exists.", e.ConstraintName), Raw: err, } return pl.SetLogError(event, input) default: event.Status = "failed" event.ErrInfo = pl.ErrorInfo{ Code: "data-create-fail", Detail: fmt.Sprintf("Database insert failed: %s", e.Message), Raw: err, } return pl.SetLogError(event, input) } }