Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add API to manage issue dependencies #17935

Merged
merged 89 commits into from
Mar 28, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
89 commits
Select commit Hold shift + click to select a range
2e4bacc
Add API to manage issue dependencies
qwerty287 Dec 8, 2021
39cda9b
Merge branch 'main' into deps-api
qwerty287 Dec 8, 2021
610dc7c
Fix swagger
qwerty287 Dec 8, 2021
657cf90
Merge branch 'main' into deps-api
qwerty287 Dec 10, 2021
9a033fb
Fix merge
qwerty287 Dec 10, 2021
8a586d0
fmt
qwerty287 Dec 10, 2021
5b90bf0
Merge branch 'main' into deps-api
qwerty287 Dec 21, 2021
881c215
Merge branch 'main' into deps-api
qwerty287 Dec 24, 2021
e3a7e53
Merge branch 'main' into deps-api
qwerty287 Jan 4, 2022
954f316
Merge branch 'main' into deps-api
qwerty287 Jan 7, 2022
0dc9bbc
Update func name
qwerty287 Jan 12, 2022
b9c7353
Merge branch 'main' into deps-api
qwerty287 Jan 12, 2022
7b47b95
Merge branch 'deps-api' of github.com:qwerty287/gitea into deps-api
qwerty287 Jan 12, 2022
2663781
Don't load attrs
qwerty287 Jan 12, 2022
dde1c05
Fix permissions
qwerty287 Jan 12, 2022
49706f1
Fix lint
qwerty287 Jan 12, 2022
c76b957
Merge branch 'main' into deps-api
qwerty287 Jan 22, 2022
0c5f827
Merge branch 'main' into deps-api
qwerty287 Feb 14, 2022
38be2e1
Merge branch 'main' into deps-api
qwerty287 Feb 19, 2022
8e5f138
Merge branch 'main' into deps-api
qwerty287 Mar 21, 2022
3e39b7a
Merge branch 'main' into deps-api
qwerty287 Mar 27, 2022
d1c188d
Fix merge
qwerty287 Mar 27, 2022
69e582c
Merge branch 'main' into deps-api
qwerty287 Mar 27, 2022
6d983bd
Merge branch 'main' into deps-api
qwerty287 Apr 5, 2022
9040b3d
Merge branch 'main' into deps-api
qwerty287 Apr 15, 2022
0f1be7e
Merge branch 'main' into deps-api
qwerty287 Apr 28, 2022
f87ca3c
Fix merge
qwerty287 Apr 28, 2022
f7f4f29
Merge branch 'main' into deps-api
qwerty287 May 4, 2022
6f6c084
Merge branch 'main' into deps-api
6543 May 15, 2022
8fe30ba
adopt refactor
6543 May 15, 2022
d39a04d
Merge branch 'main' into deps-api
qwerty287 Jun 16, 2022
b3a38cf
Adapt refactors
qwerty287 Jun 16, 2022
e1beca7
Merge branch 'main' into deps-api
qwerty287 Jul 18, 2022
21ef6f9
Merge branch 'main' into deps-api
qwerty287 Aug 15, 2022
33eb8da
Merge main
MaeIsBad Aug 16, 2022
efb3f99
Merge branch 'main' into deps-api
qwerty287 Aug 31, 2022
8d59495
Merge branch 'main' into deps-api
qwerty287 Sep 25, 2022
33f5fe0
Merge branch 'main' into deps-api
qwerty287 Sep 26, 2022
dc5afba
Merge branch 'main' into deps-api
qwerty287 Sep 28, 2022
7aa5241
Merge branch 'main' into deps-api
6543 Sep 29, 2022
627a698
Merge branch 'main' into deps-api
qwerty287 Sep 29, 2022
e846811
Merge branch 'main' into deps-api
qwerty287 Sep 29, 2022
eaaa412
Merge branch 'main' into deps-api
6543 Oct 16, 2022
0d068b5
Merge branch 'main' into deps-api
6543 Oct 19, 2022
968e54a
Merge branch 'main' into deps-api
6543 Oct 19, 2022
60d0c06
Merge branch 'main' into deps-api
qwerty287 Oct 20, 2022
cee38a8
Check if issue can be accessed
qwerty287 Oct 20, 2022
62704ac
Merge branch 'main' into deps-api
6543 Oct 20, 2022
ea9f55b
rm reqRepoWriter
qwerty287 Oct 20, 2022
bec7f23
Merge branch 'main' into deps-api
qwerty287 Oct 21, 2022
4932e2d
Merge branch 'main' into deps-api
6543 Oct 22, 2022
b7eb74e
Merge branch 'main' into deps-api
qwerty287 Oct 22, 2022
699639a
Merge branch 'deps-api' of github.com:qwerty287/gitea into deps-api
qwerty287 Oct 22, 2022
9e68e22
Merge branch 'main' into deps-api
qwerty287 Nov 4, 2022
2f16641
Merge branch 'main' into deps-api
qwerty287 Nov 16, 2022
5722075
Merge branch 'main' into deps-api
qwerty287 Mar 16, 2023
4141bd9
fix merge
qwerty287 Mar 16, 2023
39e65f4
Get perms before issue
qwerty287 Mar 18, 2023
6f9926c
Move to new file `issue_dep`
qwerty287 Mar 18, 2023
8863019
Merge branch 'main' into deps-api
qwerty287 Mar 18, 2023
d81caf9
Merge branch 'main' into deps-api
qwerty287 Mar 19, 2023
221c460
Apply patch
qwerty287 Mar 19, 2023
98732ed
Merge branch 'main' into deps-api
qwerty287 Mar 19, 2023
6ba39d0
make fmt
qwerty287 Mar 19, 2023
bac7eb6
Update routers/api/v1/api.go
qwerty287 Mar 20, 2023
96831f4
Use full name
zeripath Mar 20, 2023
1b1e755
More adjustments
zeripath Mar 20, 2023
b3ae625
Merge pull request #4 from zeripath/deps-api
qwerty287 Mar 21, 2023
259b1a4
Merge branch 'main' into deps-api
qwerty287 Mar 21, 2023
8616ea2
Merge branch 'main' into deps-api
qwerty287 Mar 21, 2023
7351a1e
fix swagger
zeripath Mar 21, 2023
3c24b3b
apply patch by @zeripath
qwerty287 Mar 22, 2023
c58d97e
Merge branch 'main' into deps-api
qwerty287 Mar 22, 2023
b790153
Merge branch 'main' into deps-api
qwerty287 Mar 24, 2023
d075ffd
Merge branch 'main' into deps-api
qwerty287 Mar 26, 2023
44a120e
Properly handle permissions in the UI and avoid the permissions map
zeripath Mar 26, 2023
21dd56d
Merge pull request #5 from zeripath/deps-api
qwerty287 Mar 26, 2023
ee56bd5
Merge branch 'main' into deps-api
qwerty287 Mar 26, 2023
37081b4
ignore hidden (fix nil pointer)
qwerty287 Mar 26, 2023
aed6ee7
Revert "ignore hidden (fix nil pointer)"
qwerty287 Mar 26, 2023
ebef894
fix nil pointer correctly
qwerty287 Mar 26, 2023
2dd02de
Merge branch 'main' into deps-api
qwerty287 Mar 27, 2023
cba5d17
Update routers/api/v1/repo/issue_dependency.go
qwerty287 Mar 27, 2023
e7b9aca
Merge branch 'main' into deps-api
qwerty287 Mar 27, 2023
438c87b
Merge branch 'main' into deps-api
qwerty287 Mar 27, 2023
55c43e6
Merge branch 'main' into deps-api
lunny Mar 28, 2023
7029b97
Merge branch 'main' into deps-api
lunny Mar 28, 2023
749b034
Merge branch 'main' into deps-api
lunny Mar 28, 2023
56a916b
Merge branch 'main' into deps-api
jolheiser Mar 28, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion models/issues/dependency.go
Original file line number Diff line number Diff line change
Expand Up @@ -134,7 +134,7 @@ func CreateIssueDependency(user *user_model.User, issue, dep *Issue) error {
}
defer committer.Close()

