mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2024-12-22 15:23:51 +01:00
Add create, list, view issue
This commit is contained in:
parent
b3cfd9fe0c
commit
59ffdbf6f8
11 changed files with 217 additions and 51 deletions
|
@ -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 a new issue