2022-03-19 08:55:58 -05:00
|
|
|
// Copyright 2022 The Gitea Authors. All rights reserved.
|
2021-10-26 15:59:14 -10:00
|
|
|
// Use of this source code is governed by a MIT-style
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
|
|
|
package activitypub
|
|
|
|
|
|
|
|
import (
|
|
|
|
"net/http"
|
|
|
|
"strings"
|
|
|
|
|
2021-10-28 17:13:24 -10:00
|
|
|
"code.gitea.io/gitea/modules/activitypub"
|
2021-10-26 15:59:14 -10:00
|
|
|
"code.gitea.io/gitea/modules/context"
|
2022-06-09 17:59:43 -05:00
|
|
|
"code.gitea.io/gitea/modules/json"
|
2021-10-26 15:59:14 -10:00
|
|
|
"code.gitea.io/gitea/modules/setting"
|
|
|
|
"code.gitea.io/gitea/routers/api/v1/user"
|
2022-03-19 09:14:08 -05:00
|
|
|
|
2022-05-23 11:43:59 -05:00
|
|
|
ap "github.com/go-ap/activitypub"
|
2021-10-26 15:59:14 -10:00
|
|
|
)
|
|
|
|
|
2021-11-10 13:35:02 +01:00
|
|
|
// Person function
|
2021-10-26 15:59:14 -10:00
|
|
|
func Person(ctx *context.APIContext) {
|
2021-11-10 13:35:02 +01:00
|
|
|
// swagger:operation GET /activitypub/user/{username} activitypub activitypubPerson
|
2021-10-26 15:59:14 -10:00
|
|
|
// ---
|
|
|
|
// summary: Returns the person
|
|
|
|
// produces:
|
|
|
|
// - application/json
|
|
|
|
// parameters:
|
|
|
|
// - name: username
|
|
|
|
// in: path
|
|
|
|
// description: username of the user
|
|
|
|
// type: string
|
|
|
|
// required: true
|
|
|
|
// responses:
|
|
|
|
// "200":
|
|
|
|
// "$ref": "#/responses/ActivityPub"
|
|
|
|
|
2021-10-28 17:13:24 -10:00
|
|
|
user := user.GetUserByParamsName(ctx, "username")
|
2022-03-24 18:44:44 -05:00
|
|
|
if user == nil {
|
2022-03-27 12:25:56 -05:00
|
|
|
return
|
2022-03-24 18:44:44 -05:00
|
|
|
}
|
2021-10-26 15:59:14 -10:00
|
|
|
username := ctx.Params("username")
|
2022-06-09 17:43:54 -05:00
|
|
|
|
2021-10-26 15:59:14 -10:00
|
|
|
link := strings.TrimSuffix(setting.AppURL, "/") + strings.TrimSuffix(ctx.Req.URL.EscapedPath(), "/")
|
2022-05-23 11:43:59 -05:00
|
|
|
person := ap.PersonNew(ap.IRI(link))
|
2021-10-26 15:59:14 -10:00
|
|
|
|
2022-05-23 11:43:59 -05:00
|
|
|
name := ap.NaturalLanguageValuesNew()
|
2022-06-09 17:59:43 -05:00
|
|
|
err := name.Set("en", ap.Content(username))
|
|
|
|
if err != nil {
|
|
|
|
ctx.Error(http.StatusInternalServerError, "Set name", err)
|
|
|
|
return
|
|
|
|
}
|
2022-05-23 11:43:59 -05:00
|
|
|
person.Name = name
|
2021-10-26 15:59:14 -10:00
|
|
|
|
2022-06-11 11:00:45 -05:00
|
|
|
ap.Inbox.AddTo(person)
|
|
|
|
ap.Outbox.AddTo(person)
|
2021-10-28 17:13:24 -10:00
|
|
|
|
2022-05-23 11:43:59 -05:00
|
|
|
person.PublicKey.ID = ap.IRI(link + "#main-key")
|
|
|
|
person.PublicKey.Owner = ap.IRI(link)
|
2022-06-09 17:43:54 -05:00
|
|
|
|
2022-05-09 19:10:45 -05:00
|
|
|
publicKeyPem, err := activitypub.GetPublicKey(user)
|
|
|
|
if err != nil {
|
2021-10-28 17:13:24 -10:00
|
|
|
ctx.Error(http.StatusInternalServerError, "GetPublicKey", err)
|
2022-03-30 15:52:52 -05:00
|
|
|
return
|
2021-10-28 17:13:24 -10:00
|
|
|
}
|
2022-05-23 11:43:59 -05:00
|
|
|
person.PublicKey.PublicKeyPem = publicKeyPem
|
2021-10-28 17:13:24 -10:00
|
|
|
|
2022-05-23 11:43:59 -05:00
|
|
|
binary, err := person.MarshalJSON()
|
2022-03-30 15:52:52 -05:00
|
|
|
if err != nil {
|
|
|
|
ctx.Error(http.StatusInternalServerError, "Serialize", err)
|
|
|
|
}
|
2022-06-09 17:59:43 -05:00
|
|
|
|
|
|
|
var jsonmap map[string]interface{}
|
2022-06-10 10:37:55 -05:00
|
|
|
err = json.Unmarshal(binary, &jsonmap)
|
2022-06-09 17:59:43 -05:00
|
|
|
if err != nil {
|
|
|
|
ctx.Error(http.StatusInternalServerError, "Unmarshall", err)
|
|
|
|
}
|
|
|
|
|
2022-06-10 11:04:07 -05:00
|
|
|
jsonmap["@context"] = "https://www.w3.org/ns/activitystreams"
|
|
|
|
|
2022-06-09 17:59:43 -05:00
|
|
|
ctx.JSON(http.StatusOK, jsonmap)
|
2021-10-26 15:59:14 -10:00
|
|
|
}
|
2021-11-10 13:35:02 +01:00
|
|
|
|
|
|
|
// PersonInbox function
|
|
|
|
func PersonInbox(ctx *context.APIContext) {
|
|
|
|
// swagger:operation POST /activitypub/user/{username}/inbox activitypub activitypubPersonInbox
|
|
|
|
// ---
|
|
|
|
// summary: Send to the inbox
|
|
|
|
// produces:
|
|
|
|
// - application/json
|
|
|
|
// parameters:
|
|
|
|
// - name: username
|
|
|
|
// in: path
|
|
|
|
// description: username of the user
|
|
|
|
// type: string
|
|
|
|
// required: true
|
|
|
|
// responses:
|
|
|
|
// responses:
|
|
|
|
// "204":
|
|
|
|
// "$ref": "#/responses/empty"
|
|
|
|
|
|
|
|
ctx.Status(http.StatusNoContent)
|
|
|
|
}
|