// Check if it aleready exists
// Check if it already exists
exists, err := issueDepExists(ctx, issue.ID, dep.ID)
if err != nil {
return err
Expand Down
23 changes: 14 additions & 9 deletions models/issues/issue.go
Original file line number Diff line number Diff line change
Expand Up @@ -189,7 +189,7 @@ func (issue *Issue) IsOverdue() bool {

// LoadRepo loads issue's repository
func (issue *Issue) LoadRepo(ctx context.Context) (err error) {
if issue.Repo == nil {
if issue.Repo == nil && issue.RepoID != 0 {
issue.Repo, err = repo_model.GetRepositoryByID(ctx, issue.RepoID)
if err != nil {
return fmt.Errorf("getRepositoryByID [%d]: %w", issue.RepoID, err)
Expand Down Expand Up @@ -223,7 +223,7 @@ func (issue *Issue) GetPullRequest() (pr *PullRequest, err error) {

// LoadLabels loads labels
func (issue *Issue) LoadLabels(ctx context.Context) (err error) {
if issue.Labels == nil {
if issue.Labels == nil && issue.ID != 0 {
issue.Labels, err = GetLabelsByIssueID(ctx, issue.ID)
if err != nil {
return fmt.Errorf("getLabelsByIssueID [%d]: %w", issue.ID, err)
Expand All @@ -234,7 +234,7 @@ func (issue *Issue) LoadLabels(ctx context.Context) (err error) {

// LoadPoster loads poster
func (issue *Issue) LoadPoster(ctx context.Context) (err error) {
if issue.Poster == nil {
if issue.Poster == nil && issue.PosterID != 0 {
issue.Poster, err = user_model.GetPossibleUserByID(ctx, issue.PosterID)
if err != nil {
issue.PosterID = -1
Expand All @@ -252,7 +252,7 @@ func (issue *Issue) LoadPoster(ctx context.Context) (err error) {
// LoadPullRequest loads pull request info
func (issue *Issue) LoadPullRequest(ctx context.Context) (err error) {
if issue.IsPull {
if issue.PullRequest == nil {
if issue.PullRequest == nil && issue.ID != 0 {
issue.PullRequest, err = GetPullRequestByIssueID(ctx, issue.ID)
if err != nil {
if IsErrPullRequestNotExist(err) {
Expand All @@ -261,7 +261,9 @@ func (issue *Issue) LoadPullRequest(ctx context.Context) (err error) {
return fmt.Errorf("getPullRequestByIssueID [%d]: %w", issue.ID, err)
}
}
issue.PullRequest.Issue = issue
if issue.PullRequest != nil {
issue.PullRequest.Issue = issue
}
}
return nil
}
Expand Down Expand Up @@ -2128,15 +2130,18 @@ func (issue *Issue) GetParticipantIDsByIssue(ctx context.Context) ([]int64, erro
}

// BlockedByDependencies finds all Dependencies an issue is blocked by
func (issue *Issue) BlockedByDependencies(ctx context.Context) (issueDeps []*DependencyInfo, err error) {
err = db.GetEngine(ctx).
func (issue *Issue) BlockedByDependencies(ctx context.Context, opts db.ListOptions) (issueDeps []*DependencyInfo, err error) {
sess := db.GetEngine(ctx).
Table("issue").
Join("INNER", "repository", "repository.id = issue.repo_id").
Join("INNER", "issue_dependency", "issue_dependency.dependency_id = issue.id").
Where("issue_id = ?", issue.ID).
// sort by repo id then created date, with the issues of the same repo at the beginning of the list
OrderBy("CASE WHEN issue.repo_id = ? THEN 0 ELSE issue.repo_id END, issue.created_unix DESC", issue.RepoID).
Find(&issueDeps)
OrderBy("CASE WHEN issue.repo_id = ? THEN 0 ELSE issue.repo_id END, issue.created_unix DESC", issue.RepoID)
if opts.Page != 0 {
sess = db.SetSessionPagination(sess, &opts)
}
err = sess.Find(&issueDeps)

for _, depInfo := range issueDeps {
depInfo.Issue.Repo = &depInfo.Repository
Expand Down
8 changes: 8 additions & 0 deletions modules/structs/issue.go
Original file line number Diff line number Diff line change
Expand Up @@ -211,3 +211,11 @@ func (it IssueTemplate) Type() IssueTemplateType {
}
return ""
}

// IssueMeta basic issue information
// swagger:model
type IssueMeta struct {
Index int64 `json:"index"`
Owner string `json:"owner"`
Name string `json:"repo"`
}
3 changes: 3 additions & 0 deletions options/locale/locale_en-US.ini
Original file line number Diff line number Diff line change
Expand Up @@ -1489,6 +1489,9 @@ issues.due_date_invalid = "The due date is invalid or out of range. Please use t
issues.dependency.title = Dependencies
issues.dependency.issue_no_dependencies = No dependencies set.
issues.dependency.pr_no_dependencies = No dependencies set.
issues.dependency.no_permission_1 = "You do not have permission to read %d dependency"
issues.dependency.no_permission_n = "You do not have permission to read %d dependencies"
issues.dependency.no_permission.can_remove = "You do not have permission to read this dependency but can remove this dependency"
issues.dependency.add = Add dependency…
issues.dependency.cancel = Cancel
issues.dependency.remove = Remove
Expand Down
8 changes: 8 additions & 0 deletions routers/api/v1/api.go
Original file line number Diff line number Diff line change
Expand Up @@ -1026,6 +1026,14 @@ func Routes(ctx gocontext.Context) *web.Route {
Patch(reqToken(auth_model.AccessTokenScopeRepo), mustNotBeArchived, bind(api.EditAttachmentOptions{}), repo.EditIssueAttachment).
Delete(reqToken(auth_model.AccessTokenScopeRepo), mustNotBeArchived, repo.DeleteIssueAttachment)
}, mustEnableAttachments)
m.Combo("/dependencies").
Get(repo.GetIssueDependencies).
Post(reqToken(auth_model.AccessTokenScopeRepo), mustNotBeArchived, bind(api.IssueMeta{}), repo.CreateIssueDependency).
Delete(reqToken(auth_model.AccessTokenScopeRepo), mustNotBeArchived, bind(api.IssueMeta{}), repo.RemoveIssueDependency)
m.Combo("/blocks").
Get(repo.GetIssueBlocks).
Post(reqToken(auth_model.AccessTokenScopeRepo), bind(api.IssueMeta{}), repo.CreateIssueBlocking).
Delete(reqToken(auth_model.AccessTokenScopeRepo), bind(api.IssueMeta{}), repo.RemoveIssueBlocking)
})
}, mustEnableIssuesOrPulls)
m.Group("/labels", func() {
Expand Down
Loading