2014-02-18 03:38:50 +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 user
import (
2014-03-15 13:30:59 +04:00
"fmt"
2014-02-18 03:38:50 +04:00
"net/http"
2014-03-08 02:08:21 +04:00
"github.com/codegangsta/martini"
2014-02-18 03:38:50 +04:00
"github.com/martini-contrib/render"
2014-03-03 18:44:51 +04:00
"github.com/martini-contrib/sessions"
2014-02-18 03:38:50 +04:00
"github.com/gogits/gogs/models"
2014-03-06 11:21:44 +04:00
"github.com/gogits/gogs/modules/auth"
"github.com/gogits/gogs/modules/base"
2014-03-08 02:22:15 +04:00
"github.com/gogits/gogs/modules/log"
2014-03-15 15:01:50 +04:00
"github.com/gogits/gogs/modules/middleware"
2014-02-18 03:38:50 +04:00
)
2014-03-06 17:33:17 +04:00
func Dashboard ( r render . Render , data base . TmplData , session sessions . Session ) {
data [ "Title" ] = "Dashboard"
2014-03-08 01:05:18 +04:00
data [ "PageIsUserDashboard" ] = true
2014-03-11 10:17:05 +04:00
repos , err := models . GetRepositories ( & models . User { Id : auth . SignedInId ( session ) } )
if err != nil {
2014-03-14 09:59:07 +04:00
log . Handle ( 200 , "user.Dashboard" , data , r , err )
2014-03-11 10:17:05 +04:00
return
}
data [ "MyRepos" ] = repos
2014-03-15 13:30:59 +04:00
feeds , err := models . GetFeeds ( auth . SignedInId ( session ) , 0 , false )
if err != nil {
log . Handle ( 200 , "user.Dashboard" , data , r , err )
return
}
data [ "Feeds" ] = feeds
2014-03-06 17:33:17 +04:00
r . HTML ( 200 , "user/dashboard" , data )
}
2014-03-15 15:01:50 +04:00
func Profile ( ctx * middleware . Context , params martini . Params ) {
ctx . Data [ "Title" ] = "Profile"
2014-03-06 22:18:19 +04:00
// TODO: Need to check view self or others.
2014-03-08 02:08:21 +04:00
user , err := models . GetUserByName ( params [ "username" ] )
if err != nil {
2014-03-15 15:01:50 +04:00
ctx . Log ( 200 , "user.Profile" , err )
2014-03-08 02:08:21 +04:00
return
}
2014-03-15 15:01:50 +04:00
ctx . Data [ "Owner" ] = user
2014-03-15 11:28:06 +04:00
2014-03-15 15:01:50 +04:00
tab := ctx . Query ( "tab" )
ctx . Data [ "TabName" ] = tab
2014-03-15 11:28:06 +04:00
switch tab {
case "activity" :
feeds , err := models . GetFeeds ( user . Id , 0 , true )
if err != nil {
2014-03-15 15:01:50 +04:00
ctx . Log ( 200 , "user.Profile" , err )
2014-03-15 11:28:06 +04:00
return
}
2014-03-15 15:01:50 +04:00
ctx . Data [ "Feeds" ] = feeds
2014-03-15 11:28:06 +04:00
default :
2014-03-15 08:50:51 +04:00
}
2014-03-15 11:28:06 +04:00
2014-03-15 15:01:50 +04:00
ctx . Render . HTML ( 200 , "user/profile" , ctx . Data )
2014-03-02 17:47:55 +04:00
}
2014-03-06 20:42:14 +04:00
func SignIn ( form auth . LogInForm , data base . TmplData , req * http . Request , r render . Render , session sessions . Session ) {
data [ "Title" ] = "Log In"
if req . Method == "GET" {
r . HTML ( 200 , "user/signin" , data )
return
}
if hasErr , ok := data [ "HasError" ] ; ok && hasErr . ( bool ) {
r . HTML ( 200 , "user/signin" , data )
return
}
user , err := models . LoginUserPlain ( form . UserName , form . Password )
if err != nil {
if err . Error ( ) == models . ErrUserNotExist . Error ( ) {
data [ "HasError" ] = true
data [ "ErrorMsg" ] = "Username or password is not correct"
auth . AssignForm ( form , data )
r . HTML ( 200 , "user/signin" , data )
2014-03-03 16:35:44 +04:00
return
}
2014-03-06 20:42:14 +04:00
2014-03-14 09:59:07 +04:00
log . Handle ( 200 , "user.SignIn" , data , r , err )
2014-03-06 20:42:14 +04:00
return
2014-03-02 11:31:06 +04:00
}
2014-03-06 20:42:14 +04:00
session . Set ( "userId" , user . Id )
session . Set ( "userName" , user . Name )
r . Redirect ( "/" )
2014-02-18 03:38:50 +04:00
}
2014-03-06 22:18:19 +04:00
func SignOut ( r render . Render , session sessions . Session ) {
session . Delete ( "userId" )
session . Delete ( "userName" )
r . Redirect ( "/" )
}
2014-03-06 11:21:44 +04:00
func SignUp ( form auth . RegisterForm , data base . TmplData , req * http . Request , r render . Render ) {
data [ "Title" ] = "Sign Up"
2014-03-06 18:55:32 +04:00
data [ "PageIsSignUp" ] = true
2014-03-06 11:21:44 +04:00
2014-02-18 03:38:50 +04:00
if req . Method == "GET" {
2014-03-04 04:03:08 +04:00
r . HTML ( 200 , "user/signup" , data )
2014-02-18 03:38:50 +04:00
return
}
2014-03-06 20:10:35 +04:00
if form . Password != form . RetypePasswd {
data [ "HasError" ] = true
data [ "Err_Password" ] = true
data [ "Err_RetypePasswd" ] = true
data [ "ErrorMsg" ] = "Password and re-type password are not same"
auth . AssignForm ( form , data )
}
2014-03-06 11:21:44 +04:00
if hasErr , ok := data [ "HasError" ] ; ok && hasErr . ( bool ) {
r . HTML ( 200 , "user/signup" , data )
return
2014-02-19 02:31:16 +04:00
}
2014-03-04 04:03:08 +04:00
2014-03-06 11:21:44 +04:00
u := & models . User {
2014-03-06 20:10:35 +04:00
Name : form . UserName ,
2014-03-06 11:21:44 +04:00
Email : form . Email ,
Passwd : form . Password ,
2014-02-19 02:31:16 +04:00
}
2014-03-06 11:21:44 +04:00
if err := models . RegisterUser ( u ) ; err != nil {
2014-03-06 20:10:35 +04:00
data [ "HasError" ] = true
auth . AssignForm ( form , data )
switch err . Error ( ) {
case models . ErrUserAlreadyExist . Error ( ) :
2014-03-06 11:21:44 +04:00
data [ "Err_Username" ] = true
data [ "ErrorMsg" ] = "Username has been already taken"
r . HTML ( 200 , "user/signup" , data )
2014-03-06 20:10:35 +04:00
case models . ErrEmailAlreadyUsed . Error ( ) :
data [ "Err_Email" ] = true
data [ "ErrorMsg" ] = "E-mail address has been already used"
r . HTML ( 200 , "user/signup" , data )
default :
2014-03-14 09:59:07 +04:00
log . Handle ( 200 , "user.SignUp" , data , r , err )
2014-03-06 11:21:44 +04:00
}
2014-02-19 02:31:16 +04:00
return
}
2014-03-06 11:21:44 +04:00
r . Redirect ( "/user/login" )
2014-02-18 03:38:50 +04:00
}
2014-02-19 22:13:02 +04:00
2014-03-11 10:17:05 +04:00
func Delete ( data base . TmplData , req * http . Request , session sessions . Session , r render . Render ) {
2014-03-11 07:41:38 +04:00
data [ "Title" ] = "Delete Account"
2014-03-08 02:08:21 +04:00
2014-02-20 06:45:43 +04:00
if req . Method == "GET" {
2014-03-08 02:08:21 +04:00
r . HTML ( 200 , "user/delete" , data )
2014-02-20 06:45:43 +04:00
return
}
2014-03-11 10:17:05 +04:00
id := auth . SignedInId ( session )
u := & models . User { Id : id }
2014-03-11 19:40:47 +04:00
if err := models . DeleteUser ( u ) ; err != nil {
data [ "HasError" ] = true
switch err . Error ( ) {
case models . ErrUserOwnRepos . Error ( ) :
data [ "ErrorMsg" ] = "Your account still have ownership of repository, you have to delete or transfer them first."
default :
2014-03-14 09:59:07 +04:00
log . Handle ( 200 , "user.Delete" , data , r , err )
2014-03-11 19:40:47 +04:00
return
}
}
r . HTML ( 200 , "user/delete" , data )
2014-02-19 22:13:02 +04:00
}
2014-03-13 09:14:43 +04:00
2014-03-15 13:30:59 +04:00
const (
feedTpl = ` < i class = "icon fa fa-%s" > < / i >
< div class = "info" > < span class = "meta" > % s < / span > < br > % s < / div > `
)
2014-03-13 10:09:36 +04:00
func Feeds ( form auth . FeedsForm , r render . Render ) {
2014-03-15 13:30:59 +04:00
actions , err := models . GetFeeds ( form . UserId , form . Page * 20 , false )
2014-03-13 09:14:43 +04:00
if err != nil {
2014-03-13 10:09:36 +04:00
r . JSON ( 500 , err )
2014-03-13 09:14:43 +04:00
}
2014-03-15 13:30:59 +04:00
feeds := make ( [ ] string , len ( actions ) )
for i := range actions {
feeds [ i ] = fmt . Sprintf ( feedTpl , base . ActionIcon ( actions [ i ] . OpType ) ,
base . TimeSince ( actions [ i ] . Created ) , base . ActionDesc ( actions [ i ] ) )
}
r . JSON ( 200 , & feeds )
2014-03-13 09:14:43 +04:00
}