move api/server to api/edge/bff
This commit is contained in:
29
api/edge/bff/internal/server/siteimp/call.go
Normal file
29
api/edge/bff/internal/server/siteimp/call.go
Normal file
@@ -0,0 +1,29 @@
|
||||
package siteimp
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
"net/http"
|
||||
|
||||
"github.com/tech/sendico/pkg/api/http/response"
|
||||
snotifications "github.com/tech/sendico/pkg/messaging/notifications/site"
|
||||
"github.com/tech/sendico/pkg/model"
|
||||
"go.uber.org/zap"
|
||||
)
|
||||
|
||||
func (a *SiteAPI) callRequest(r *http.Request) http.HandlerFunc {
|
||||
var request model.CallRequest
|
||||
if err := json.NewDecoder(r.Body).Decode(&request); err != nil {
|
||||
a.logger.Warn("Failed to decode call request payload", zap.Error(err))
|
||||
return response.BadRequest(a.logger, a.Name(), "invalid_payload", "Failed to decode call request payload")
|
||||
}
|
||||
request.Normalize()
|
||||
if err := request.Validate(); err != nil {
|
||||
a.logger.Warn("Call request validation failed", zap.Error(err))
|
||||
return response.BadPayload(a.logger, a.Name(), err)
|
||||
}
|
||||
if err := a.producer.SendMessage(snotifications.CallRequest(a.Name(), &request)); err != nil {
|
||||
a.logger.Warn("Failed to enqueue call request notification", zap.Error(err))
|
||||
return response.Internal(a.logger, a.Name(), err)
|
||||
}
|
||||
return a.acceptedQueued()
|
||||
}
|
||||
32
api/edge/bff/internal/server/siteimp/contact.go
Normal file
32
api/edge/bff/internal/server/siteimp/contact.go
Normal file
@@ -0,0 +1,32 @@
|
||||
package siteimp
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
"net/http"
|
||||
|
||||
"github.com/tech/sendico/pkg/api/http/response"
|
||||
snotifications "github.com/tech/sendico/pkg/messaging/notifications/site"
|
||||
"github.com/tech/sendico/pkg/model"
|
||||
"go.uber.org/zap"
|
||||
)
|
||||
|
||||
func (a *SiteAPI) contactRequest(r *http.Request) http.HandlerFunc {
|
||||
var request model.ContactRequest
|
||||
if err := json.NewDecoder(r.Body).Decode(&request); err != nil {
|
||||
a.logger.Warn("Failed to decode contact request payload", zap.Error(err))
|
||||
return response.BadRequest(a.logger, a.Name(), "invalid_payload", "Failed to decode contact request payload")
|
||||
}
|
||||
request.Normalize()
|
||||
if request.Topic == "" {
|
||||
request.Topic = model.ContactRequestTopicSiteContact
|
||||
}
|
||||
if err := request.Validate(); err != nil {
|
||||
a.logger.Warn("Contact request validation failed", zap.Error(err))
|
||||
return response.BadPayload(a.logger, a.Name(), err)
|
||||
}
|
||||
if err := a.producer.SendMessage(snotifications.ContactRequest(a.Name(), &request)); err != nil {
|
||||
a.logger.Warn("Failed to enqueue contact request notification", zap.Error(err))
|
||||
return response.Internal(a.logger, a.Name(), err)
|
||||
}
|
||||
return a.acceptedQueued()
|
||||
}
|
||||
31
api/edge/bff/internal/server/siteimp/demo.go
Normal file
31
api/edge/bff/internal/server/siteimp/demo.go
Normal file
@@ -0,0 +1,31 @@
|
||||
package siteimp
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
"net/http"
|
||||
|
||||
"github.com/tech/sendico/pkg/api/http/response"
|
||||
snotifications "github.com/tech/sendico/pkg/messaging/notifications/site"
|
||||
"github.com/tech/sendico/pkg/model"
|
||||
"go.uber.org/zap"
|
||||
)
|
||||
|
||||
func (a *SiteAPI) demoRequest(r *http.Request) http.HandlerFunc {
|
||||
var request model.DemoRequest
|
||||
if err := json.NewDecoder(r.Body).Decode(&request); err != nil {
|
||||
a.logger.Warn("Failed to decode demo request payload", zap.Error(err))
|
||||
return response.BadRequest(a.logger, a.Name(), "invalid_payload", "Failed to decode demo request payload")
|
||||
}
|
||||
request.Normalize()
|
||||
if err := request.Validate(); err != nil {
|
||||
a.logger.Warn("Demo request validation failed", zap.Error(err))
|
||||
return response.BadPayload(a.logger, a.Name(), err)
|
||||
}
|
||||
|
||||
if err := a.producer.SendMessage(snotifications.DemoRequest(a.Name(), &request)); err != nil {
|
||||
a.logger.Warn("Failed to enqueue demo request notification", zap.Error(err))
|
||||
return response.Internal(a.logger, a.Name(), err)
|
||||
}
|
||||
|
||||
return a.acceptedQueued()
|
||||
}
|
||||
19
api/edge/bff/internal/server/siteimp/response.go
Normal file
19
api/edge/bff/internal/server/siteimp/response.go
Normal file
@@ -0,0 +1,19 @@
|
||||
package siteimp
|
||||
|
||||
import (
|
||||
"net/http"
|
||||
|
||||
"github.com/tech/sendico/pkg/api/http/response"
|
||||
)
|
||||
|
||||
type enqueueResponse struct {
|
||||
Status string `json:"status"`
|
||||
}
|
||||
|
||||
func newEnqueueResponse() enqueueResponse {
|
||||
return enqueueResponse{Status: "queued"}
|
||||
}
|
||||
|
||||
func (a *SiteAPI) acceptedQueued() http.HandlerFunc {
|
||||
return response.Accepted(a.logger, newEnqueueResponse())
|
||||
}
|
||||
36
api/edge/bff/internal/server/siteimp/service.go
Normal file
36
api/edge/bff/internal/server/siteimp/service.go
Normal file
@@ -0,0 +1,36 @@
|
||||
package siteimp
|
||||
|
||||
import (
|
||||
"context"
|
||||
|
||||
api "github.com/tech/sendico/pkg/api/http"
|
||||
"github.com/tech/sendico/pkg/messaging"
|
||||
"github.com/tech/sendico/pkg/mlogger"
|
||||
"github.com/tech/sendico/pkg/mservice"
|
||||
eapi "github.com/tech/sendico/server/interface/api"
|
||||
)
|
||||
|
||||
type SiteAPI struct {
|
||||
logger mlogger.Logger
|
||||
producer messaging.Producer
|
||||
}
|
||||
|
||||
func (a *SiteAPI) Name() mservice.Type {
|
||||
return mservice.Site
|
||||
}
|
||||
|
||||
func (a *SiteAPI) Finish(_ context.Context) error {
|
||||
return nil
|
||||
}
|
||||
|
||||
func CreateAPI(a eapi.API) (*SiteAPI, error) {
|
||||
p := &SiteAPI{
|
||||
logger: a.Logger().Named(mservice.Site),
|
||||
producer: a.Register().Messaging().Producer(),
|
||||
}
|
||||
|
||||
a.Register().Handler(mservice.Site, "/request/demo", api.Post, p.demoRequest)
|
||||
a.Register().Handler(mservice.Site, "/request/contact", api.Post, p.contactRequest)
|
||||
a.Register().Handler(mservice.Site, "/request/call", api.Post, p.callRequest)
|
||||
return p, nil
|
||||
}
|
||||
Reference in New Issue
Block a user