aboutsummaryrefslogtreecommitdiff
path: root/common/http
diff options
context:
space:
mode:
authorruben <code@rbn.im>2019-05-21 22:56:55 +0200
committerBrendan Abolivier <babolivier@matrix.org>2019-05-21 21:56:55 +0100
commit74827428bd3e11faab65f12204449c1b9469b0ae (patch)
tree0decafa542436a0667ed2d3e3cfd4df0f03de1e5 /common/http
parent4d588f7008afe5600219ac0930c2eee2de5c447b (diff)
use go module for dependencies (#594)
Diffstat (limited to 'common/http')
-rw-r--r--common/http/http.go57
1 files changed, 57 insertions, 0 deletions
diff --git a/common/http/http.go b/common/http/http.go
new file mode 100644
index 00000000..3c647544
--- /dev/null
+++ b/common/http/http.go
@@ -0,0 +1,57 @@
+package http
+
+import (
+ "bytes"
+ "context"
+ "encoding/json"
+ "fmt"
+ "net/http"
+
+ opentracing "github.com/opentracing/opentracing-go"
+ "github.com/opentracing/opentracing-go/ext"
+)
+
+// PostJSON performs a POST request with JSON on an internal HTTP API
+func PostJSON(
+ ctx context.Context, span opentracing.Span, httpClient *http.Client,
+ apiURL string, request, response interface{},
+) error {
+ jsonBytes, err := json.Marshal(request)
+ if err != nil {
+ return err
+ }
+
+ req, err := http.NewRequest(http.MethodPost, apiURL, bytes.NewReader(jsonBytes))
+ if err != nil {
+ return err
+ }
+
+ // Mark the span as being an RPC client.
+ ext.SpanKindRPCClient.Set(span)
+ carrier := opentracing.HTTPHeadersCarrier(req.Header)
+ tracer := opentracing.GlobalTracer()
+
+ if err = tracer.Inject(span.Context(), opentracing.HTTPHeaders, carrier); err != nil {
+ return err
+ }
+
+ req.Header.Set("Content-Type", "application/json")
+
+ res, err := httpClient.Do(req.WithContext(ctx))
+ if res != nil {
+ defer (func() { err = res.Body.Close() })()
+ }
+ if err != nil {
+ return err
+ }
+ if res.StatusCode != http.StatusOK {
+ var errorBody struct {
+ Message string `json:"message"`
+ }
+ if err = json.NewDecoder(res.Body).Decode(&errorBody); err != nil {
+ return err
+ }
+ return fmt.Errorf("api: %d: %s", res.StatusCode, errorBody.Message)
+ }
+ return json.NewDecoder(res.Body).Decode(response)
+}