releaseAttachments = append(releaseAttachments, attachments[i].RelativePath())
}
+ if _, err = sess.In("release_id", builder.Select("id").From("`release`").Where(builder.Eq{"`release`.repo_id": repoID})).
+ Delete(&Attachment{}); err != nil {
+ return err
+ }
+
if _, err := sess.Exec("UPDATE `user` SET num_stars=num_stars-1 WHERE id IN (SELECT `uid` FROM `star` WHERE repo_id = ?)", repo.ID); err != nil {
return err
}
"net/http"
"net/url"
"os"
+ "path"
"path/filepath"
"strconv"
"strings"
if err != nil {
log.Error("Fetch branch from %s failed: %v", pr.Head.CloneURL, err)
} else {
- headBranch := filepath.Join(g.gitPath(), "refs", "heads", pr.Head.OwnerName, pr.Head.Ref)
+ // a new branch name with <original_owner_name/original_branchname> will be created to as new head branch
+ ref := path.Join(pr.Head.OwnerName, pr.Head.Ref)
+ headBranch := filepath.Join(g.gitPath(), "refs", "heads", ref)
if err := os.MkdirAll(filepath.Dir(headBranch), os.ModePerm); err != nil {
return err
}
if err != nil {
return err
}
+ pr.Head.Ref = ref
}
}
}
}
+ // whatever it's a forked repo PR, we have to change head info as the same as the base info
+ pr.Head.OwnerName = pr.Base.OwnerName
+ pr.Head.RepoName = pr.Base.RepoName
}
var err error
if !release.Draft {
commit, err := g.gitRepo.GetTagCommit(rel.TagName)
if err != nil {
- return fmt.Errorf("GetCommit: %v", err)
+ return fmt.Errorf("GetTagCommit[%v]: %v", rel.TagName, err)
}
rel.NumCommits, err = commit.CommitsCount()
if err != nil {
if err := json.Unmarshal(body, &ret); err != nil {
return http.StatusInternalServerError, fmt.Sprintf("Response body Unmarshal error: %v", err.Error())
}
+ return http.StatusInternalServerError, ret.Err
}
return http.StatusOK, fmt.Sprintf("Restore repo %s/%s successfully", ownerName, repoName)
commit, err := gitRepo.GetCommit(mergeCommit[:40])
if err != nil {
- return nil, fmt.Errorf("GetCommit: %v", err)
+ return nil, fmt.Errorf("GetMergeCommit[%v]: %v", mergeCommit[:40], err)
}
return commit, nil
commit, err := gitRepo.GetCommit(rel.Target)
if err != nil {
- return false, fmt.Errorf("GetCommit: %v", err)
+ return false, fmt.Errorf("createTag::GetCommit[%v]: %v", rel.Target, err)
}
// Trim '--' prefix to prevent command line argument vulnerability.