move api/server to api/edge/bff
This commit is contained in:
69
api/edge/bff/internal/server/papitemplate/archive.go
Normal file
69
api/edge/bff/internal/server/papitemplate/archive.go
Normal file
@@ -0,0 +1,69 @@
|
||||
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"
|
||||
mutil "github.com/tech/sendico/server/internal/mutil/param"
|
||||
"go.uber.org/zap"
|
||||
)
|
||||
|
||||
func (a *ProtectedAPI[T]) archive(r *http.Request, account *model.Account, accessToken *sresponse.TokenData) http.HandlerFunc {
|
||||
objectRef, err := a.Cph.GetRef(r)
|
||||
if err != nil {
|
||||
a.Logger.Warn("Failed to restore object reference", zap.Error(err), mutil.PLog(a.Cph, r))
|
||||
return response.BadReference(a.Logger, a.Name(), a.Cph.Name(), a.Cph.GetID(r), err)
|
||||
}
|
||||
organizationRef, err := a.Oph.GetRef(r)
|
||||
if err != nil {
|
||||
a.Logger.Warn("Failed to restore organization reference", zap.Error(err), mutil.PLog(a.Oph, r))
|
||||
return response.BadReference(a.Logger, a.Name(), a.Oph.Name(), a.Oph.GetID(r), err)
|
||||
}
|
||||
|
||||
archived, err := mutil.GetArchiveParam(a.Logger, r)
|
||||
if err != nil {
|
||||
a.Logger.Warn("Failed to read optional 'archived' param", zap.Error(err))
|
||||
return response.Auto(a.Logger, a.resource, err)
|
||||
}
|
||||
if archived == nil {
|
||||
a.Logger.Warn("No archivation setting provided")
|
||||
return response.BadRequest(a.Logger, a.resource, "invalid_query_parameter", "'archived' pram must be present")
|
||||
}
|
||||
cascade, err := mutil.GetCascadeParam(a.Logger, r)
|
||||
if err != nil {
|
||||
a.Logger.Warn("Failed to read optional 'cascade' param", zap.Error(err))
|
||||
return response.Auto(a.Logger, a.resource, err)
|
||||
}
|
||||
if cascade == nil {
|
||||
a.Logger.Warn("Cascade property not specified, defaulting to false")
|
||||
csc := false
|
||||
cascade = &csc
|
||||
}
|
||||
|
||||
ctx := r.Context()
|
||||
_, err = a.a.DBFactory().TransactionFactory().CreateTransaction().Execute(ctx, func(ctx context.Context) (any, error) {
|
||||
return nil, a.DB.SetArchived(r.Context(), *account.GetID(), organizationRef, objectRef, *archived, *cascade)
|
||||
})
|
||||
if err != nil {
|
||||
a.Logger.Warn("Failed to change archive property", zap.Error(err), mzap.StorableRef(account), mutil.PLog(a.Cph, r),
|
||||
zap.Bool("archived", *archived), zap.Bool("cascade", *cascade))
|
||||
return response.Auto(a.Logger, a.Name(), err)
|
||||
}
|
||||
|
||||
if a.nconfig.NeedArchiveNotification {
|
||||
var object T
|
||||
if err := a.DB.Get(ctx, *account.GetID(), objectRef, &object); err != nil {
|
||||
a.Logger.Warn("Failed to fetch object for notification", zap.Error(err), mzap.StorableRef(account), mutil.PLog(a.Cph, r))
|
||||
} else {
|
||||
if err := a.nconfig.ArchiveNotification(&object, *account.GetID()); err != nil {
|
||||
a.Logger.Warn("Failed to send archivation notification", zap.Error(err), mzap.StorableRef(account), mutil.PLog(a.Cph, r))
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return a.Objects([]T{}, accessToken)
|
||||
}
|
||||
Reference in New Issue
Block a user