package mysqlkindboxreq

import (
	"context"
	"database/sql"
	"time"

	"git.gocasts.ir/ebhomengo/niki/entity"
	errmsg "git.gocasts.ir/ebhomengo/niki/pkg/err_msg"
	richerror "git.gocasts.ir/ebhomengo/niki/pkg/rich_error"
	"git.gocasts.ir/ebhomengo/niki/repository/mysql"
)

func (d *DB) UpdateKindBoxReq(ctx context.Context, kindBoxReq entity.KindBoxReq) error {
	const op = "mysqlkindboxreq.UpdateKindBoxReq"

	var (
		senderAgentID sql.NullInt64
		deliveredAt   sql.NullTime
	)
	if kindBoxReq.SenderAgentID != 0 {
		senderAgentID = sql.NullInt64{Int64: int64(kindBoxReq.SenderAgentID), Valid: true}
	} else {
		senderAgentID = sql.NullInt64{Int64: 0, Valid: false}
	}
	if !kindBoxReq.DeliveredAt.IsZero() {
		deliveredAt = sql.NullTime{Time: kindBoxReq.DeliveredAt, Valid: true}
	} else {
		deliveredAt = sql.NullTime{Time: time.Time{}, Valid: false}
	}

	query := `UPDATE kind_box_reqs
			  SET benefactor_id = ?, kind_box_type = ?, count_requested = ?, count_accepted = ?,
			      description = ?, status = ?, deliver_refer_time_id = ?, deliver_refer_date = ?,
			      deliver_address_id = ?, sender_agent_id = ?, delivered_at = ? 
			  WHERE id = ? AND deleted_at IS NULL`
	//nolint
	stmt, err := d.conn.PrepareStatement(ctx, mysql.StatementKeyKindBoxReqUpdate, query)
	if err != nil {
		return richerror.New(op).WithErr(err).
			WithMessage(errmsg.ErrorMsgCantPrepareStatement).WithKind(richerror.KindUnexpected)
	}

	_, uErr := stmt.ExecContext(ctx, kindBoxReq.BenefactorID, kindBoxReq.KindBoxType,
		kindBoxReq.CountRequested, kindBoxReq.CountAccepted, kindBoxReq.Description, kindBoxReq.Status,
		kindBoxReq.DeliverReferTimeID, kindBoxReq.DeliverReferDate, kindBoxReq.DeliverAddressID,
		senderAgentID, deliveredAt, kindBoxReq.ID)
	if uErr != nil {
		return richerror.New(op).WithErr(uErr).WithMessage(errmsg.ErrorMsgCantUpdateRecord).
			WithKind(richerror.KindUnexpected)
	}

	return nil
}