Add create, list, view issue
This commit is contained in:
		
							parent
							
								
									b3cfd9fe0c
								
							
						
					
					
						commit
						59ffdbf6f8
					
				| @ -5,7 +5,7 @@ Gogs(Go Git Service) is a GitHub-like clone in the Go Programming Language. | |||||||
| 
 | 
 | ||||||
| Since we choose to use pure Go implementation of Git manipulation, Gogs certainly supports **ALL platforms**  that Go supports, including Linux, Max OS X, and Windows with **ZERO** dependency. | Since we choose to use pure Go implementation of Git manipulation, Gogs certainly supports **ALL platforms**  that Go supports, including Linux, Max OS X, and Windows with **ZERO** dependency. | ||||||
| 
 | 
 | ||||||
| ##### Current version: 0.1.5 Alpha | ##### Current version: 0.1.6 Alpha | ||||||
| 
 | 
 | ||||||
| ## Purpose | ## Purpose | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -30,7 +30,7 @@ type Action struct { | |||||||
| 	ActUserName string // Action user name.
 | 	ActUserName string // Action user name.
 | ||||||
| 	RepoId      int64 | 	RepoId      int64 | ||||||
| 	RepoName    string | 	RepoName    string | ||||||
| 	Content     string | 	Content     string    `xorm:"TEXT"` | ||||||
| 	Created     time.Time `xorm:"created"` | 	Created     time.Time `xorm:"created"` | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -5,12 +5,17 @@ | |||||||
| package models | package models | ||||||
| 
 | 
 | ||||||
