builder.go 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. package builder
  2. import (
  3. "fmt"
  4. "reflect"
  5. "strings"
  6. )
  7. const dbTag = "db"
  8. // RawFieldNames converts golang struct field into slice string.
  9. func RawFieldNames(in interface{}, postgresSql ...bool) []string {
  10. out := make([]string, 0)
  11. v := reflect.ValueOf(in)
  12. if v.Kind() == reflect.Ptr {
  13. v = v.Elem()
  14. }
  15. var pg bool
  16. if len(postgresSql) > 0 {
  17. pg = postgresSql[0]
  18. }
  19. // we only accept structs
  20. if v.Kind() != reflect.Struct {
  21. panic(fmt.Errorf("ToMap only accepts structs; got %T", v))
  22. }
  23. typ := v.Type()
  24. for i := 0; i < v.NumField(); i++ {
  25. // gets us a StructField
  26. fi := typ.Field(i)
  27. if tagv := fi.Tag.Get(dbTag); tagv != "" {
  28. if pg {
  29. out = append(out, tagv)
  30. } else {
  31. out = append(out, fmt.Sprintf("`%s`", tagv))
  32. }
  33. } else {
  34. if pg {
  35. out = append(out, fi.Name)
  36. } else {
  37. out = append(out, fmt.Sprintf("`%s`", fi.Name))
  38. }
  39. }
  40. }
  41. return out
  42. }
  43. // PostgreSqlJoin concatenates the given elements into a string.
  44. func PostgreSqlJoin(elems []string) string {
  45. b := new(strings.Builder)
  46. for index, e := range elems {
  47. b.WriteString(fmt.Sprintf("%s = $%d, ", e, index+2))
  48. }
  49. if b.Len() == 0 {
  50. return b.String()
  51. }
  52. return b.String()[0 : b.Len()-2]
  53. }