Browse Source

create repository from web

for-closed-social
Lunny Xiao 10 years ago
parent
commit
f7826d4ed7
5 changed files with 74 additions and 7 deletions
  1. +15
    -2
      models/repo.go
  2. +12
    -0
      models/user.go
  3. +27
    -5
      routers/repo/repo.go
  4. +12
    -0
      templates/repo/create.tmpl
  5. +8
    -0
      templates/repo/created.tmpl

+ 15
- 2
models/repo.go View File

@ -46,12 +46,12 @@ func IsRepositoryExist(user *User, reposName string) (bool, error) {
//
func CreateRepository(user *User, reposName string) (*Repo, error) {
f := RepoPath(user.Name, reposName)
_, err := git.InitRepository(f, false)
_, err := git.InitRepository(f, true)
if err != nil {
return nil, err
}
repo := Repo{OwnerId: user.Id, Name: reposName}
repo := Repo{OwnerId: user.Id, Name: reposName, LowerName: strings.ToLower(reposName)}
session := orm.NewSession()
defer session.Close()
session.Begin()
@ -64,6 +64,19 @@ func CreateRepository(user *User, reposName string) (*Repo, error) {
session.Rollback()
return nil, err
}
access := Access{UserName: user.Name,
RepoName: repo.Name,
Mode: AU_WRITABLE,
}
_, err = session.Insert(&access)
if err != nil {
err2 := os.RemoveAll(f)
if err2 != nil {
log.Error("delete repo directory %s/%s failed", user.Name, reposName)
}
session.Rollback()
return nil, err
}
_, err = session.Exec("update user set num_repos = num_repos + 1 where id = ?", user.Id)
if err != nil {
err2 := os.RemoveAll(f)

+ 12
- 0
models/user.go View File

@ -161,6 +161,18 @@ func GetUserByKeyId(keyId int64) (*User, error) {
return user, nil
}
func GetUserById(id int64) (*User, error) {
user := new(User)
has, err := orm.Id(id).Get(user)
if err != nil {
return nil, err
}
if !has {
return nil, ErrUserNotExist
}
return user, nil
}
// LoginUserPlain validates user by raw user name and password.
func LoginUserPlain(name, passwd string) (*User, error) {
user := User{Name: name, Passwd: passwd}

+ 27
- 5
routers/repo/repo.go View File

@ -7,6 +7,7 @@ package repo
import (
"fmt"
"net/http"
"strconv"
"github.com/martini-contrib/render"
@ -21,11 +22,32 @@ func Create(req *http.Request, r render.Render) {
return
}
u := &models.User{}
_, err := models.CreateRepository(u, "")
r.HTML(403, "status/403", map[string]interface{}{
"Title": fmt.Sprintf("%v", err),
})
// TODO: access check
fmt.Println(req.FormValue("userId"), req.FormValue("name"))
id, err := strconv.ParseInt(req.FormValue("userId"), 10, 64)
if err == nil {
var user *models.User
user, err = models.GetUserById(id)
if user == nil {
err = models.ErrUserNotExist
}
if err == nil {
_, err = models.CreateRepository(user, req.FormValue("name"))
}
if err == nil {
r.HTML(200, "repo/created", map[string]interface{}{
"RepoName": user.Name + "/" + req.FormValue("name"),
})
return
}
}
if err != nil {
r.HTML(403, "status/403", map[string]interface{}{
"Title": fmt.Sprintf("%v", err),
})
}
}
func Delete(req *http.Request, r render.Render) {

+ 12
- 0
templates/repo/create.tmpl View File

@ -3,7 +3,19 @@
<div class="container">
<form action="/repo/create" method="post" class="form-horizontal">
<div class="form-group">
<div class="col-md-offset-4 col-md-3">
Owner: <input name="userId" type="hidden" value="1"/>lunny
</div>
<div class="col-md-offset-4 col-md-3">
repo name: <input name="name" type="text"/>
</div>
<div class="col-md-offset-4 col-md-3">
description(optional): <input name="desc" type="text"/>
</div>
<div class="col-md-offset-4 col-md-3">
</div>
<div class="col-md-offset-4 col-md-3">
<button type="submit" class="btn btn-info">Create repository</button>
</div>
</div>

+ 8
- 0
templates/repo/created.tmpl View File

@ -0,0 +1,8 @@
{{template "base/head" .}}
{{template "base/navbar" .}}
<div class="container">
<div class="col-md-offset-4 col-md-3">
Created successfully!
</div>
</div>
{{template "base/footer" .}}

Loading…
Cancel
Save