Files
sendico/api/edge/bff/internal/server/logoimp/logo.go
2026-02-28 00:39:20 +01:00

41 lines
1.3 KiB
Go

package logoimp
import (
_ "embed"
"net/http"
"github.com/tech/sendico/pkg/api/http/response"
"github.com/tech/sendico/pkg/model"
"github.com/tech/sendico/pkg/mservice"
"github.com/tech/sendico/server/assets"
"github.com/tech/sendico/server/internal/mutil/imagewriter"
mutil "github.com/tech/sendico/server/internal/mutil/param"
"go.uber.org/zap"
)
func (a *LogoAPI) getLogo(r *http.Request) http.HandlerFunc {
accountRef, err := mutil.GetAccountRef(r)
if err != nil {
a.logger.Warn("Invalid account reference", zap.Error(err))
return response.BadReference(a.logger, a.Name(), mutil.AccountRefName(), mutil.GetAccountID(r), err)
}
// new context for execution
var account model.Account
if err := a.adb.Get(r.Context(), accountRef, &account); err != nil {
a.logger.Warn("Failed to fetch account data", zap.Error(err))
return response.NotFound(a.logger, mservice.Accounts, err.Error())
}
res := func(w http.ResponseWriter, r *http.Request) {
// TODO: delayed response due to context expiration after writing reposnse :(
if err = imagewriter.WriteImage(w, &assets.MailLogo, "image/png"); err != nil {
a.logger.Error("Failed to send logo", zap.Error(err))
}
// ma.Identify(acc.Email)
// ampli.Instance.EmailOpened(acc.Email,
// ampli.EmailOpened.Builder().EmailType(mutil.GetParam(r, "email_type")).Build())
}
return res
}