diff options
Diffstat (limited to 'routers/repo/issue.go')
-rw-r--r-- | routers/repo/issue.go | 52 |
1 files changed, 14 insertions, 38 deletions
diff --git a/routers/repo/issue.go b/routers/repo/issue.go index 46b513b265..24fecaf415 100644 --- a/routers/repo/issue.go +++ b/routers/repo/issue.go @@ -11,8 +11,6 @@ import ( "io/ioutil" "net/http" "net/url" - "path" - "regexp" "strings" "time" @@ -22,7 +20,6 @@ import ( "github.com/gogits/gogs/models" "github.com/gogits/gogs/modules/auth" "github.com/gogits/gogs/modules/base" - "github.com/gogits/gogs/modules/bindata" "github.com/gogits/gogs/modules/context" "github.com/gogits/gogs/modules/log" "github.com/gogits/gogs/modules/markdown" @@ -945,51 +942,30 @@ func Labels(ctx *context.Context) { ctx.HTML(200, LABELS) } -func getLabelTemplateFile(name string) ([]byte, error) { - relPath := path.Join("conf/label", strings.TrimLeft(name, "./")) - - // Use custom file when available. - customPath := path.Join(setting.CustomPath, relPath) - if com.IsFile(customPath) { - return ioutil.ReadFile(customPath) - } - return bindata.Asset(relPath) -} - func InitializeLabels(ctx *context.Context, form auth.InitializeLabelsForm) { if ctx.HasError() { - ctx.Flash.Error(ctx.Data["ErrorMsg"].(string)) ctx.Redirect(ctx.Repo.RepoLink + "/labels") return } - data, err := getLabelTemplateFile(form.TemplateName) + list, err := models.GetLabelTemplateFile(form.TemplateName) if err != nil { + ctx.Flash.Error(ctx.Tr("repo.issues.label_templates.fail_to_load_file", form.TemplateName, err)) ctx.Redirect(ctx.Repo.RepoLink + "/labels") return } - r, _ := regexp.Compile("#([a-fA-F0-9]{6})") - for i, line := range strings.Split(string(data), "\n") { - if len(line) > 0 { - line_x := strings.SplitN(strings.Trim(line, " \t"), " ", 2) - if len(line_x) == 2 && len(line_x[1]) > 0 { - if r.MatchString(line_x[0]) { - l := &models.Label{ - RepoID: ctx.Repo.Repository.ID, - Name: line_x[1], - Color: line_x[0], - } - if err := models.NewLabel(l); err != nil { - ctx.Handle(500, "InitializeLabelsFromTemplate", err) - return - } - } else { - log.Warn("Line %d on the label template file '%s': Bad HTML color code", i+1, form.TemplateName) - } - } else { - log.Warn("Line %d on the label template file '%s': Line is malformed", i+1, form.TemplateName) - } + + labels := make([]*models.Label, len(list)) + for i := 0; i < len(list); i++ { + labels[i] = &models.Label{ + RepoID: ctx.Repo.Repository.ID, + Name: list[i][0], + Color: list[i][1], } } + if err := models.NewLabels(labels...); err != nil { + ctx.Handle(500, "NewLabels", err) + return + } ctx.Redirect(ctx.Repo.RepoLink + "/labels") } @@ -1008,7 +984,7 @@ func NewLabel(ctx *context.Context, form auth.CreateLabelForm) { Name: form.Title, Color: form.Color, } - if err := models.NewLabel(l); err != nil { + if err := models.NewLabels(l); err != nil { ctx.Handle(500, "NewLabel", err) return } |