nidus-sync/db/query/comms/contact.go

80 lines
2.5 KiB
Go
Raw Normal View History

package comms
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/jet/postgres"
"github.com/Gleipnir-Technology/nidus-sync/db/gen/nidus-sync/comms/model"
"github.com/Gleipnir-Technology/nidus-sync/db/gen/nidus-sync/comms/table"
)
func ContactInsert(ctx context.Context, txn db.Ex, m model.Contact) (model.Contact, error) {
statement := table.Contact.INSERT(table.Contact.MutableColumns).
MODEL(m).
RETURNING(table.Contact.AllColumns)
return db.ExecuteOneTx[model.Contact](ctx, txn, statement)
}
func ContactEmptyForOrganization(ctx context.Context, txn db.Ex, org_id int64) (*model.Contact, error) {
statement := table.Contact.SELECT(
table.Contact.AllColumns,
).FROM(table.Contact).
WHERE(
postgres.AND(
table.Contact.OrganizationID.EQ(postgres.Int(org_id)),
table.Contact.Name.EQ(postgres.String("")),
postgres.NOT(
postgres.EXISTS(
postgres.SELECT(
postgres.Int(1),
).FROM(table.ContactEmail).
WHERE(table.ContactEmail.ContactID.EQ(table.Contact.ID)),
)),
postgres.NOT(
postgres.EXISTS(
postgres.SELECT(
postgres.Int(1),
).FROM(table.ContactPhone).
WHERE(table.ContactPhone.ContactID.EQ(table.Contact.ID)),
)),
),
)
row, err := db.ExecuteOne[model.Contact](ctx, statement)
if err != nil {
if errors.Is(err, db.ErrNoRows) {
return nil, nil
}
return nil, fmt.Errorf("query contact: %w", err)
}
return &row, nil
}
func ContactFromID(ctx context.Context, txn db.Ex, id int64) (model.Contact, error) {
statement := table.Contact.SELECT(
table.Contact.AllColumns,
).FROM(table.Contact).
WHERE(table.Contact.ID.EQ(postgres.Int(id)))
return db.ExecuteOne[model.Contact](ctx, statement)
}
func ContactUpdateName(ctx context.Context, txn db.Ex, id int64, name string) error {
statement := table.Contact.UPDATE().
SET(
table.Contact.Name.SET(postgres.String(name)),
).
WHERE(table.Contact.OrganizationID.EQ(postgres.Int(id)))
return db.ExecuteNoneTx(ctx, txn, statement)
}
2026-05-15 20:10:14 +00:00
func ContactsFromOrganizationID(ctx context.Context, txn db.Ex, org_id int64) ([]model.Contact, error) {
statement := table.Contact.SELECT(
table.Contact.AllColumns,
).FROM(table.Contact).
2026-05-15 20:10:14 +00:00
WHERE(table.Contact.OrganizationID.EQ(postgres.Int(org_id)))
return db.ExecuteManyTx[model.Contact](ctx, txn, statement)
}