forked from ebhomengo/niki
55 lines
2.1 KiB
Go
55 lines
2.1 KiB
Go
package mysqlkindboxreq
|
|
|
|
import (
|
|
"context"
|
|
"git.gocasts.ir/ebhomengo/niki/entity"
|
|
errmsg "git.gocasts.ir/ebhomengo/niki/pkg/err_msg"
|
|
richerror "git.gocasts.ir/ebhomengo/niki/pkg/rich_error"
|
|
)
|
|
|
|
func (d DB) AddKindBoxReq(ctx context.Context, kindBoxReq entity.KindBoxReq) (entity.KindBoxReq, error) {
|
|
const op = "mysqlkindboxreq.AddKindBoxReq"
|
|
|
|
res, err := d.conn.Conn().ExecContext(ctx, `insert into kind_box_reqs(benefactor_id,kind_box_type,address_id,count_requested,refer_date,status) values (?,?,?,?,?,?)`,
|
|
kindBoxReq.BenefactorID, kindBoxReq.KindBoxType.String(), kindBoxReq.AddressID, kindBoxReq.CountRequested, kindBoxReq.ReferDate, kindBoxReq.Status.String())
|
|
if err != nil {
|
|
return entity.KindBoxReq{}, richerror.New(op).WithErr(err).
|
|
WithMessage(errmsg.ErrorMsgNotFound).WithKind(richerror.KindUnexpected)
|
|
}
|
|
|
|
//nolint
|
|
// err is always nil
|
|
id, _ := res.LastInsertId()
|
|
kindBoxReq.ID = uint(id)
|
|
|
|
return kindBoxReq, nil
|
|
}
|
|
|
|
func (d DB) AcceptKindBoxReq(ctx context.Context, kindBoxReqID uint, countAccepted uint, description string) error {
|
|
op := richerror.Op("mysqlkindboxreq.AcceptKindBoxReq")
|
|
statement, err := d.conn.Conn().
|
|
Prepare(`update kind_box_reqs set count_accepted = ? , description = ? , status = ? where id = ?`)
|
|
if err != nil {
|
|
return richerror.New(op).WithErr(err).
|
|
WithMessage(errmsg.ErrorMsgSomethingWentWrong).WithKind(richerror.KindUnexpected)
|
|
}
|
|
_, eErr := statement.ExecContext(ctx, countAccepted, description, entity.KindBoxReqAcceptedStatus.String(), kindBoxReqID)
|
|
if eErr != nil {
|
|
return richerror.New(op).WithErr(eErr).
|
|
WithMessage(errmsg.ErrorMsgSomethingWentWrong).WithKind(richerror.KindUnexpected)
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func (d DB) FindByID(ctx context.Context, id uint) (entity.KindBoxReq, error) {
|
|
op := richerror.Op("mysqlkindboxreq.findByID")
|
|
row := d.conn.Conn().QueryRowContext(ctx, `select * from kind_box_reqs where id = ?`, id)
|
|
k, err := scanKindBoxReq(row)
|
|
if err != nil {
|
|
return entity.KindBoxReq{}, richerror.New(op).WithErr(err).
|
|
WithMessage(errmsg.ErrorMsgCantScanQueryResult).WithKind(richerror.KindUnexpected)
|
|
}
|
|
return k, nil
|
|
}
|