forked from stellar/go
/
request_handler_receive.go
48 lines (41 loc) · 1.32 KB
/
request_handler_receive.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
package handlers
import (
log "github.com/sirupsen/logrus"
"net/http"
"github.com/stellar/go/services/internal/bridge-compliance-shared/http/helpers"
callback "github.com/stellar/go/services/internal/bridge-compliance-shared/protocols/compliance"
)
// HandlerReceive implements /receive endpoint
func (rh *RequestHandler) HandlerReceive(w http.ResponseWriter, r *http.Request) {
request := &callback.ReceiveRequest{}
err := helpers.FromRequest(r, request)
if err != nil {
log.Error(err.Error())
helpers.Write(w, helpers.InvalidParameterError)
return
}
err = helpers.Validate(request)
if err != nil {
switch err := err.(type) {
case *helpers.ErrorResponse:
helpers.Write(w, err)
default:
log.Error(err)
helpers.Write(w, helpers.InternalServerError)
}
return
}
authorizedTransaction, err := rh.Database.GetAuthorizedTransactionByMemo(request.Memo)
if err != nil {
log.WithFields(log.Fields{"err": err}).Error("Error getting authorizedTransaction")
helpers.Write(w, helpers.InternalServerError)
return
}
if authorizedTransaction == nil {
log.WithFields(log.Fields{"memo": request.Memo}).Warn("authorizedTransaction not found")
helpers.Write(w, callback.TransactionNotFoundError)
return
}
response := callback.ReceiveResponse{Data: authorizedTransaction.Data}
helpers.Write(w, &response)
}