Check if label template exist first (#14384)
* add check * refactor * rollback repo on error after session closed
This commit is contained in:
parent
127907c5e6
commit
2686e6bbbe
5 changed files with 40 additions and 33 deletions
|
@ -47,7 +47,7 @@ type Label struct {
|
||||||
func GetLabelTemplateFile(name string) ([][3]string, error) {
|
func GetLabelTemplateFile(name string) ([][3]string, error) {
|
||||||
data, err := GetRepoInitFile("label", name)
|
data, err := GetRepoInitFile("label", name)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, fmt.Errorf("GetRepoInitFile: %v", err)
|
return nil, ErrIssueLabelTemplateLoad{name, fmt.Errorf("GetRepoInitFile: %v", err)}
|
||||||
}
|
}
|
||||||
|
|
||||||
lines := strings.Split(string(data), "\n")
|
lines := strings.Split(string(data), "\n")
|
||||||
|
@ -62,7 +62,7 @@ func GetLabelTemplateFile(name string) ([][3]string, error) {
|
||||||
|
|
||||||
fields := strings.SplitN(parts[0], " ", 2)
|
fields := strings.SplitN(parts[0], " ", 2)
|
||||||
if len(fields) != 2 {
|
if len(fields) != 2 {
|
||||||
return nil, fmt.Errorf("line is malformed: %s", line)
|
return nil, ErrIssueLabelTemplateLoad{name, fmt.Errorf("line is malformed: %s", line)}
|
||||||
}
|
}
|
||||||
|
|
||||||
color := strings.Trim(fields[0], " ")
|
color := strings.Trim(fields[0], " ")
|
||||||
|
@ -70,7 +70,7 @@ func GetLabelTemplateFile(name string) ([][3]string, error) {
|
||||||
color = "#" + color
|
color = "#" + color
|
||||||
}
|
}
|
||||||
if !LabelColorPattern.MatchString(color) {
|
if !LabelColorPattern.MatchString(color) {
|
||||||
return nil, fmt.Errorf("bad HTML color code in line: %s", line)
|
return nil, ErrIssueLabelTemplateLoad{name, fmt.Errorf("bad HTML color code in line: %s", line)}
|
||||||
}
|
}
|
||||||
|
|
||||||
var description string
|
var description string
|
||||||
|
@ -167,7 +167,7 @@ func (label *Label) ForegroundColor() template.CSS {
|
||||||
func loadLabels(labelTemplate string) ([]string, error) {
|
func loadLabels(labelTemplate string) ([]string, error) {
|
||||||
list, err := GetLabelTemplateFile(labelTemplate)
|
list, err := GetLabelTemplateFile(labelTemplate)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, ErrIssueLabelTemplateLoad{labelTemplate, err}
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
labels := make([]string, len(list))
|
labels := make([]string, len(list))
|
||||||
|
@ -186,7 +186,7 @@ func LoadLabelsFormatted(labelTemplate string) (string, error) {
|
||||||
func initializeLabels(e Engine, id int64, labelTemplate string, isOrg bool) error {
|
func initializeLabels(e Engine, id int64, labelTemplate string, isOrg bool) error {
|
||||||
list, err := GetLabelTemplateFile(labelTemplate)
|
list, err := GetLabelTemplateFile(labelTemplate)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return ErrIssueLabelTemplateLoad{labelTemplate, err}
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
labels := make([]*Label, len(list))
|
labels := make([]*Label, len(list))
|
||||||
|
|
|
@ -1511,26 +1511,27 @@ func UpdateRepositoryUnits(repo *Repository, units []RepoUnit, deleteUnitTypes [
|
||||||
}
|
}
|
||||||
|
|
||||||
// DeleteRepository deletes a repository for a user or organization.
|
// DeleteRepository deletes a repository for a user or organization.
|
||||||
|
// make sure if you call this func to close open sessions (sqlite will otherwise get a deadlock)
|
||||||
func DeleteRepository(doer *User, uid, repoID int64) error {
|
func DeleteRepository(doer *User, uid, repoID int64) error {
|
||||||
|
sess := x.NewSession()
|
||||||
|
defer sess.Close()
|
||||||
|
if err := sess.Begin(); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
// In case is a organization.
|
// In case is a organization.
|
||||||
org, err := GetUserByID(uid)
|
org, err := getUserByID(sess, uid)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
if org.IsOrganization() {
|
if org.IsOrganization() {
|
||||||
if err = org.GetTeams(&SearchTeamOptions{}); err != nil {
|
if err = org.getTeams(sess); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
sess := x.NewSession()
|
repo := &Repository{OwnerID: uid}
|
||||||
defer sess.Close()
|
has, err := sess.ID(repoID).Get(repo)
|
||||||
if err = sess.Begin(); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
repo := &Repository{ID: repoID, OwnerID: uid}
|
|
||||||
has, err := sess.Get(repo)
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
} else if !has {
|
} else if !has {
|
||||||
|
@ -1679,14 +1680,7 @@ func DeleteRepository(doer *User, uid, repoID int64) error {
|
||||||
}
|
}
|
||||||
|
|
||||||
if err = sess.Commit(); err != nil {
|
if err = sess.Commit(); err != nil {
|
||||||
sess.Close()
|
return err
|
||||||
if len(deployKeys) > 0 {
|
|
||||||
// We need to rewrite the public keys because the commit failed
|
|
||||||
if err2 := RewriteAllPublicKeys(); err2 != nil {
|
|
||||||
return fmt.Errorf("Commit: %v SSH Keys: %v", err, err2)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return fmt.Errorf("Commit: %v", err)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sess.Close()
|
sess.Close()
|
||||||
|
|
|
@ -27,6 +27,13 @@ func CreateRepository(doer, u *models.User, opts models.CreateRepoOptions) (*mod
|
||||||
opts.DefaultBranch = setting.Repository.DefaultBranch
|
opts.DefaultBranch = setting.Repository.DefaultBranch
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Check if label template exist
|
||||||
|
if len(opts.IssueLabels) > 0 {
|
||||||
|
if _, err := models.GetLabelTemplateFile(opts.IssueLabels); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
repo := &models.Repository{
|
repo := &models.Repository{
|
||||||
OwnerID: u.ID,
|
OwnerID: u.ID,
|
||||||
Owner: u,
|
Owner: u,
|
||||||
|
@ -45,6 +52,8 @@ func CreateRepository(doer, u *models.User, opts models.CreateRepoOptions) (*mod
|
||||||
TrustModel: opts.TrustModel,
|
TrustModel: opts.TrustModel,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var rollbackRepo *models.Repository
|
||||||
|
|
||||||
if err := models.WithTx(func(ctx models.DBContext) error {
|
if err := models.WithTx(func(ctx models.DBContext) error {
|
||||||
if err := models.CreateRepository(ctx, doer, u, repo, false); err != nil {
|
if err := models.CreateRepository(ctx, doer, u, repo, false); err != nil {
|
||||||
return err
|
return err
|
||||||
|
@ -76,7 +85,7 @@ func CreateRepository(doer, u *models.User, opts models.CreateRepoOptions) (*mod
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if err := initRepository(ctx, repoPath, doer, repo, opts); err != nil {
|
if err = initRepository(ctx, repoPath, doer, repo, opts); err != nil {
|
||||||
if err2 := util.RemoveAll(repoPath); err2 != nil {
|
if err2 := util.RemoveAll(repoPath); err2 != nil {
|
||||||
log.Error("initRepository: %v", err)
|
log.Error("initRepository: %v", err)
|
||||||
return fmt.Errorf(
|
return fmt.Errorf(
|
||||||
|
@ -87,10 +96,9 @@ func CreateRepository(doer, u *models.User, opts models.CreateRepoOptions) (*mod
|
||||||
|
|
||||||
// Initialize Issue Labels if selected
|
// Initialize Issue Labels if selected
|
||||||
if len(opts.IssueLabels) > 0 {
|
if len(opts.IssueLabels) > 0 {
|
||||||
if err := models.InitializeLabels(ctx, repo.ID, opts.IssueLabels, false); err != nil {
|
if err = models.InitializeLabels(ctx, repo.ID, opts.IssueLabels, false); err != nil {
|
||||||
if errDelete := models.DeleteRepository(doer, u.ID, repo.ID); errDelete != nil {
|
rollbackRepo = repo
|
||||||
log.Error("Rollback deleteRepository: %v", errDelete)
|
rollbackRepo.OwnerID = u.ID
|
||||||
}
|
|
||||||
return fmt.Errorf("InitializeLabels: %v", err)
|
return fmt.Errorf("InitializeLabels: %v", err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -99,13 +107,18 @@ func CreateRepository(doer, u *models.User, opts models.CreateRepoOptions) (*mod
|
||||||
SetDescription(fmt.Sprintf("CreateRepository(git update-server-info): %s", repoPath)).
|
SetDescription(fmt.Sprintf("CreateRepository(git update-server-info): %s", repoPath)).
|
||||||
RunInDir(repoPath); err != nil {
|
RunInDir(repoPath); err != nil {
|
||||||
log.Error("CreateRepository(git update-server-info) in %v: Stdout: %s\nError: %v", repo, stdout, err)
|
log.Error("CreateRepository(git update-server-info) in %v: Stdout: %s\nError: %v", repo, stdout, err)
|
||||||
if errDelete := models.DeleteRepository(doer, u.ID, repo.ID); errDelete != nil {
|
rollbackRepo = repo
|
||||||
log.Error("Rollback deleteRepository: %v", errDelete)
|
rollbackRepo.OwnerID = u.ID
|
||||||
}
|
|
||||||
return fmt.Errorf("CreateRepository(git update-server-info): %v", err)
|
return fmt.Errorf("CreateRepository(git update-server-info): %v", err)
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}); err != nil {
|
}); err != nil {
|
||||||
|
if rollbackRepo != nil {
|
||||||
|
if errDelete := models.DeleteRepository(doer, rollbackRepo.OwnerID, rollbackRepo.ID); errDelete != nil {
|
||||||
|
log.Error("Rollback deleteRepository: %v", errDelete)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -106,7 +106,7 @@ type CreateRepoOption struct {
|
||||||
Description string `json:"description" binding:"MaxSize(255)"`
|
Description string `json:"description" binding:"MaxSize(255)"`
|
||||||
// Whether the repository is private
|
// Whether the repository is private
|
||||||
Private bool `json:"private"`
|
Private bool `json:"private"`
|
||||||
// Issue Label set to use
|
// Label-Set to use
|
||||||
IssueLabels string `json:"issue_labels"`
|
IssueLabels string `json:"issue_labels"`
|
||||||
// Whether the repository should be auto-intialized?
|
// Whether the repository should be auto-intialized?
|
||||||
AutoInit bool `json:"auto_init"`
|
AutoInit bool `json:"auto_init"`
|
||||||
|
|
|
@ -12488,7 +12488,7 @@
|
||||||
"x-go-name": "Gitignores"
|
"x-go-name": "Gitignores"
|
||||||
},
|
},
|
||||||
"issue_labels": {
|
"issue_labels": {
|
||||||
"description": "Issue Label set to use",
|
"description": "Label-Set to use",
|
||||||
"type": "string",
|
"type": "string",
|
||||||
"x-go-name": "IssueLabels"
|
"x-go-name": "IssueLabels"
|
||||||
},
|
},
|
||||||
|
|
Reference in a new issue