| import ( | import ( | ||||||
|  | 	"errors" | ||||||
| 	"strings" | 	"strings" | ||||||
| 	"time" | 	"time" | ||||||
| 
 | 
 | ||||||
| 	"github.com/gogits/gogs/modules/base" | 	"github.com/gogits/gogs/modules/base" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
|  | var ( | ||||||
|  | 	ErrIssueNotExist = errors.New("Issue does not exist") | ||||||
|  | ) | ||||||
|  | 
 | ||||||
| // Issue represents an issue or pull request of repository.
 | // Issue represents an issue or pull request of repository.
 | ||||||
| type Issue struct { | type Issue struct { | ||||||
| 	Id          int64 | 	Id          int64 | ||||||
| @ -22,22 +27,25 @@ type Issue struct { | |||||||
| 	AssigneeId  int64 | 	AssigneeId  int64 | ||||||
| 	IsPull      bool // Indicates whether is a pull request or not.
 | 	IsPull      bool // Indicates whether is a pull request or not.
 | ||||||
| 	IsClosed    bool | 	IsClosed    bool | ||||||
| 	Labels      string | 	Labels      string `xorm:"TEXT"` | ||||||
| 	Mentions    string | 	Mentions    string `xorm:"TEXT"` | ||||||
| 	Content     string | 	Content     string `xorm:"TEXT"` | ||||||
| 	NumComments int | 	NumComments int | ||||||
| 	Created     time.Time `xorm:"created"` | 	Created     time.Time `xorm:"created"` | ||||||
| 	Updated     time.Time `xorm:"updated"` | 	Updated     time.Time `xorm:"updated"` | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // CreateIssue creates new issue for repository.
 | // CreateIssue creates new issue for repository.
 | ||||||
| func CreateIssue(userId, repoId, milestoneId, assigneeId int64, name, labels, mentions, content string, isPull bool) error { | func CreateIssue(userId, repoId, milestoneId, assigneeId int64, name, labels, content string, isPull bool) (*Issue, error) { | ||||||
| 	count, err := GetIssueCount(repoId) | 	count, err := GetIssueCount(repoId) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return nil, err | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	_, err = orm.Insert(&Issue{ | 	// TODO: find out mentions
 | ||||||
|  | 	mentions := "" | ||||||
|  | 
 | ||||||
|  | 	issue := &Issue{ | ||||||
| 		Index:       count + 1, | 		Index:       count + 1, | ||||||
| 		Name:        name, | 		Name:        name, | ||||||
| 		RepoId:      repoId, | 		RepoId:      repoId, | ||||||
| @ -48,8 +56,9 @@ func CreateIssue(userId, repoId, milestoneId, assigneeId int64, name, labels, me | |||||||
| 		Labels:      labels, | 		Labels:      labels, | ||||||
| 		Mentions:    mentions, | 		Mentions:    mentions, | ||||||
| 		Content:     content, | 		Content:     content, | ||||||
| 	}) | 	} | ||||||
| 	return err | 	_, err = orm.Insert(issue) | ||||||
|  | 	return issue, err | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // GetIssueCount returns count of issues in the repository.
 | // GetIssueCount returns count of issues in the repository.
 | ||||||
| @ -57,9 +66,28 @@ func GetIssueCount(repoId int64) (int64, error) { | |||||||
| 	return orm.Count(&Issue{RepoId: repoId}) | 	return orm.Count(&Issue{RepoId: repoId}) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | // GetIssueById returns issue object by given id.
 | ||||||
|  | func GetIssueById(id int64) (*Issue, error) { | ||||||
|  | 	issue := new(Issue) | ||||||
|  | 	has, err := orm.Id(id).Get(issue) | ||||||
|  | 	if err != nil { | ||||||
|  | 		return nil, err | ||||||
|  | 	} else if !has { | ||||||
|  | 		return nil, ErrIssueNotExist | ||||||
|  | 	} | ||||||
|  | 	return issue, nil | ||||||
|  | } | ||||||
|  | 
 | ||||||
| // GetIssues returns a list of issues by given conditions.
 | // GetIssues returns a list of issues by given conditions.
 | ||||||
| func GetIssues(userId, repoId, posterId, milestoneId int64, page int, isClosed, isMention bool, labels, sortType string) ([]Issue, error) { | func GetIssues(userId, repoId, posterId, milestoneId int64, page int, isClosed, isMention bool, labels, sortType string) ([]Issue, error) { | ||||||
| 	sess := orm.Limit(20, (page-1)*20).Where("repo_id=?", repoId).And("is_closed=?", isClosed) | 	sess := orm.Limit(20, (page-1)*20) | ||||||
|  | 
 | ||||||
|  | 	if repoId > 0 { | ||||||
|  | 		sess = sess.Where("repo_id=?", repoId).And("is_closed=?", isClosed) | ||||||
|  | 	} else { | ||||||
|  | 		sess = sess.Where("is_closed=?", isClosed) | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	if userId > 0 { | 	if userId > 0 { | ||||||
| 		sess = sess.And("assignee_id=?", userId) | 		sess = sess.And("assignee_id=?", userId) | ||||||
| 	} else if posterId > 0 { | 	} else if posterId > 0 { | ||||||
|  | |||||||
| @ -80,7 +80,7 @@ type PublicKey struct { | |||||||
| 	OwnerId     int64  `xorm:"index"` | 	OwnerId     int64  `xorm:"index"` | ||||||
| 	Name        string `xorm:"unique not null"` | 	Name        string `xorm:"unique not null"` | ||||||
| 	Fingerprint string | 	Fingerprint string | ||||||
| 	Content     string    `xorm:"text not null"` | 	Content     string    `xorm:"TEXT not null"` | ||||||
| 	Created     time.Time `xorm:"created"` | 	Created     time.Time `xorm:"created"` | ||||||
| 	Updated     time.Time `xorm:"updated"` | 	Updated     time.Time `xorm:"updated"` | ||||||
| } | } | ||||||
|  | |||||||
| @ -372,6 +372,13 @@ func RepoPath(userName, repoName string) string { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func UpdateRepository(repo *Repository) error { | func UpdateRepository(repo *Repository) error { | ||||||
|  | 	if len(repo.Description) > 255 { | ||||||
|  | 		repo.Description = repo.Description[:255] | ||||||
|  | 	} | ||||||
|  | 	if len(repo.Website) > 255 { | ||||||
|  | 		repo.Website = repo.Website[:255] | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	_, err := orm.Id(repo.Id).UseBool().Cols("description", "website").Update(repo) | 	_, err := orm.Id(repo.Id).UseBool().Cols("description", "website").Update(repo) | ||||||
| 	return err | 	return err | ||||||
| } | } | ||||||
|  | |||||||
| @ -201,6 +201,13 @@ func VerifyUserActiveCode(code string) (user *User) { | |||||||
| 
 | 
 | ||||||
| // UpdateUser updates user's information.
 | // UpdateUser updates user's information.
 | ||||||
| func UpdateUser(user *User) (err error) { | func UpdateUser(user *User) (err error) { | ||||||
|  | 	if len(user.Location) > 255 { | ||||||
|  | 		user.Location = user.Location[:255] | ||||||
|  | 	} | ||||||
|  | 	if len(user.Website) > 255 { | ||||||
|  | 		user.Website = user.Website[:255] | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	_, err = orm.Id(user.Id).UseBool().Cols("website", "location").Update(user) | 	_, err = orm.Id(user.Id).UseBool().Cols("website", "location").Update(user) | ||||||
| 	return err | 	return err | ||||||
| } | } | ||||||
|  | |||||||
							
								
								
									
										54
									
								
								modules/auth/issue.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										54
									
								
								modules/auth/issue.go
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,54 @@ | |||||||
|  | // 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 auth | ||||||
|  | 
 | ||||||
|  | import ( | ||||||
|  | 	"net/http" | ||||||
|  | 	"reflect" | ||||||
|  | 
 | ||||||
|  | 	"github.com/codegangsta/martini" | ||||||
|  | 
 | ||||||
|  | 	"github.com/gogits/binding" | ||||||
|  | 
 | ||||||
|  | 	"github.com/gogits/gogs/modules/base" | ||||||
|  | 	"github.com/gogits/gogs/modules/log" | ||||||
|  | ) | ||||||
|  | 
 | ||||||
|  | type CreateIssueForm struct { | ||||||
|  | 	IssueName   string `form:"name" binding:"Required;MaxSize(50)"` | ||||||
|  | 	RepoId      int64  `form:"repoid" binding:"Required"` | ||||||
|  | 	MilestoneId int64  `form:"milestoneid" binding:"Required"` | ||||||
|  | 	AssigneeId  int64  `form:"assigneeid"` | ||||||
|  | 	Labels      string `form:"labels"` | ||||||
|  | 	Content     string `form:"content"` | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func (f *CreateIssueForm) Name(field string) string { | ||||||
|  | 	names := map[string]string{ | ||||||
|  | 		"IssueName":   "Issue name", | ||||||
|  | 		"RepoId":      "Repository ID", | ||||||
|  | 		"MilestoneId": "Milestone ID", | ||||||
|  | 	} | ||||||
|  | 	return names[field] | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func (f *CreateIssueForm) Validate(errors *binding.Errors, req *http.Request, context martini.Context) { | ||||||
|  | 	if req.Method == "GET" || errors.Count() == 0 { | ||||||
|  | 		return | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	data := context.Get(reflect.TypeOf(base.TmplData{})).Interface().(base.TmplData) | ||||||
|  | 	data["HasError"] = true | ||||||
|  | 	AssignForm(f, data) | ||||||
|  | 
 | ||||||
|  | 	if len(errors.Overall) > 0 { | ||||||
|  | 		for _, err := range errors.Overall { | ||||||
|  | 			log.Error("CreateIssueForm.Validate: %v", err) | ||||||
|  | 		} | ||||||
|  | 		return | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	validate(errors, data, f) | ||||||
|  | } | ||||||
| @ -5,14 +5,19 @@ | |||||||
| package repo | package repo | ||||||
| 
 | 
 | ||||||
| import ( | import ( | ||||||
|  | 	"fmt" | ||||||
|  | 
 | ||||||
| 	"github.com/codegangsta/martini" | 	"github.com/codegangsta/martini" | ||||||
| 
 | 
 | ||||||
| 	"github.com/gogits/gogs/models" | 	"github.com/gogits/gogs/models" | ||||||
|  | 	"github.com/gogits/gogs/modules/auth" | ||||||
| 	"github.com/gogits/gogs/modules/base" | 	"github.com/gogits/gogs/modules/base" | ||||||
|  | 	"github.com/gogits/gogs/modules/log" | ||||||
| 	"github.com/gogits/gogs/modules/middleware" | 	"github.com/gogits/gogs/modules/middleware" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| func Issues(ctx *middleware.Context, params martini.Params) { | func Issues(ctx *middleware.Context, params martini.Params) { | ||||||
|  | 	ctx.Data["Title"] = "Issues" | ||||||
| 	ctx.Data["IsRepoToolbarIssues"] = true | 	ctx.Data["IsRepoToolbarIssues"] = true | ||||||
| 
 | 
 | ||||||
| 	milestoneId, _ := base.StrTo(params["milestone"]).Int() | 	milestoneId, _ := base.StrTo(params["milestone"]).Int() | ||||||
| @ -29,12 +34,52 @@ func Issues(ctx *middleware.Context, params martini.Params) { | |||||||
| 	ctx.HTML(200, "repo/issues") | 	ctx.HTML(200, "repo/issues") | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func CreateIssue(ctx *middleware.Context, params martini.Params) { | func CreateIssue(ctx *middleware.Context, params martini.Params, form auth.CreateIssueForm) { | ||||||
| 	if !ctx.Repo.IsOwner { | 	if !ctx.Repo.IsOwner { | ||||||
| 		ctx.Error(404) | 		ctx.Error(404) | ||||||
| 		return | 		return | ||||||
| 	} | 	} | ||||||
| 	// else if err = models.CreateIssue(userId, repoId, milestoneId, assigneeId, name, labels, mentions, content, isPull); err != nil {
 |  | ||||||
| 
 | 
 | ||||||
| 	// }
 | 	ctx.Data["Title"] = "Create issue" | ||||||
|  | 
 | ||||||
|  | 	if ctx.Req.Method == "GET" { | ||||||
|  | 		ctx.HTML(200, "issue/create") | ||||||
|  | 		return | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	if ctx.HasError() { | ||||||
|  | 		ctx.HTML(200, "issue/create") | ||||||
|  | 		return | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	issue, err := models.CreateIssue(ctx.User.Id, form.RepoId, form.MilestoneId, form.AssigneeId, | ||||||
|  | 		form.IssueName, form.Labels, form.Content, false) | ||||||
|  | 	if err == nil { | ||||||
|  | 		log.Trace("%s Issue created: %d", form.RepoId, issue.Id) | ||||||
|  | 		ctx.Redirect(fmt.Sprintf("/%s/%s/issues/%d", params["username"], params["reponame"], issue.Index), 302) | ||||||
|  | 		return | ||||||
|  | 	} | ||||||
|  | 	ctx.Handle(200, "issue.CreateIssue", err) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func ViewIssue(ctx *middleware.Context, params martini.Params) { | ||||||
|  | 	issueid, err := base.StrTo(params["issueid"]).Int() | ||||||
|  | 	if err != nil { | ||||||
|  | 		ctx.Error(404) | ||||||
|  | 		return | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	issue, err := models.GetIssueById(int64(issueid)) | ||||||
|  | 	if err != nil { | ||||||
|  | 		if err == models.ErrIssueNotExist { | ||||||
|  | 			ctx.Error(404) | ||||||
|  | 		} else { | ||||||
|  | 			ctx.Handle(200, "issue.ViewIssue", err) | ||||||
|  | 		} | ||||||
|  | 		return | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	ctx.Data["Title"] = issue.Name | ||||||
|  | 	ctx.Data["Issue"] = issue | ||||||
|  | 	ctx.HTML(200, "issue/view") | ||||||
| } | } | ||||||
|  | |||||||
| @ -31,6 +31,11 @@ func Create(ctx *middleware.Context, form auth.CreateRepoForm) { | |||||||
| 		return | 		return | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	if ctx.HasError() { | ||||||
|  | 		ctx.HTML(200, "repo/create") | ||||||
|  | 		return | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	_, err := models.CreateRepository(ctx.User, form.RepoName, form.Description, | 	_, err := models.CreateRepository(ctx.User, form.RepoName, form.Description, | ||||||
| 		form.Language, form.License, form.Visibility == "private", form.InitReadme == "on") | 		form.Language, form.License, form.Visibility == "private", form.InitReadme == "on") | ||||||
| 	if err == nil { | 	if err == nil { | ||||||
|  | |||||||
| @ -27,7 +27,7 @@ | |||||||
|                             <td>{{.Id}}</td> |                             <td>{{.Id}}</td> | ||||||
|                             <th>{{.UserName}}</th> |                             <th>{{.UserName}}</th> | ||||||
|                             <td><a href="/{{.UserName}}/{{.Name}}">{{.Name}}</a></td> |                             <td><a href="/{{.UserName}}/{{.Name}}">{{.Name}}</a></td> | ||||||
|                             <td><i class="fa fa{{if .Private}}-check{{end}}-square-o"></i></td> |                             <td><i class="fa fa{{if .IsPrivate}}-check{{end}}-square-o"></i></td> | ||||||
|                             <td>{{.NumWatches}}</td> |                             <td>{{.NumWatches}}</td> | ||||||
|                             <td>{{.NumForks}}</td> |                             <td>{{.NumForks}}</td> | ||||||
|                             <td>{{DateFormat .Created "M d, Y"}}</td> |                             <td>{{DateFormat .Created "M d, Y"}}</td> | ||||||
|  | |||||||
							
								
								
									
										90
									
								
								web.go
									
									
									
									
									
								
							
							
						
						
									
										90
									
								
								web.go
									
									
									
									
									
								
							| @ -91,53 +91,73 @@ func runWeb(*cli.Context) { | |||||||
| 	m.Get("/issues", reqSignIn, user.Issues) | 	m.Get("/issues", reqSignIn, user.Issues) | ||||||
| 	m.Get("/pulls", reqSignIn, user.Pulls) | 	m.Get("/pulls", reqSignIn, user.Pulls) | ||||||
| 	m.Get("/stars", reqSignIn, user.Stars) | 	m.Get("/stars", reqSignIn, user.Stars) | ||||||
| 	m.Any("/user/login", reqSignOut, binding.BindIgnErr(auth.LogInForm{}), user.SignIn) | 	m.Get("/help", routers.Help) | ||||||
| 	m.Any("/user/logout", reqSignIn, user.SignOut) |  | ||||||
| 	m.Any("/user/sign_up", reqSignOut, binding.BindIgnErr(auth.RegisterForm{}), user.SignUp) |  | ||||||
| 	m.Any("/user/delete", reqSignIn, user.Delete) |  | ||||||
| 	m.Get("/user/feeds", binding.Bind(auth.FeedsForm{}), user.Feeds) |  | ||||||
| 	m.Get("/user/activate", user.Activate) |  | ||||||
| 
 | 
 | ||||||
| 	m.Any("/user/setting", reqSignIn, binding.BindIgnErr(auth.UpdateProfileForm{}), user.Setting) | 	m.Group("/user", func(r martini.Router) { | ||||||
| 	m.Any("/user/setting/password", reqSignIn, binding.BindIgnErr(auth.UpdatePasswdForm{}), user.SettingPassword) | 		r.Any("/login", binding.BindIgnErr(auth.LogInForm{}), user.SignIn) | ||||||
| 	m.Any("/user/setting/ssh", reqSignIn, binding.BindIgnErr(auth.AddSSHKeyForm{}), user.SettingSSHKeys) | 		r.Any("/sign_up", reqSignOut, binding.BindIgnErr(auth.RegisterForm{}), user.SignUp) | ||||||
| 	m.Any("/user/setting/notification", reqSignIn, user.SettingNotification) | 	}, reqSignOut) | ||||||
| 	m.Any("/user/setting/security", reqSignIn, user.SettingSecurity) | 	m.Group("/user", func(r martini.Router) { | ||||||
|  | 		r.Any("/logout", user.SignOut) | ||||||
|  | 		r.Any("/delete", user.Delete) | ||||||
|  | 		r.Any("/setting", binding.BindIgnErr(auth.UpdateProfileForm{}), user.Setting) | ||||||
|  | 	}, reqSignIn) | ||||||
|  | 	m.Group("/user", func(r martini.Router) { | ||||||
|  | 		r.Get("/feeds", binding.Bind(auth.FeedsForm{}), user.Feeds) | ||||||
|  | 		r.Get("/activate", user.Activate) | ||||||
|  | 	}) | ||||||
|  | 
 | ||||||
|  | 	m.Group("/user/setting", func(r martini.Router) { | ||||||
|  | 		r.Any("/password", binding.BindIgnErr(auth.UpdatePasswdForm{}), user.SettingPassword) | ||||||
|  | 		r.Any("/ssh", binding.BindIgnErr(auth.AddSSHKeyForm{}), user.SettingSSHKeys) | ||||||
|  | 		r.Any("/notification", user.SettingNotification) | ||||||
|  | 		r.Any("/security", user.SettingSecurity) | ||||||
|  | 	}, reqSignIn) | ||||||
| 
 | 
 | ||||||
| 	m.Get("/user/:username", ignSignIn, user.Profile) | 	m.Get("/user/:username", ignSignIn, user.Profile) | ||||||
| 
 | 
 | ||||||
| 	m.Any("/repo/create", reqSignIn, binding.BindIgnErr(auth.CreateRepoForm{}), repo.Create) | 	m.Any("/repo/create", reqSignIn, binding.BindIgnErr(auth.CreateRepoForm{}), repo.Create) | ||||||
| 
 | 
 | ||||||
| 	m.Get("/help", routers.Help) |  | ||||||
| 
 |  | ||||||
| 	adminReq := middleware.Toggle(&middleware.ToggleOptions{SignInRequire: true, AdminRequire: true}) | 	adminReq := middleware.Toggle(&middleware.ToggleOptions{SignInRequire: true, AdminRequire: true}) | ||||||
| 
 | 
 | ||||||
| 	m.Get("/admin", adminReq, admin.Dashboard) | 	m.Get("/admin", adminReq, admin.Dashboard) | ||||||
| 	m.Get("/admin/users", adminReq, admin.Users) | 	m.Group("/admin", func(r martini.Router) { | ||||||
| 	m.Any("/admin/users/new", adminReq, binding.BindIgnErr(auth.RegisterForm{}), admin.NewUser) | 		r.Get("/users", admin.Users) | ||||||
| 	m.Any("/admin/users/:userid", adminReq, binding.BindIgnErr(auth.AdminEditUserForm{}), admin.EditUser) | 		r.Get("/repos", admin.Repositories) | ||||||
| 	m.Any("/admin/users/:userid/delete", adminReq, admin.DeleteUser) | 		r.Get("/config", admin.Config) | ||||||
| 	m.Get("/admin/repos", adminReq, admin.Repositories) | 	}, adminReq) | ||||||
| 	m.Get("/admin/config", adminReq, admin.Config) | 	m.Group("/admin/users", func(r martini.Router) { | ||||||
|  | 		r.Any("/new", binding.BindIgnErr(auth.RegisterForm{}), admin.NewUser) | ||||||
|  | 		r.Any("/:userid", binding.BindIgnErr(auth.AdminEditUserForm{}), admin.EditUser) | ||||||
|  | 		r.Any("/:userid/delete", admin.DeleteUser) | ||||||
|  | 	}, adminReq) | ||||||
| 
 | 
 | ||||||
| 	m.Post("/:username/:reponame/settings", reqSignIn, middleware.RepoAssignment(true), repo.SettingPost) | 	m.Group("/:username/:reponame", func(r martini.Router) { | ||||||
| 	m.Get("/:username/:reponame/settings", reqSignIn, middleware.RepoAssignment(true), repo.Setting) | 		r.Post("/settings", repo.SettingPost) | ||||||
|  | 		r.Get("/settings", repo.Setting) | ||||||
|  | 		r.Get("/action/:action", repo.Action) | ||||||
|  | 	}, reqSignIn, middleware.RepoAssignment(true)) | ||||||
|  | 	m.Group("/:username/:reponame", func(r martini.Router) { | ||||||
|  | 		r.Get("/commits/:branchname", repo.Commits) | ||||||
|  | 		r.Get("/issues", repo.Issues) | ||||||
|  | 		r.Any("/issues/new", binding.BindIgnErr(auth.CreateIssueForm{}), repo.CreateIssue) | ||||||
|  | 		r.Get("/issues/:issueid", repo.ViewIssue) | ||||||
|  | 		r.Get("/pulls", repo.Pulls) | ||||||
|  | 		r.Get("/branches", repo.Branches) | ||||||
|  | 		r.Get("/src/:branchname", repo.Single) | ||||||
|  | 		r.Get("/src/:branchname/**", repo.Single) | ||||||
|  | 		r.Get("/commits/:branchname", repo.Commits) | ||||||
|  | 		r.Get("/commits/:branchname", repo.Commits) | ||||||
|  | 	}, ignSignIn, middleware.RepoAssignment(true)) | ||||||
| 
 | 
 | ||||||
| 	m.Get("/:username/:reponame/commits/:branchname", ignSignIn, middleware.RepoAssignment(true), repo.Commits) | 	// TODO: implement single commit page
 | ||||||
| 	m.Get("/:username/:reponame/issues", ignSignIn, middleware.RepoAssignment(true), repo.Issues) | 	// m.Get("/:username/:reponame/commit/:commitid/**", ignSignIn, middleware.RepoAssignment(true), repo.Single)
 | ||||||
| 	m.Get("/:username/:reponame/pulls", ignSignIn, middleware.RepoAssignment(true), repo.Pulls) | 	// m.Get("/:username/:reponame/commit/:commitid", ignSignIn, middleware.RepoAssignment(true), repo.Single)
 | ||||||
| 	m.Get("/:username/:reponame/branches", ignSignIn, middleware.RepoAssignment(true), repo.Branches) |  | ||||||
| 	m.Get("/:username/:reponame/action/:action", reqSignIn, middleware.RepoAssignment(true), repo.Action) |  | ||||||
| 	m.Get("/:username/:reponame/src/:branchname/**", |  | ||||||
| 		ignSignIn, middleware.RepoAssignment(true), repo.Single) |  | ||||||
| 	m.Get("/:username/:reponame/src/:branchname", |  | ||||||
| 		ignSignIn, middleware.RepoAssignment(true), repo.Single) |  | ||||||
| 	m.Get("/:username/:reponame/commit/:commitid/**", ignSignIn, middleware.RepoAssignment(true), repo.Single) |  | ||||||
| 	m.Get("/:username/:reponame/commit/:commitid", ignSignIn, middleware.RepoAssignment(true), repo.Single) |  | ||||||
| 
 | 
 | ||||||
| 	m.Get("/:username/:reponame", ignSignIn, middleware.RepoAssignment(true), repo.Single) | 	m.Group("/:username", func(r martini.Router) { | ||||||
| 
 | 		r.Get("/:reponame", middleware.RepoAssignment(true), repo.Single) | ||||||
| 	m.Any("/:username/:reponame/**", ignSignIn, repo.Http) | 		r.Any("/:reponame/**", repo.Http) | ||||||
|  | 	}, ignSignIn) | ||||||
| 
 | 
 | ||||||
| 	if martini.Env == martini.Dev { | 	if martini.Env == martini.Dev { | ||||||
| 		m.Get("/template/**", dev.TemplatePreview) | 		m.Get("/template/**", dev.TemplatePreview) | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user