forgejo/routers/repo/repo.go

100 lines
2.5 KiB
Go
Raw Normal View History

2014-02-20 06:45:43 +04:00
// 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 repo
import (
2014-03-14 09:40:34 +04:00
"net/http"
2014-02-20 06:45:43 +04:00
"github.com/martini-contrib/render"
"github.com/martini-contrib/sessions"
2014-02-20 06:45:43 +04:00
"github.com/gogits/gogs/models"
"github.com/gogits/gogs/modules/auth"
"github.com/gogits/gogs/modules/base"
2014-03-15 17:17:16 +04:00
"github.com/gogits/gogs/modules/middleware"
2014-02-20 06:45:43 +04:00
)
2014-03-15 17:17:16 +04:00
func Create(form auth.CreateRepoForm, ctx *middleware.Context, req *http.Request, r render.Render, data base.TmplData, session sessions.Session) {
data["Title"] = "Create repository"
2014-02-20 06:45:43 +04:00
if req.Method == "GET" {
2014-03-11 09:32:36 +04:00
data["LanguageIgns"] = models.LanguageIgns
data["Licenses"] = models.Licenses
r.HTML(200, "repo/create", data)
2014-02-20 06:45:43 +04:00
return
}
2014-03-09 06:25:38 +04:00
if hasErr, ok := data["HasError"]; ok && hasErr.(bool) {
r.HTML(200, "repo/create", data)
return
}
2014-02-25 11:11:54 +04:00
// TODO: access check
2014-03-09 06:25:38 +04:00
user, err := models.GetUserById(form.UserId)
if err != nil {
if err.Error() == models.ErrUserNotExist.Error() {
data["HasError"] = true
data["ErrorMsg"] = "User does not exist"
auth.AssignForm(form, data)
r.HTML(200, "repo/create", data)
return
2014-02-25 11:11:54 +04:00
}
2014-03-09 06:25:38 +04:00
}
2014-03-11 08:53:53 +04:00
2014-03-09 06:25:38 +04:00
if err == nil {
if _, err = models.CreateRepository(user,
2014-03-11 09:32:36 +04:00
form.RepoName, form.Description, form.Language, form.License,
form.Visibility == "private", form.InitReadme == "on"); err == nil {
2014-03-15 08:55:30 +04:00
r.Redirect("/"+user.Name+"/"+form.RepoName, 302)
return
2014-02-25 11:11:54 +04:00
}
}
2014-03-10 04:06:29 +04:00
if err.Error() == models.ErrRepoAlreadyExist.Error() {
data["HasError"] = true
data["ErrorMsg"] = "Repository name has already been used"
auth.AssignForm(form, data)
r.HTML(200, "repo/create", data)
return
}
2014-03-15 17:17:16 +04:00
ctx.Handle(200, "repo.Create", err)
2014-02-20 06:45:43 +04:00
}
2014-03-15 17:17:16 +04:00
func Delete(form auth.DeleteRepoForm, ctx *middleware.Context, req *http.Request, r render.Render, data base.TmplData, session sessions.Session) {
data["Title"] = "Delete repository"
2014-02-20 06:45:43 +04:00
if req.Method == "GET" {
r.HTML(200, "repo/delete", data)
2014-02-20 06:45:43 +04:00
return
}
2014-03-13 10:39:09 +04:00
if err := models.DeleteRepository(form.UserId, form.RepoId, form.UserName); err != nil {
2014-03-15 17:17:16 +04:00
ctx.Handle(200, "repo.Delete", err)
2014-03-13 10:39:09 +04:00
return
2014-03-03 05:52:12 +04:00
}
2014-03-13 10:39:09 +04:00
r.Redirect("/", 302)
2014-02-20 06:45:43 +04:00
}
2014-03-07 07:14:51 +04:00
2014-03-15 17:17:16 +04:00
func List(ctx *middleware.Context, req *http.Request, r render.Render, data base.TmplData, session sessions.Session) {
u := auth.SignedInUser(session)
2014-03-13 07:56:25 +04:00
if u != nil {
r.Redirect("/")
return
}
data["Title"] = "Repositories"
2014-03-07 07:14:51 +04:00
repos, err := models.GetRepositories(u)
if err != nil {
2014-03-15 17:17:16 +04:00
ctx.Handle(200, "repo.List", err)
2014-03-07 07:14:51 +04:00
return
}
data["Repos"] = repos
r.HTML(200, "repo/list", data)
2014-03-07 07:14:51 +04:00
}