mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2025-01-12 10:31:16 +00:00
Make sure Person endpoint has Content-Type application/activity+json and includes PreferredUsername, URL, and Icon
Setting the correct Content-Type is essential for federating with Mastodon
This commit is contained in:
parent
ed2a6f5348
commit
f88979326c
|
@ -43,13 +43,27 @@ func Person(ctx *context.APIContext) {
|
||||||
link := strings.TrimSuffix(setting.AppURL, "/") + strings.TrimSuffix(ctx.Req.URL.EscapedPath(), "/")
|
link := strings.TrimSuffix(setting.AppURL, "/") + strings.TrimSuffix(ctx.Req.URL.EscapedPath(), "/")
|
||||||
person := ap.PersonNew(ap.IRI(link))
|
person := ap.PersonNew(ap.IRI(link))
|
||||||
|
|
||||||
name := ap.NaturalLanguageValuesNew()
|
person.Name = ap.NaturalLanguageValuesNew()
|
||||||
err := name.Set("en", ap.Content(username))
|
err := person.Name.Set("en", ap.Content(user.FullName))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
ctx.Error(http.StatusInternalServerError, "Set name", err)
|
ctx.Error(http.StatusInternalServerError, "Set Name", err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
person.Name = name
|
|
||||||
|
person.PreferredUsername = ap.NaturalLanguageValuesNew()
|
||||||
|
err = person.PreferredUsername.Set("en", ap.Content(username))
|
||||||
|
if err != nil {
|
||||||
|
ctx.Error(http.StatusInternalServerError, "Set PreferredUsername", err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
person.URL = ap.IRI(setting.AppURL + username)
|
||||||
|
|
||||||
|
person.Icon = ap.Image{
|
||||||
|
Type: ap.ImageType,
|
||||||
|
MediaType: "image/png",
|
||||||
|
URL: ap.IRI(user.AvatarLink()),
|
||||||
|
}
|
||||||
|
|
||||||
person.Inbox = nil
|
person.Inbox = nil
|
||||||
person.Inbox, _ = ap.Inbox.AddTo(person)
|
person.Inbox, _ = ap.Inbox.AddTo(person)
|
||||||
|
@ -77,9 +91,12 @@ func Person(ctx *context.APIContext) {
|
||||||
ctx.Error(http.StatusInternalServerError, "Unmarshall", err)
|
ctx.Error(http.StatusInternalServerError, "Unmarshall", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
jsonmap["@context"] = "https://www.w3.org/ns/activitystreams"
|
jsonmap["@context"] = []string{"https://www.w3.org/ns/activitystreams", "https://w3id.org/security/v1"}
|
||||||
|
|
||||||
ctx.JSON(http.StatusOK, jsonmap)
|
ctx.Resp.Header().Add("Content-Type", "application/activity+json")
|
||||||
|
ctx.Resp.WriteHeader(http.StatusOK)
|
||||||
|
binary, _ = json.Marshal(jsonmap)
|
||||||
|
ctx.Resp.Write(binary)
|
||||||
}
|
}
|
||||||
|
|
||||||
// PersonInbox function
|
// PersonInbox function
|
||||||
|
|
Loading…
Reference in a new issue