Add Note object endpoint

forgejo-federation
Anthony Wang 2022-11-27 19:29:03 +00:00
parent 3e690fbae2
commit f5a50ce457
No known key found for this signature in database
GPG Key ID: 42A5B952E6DD8D38
6 changed files with 85 additions and 6 deletions

View File

@ -29,6 +29,7 @@ type Repository struct {
// RepositoryNew initializes a Repository type actor
func RepositoryNew(id ap.ID) *Repository {
a := ap.ActorNew(id, RepositoryType)
a.Type = RepositoryType
o := Repository{Actor: *a}
return &o
}

View File

@ -0,0 +1,64 @@
// Copyright 2022 The Gitea Authors. All rights reserved.
// Use of this source code is governed by a MIT-style
// license that can be found in the LICENSE file.
package activitypub
import (
"strconv"
issues_model "code.gitea.io/gitea/models/issues"
"code.gitea.io/gitea/modules/context"
"code.gitea.io/gitea/services/activitypub"
)
// Note function returns the Note object for a comment to an issue or PR
func Note(ctx *context.APIContext) {
// swagger:operation GET /activitypub/note/{username}/{reponame}/{id}/{noteid} activitypub activitypubNote
// ---
// summary: Returns the Note object for a comment to an issue or PR
// produces
// - application/activity+json
// parameters:
// - name: username
// in: path
// description: username of the user
// type: string
// required: true
// - name: reponame
// in: path
// description: name of the repo
// type: string
// required: true
// - name: id
// in: path
// description: ID number of the issue or PR
// type: string
// required: true
// - name: noteid
// in: path
// description: ID number of the comment
// type: string
// required: true
// responses:
// "200":
// "$ref": "#/responses/ActivityPub"
index, err := strconv.ParseInt(ctx.Params("noteid"), 10, 64)
if err != nil {
ctx.ServerError("ParseInt", err)
return
}
// TODO: index can be spoofed!!!
comment, err := issues_model.GetCommentByID(ctx, index)
if err != nil {
ctx.ServerError("GetCommentByID", err)
return
}
note, err := activitypub.Note(comment)
if err != nil {
ctx.ServerError("Note", err)
return
}
response(ctx, note)
}

View File

@ -41,7 +41,6 @@ func Repo(ctx *context.APIContext) {
iri := ctx.Repo.Repository.GetIRI()
repo := forgefed.RepositoryNew(ap.IRI(iri))
repo.Type = forgefed.RepositoryType
repo.Name = ap.NaturalLanguageValuesNew()
err := repo.Name.Set("en", ap.Content(ctx.Repo.Repository.Name))
@ -148,7 +147,6 @@ func RepoInbox(ctx *context.APIContext) {
case ap.LikeType:
err = star(ctx, activity)
default:
log.Info("Incoming unsupported ActivityStreams type: %s", activity.Type)
ctx.PlainText(http.StatusNotImplemented, "ActivityStreams type not supported")
return
}

View File

@ -662,6 +662,7 @@ func Routes(ctx gocontext.Context) *web.Route {
m.Get("/followers", activitypub.RepoFollowers)
}, repoAssignment())
m.Get("/ticket/{username}/{reponame}/{id}", repoAssignment(), activitypub.Ticket)
m.Get("/note/{username}/{reponame}/{id}/{noteid}", repoAssignment(), activitypub.Note)
})
}
m.Get("/signing-key.gpg", misc.SigningKey)

View File

@ -15,15 +15,26 @@ import (
)
// Construct a Note object from a comment
func Note(comment *issues_model.Comment) *ap.Note {
func Note(comment *issues_model.Comment) (*ap.Note, error) {
err := comment.LoadPoster()
if err != nil {
return nil, err
}
err = comment.LoadIssue()
if err != nil {
return nil, err
}
note := ap.Note{
Type: ap.NoteType,
AttributedTo: ap.IRI(comment.Poster.GetIRI()),
Context: ap.IRI(comment.Issue.GetIRI()),
}
note.Content = ap.NaturalLanguageValuesNew()
_ = note.Content.Set("en", ap.Content(comment.Content))
return &note
err = note.Content.Set("en", ap.Content(comment.Content))
if err != nil {
return nil, err
}
return &note, nil
}
// Construct a Ticket object from an issue

View File

@ -32,7 +32,11 @@ func CreateIssueComment(doer *user_model.User, repo *repo_model.Repository, issu
if strings.Contains(repo.OwnerName, "@") {
// Federated comment
create := activitypub.Create(repo.OriginalURL + "/inbox", activitypub.Note(comment))
note, err := activitypub.Note(comment)
if err != nil {
return nil, err
}
create := activitypub.Create(repo.OriginalURL + "/inbox", note)
err = activitypub.Send(doer, create)
if err != nil {
return nil, err