34 lines
1.3 KiB
Go
34 lines
1.3 KiB
Go
package papitemplate
|
|
|
|
import (
|
|
"context"
|
|
"net/http"
|
|
|
|
"github.com/tech/sendico/pkg/api/http/response"
|
|
"github.com/tech/sendico/pkg/model"
|
|
"github.com/tech/sendico/pkg/mutil/mzap"
|
|
"github.com/tech/sendico/server/interface/api/sresponse"
|
|
"go.uber.org/zap"
|
|
)
|
|
|
|
func (a *ProtectedAPI[T]) reorder(r *http.Request, account *model.Account, _ *sresponse.TokenData) http.HandlerFunc {
|
|
a.Logger.Debug("Processing reorder request...")
|
|
req, filter, err := a.config.Reorder.ReqProcessor(r)
|
|
if err != nil {
|
|
a.Logger.Warn("Failed to decode tasks reorder request", zap.Error(err), mzap.StorableRef(account))
|
|
return response.BadPayload(a.Logger, a.Name(), err)
|
|
}
|
|
a.Logger.Debug("Moving objects", mzap.ObjRef("object_ref", req.ObjectRef), zap.Int("new_index", req.To))
|
|
|
|
if _, err := a.a.DBFactory().TransactionFactory().CreateTransaction().Execute(r.Context(), func(ctx context.Context) (any, error) {
|
|
// reorder is not atomic, so wrappping into transaction
|
|
return nil, a.config.Reorder.DB.Reorder(ctx, account.ID, req.ObjectRef, req.To, filter)
|
|
}); err != nil {
|
|
a.Logger.Warn("Failed to reorder tasks", zap.Error(err), mzap.ObjRef("object_ref", req.ObjectRef), zap.Int("to", req.To))
|
|
return response.Auto(a.Logger, a.Name(), err)
|
|
}
|
|
|
|
a.Logger.Debug("Reorder request processing complete")
|
|
return response.Success(a.Logger)
|
|
}
|