diff --git a/routers/repo/repo.go b/routers/repo/repo.go index a9e48021e..3a958f9ad 100644 --- a/routers/repo/repo.go +++ b/routers/repo/repo.go @@ -12,32 +12,37 @@ import ( "github.com/martini-contrib/render" "github.com/gogits/gogs/models" + "github.com/gogits/gogs/routers/user" + "github.com/martini-contrib/sessions" ) -func Create(req *http.Request, r render.Render) { +func Create(req *http.Request, r render.Render, session sessions.Session) { if req.Method == "GET" { r.HTML(200, "repo/create", map[string]interface{}{ - "Title": "Create repository", + "Title": "Create repository", + "UserName": user.SignedInName(session), + "UserId": user.SignedInId(session), + "IsSigned": user.IsSignedIn(session), }) return } // 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 { + var u *models.User + u, err = models.GetUserById(id) + if u == nil { err = models.ErrUserNotExist } if err == nil { - _, err = models.CreateRepository(user, req.FormValue("name")) + _, err = models.CreateRepository(u, req.FormValue("name")) } if err == nil { r.HTML(200, "repo/created", map[string]interface{}{ - "RepoName": user.Name + "/" + req.FormValue("name"), + "RepoName": u.Name + "/" + req.FormValue("name"), + "IsSigned": user.IsSignedIn(session), }) return } @@ -45,15 +50,17 @@ func Create(req *http.Request, r render.Render) { if err != nil { r.HTML(200, "base/error", map[string]interface{}{ - "Error": fmt.Sprintf("%v", err), + "Error": fmt.Sprintf("%v", err), + "IsSigned": user.IsSignedIn(session), }) } } -func Delete(req *http.Request, r render.Render) { +func Delete(req *http.Request, r render.Render, session sessions.Session) { if req.Method == "GET" { r.HTML(200, "repo/delete", map[string]interface{}{ - "Title": "Delete repository", + "Title": "Delete repository", + "IsSigned": user.IsSignedIn(session), }) return } @@ -62,7 +69,27 @@ func Delete(req *http.Request, r render.Render) { err := models.DeleteRepository(u, "") if err != nil { r.HTML(200, "base/error", map[string]interface{}{ - "Error": fmt.Sprintf("%v", err), + "Error": fmt.Sprintf("%v", err), + "IsSigned": user.IsSignedIn(session), }) } } + +func List(req *http.Request, r render.Render, session sessions.Session) { + u := user.SignedInUser(session) + repos, err := models.GetRepositories(u) + fmt.Println("repos", repos) + if err != nil { + r.HTML(200, "base/error", map[string]interface{}{ + "Error": fmt.Sprintf("%v", err), + "IsSigned": user.IsSignedIn(session), + }) + return + } + + r.HTML(200, "repo/list", map[string]interface{}{ + "Title": "repositories", + "Repos": repos, + "IsSigned": user.IsSignedIn(session), + }) +} diff --git a/templates/repo/create.tmpl b/templates/repo/create.tmpl index a3ad06df0..809637c4e 100644 --- a/templates/repo/create.tmpl +++ b/templates/repo/create.tmpl @@ -6,8 +6,8 @@
-

Owner-name

- +

{{.UserName}}

+
diff --git a/templates/repo/list.tmpl b/templates/repo/list.tmpl new file mode 100644 index 000000000..2c5432a17 --- /dev/null +++ b/templates/repo/list.tmpl @@ -0,0 +1,10 @@ +{{template "base/head" .}} +{{template "base/navbar" .}} +
+ +
+{{template "base/footer" .}} \ No newline at end of file diff --git a/web.go b/web.go index 47b9b14de..b89f8cca6 100644 --- a/web.go +++ b/web.go @@ -67,6 +67,7 @@ func runWeb(*cli.Context) { m.Any("/user/publickey/add", user.AddPublicKey) m.Any("/repo/create", repo.Create) m.Any("/repo/delete", repo.Delete) + m.Any("/repo/list", repo.List) listenAddr := fmt.Sprintf("%s:%s", utils.Cfg.MustValue("server", "HTTP_ADDR"),