diff options
author | 6543 <6543@obermui.de> | 2020-12-02 22:38:30 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-12-02 16:38:30 -0500 |
commit | 7ac8a770e1086a50d1fc0a194fe0d7060036fb30 (patch) | |
tree | f3c9e4e92bd158c8ef506ea46163c2dd95a57cfa /modules/convert | |
parent | 2b4a08e9621e052845062ecd71ebfd37453c0383 (diff) | |
download | gitea-7ac8a770e1086a50d1fc0a194fe0d7060036fb30.tar.gz gitea-7ac8a770e1086a50d1fc0a194fe0d7060036fb30.zip |
Move Repo APIFormat to convert package (#13787)
* Move Repo APIFormat to convert package
* tweek
Diffstat (limited to 'modules/convert')
-rw-r--r-- | modules/convert/notification.go | 2 | ||||
-rw-r--r-- | modules/convert/pull.go | 4 | ||||
-rw-r--r-- | modules/convert/pull_test.go | 2 | ||||
-rw-r--r-- | modules/convert/repository.go | 137 |
4 files changed, 141 insertions, 4 deletions
diff --git a/modules/convert/notification.go b/modules/convert/notification.go index 6934871844..fff891b15d 100644 --- a/modules/convert/notification.go +++ b/modules/convert/notification.go @@ -21,7 +21,7 @@ func ToNotificationThread(n *models.Notification) *api.NotificationThread { //since user only get notifications when he has access to use minimal access mode if n.Repository != nil { - result.Repository = n.Repository.APIFormat(models.AccessModeRead) + result.Repository = ToRepo(n.Repository, models.AccessModeRead) } //handle Subject diff --git a/modules/convert/pull.go b/modules/convert/pull.go index e522bee787..87eabcf53a 100644 --- a/modules/convert/pull.go +++ b/modules/convert/pull.go @@ -68,7 +68,7 @@ func ToAPIPullRequest(pr *models.PullRequest) *api.PullRequest { Name: pr.BaseBranch, Ref: pr.BaseBranch, RepoID: pr.BaseRepoID, - Repository: pr.BaseRepo.APIFormat(models.AccessModeNone), + Repository: ToRepo(pr.BaseRepo, models.AccessModeNone), }, Head: &api.PRBranchInfo{ Name: pr.HeadBranch, @@ -97,7 +97,7 @@ func ToAPIPullRequest(pr *models.PullRequest) *api.PullRequest { if pr.HeadRepo != nil { apiPullRequest.Head.RepoID = pr.HeadRepo.ID - apiPullRequest.Head.Repository = pr.HeadRepo.APIFormat(models.AccessModeNone) + apiPullRequest.Head.Repository = ToRepo(pr.HeadRepo, models.AccessModeNone) headGitRepo, err := git.OpenRepository(pr.HeadRepo.RepoPath()) if err != nil { diff --git a/modules/convert/pull_test.go b/modules/convert/pull_test.go index b78bbe87c9..adf42d8ca4 100644 --- a/modules/convert/pull_test.go +++ b/modules/convert/pull_test.go @@ -27,7 +27,7 @@ func TestPullRequest_APIFormat(t *testing.T) { Ref: "refs/pull/2/head", Sha: "4a357436d925b5c974181ff12a994538ddc5a269", RepoID: 1, - Repository: headRepo.APIFormat(models.AccessModeNone), + Repository: ToRepo(headRepo, models.AccessModeNone), }, apiPullRequest.Head) //withOut HeadRepo diff --git a/modules/convert/repository.go b/modules/convert/repository.go new file mode 100644 index 0000000000..f2e10447f7 --- /dev/null +++ b/modules/convert/repository.go @@ -0,0 +1,137 @@ +// Copyright 2020 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 convert + +import ( + "code.gitea.io/gitea/models" + api "code.gitea.io/gitea/modules/structs" +) + +// ToRepo converts a Repository to api.Repository +func ToRepo(repo *models.Repository, mode models.AccessMode) *api.Repository { + return innerToRepo(repo, mode, false) +} + +func innerToRepo(repo *models.Repository, mode models.AccessMode, isParent bool) *api.Repository { + var parent *api.Repository + + cloneLink := repo.CloneLink() + permission := &api.Permission{ + Admin: mode >= models.AccessModeAdmin, + Push: mode >= models.AccessModeWrite, + Pull: mode >= models.AccessModeRead, + } + if !isParent { + err := repo.GetBaseRepo() + if err != nil { + return nil + } + if repo.BaseRepo != nil { + parent = innerToRepo(repo.BaseRepo, mode, true) + } + } + + //check enabled/disabled units + hasIssues := false + var externalTracker *api.ExternalTracker + var internalTracker *api.InternalTracker + if unit, err := repo.GetUnit(models.UnitTypeIssues); err == nil { + config := unit.IssuesConfig() + hasIssues = true + internalTracker = &api.InternalTracker{ + EnableTimeTracker: config.EnableTimetracker, + AllowOnlyContributorsToTrackTime: config.AllowOnlyContributorsToTrackTime, + EnableIssueDependencies: config.EnableDependencies, + } + } else if unit, err := repo.GetUnit(models.UnitTypeExternalTracker); err == nil { + config := unit.ExternalTrackerConfig() + hasIssues = true + externalTracker = &api.ExternalTracker{ + ExternalTrackerURL: config.ExternalTrackerURL, + ExternalTrackerFormat: config.ExternalTrackerFormat, + ExternalTrackerStyle: config.ExternalTrackerStyle, + } + } + hasWiki := false + var externalWiki *api.ExternalWiki + if _, err := repo.GetUnit(models.UnitTypeWiki); err == nil { + hasWiki = true + } else if unit, err := repo.GetUnit(models.UnitTypeExternalWiki); err == nil { + hasWiki = true + config := unit.ExternalWikiConfig() + externalWiki = &api.ExternalWiki{ + ExternalWikiURL: config.ExternalWikiURL, + } + } + hasPullRequests := false + ignoreWhitespaceConflicts := false + allowMerge := false + allowRebase := false + allowRebaseMerge := false + allowSquash := false + if unit, err := repo.GetUnit(models.UnitTypePullRequests); err == nil { + config := unit.PullRequestsConfig() + hasPullRequests = true + ignoreWhitespaceConflicts = config.IgnoreWhitespaceConflicts + allowMerge = config.AllowMerge + allowRebase = config.AllowRebase + allowRebaseMerge = config.AllowRebaseMerge + allowSquash = config.AllowSquash + } + hasProjects := false + if _, err := repo.GetUnit(models.UnitTypeProjects); err == nil { + hasProjects = true + } + + if err := repo.GetOwner(); err != nil { + return nil + } + + numReleases, _ := models.GetReleaseCountByRepoID(repo.ID, models.FindReleasesOptions{IncludeDrafts: false, IncludeTags: true}) + + return &api.Repository{ + ID: repo.ID, + Owner: ToUser(repo.Owner, mode != models.AccessModeNone, mode >= models.AccessModeAdmin), + Name: repo.Name, + FullName: repo.FullName(), + Description: repo.Description, + Private: repo.IsPrivate, + Template: repo.IsTemplate, + Empty: repo.IsEmpty, + Archived: repo.IsArchived, + Size: int(repo.Size / 1024), + Fork: repo.IsFork, + Parent: parent, + Mirror: repo.IsMirror, + HTMLURL: repo.HTMLURL(), + SSHURL: cloneLink.SSH, + CloneURL: cloneLink.HTTPS, + Website: repo.Website, + Stars: repo.NumStars, + Forks: repo.NumForks, + Watchers: repo.NumWatches, + OpenIssues: repo.NumOpenIssues, + OpenPulls: repo.NumOpenPulls, + Releases: int(numReleases), + DefaultBranch: repo.DefaultBranch, + Created: repo.CreatedUnix.AsTime(), + Updated: repo.UpdatedUnix.AsTime(), + Permissions: permission, + HasIssues: hasIssues, + ExternalTracker: externalTracker, + InternalTracker: internalTracker, + HasWiki: hasWiki, + HasProjects: hasProjects, + ExternalWiki: externalWiki, + HasPullRequests: hasPullRequests, + IgnoreWhitespaceConflicts: ignoreWhitespaceConflicts, + AllowMerge: allowMerge, + AllowRebase: allowRebase, + AllowRebaseMerge: allowRebaseMerge, + AllowSquash: allowSquash, + AvatarURL: repo.AvatarLink(), + Internal: !repo.IsPrivate && repo.Owner.Visibility == api.VisibleTypePrivate, + } +} |