forked from cosmos/cosmos-sdk
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathenum.go
68 lines (59 loc) · 1.69 KB
/
enum.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
package postgres
import (
"context"
"database/sql"
"fmt"
"io"
"strings"
"cosmossdk.io/schema"
)
// createEnumType creates an enum type in the database.
func (m *moduleIndexer) createEnumType(ctx context.Context, conn dbConn, enum schema.EnumType) error {
typeName := enumTypeName(m.moduleName, enum.Name)
row := conn.QueryRowContext(ctx, "SELECT 1 FROM pg_type WHERE typname = $1", typeName)
var res interface{}
if err := row.Scan(&res); err != nil {
if err != sql.ErrNoRows {
return fmt.Errorf("failed to check if enum type %q exists: %v", typeName, err) //nolint:errorlint // using %v for go 1.12 compat
}
} else {
// the enum type already exists
return nil
}
buf := new(strings.Builder)
err := createEnumTypeSql(buf, m.moduleName, enum)
if err != nil {
return err
}
sqlStr := buf.String()
if m.options.logger != nil {
m.options.logger.Debug("Creating enum type", "sql", sqlStr)
}
_, err = conn.ExecContext(ctx, sqlStr)
return err
}
// createEnumTypeSql generates a CREATE TYPE statement for the enum definition.
func createEnumTypeSql(writer io.Writer, moduleName string, enum schema.EnumType) error {
_, err := fmt.Fprintf(writer, "CREATE TYPE %q AS ENUM (", enumTypeName(moduleName, enum.Name))
if err != nil {
return err
}
for i, value := range enum.Values {
if i > 0 {
_, err = fmt.Fprintf(writer, ", ")
if err != nil {
return err
}
}
_, err = fmt.Fprintf(writer, "'%s'", value.Name)
if err != nil {
return err
}
}
_, err = fmt.Fprintf(writer, ");")
return err
}
// enumTypeName returns the name of the enum type scoped to the module.
func enumTypeName(moduleName, enumName string) string {
return fmt.Sprintf("%s_%s", moduleName, enumName)
}