34 lines
1.1 KiB
Go
34 lines
1.1 KiB
Go
package aapitemplate
|
|
|
|
import (
|
|
"errors"
|
|
"net/http"
|
|
|
|
"github.com/tech/sendico/pkg/api/http/response"
|
|
"github.com/tech/sendico/pkg/merrors"
|
|
"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 *AccountAPI[T]) list(r *http.Request, account *model.Account, accessToken *sresponse.TokenData) http.HandlerFunc {
|
|
ctx := r.Context()
|
|
organizationRef, err := a.Orgph.GetRef(r)
|
|
if err != nil {
|
|
a.Logger.Warn("Failed to restore organization reference", zap.Error(err), mutil.PLog(a.Orgph, r))
|
|
return response.BadReference(a.Logger, a.Name(), a.Orgph.Name(), a.Orgph.GetID(r), err)
|
|
}
|
|
objects, err := a.DB.List(ctx, *account.GetID(), organizationRef)
|
|
if err != nil {
|
|
if !errors.Is(err, merrors.ErrNoData) {
|
|
a.Logger.Warn("Failed to list objects", zap.Error(err), mzap.StorableRef(account))
|
|
return response.Auto(a.Logger, a.Name(), err)
|
|
} else {
|
|
a.Logger.Debug("No objects available", zap.Error(err), mzap.StorableRef(account))
|
|
}
|
|
}
|
|
return a.Objects(objects, accessToken)
|
|
}
|