70 lines
2.4 KiB
Go
70 lines
2.4 KiB
Go
|
|
package public
|
||
|
|
|
||
|
|
import (
|
||
|
|
"context"
|
||
|
|
"errors"
|
||
|
|
"fmt"
|
||
|
|
|
||
|
|
//"github.com/Gleipnir-Technology/bob"
|
||
|
|
"github.com/Gleipnir-Technology/nidus-sync/db"
|
||
|
|
//"github.com/Gleipnir-Technology/nidus-sync/db/gen/nidus-sync/public/enum"
|
||
|
|
"github.com/Gleipnir-Technology/nidus-sync/db/gen/nidus-sync/public/model"
|
||
|
|
"github.com/Gleipnir-Technology/nidus-sync/db/gen/nidus-sync/public/table"
|
||
|
|
"github.com/go-jet/jet/v2/postgres"
|
||
|
|
)
|
||
|
|
|
||
|
|
func AddressFromGID(ctx context.Context, txn db.Ex, gid string) (*model.Address, error) {
|
||
|
|
statement := table.Address.SELECT(
|
||
|
|
table.Address.AllColumns,
|
||
|
|
).FROM(table.Address).
|
||
|
|
WHERE(table.Address.Gid.EQ(postgres.String(gid)))
|
||
|
|
result, err := db.ExecuteOneTx[model.Address](ctx, txn, statement)
|
||
|
|
if err != nil {
|
||
|
|
if errors.Is(err, db.ErrNoRows) {
|
||
|
|
return nil, nil
|
||
|
|
}
|
||
|
|
return nil, fmt.Errorf("execute one: %w", err)
|
||
|
|
}
|
||
|
|
return &result, nil
|
||
|
|
}
|
||
|
|
func AddressFromID(ctx context.Context, txn db.Ex, comm_id int64) (model.Address, error) {
|
||
|
|
statement := table.Address.SELECT(
|
||
|
|
table.Address.AllColumns,
|
||
|
|
).FROM(table.Address).
|
||
|
|
WHERE(table.Address.ID.EQ(postgres.Int(comm_id)))
|
||
|
|
return db.ExecuteOne[model.Address](ctx, statement)
|
||
|
|
}
|
||
|
|
func AddressesFromIDs(ctx context.Context, txn db.Ex, address_ids []int64) ([]model.Address, error) {
|
||
|
|
sql_ids := make([]postgres.Expression, len(address_ids))
|
||
|
|
for i, address_id := range address_ids {
|
||
|
|
sql_ids[i] = postgres.Int(address_id)
|
||
|
|
}
|
||
|
|
statement := table.Address.SELECT(
|
||
|
|
table.Address.AllColumns,
|
||
|
|
).FROM(table.Address).
|
||
|
|
WHERE(table.Address.ID.IN(sql_ids...))
|
||
|
|
return db.ExecuteManyTx[model.Address](ctx, txn, statement)
|
||
|
|
}
|
||
|
|
func AddressInsert(ctx context.Context, txn db.Ex, a model.Address) (model.Address, error) {
|
||
|
|
statement := table.Address.
|
||
|
|
INSERT(table.Address.MutableColumns).
|
||
|
|
MODEL(a).
|
||
|
|
RETURNING(table.Address.AllColumns)
|
||
|
|
return db.ExecuteOneTx[model.Address](ctx, txn, statement)
|
||
|
|
}
|
||
|
|
func AddressInserts(ctx context.Context, txn db.Ex, addresses []model.Address) ([]model.Address, error) {
|
||
|
|
statement := table.Address.
|
||
|
|
INSERT(table.Address.MutableColumns).
|
||
|
|
MODELS(addresses).
|
||
|
|
RETURNING(table.Address.AllColumns)
|
||
|
|
return db.ExecuteManyTx[model.Address](ctx, txn, statement)
|
||
|
|
}
|
||
|
|
|
||
|
|
func addressQuery() postgres.InsertStatement {
|
||
|
|
return table.Address.INSERT(
|
||
|
|
table.Address.MutableColumns,
|
||
|
|
)
|
||
|
|
//im.Into("address", "country", "created", "gid", "h3cell", "id", "locality", "location", "number_", "postal_code", "region", "street", "unit"),
|
||
|
|
//im.Returning("id"),
|
||
|
|
}
|