Delete fork code and move createPullRequest to create.go
This commit is contained in:
parent
fd4d0e730e
commit
2d74e4f555
6 changed files with 98 additions and 162 deletions
|
@ -10,7 +10,7 @@ import (
|
||||||
|
|
||||||
activities_model "code.gitea.io/gitea/models/activities"
|
activities_model "code.gitea.io/gitea/models/activities"
|
||||||
"code.gitea.io/gitea/models/db"
|
"code.gitea.io/gitea/models/db"
|
||||||
issue_model "code.gitea.io/gitea/models/issues"
|
issues_model "code.gitea.io/gitea/models/issues"
|
||||||
repo_model "code.gitea.io/gitea/models/repo"
|
repo_model "code.gitea.io/gitea/models/repo"
|
||||||
"code.gitea.io/gitea/models/unittest"
|
"code.gitea.io/gitea/models/unittest"
|
||||||
user_model "code.gitea.io/gitea/models/user"
|
user_model "code.gitea.io/gitea/models/user"
|
||||||
|
@ -31,7 +31,7 @@ func TestAction_GetRepoLink(t *testing.T) {
|
||||||
assert.NoError(t, unittest.PrepareTestDatabase())
|
assert.NoError(t, unittest.PrepareTestDatabase())
|
||||||
repo := unittest.AssertExistsAndLoadBean(t, &repo_model.Repository{ID: 1})
|
repo := unittest.AssertExistsAndLoadBean(t, &repo_model.Repository{ID: 1})
|
||||||
owner := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: repo.OwnerID})
|
owner := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: repo.OwnerID})
|
||||||
comment := unittest.AssertExistsAndLoadBean(t, &issue_model.Comment{ID: 2})
|
comment := unittest.AssertExistsAndLoadBean(t, &issues_model.Comment{ID: 2})
|
||||||
action := &activities_model.Action{RepoID: repo.ID, CommentID: comment.ID}
|
action := &activities_model.Action{RepoID: repo.ID, CommentID: comment.ID}
|
||||||
setting.AppSubURL = "/suburl"
|
setting.AppSubURL = "/suburl"
|
||||||
expected := path.Join(setting.AppSubURL, owner.Name, repo.Name)
|
expected := path.Join(setting.AppSubURL, owner.Name, repo.Name)
|
||||||
|
|
|
@ -16,6 +16,7 @@ import (
|
||||||
ap "github.com/go-ap/activitypub"
|
ap "github.com/go-ap/activitypub"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
// Fetch and load a remote object
|
||||||
func AuthorizeInteraction(ctx *context.Context) {
|
func AuthorizeInteraction(ctx *context.Context) {
|
||||||
uri, err := url.Parse(ctx.Req.URL.Query().Get("uri"))
|
uri, err := url.Parse(ctx.Req.URL.Query().Get("uri"))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -40,10 +41,6 @@ func AuthorizeInteraction(ctx *context.Context) {
|
||||||
switch object.GetType() {
|
switch object.GetType() {
|
||||||
case ap.PersonType:
|
case ap.PersonType:
|
||||||
// Federated user
|
// Federated user
|
||||||
if err != nil {
|
|
||||||
ctx.ServerError("UnmarshalJSON", err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
err = createPerson(ctx, object.(*ap.Person))
|
err = createPerson(ctx, object.(*ap.Person))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
ctx.ServerError("FederatedUserNew", err)
|
ctx.ServerError("FederatedUserNew", err)
|
||||||
|
@ -71,35 +68,9 @@ func AuthorizeInteraction(ctx *context.Context) {
|
||||||
}
|
}
|
||||||
ctx.Redirect(username + "/" + reponame)
|
ctx.Redirect(username + "/" + reponame)
|
||||||
case forgefed.TicketType:
|
case forgefed.TicketType:
|
||||||
// Federated ticket
|
// Federated issue or pull request
|
||||||
err = forgefed.OnTicket(object, func(t *forgefed.Ticket) error {
|
err = forgefed.OnTicket(object, func(t *forgefed.Ticket) error {
|
||||||
// TODO: make sure federated user exists
|
return createTicket(ctx, t)
|
||||||
// Also, refactor this code to reduce the chance of accidentally creating import cycles
|
|
||||||
repoURL, err := url.Parse(t.Context.GetLink().String())
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
// Fetch repository object
|
|
||||||
resp, err := activitypub.Fetch(repoURL)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
// Parse repository object
|
|
||||||
ap.ItemTyperFunc = forgefed.GetItemByType
|
|
||||||
ap.JSONItemUnmarshal = forgefed.JSONUnmarshalerFn
|
|
||||||
ap.NotEmptyChecker = forgefed.NotEmpty
|
|
||||||
object, err := ap.UnmarshalJSON(resp)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
// Create federated repo
|
|
||||||
err = forgefed.OnRepository(object, func(r *forgefed.Repository) error {
|
|
||||||
return createRepository(ctx, r)
|
|
||||||
})
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
return createIssue(ctx, t)
|
|
||||||
})
|
})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
ctx.ServerError("ReceiveIssue", err)
|
ctx.ServerError("ReceiveIssue", err)
|
||||||
|
|
|
@ -12,7 +12,7 @@ import (
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"code.gitea.io/gitea/models/auth"
|
"code.gitea.io/gitea/models/auth"
|
||||||
issue_model "code.gitea.io/gitea/models/issues"
|
issues_model "code.gitea.io/gitea/models/issues"
|
||||||
repo_model "code.gitea.io/gitea/models/repo"
|
repo_model "code.gitea.io/gitea/models/repo"
|
||||||
user_model "code.gitea.io/gitea/models/user"
|
user_model "code.gitea.io/gitea/models/user"
|
||||||
"code.gitea.io/gitea/modules/forgefed"
|
"code.gitea.io/gitea/modules/forgefed"
|
||||||
|
@ -20,6 +20,7 @@ import (
|
||||||
"code.gitea.io/gitea/modules/setting"
|
"code.gitea.io/gitea/modules/setting"
|
||||||
"code.gitea.io/gitea/services/activitypub"
|
"code.gitea.io/gitea/services/activitypub"
|
||||||
issue_service "code.gitea.io/gitea/services/issue"
|
issue_service "code.gitea.io/gitea/services/issue"
|
||||||
|
pull_service "code.gitea.io/gitea/services/pull"
|
||||||
repo_service "code.gitea.io/gitea/services/repository"
|
repo_service "code.gitea.io/gitea/services/repository"
|
||||||
user_service "code.gitea.io/gitea/services/user"
|
user_service "code.gitea.io/gitea/services/user"
|
||||||
|
|
||||||
|
@ -120,6 +121,7 @@ func createRepository(ctx context.Context, repository *forgefed.Repository) erro
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Check if repo exists
|
||||||
_, err = repo_model.GetRepositoryByOwnerAndNameCtx(ctx, user.Name, repository.Name.String())
|
_, err = repo_model.GetRepositoryByOwnerAndNameCtx(ctx, user.Name, repository.Name.String())
|
||||||
if err == nil {
|
if err == nil {
|
||||||
return nil
|
return nil
|
||||||
|
@ -143,8 +145,41 @@ func createRepository(ctx context.Context, repository *forgefed.Repository) erro
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Create a ticket
|
||||||
|
func createTicket(ctx context.Context, ticket *forgefed.Ticket) error {
|
||||||
|
if ticket.Origin != nil {
|
||||||
|
return createPullRequest(ctx, ticket)
|
||||||
|
}
|
||||||
|
return createIssue(ctx, ticket)
|
||||||
|
}
|
||||||
|
|
||||||
// Create an issue
|
// Create an issue
|
||||||
func createIssue(ctx context.Context, ticket *forgefed.Ticket) error {
|
func createIssue(ctx context.Context, ticket *forgefed.Ticket) error {
|
||||||
|
repoURL, err := url.Parse(ticket.Context.GetLink().String())
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
// Fetch repository object
|
||||||
|
resp, err := activitypub.Fetch(repoURL)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
// Parse repository object
|
||||||
|
ap.ItemTyperFunc = forgefed.GetItemByType
|
||||||
|
ap.JSONItemUnmarshal = forgefed.JSONUnmarshalerFn
|
||||||
|
ap.NotEmptyChecker = forgefed.NotEmpty
|
||||||
|
object, err := ap.UnmarshalJSON(resp)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
// Create federated repo
|
||||||
|
err = forgefed.OnRepository(object, func(r *forgefed.Repository) error {
|
||||||
|
return createRepository(ctx, r)
|
||||||
|
})
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
// Construct issue
|
// Construct issue
|
||||||
user, err := activitypub.PersonIRIToUser(ctx, ap.IRI(ticket.AttributedTo.GetLink().String()))
|
user, err := activitypub.PersonIRIToUser(ctx, ap.IRI(ticket.AttributedTo.GetLink().String()))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -158,7 +193,7 @@ func createIssue(ctx context.Context, ticket *forgefed.Ticket) error {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
issue := &issue_model.Issue{
|
issue := &issues_model.Issue{
|
||||||
ID: idx,
|
ID: idx,
|
||||||
RepoID: repo.ID,
|
RepoID: repo.ID,
|
||||||
Repo: repo,
|
Repo: repo,
|
||||||
|
@ -170,6 +205,56 @@ func createIssue(ctx context.Context, ticket *forgefed.Ticket) error {
|
||||||
return issue_service.NewIssue(repo, issue, nil, nil, nil)
|
return issue_service.NewIssue(repo, issue, nil, nil, nil)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Create a pull request
|
||||||
|
func createPullRequest(ctx context.Context, ticket *forgefed.Ticket) error {
|
||||||
|
// TODO: Clean this up
|
||||||
|
|
||||||
|
actorUser, err := activitypub.PersonIRIToUser(ctx, ticket.AttributedTo.GetLink())
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
// TODO: The IRI processing stuff should be moved to iri.go
|
||||||
|
originIRI := ticket.Origin.GetLink()
|
||||||
|
originIRISplit := strings.Split(originIRI.String(), "/")
|
||||||
|
originInstance := originIRISplit[2]
|
||||||
|
originUsername := originIRISplit[3]
|
||||||
|
originReponame := originIRISplit[4]
|
||||||
|
originBranch := originIRISplit[len(originIRISplit)-1]
|
||||||
|
originRepo, _ := repo_model.GetRepositoryByOwnerAndName(originUsername+"@"+originInstance, originReponame)
|
||||||
|
|
||||||
|
targetIRI := ticket.Target.GetLink()
|
||||||
|
targetIRISplit := strings.Split(targetIRI.String(), "/")
|
||||||
|
// targetInstance := targetIRISplit[2]
|
||||||
|
targetUsername := targetIRISplit[3]
|
||||||
|
targetReponame := targetIRISplit[4]
|
||||||
|
targetBranch := targetIRISplit[len(targetIRISplit)-1]
|
||||||
|
|
||||||
|
targetRepo, _ := repo_model.GetRepositoryByOwnerAndName(targetUsername, targetReponame)
|
||||||
|
|
||||||
|
prIssue := &issues_model.Issue{
|
||||||
|
RepoID: targetRepo.ID,
|
||||||
|
Title: "Hello from test.exozy.me!", // Don't hardcode, get the title from the Ticket object
|
||||||
|
PosterID: actorUser.ID,
|
||||||
|
Poster: actorUser,
|
||||||
|
IsPull: true,
|
||||||
|
Content: "🎉", // TODO: Get content from Ticket object
|
||||||
|
}
|
||||||
|
|
||||||
|
pr := &issues_model.PullRequest{
|
||||||
|
HeadRepoID: originRepo.ID,
|
||||||
|
BaseRepoID: targetRepo.ID,
|
||||||
|
HeadBranch: originBranch,
|
||||||
|
BaseBranch: targetBranch,
|
||||||
|
HeadRepo: originRepo,
|
||||||
|
BaseRepo: targetRepo,
|
||||||
|
MergeBase: "",
|
||||||
|
Type: issues_model.PullRequestGitea,
|
||||||
|
}
|
||||||
|
|
||||||
|
return pull_service.NewPullRequest(ctx, targetRepo, prIssue, []int64{}, []string{}, pr, []int64{})
|
||||||
|
}
|
||||||
|
|
||||||
// Create a comment
|
// Create a comment
|
||||||
func createComment(ctx context.Context, note *ap.Note) error {
|
func createComment(ctx context.Context, note *ap.Note) error {
|
||||||
actorUser, err := activitypub.PersonIRIToUser(ctx, note.AttributedTo.GetLink())
|
actorUser, err := activitypub.PersonIRIToUser(ctx, note.AttributedTo.GetLink())
|
||||||
|
@ -185,11 +270,11 @@ func createComment(ctx context.Context, note *ap.Note) error {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
issue, err := issue_model.GetIssueByIndex(repo.ID, idx)
|
issue, err := issues_model.GetIssueByIndex(repo.ID, idx)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
_, err = issue_model.CreateCommentCtx(ctx, &issue_model.CreateCommentOptions{
|
_, err = issues_model.CreateCommentCtx(ctx, &issues_model.CreateCommentOptions{
|
||||||
Doer: actorUser,
|
Doer: actorUser,
|
||||||
Repo: repo,
|
Repo: repo,
|
||||||
Issue: issue,
|
Issue: issue,
|
||||||
|
|
|
@ -1,51 +0,0 @@
|
||||||
// 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 (
|
|
||||||
"context"
|
|
||||||
|
|
||||||
repo_model "code.gitea.io/gitea/models/repo"
|
|
||||||
user_model "code.gitea.io/gitea/models/user"
|
|
||||||
"code.gitea.io/gitea/modules/forgefed"
|
|
||||||
"code.gitea.io/gitea/services/activitypub"
|
|
||||||
repo_service "code.gitea.io/gitea/services/repository"
|
|
||||||
|
|
||||||
ap "github.com/go-ap/activitypub"
|
|
||||||
)
|
|
||||||
|
|
||||||
func fork(ctx context.Context, create ap.Create) error {
|
|
||||||
// Object is the new fork repository
|
|
||||||
repository, err := ap.To[forgefed.Repository](create.Object)
|
|
||||||
if err != nil {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// TODO: Clean this up
|
|
||||||
actor, err := activitypub.PersonIRIToUser(ctx, create.Actor.GetLink())
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
// Don't create an actual copy of the remote repo!
|
|
||||||
// https://gitea.com/xy/gitea/issues/7
|
|
||||||
|
|
||||||
// Create the fork
|
|
||||||
repoIRI := repository.GetLink()
|
|
||||||
username, reponame, err := activitypub.RepositoryIRIToName(repoIRI)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
// FederatedUserNew(username + "@" + instance, )
|
|
||||||
user, _ := user_model.GetUserByName(ctx, username)
|
|
||||||
|
|
||||||
// var repo forgefed.Repository
|
|
||||||
// repo = activity.Object
|
|
||||||
repo, _ := repo_model.GetRepositoryByOwnerAndName(actor.Name, reponame) // hardcoded for now :(
|
|
||||||
|
|
||||||
_, err = repo_service.ForkRepository(ctx, user, user, repo_service.ForkRepoOptions{BaseRepo: repo, Name: reponame, Description: "this is a remote fork"})
|
|
||||||
return err
|
|
||||||
}
|
|
|
@ -1,66 +0,0 @@
|
||||||
// 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 (
|
|
||||||
"context"
|
|
||||||
"strings"
|
|
||||||
|
|
||||||
issues_model "code.gitea.io/gitea/models/issues"
|
|
||||||
repo_model "code.gitea.io/gitea/models/repo"
|
|
||||||
"code.gitea.io/gitea/modules/forgefed"
|
|
||||||
"code.gitea.io/gitea/modules/log"
|
|
||||||
"code.gitea.io/gitea/services/activitypub"
|
|
||||||
pull_service "code.gitea.io/gitea/services/pull"
|
|
||||||
)
|
|
||||||
|
|
||||||
func createPullRequest(ctx context.Context, ticket *forgefed.Ticket) error {
|
|
||||||
// TODO: Clean this up
|
|
||||||
|
|
||||||
actorUser, err := activitypub.PersonIRIToUser(ctx, ticket.AttributedTo.GetLink())
|
|
||||||
if err != nil {
|
|
||||||
log.Warn("Couldn't find ticket actor user", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
// TODO: The IRI processing stuff should be moved to iri.go
|
|
||||||
originIRI := ticket.Origin.GetLink()
|
|
||||||
originIRISplit := strings.Split(originIRI.String(), "/")
|
|
||||||
originInstance := originIRISplit[2]
|
|
||||||
originUsername := originIRISplit[3]
|
|
||||||
originReponame := originIRISplit[4]
|
|
||||||
originBranch := originIRISplit[len(originIRISplit)-1]
|
|
||||||
originRepo, _ := repo_model.GetRepositoryByOwnerAndName(originUsername+"@"+originInstance, originReponame)
|
|
||||||
|
|
||||||
targetIRI := ticket.Target.GetLink()
|
|
||||||
targetIRISplit := strings.Split(targetIRI.String(), "/")
|
|
||||||
// targetInstance := targetIRISplit[2]
|
|
||||||
targetUsername := targetIRISplit[3]
|
|
||||||
targetReponame := targetIRISplit[4]
|
|
||||||
targetBranch := targetIRISplit[len(targetIRISplit)-1]
|
|
||||||
|
|
||||||
targetRepo, _ := repo_model.GetRepositoryByOwnerAndName(targetUsername, targetReponame)
|
|
||||||
|
|
||||||
prIssue := &issues_model.Issue{
|
|
||||||
RepoID: targetRepo.ID,
|
|
||||||
Title: "Hello from test.exozy.me!", // Don't hardcode, get the title from the Ticket object
|
|
||||||
PosterID: actorUser.ID,
|
|
||||||
Poster: actorUser,
|
|
||||||
IsPull: true,
|
|
||||||
Content: "🎉", // TODO: Get content from Ticket object
|
|
||||||
}
|
|
||||||
|
|
||||||
pr := &issues_model.PullRequest{
|
|
||||||
HeadRepoID: originRepo.ID,
|
|
||||||
BaseRepoID: targetRepo.ID,
|
|
||||||
HeadBranch: originBranch,
|
|
||||||
BaseBranch: targetBranch,
|
|
||||||
HeadRepo: originRepo,
|
|
||||||
BaseRepo: targetRepo,
|
|
||||||
MergeBase: "",
|
|
||||||
Type: issues_model.PullRequestGitea,
|
|
||||||
}
|
|
||||||
|
|
||||||
return pull_service.NewPullRequest(ctx, targetRepo, prIssue, []int64{}, []string{}, pr, []int64{})
|
|
||||||
}
|
|
|
@ -127,16 +127,13 @@ func RepoInbox(ctx *context.APIContext) {
|
||||||
switch o.Type {
|
switch o.Type {
|
||||||
case forgefed.RepositoryType:
|
case forgefed.RepositoryType:
|
||||||
// Fork created by remote instance
|
// Fork created by remote instance
|
||||||
return fork(ctx, activity)
|
return forgefed.OnRepository(o, func(r *forgefed.Repository) error {
|
||||||
|
return createRepository(ctx, r)
|
||||||
|
})
|
||||||
case forgefed.TicketType:
|
case forgefed.TicketType:
|
||||||
// New issue or pull request
|
// New issue or pull request
|
||||||
return forgefed.OnTicket(o, func(t *forgefed.Ticket) error {
|
return forgefed.OnTicket(o, func(t *forgefed.Ticket) error {
|
||||||
if t.Origin != nil {
|
return createTicket(ctx, t)
|
||||||
// New pull request
|
|
||||||
return createPullRequest(ctx, t)
|
|
||||||
}
|
|
||||||
// New issue
|
|
||||||
return createIssue(ctx, t)
|
|
||||||
})
|
})
|
||||||
case ap.NoteType:
|
case ap.NoteType:
|
||||||
// New comment
|
// New comment
|
||||||
|
|
Loading…
Add table
Reference in a new issue