| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271 | // Copyright 2014 The Gogs 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 repoimport (	"github.com/gogits/gogs/models"	"github.com/gogits/gogs/modules/auth"	"github.com/gogits/gogs/modules/base"	"github.com/gogits/gogs/modules/log"	"github.com/gogits/gogs/modules/middleware")const (	RELEASES     base.TplName = "repo/release/list"	RELEASE_NEW  base.TplName = "repo/release/new"	RELEASE_EDIT base.TplName = "repo/release/edit")func Releases(ctx *middleware.Context) {	ctx.Data["Title"] = ctx.Tr("repo.release.releases")	ctx.Data["IsRepoToolbarReleases"] = true	ctx.Data["IsRepoReleaseNew"] = false	rawTags, err := ctx.Repo.GitRepo.GetTags()	if err != nil {		ctx.Handle(500, "GetTags", err)		return	}	rels, err := models.GetReleasesByRepoId(ctx.Repo.Repository.Id)	if err != nil {		ctx.Handle(500, "GetReleasesByRepoId", err)		return	}	// Temproray cache commits count of used branches to speed up.	countCache := make(map[string]int)	tags := make([]*models.Release, len(rawTags))	for i, rawTag := range rawTags {		for j, rel := range rels {			if rel == nil || (rel.IsDraft && !ctx.Repo.IsOwner) {				continue			}			if rel.TagName == rawTag {				rel.Publisher, err = models.GetUserById(rel.PublisherId)				if err != nil {					ctx.Handle(500, "GetUserById", err)					return				}				// FIXME: duplicated code.				// Get corresponding target if it's not the current branch.				if ctx.Repo.BranchName != rel.Target {					// Get count if not exists.					if _, ok := countCache[rel.Target]; !ok {						commit, err := ctx.Repo.GitRepo.GetCommitOfBranch(ctx.Repo.BranchName)						if err != nil {							ctx.Handle(500, "GetCommitOfBranch", err)							return						}						countCache[ctx.Repo.BranchName], err = commit.CommitsCount()						if err != nil {							ctx.Handle(500, "CommitsCount2", err)							return						}					}					rel.NumCommitsBehind = countCache[ctx.Repo.BranchName] - rel.NumCommits				} else {					rel.NumCommitsBehind = ctx.Repo.CommitsCount - rel.NumCommits				}				rel.Note = base.RenderMarkdownString(rel.Note, ctx.Repo.RepoLink)				tags[i] = rel				rels[j] = nil // Mark as used.				break			}		}		if tags[i] == nil {			commit, err := ctx.Repo.GitRepo.GetCommitOfTag(rawTag)			if err != nil {				ctx.Handle(500, "GetCommitOfTag2", err)				return			}			tags[i] = &models.Release{				Title:   rawTag,				TagName: rawTag,				Sha1:    commit.Id.String(),			}			tags[i].NumCommits, err = ctx.Repo.GitRepo.CommitsCount(commit.Id.String())			if err != nil {				ctx.Handle(500, "CommitsCount", err)				return			}			tags[i].NumCommitsBehind = ctx.Repo.CommitsCount - tags[i].NumCommits		}	}	for _, rel := range rels {		if rel == nil {			continue		}		rel.Publisher, err = models.GetUserById(rel.PublisherId)		if err != nil {			ctx.Handle(500, "GetUserById", err)			return		}		// FIXME: duplicated code.		// Get corresponding target if it's not the current branch.		if ctx.Repo.BranchName != rel.Target {			// Get count if not exists.			if _, ok := countCache[rel.Target]; !ok {				commit, err := ctx.Repo.GitRepo.GetCommitOfBranch(ctx.Repo.BranchName)				if err != nil {					ctx.Handle(500, "GetCommitOfBranch", err)					return				}				countCache[ctx.Repo.BranchName], err = commit.CommitsCount()				if err != nil {					ctx.Handle(500, "CommitsCount2", err)					return				}			}			rel.NumCommitsBehind = countCache[ctx.Repo.BranchName] - rel.NumCommits		} else {			rel.NumCommitsBehind = ctx.Repo.CommitsCount - rel.NumCommits		}		rel.Note = base.RenderMarkdownString(rel.Note, ctx.Repo.RepoLink)		tags = append(tags, rel)	}	models.SortReleases(tags)	ctx.Data["Releases"] = tags	ctx.HTML(200, RELEASES)}func NewRelease(ctx *middleware.Context) {	if !ctx.Repo.IsOwner {		ctx.Handle(403, "release.ReleasesNew", nil)		return	}	ctx.Data["Title"] = ctx.Tr("repo.release.new_release")	ctx.Data["tag_target"] = ctx.Repo.Repository.DefaultBranch	ctx.Data["IsRepoToolbarReleases"] = true	ctx.Data["IsRepoReleaseNew"] = true	ctx.HTML(200, RELEASE_NEW)}func NewReleasePost(ctx *middleware.Context, form auth.NewReleaseForm) {	if !ctx.Repo.IsOwner {		ctx.Handle(403, "release.ReleasesNew", nil)		return	}	ctx.Data["Title"] = ctx.Tr("repo.release.new_release")	ctx.Data["IsRepoToolbarReleases"] = true	ctx.Data["IsRepoReleaseNew"] = true	if ctx.HasError() {		ctx.HTML(200, RELEASE_NEW)		return	}	if !ctx.Repo.GitRepo.IsBranchExist(form.Target) {		ctx.RenderWithErr(ctx.Tr("form.target_branch_not_exist"), RELEASE_NEW, &form)		return	}	commit, err := ctx.Repo.GitRepo.GetCommitOfBranch(form.Target)	if err != nil {		ctx.Handle(500, "GetCommitOfBranch", err)		return	}	commitsCount, err := commit.CommitsCount()	if err != nil {		ctx.Handle(500, "CommitsCount", err)		return	}	rel := &models.Release{		RepoId:       ctx.Repo.Repository.Id,		PublisherId:  ctx.User.Id,		Title:        form.Title,		TagName:      form.TagName,		Target:       form.Target,		Sha1:         commit.Id.String(),		NumCommits:   commitsCount,		Note:         form.Content,		IsDraft:      len(form.Draft) > 0,		IsPrerelease: form.Prerelease,	}	if err = models.CreateRelease(ctx.Repo.GitRepo, rel); err != nil {		if err == models.ErrReleaseAlreadyExist {			ctx.RenderWithErr(ctx.Tr("repo.release.tag_name_already_exist"), RELEASE_NEW, &form)		} else {			ctx.Handle(500, "CreateRelease", err)		}		return	}	log.Trace("%s Release created: %s/%s:%s", ctx.Req.RequestURI, ctx.User.LowerName, ctx.Repo.Repository.Name, form.TagName)	ctx.Redirect(ctx.Repo.RepoLink + "/releases")}func EditRelease(ctx *middleware.Context) {	if !ctx.Repo.IsOwner {		ctx.Handle(403, "release.ReleasesEdit", nil)		return	}	tagName := ctx.Params(":tagname")	rel, err := models.GetRelease(ctx.Repo.Repository.Id, tagName)	if err != nil {		if err == models.ErrReleaseNotExist {			ctx.Handle(404, "GetRelease", err)		} else {			ctx.Handle(500, "GetRelease", err)		}		return	}	ctx.Data["Release"] = rel	ctx.Data["Title"] = ctx.Tr("repo.release.edit_release")	ctx.Data["IsRepoToolbarReleases"] = true	ctx.HTML(200, RELEASE_EDIT)}func EditReleasePost(ctx *middleware.Context, form auth.EditReleaseForm) {	if !ctx.Repo.IsOwner {		ctx.Handle(403, "release.EditReleasePost", nil)		return	}	tagName := ctx.Params(":tagname")	rel, err := models.GetRelease(ctx.Repo.Repository.Id, tagName)	if err != nil {		if err == models.ErrReleaseNotExist {			ctx.Handle(404, "GetRelease", err)		} else {			ctx.Handle(500, "GetRelease", err)		}		return	}	ctx.Data["Release"] = rel	if ctx.HasError() {		ctx.HTML(200, RELEASE_EDIT)		return	}	ctx.Data["Title"] = ctx.Tr("repo.release.edit_release")	ctx.Data["IsRepoToolbarReleases"] = true	rel.Title = form.Title	rel.Note = form.Content	rel.IsDraft = len(form.Draft) > 0	rel.IsPrerelease = form.Prerelease	if err = models.UpdateRelease(ctx.Repo.GitRepo, rel); err != nil {		ctx.Handle(500, "UpdateRelease", err)		return	}	ctx.Redirect(ctx.Repo.RepoLink + "/releases")}
 |