summaryrefslogtreecommitdiff
path: root/internal/api/wellknown/webfinger/webfingerget.go
diff options
context:
space:
mode:
Diffstat (limited to 'internal/api/wellknown/webfinger/webfingerget.go')
-rw-r--r--internal/api/wellknown/webfinger/webfingerget.go15
1 files changed, 12 insertions, 3 deletions
diff --git a/internal/api/wellknown/webfinger/webfingerget.go b/internal/api/wellknown/webfinger/webfingerget.go
index 5cd0a7a35..02f366ea6 100644
--- a/internal/api/wellknown/webfinger/webfingerget.go
+++ b/internal/api/wellknown/webfinger/webfingerget.go
@@ -18,6 +18,7 @@
package webfinger
import (
+ "encoding/json"
"errors"
"fmt"
"net/http"
@@ -48,14 +49,14 @@ import (
// - .well-known
//
// produces:
-// - application/json
+// - application/jrd+json
//
// responses:
// '200':
// schema:
// "$ref": "#/definitions/wellKnownResponse"
func (m *Module) WebfingerGETRequest(c *gin.Context) {
- if _, err := apiutil.NegotiateAccept(c, apiutil.JSONAcceptHeaders...); err != nil {
+ if _, err := apiutil.NegotiateAccept(c, apiutil.WebfingerJSONAcceptHeaders...); err != nil {
apiutil.ErrorHandler(c, gtserror.NewErrorNotAcceptable(err, err.Error()), m.processor.InstanceGetV1)
return
}
@@ -86,5 +87,13 @@ func (m *Module) WebfingerGETRequest(c *gin.Context) {
return
}
- c.JSON(http.StatusOK, resp)
+ b, err := json.Marshal(resp)
+ if err != nil {
+ apiutil.ErrorHandler(c, gtserror.NewErrorInternalError(err), m.processor.InstanceGetV1)
+ return
+ }
+
+ // Always return "application/jrd+json" regardless of negotiated
+ // format. See https://www.rfc-editor.org/rfc/rfc7033#section-10.2
+ c.Data(http.StatusOK, string(apiutil.AppJRDJSON), b)
}