2014-06-30 00:30:41 +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.
2014-06-27 17:33:49 +04:00
package org
import (
2014-08-26 14:11:15 +04:00
"path"
2014-08-24 17:09:05 +04:00
"github.com/Unknwon/com"
2014-06-30 00:30:41 +04:00
"github.com/gogits/gogs/models"
2014-07-03 00:42:16 +04:00
"github.com/gogits/gogs/modules/auth"
2014-06-30 00:30:41 +04:00
"github.com/gogits/gogs/modules/base"
2014-07-03 00:42:16 +04:00
"github.com/gogits/gogs/modules/log"
2014-06-27 17:33:49 +04:00
"github.com/gogits/gogs/modules/middleware"
)
2014-06-30 00:30:41 +04:00
const (
2014-08-26 14:11:15 +04:00
TEAMS base . TplName = "org/team/teams"
TEAM_NEW base . TplName = "org/team/new"
TEAM_MEMBERS base . TplName = "org/team/members"
TEAM_REPOSITORIES base . TplName = "org/team/repositories"
2014-06-30 00:30:41 +04:00
)
2014-07-26 10:28:04 +04:00
func Teams ( ctx * middleware . Context ) {
2014-08-16 12:21:17 +04:00
org := ctx . Org . Organization
ctx . Data [ "Title" ] = org . FullName
ctx . Data [ "PageIsOrgTeams" ] = true
2014-06-30 00:30:41 +04:00
2014-08-16 12:21:17 +04:00
if err := org . GetTeams ( ) ; err != nil {
ctx . Handle ( 500 , "GetTeams" , err )
2014-06-30 00:30:41 +04:00
return
}
for _ , t := range org . Teams {
2014-08-16 12:21:17 +04:00
if err := t . GetMembers ( ) ; err != nil {
ctx . Handle ( 500 , "GetMembers" , err )
2014-06-30 00:30:41 +04:00
return
}
}
ctx . Data [ "Teams" ] = org . Teams
ctx . HTML ( 200 , TEAMS )
2014-06-27 17:33:49 +04:00
}
2014-08-16 12:21:17 +04:00
func TeamsAction ( ctx * middleware . Context ) {
2014-08-24 17:09:05 +04:00
uid := com . StrTo ( ctx . Query ( "uid" ) ) . MustInt64 ( )
if uid == 0 {
ctx . Redirect ( ctx . Org . OrgLink + "/teams" )
return
}
page := ctx . Query ( "page" )
2014-08-16 12:21:17 +04:00
var err error
switch ctx . Params ( ":action" ) {
case "join" :
2014-08-24 17:09:05 +04:00
if ! ctx . Org . IsOwner {
ctx . Error ( 404 )
return
}
2014-08-16 12:58:32 +04:00
err = ctx . Org . Team . AddMember ( ctx . User . Id )
2014-08-16 12:21:17 +04:00
case "leave" :
2014-08-16 12:58:32 +04:00
err = ctx . Org . Team . RemoveMember ( ctx . User . Id )
2014-08-24 17:09:05 +04:00
case "remove" :
if ! ctx . Org . IsOwner {
ctx . Error ( 404 )
return
}
err = ctx . Org . Team . RemoveMember ( uid )
page = "team"
case "add" :
if ! ctx . Org . IsOwner {
ctx . Error ( 404 )
return
}
uname := ctx . Query ( "uname" )
var u * models . User
u , err = models . GetUserByName ( uname )
if err != nil {
2015-08-05 06:14:17 +03:00
if models . IsErrUserNotExist ( err ) {
2014-08-24 17:09:05 +04:00
ctx . Flash . Error ( ctx . Tr ( "form.user_not_exist" ) )
ctx . Redirect ( ctx . Org . OrgLink + "/teams/" + ctx . Org . Team . LowerName )
} else {
ctx . Handle ( 500 , " GetUserByName" , err )
}
return
}
err = ctx . Org . Team . AddMember ( u . Id )
page = "team"
2014-07-03 00:42:16 +04:00
}
2014-08-16 12:21:17 +04:00
if err != nil {
2015-03-18 04:51:39 +03:00
if models . IsErrLastOrgOwner ( err ) {
2014-08-24 17:09:05 +04:00
ctx . Flash . Error ( ctx . Tr ( "form.last_org_owner" ) )
} else {
2014-09-13 05:36:26 +04:00
log . Error ( 3 , "Action(%s): %v" , ctx . Params ( ":action" ) , err )
2014-08-24 17:09:05 +04:00
ctx . JSON ( 200 , map [ string ] interface { } {
"ok" : false ,
"err" : err . Error ( ) ,
} )
return
}
}
switch page {
case "team" :
ctx . Redirect ( ctx . Org . OrgLink + "/teams/" + ctx . Org . Team . LowerName )
default :
ctx . Redirect ( ctx . Org . OrgLink + "/teams" )
2014-07-03 00:42:16 +04:00
}
2014-08-16 12:21:17 +04:00
}
2014-07-03 00:42:16 +04:00
2014-08-26 14:11:15 +04:00
func TeamsRepoAction ( ctx * middleware . Context ) {
if ! ctx . Org . IsOwner {
ctx . Error ( 404 )
return
}
var err error
switch ctx . Params ( ":action" ) {
case "add" :
2015-11-22 09:32:09 +03:00
repoName := path . Base ( ctx . Query ( "repo_name" ) )
2014-08-26 14:11:15 +04:00
var repo * models . Repository
repo , err = models . GetRepositoryByName ( ctx . Org . Organization . Id , repoName )
if err != nil {
2015-03-16 11:04:27 +03:00
if models . IsErrRepoNotExist ( err ) {
2014-10-10 13:06:12 +04:00
ctx . Flash . Error ( ctx . Tr ( "org.teams.add_nonexistent_repo" ) )
ctx . Redirect ( ctx . Org . OrgLink + "/teams/" + ctx . Org . Team . LowerName + "/repositories" )
return
}
2014-08-26 14:11:15 +04:00
ctx . Handle ( 500 , "GetRepositoryByName" , err )
return
}
err = ctx . Org . Team . AddRepository ( repo )
case "remove" :
err = ctx . Org . Team . RemoveRepository ( com . StrTo ( ctx . Query ( "repoid" ) ) . MustInt64 ( ) )
}
if err != nil {
2015-02-11 07:44:16 +03:00
log . Error ( 3 , "Action(%s): '%s' %v" , ctx . Params ( ":action" ) , ctx . Org . Team . Name , err )
ctx . Handle ( 500 , "TeamsRepoAction" , err )
2014-08-26 14:11:15 +04:00
return
}
ctx . Redirect ( ctx . Org . OrgLink + "/teams/" + ctx . Org . Team . LowerName + "/repositories" )
}
2014-08-16 12:21:17 +04:00
func NewTeam ( ctx * middleware . Context ) {
ctx . Data [ "Title" ] = ctx . Org . Organization . FullName
ctx . Data [ "PageIsOrgTeams" ] = true
ctx . Data [ "PageIsOrgTeamsNew" ] = true
ctx . Data [ "Team" ] = & models . Team { }
2014-07-03 00:42:16 +04:00
ctx . HTML ( 200 , TEAM_NEW )
}
2014-07-26 10:28:04 +04:00
func NewTeamPost ( ctx * middleware . Context , form auth . CreateTeamForm ) {
2014-08-16 12:21:17 +04:00
ctx . Data [ "Title" ] = ctx . Org . Organization . FullName
ctx . Data [ "PageIsOrgTeams" ] = true
ctx . Data [ "PageIsOrgTeamsNew" ] = true
ctx . Data [ "Team" ] = & models . Team { }
2014-07-03 00:42:16 +04:00
if ctx . HasError ( ) {
ctx . HTML ( 200 , TEAM_NEW )
return
}
// Validate permission level.
2015-02-05 16:29:08 +03:00
var auth models . AccessMode
2014-07-03 00:42:16 +04:00
switch form . Permission {
case "read" :
2015-02-09 14:36:33 +03:00
auth = models . ACCESS_MODE_READ
2014-07-03 00:42:16 +04:00
case "write" :
2015-02-09 14:36:33 +03:00
auth = models . ACCESS_MODE_WRITE
2014-07-03 00:42:16 +04:00
case "admin" :
2015-02-09 14:36:33 +03:00
auth = models . ACCESS_MODE_ADMIN
2014-07-03 00:42:16 +04:00
default :
ctx . Error ( 401 )
return
}
2014-08-16 12:21:17 +04:00
org := ctx . Org . Organization
2014-07-03 00:42:16 +04:00
t := & models . Team {
2015-02-23 10:15:53 +03:00
OrgID : org . Id ,
2014-07-03 00:42:16 +04:00
Name : form . TeamName ,
Description : form . Description ,
Authorize : auth ,
}
2014-08-16 12:21:17 +04:00
if err := models . NewTeam ( t ) ; err != nil {
switch err {
case models . ErrTeamNameIllegal :
ctx . Data [ "Err_TeamName" ] = true
ctx . RenderWithErr ( ctx . Tr ( "form.illegal_team_name" ) , TEAM_NEW , & form )
case models . ErrTeamAlreadyExist :
2014-07-03 00:42:16 +04:00
ctx . Data [ "Err_TeamName" ] = true
2014-08-16 12:21:17 +04:00
ctx . RenderWithErr ( ctx . Tr ( "form.team_name_been_taken" ) , TEAM_NEW , & form )
default :
ctx . Handle ( 500 , "NewTeam" , err )
2014-07-03 00:42:16 +04:00
}
return
}
2014-08-16 12:21:17 +04:00
log . Trace ( "Team created: %s/%s" , org . Name , t . Name )
ctx . Redirect ( ctx . Org . OrgLink + "/teams/" + t . LowerName )
2014-06-27 17:33:49 +04:00
}
2014-06-27 18:04:04 +04:00
2014-08-24 17:09:05 +04:00
func TeamMembers ( ctx * middleware . Context ) {
ctx . Data [ "Title" ] = ctx . Org . Team . Name
ctx . Data [ "PageIsOrgTeams" ] = true
if err := ctx . Org . Team . GetMembers ( ) ; err != nil {
ctx . Handle ( 500 , "GetMembers" , err )
return
}
ctx . HTML ( 200 , TEAM_MEMBERS )
}
2014-08-26 14:11:15 +04:00
func TeamRepositories ( ctx * middleware . Context ) {
ctx . Data [ "Title" ] = ctx . Org . Team . Name
ctx . Data [ "PageIsOrgTeams" ] = true
if err := ctx . Org . Team . GetRepositories ( ) ; err != nil {
ctx . Handle ( 500 , "GetRepositories" , err )
return
}
ctx . HTML ( 200 , TEAM_REPOSITORIES )
}
2014-07-26 10:28:04 +04:00
func EditTeam ( ctx * middleware . Context ) {
2014-08-24 17:09:05 +04:00
ctx . Data [ "Title" ] = ctx . Org . Organization . FullName
ctx . Data [ "PageIsOrgTeams" ] = true
ctx . Data [ "team_name" ] = ctx . Org . Team . Name
ctx . Data [ "desc" ] = ctx . Org . Team . Description
ctx . HTML ( 200 , TEAM_NEW )
2014-06-27 18:04:04 +04:00
}
2014-07-07 14:13:42 +04:00
2014-08-24 17:09:05 +04:00
func EditTeamPost ( ctx * middleware . Context , form auth . CreateTeamForm ) {
t := ctx . Org . Team
ctx . Data [ "Title" ] = ctx . Org . Organization . FullName
2014-08-23 16:24:02 +04:00
ctx . Data [ "PageIsOrgTeams" ] = true
2014-08-24 17:09:05 +04:00
ctx . Data [ "team_name" ] = t . Name
ctx . Data [ "desc" ] = t . Description
if ctx . HasError ( ) {
ctx . HTML ( 200 , TEAM_NEW )
return
}
isAuthChanged := false
if ! t . IsOwnerTeam ( ) {
// Validate permission level.
2015-02-05 16:29:08 +03:00
var auth models . AccessMode
2014-08-24 17:09:05 +04:00
switch form . Permission {
case "read" :
2015-02-09 14:36:33 +03:00
auth = models . ACCESS_MODE_READ
2014-08-24 17:09:05 +04:00
case "write" :
2015-02-09 14:36:33 +03:00
auth = models . ACCESS_MODE_WRITE
2014-08-24 17:09:05 +04:00
case "admin" :
2015-02-09 14:36:33 +03:00
auth = models . ACCESS_MODE_ADMIN
2014-08-24 17:09:05 +04:00
default :
ctx . Error ( 401 )
return
}
t . Name = form . TeamName
if t . Authorize != auth {
isAuthChanged = true
t . Authorize = auth
}
}
t . Description = form . Description
if err := models . UpdateTeam ( t , isAuthChanged ) ; err != nil {
if err == models . ErrTeamNameIllegal {
ctx . Data [ "Err_TeamName" ] = true
ctx . RenderWithErr ( ctx . Tr ( "form.illegal_team_name" ) , TEAM_NEW , & form )
} else {
ctx . Handle ( 500 , "UpdateTeam" , err )
}
return
}
ctx . Redirect ( ctx . Org . OrgLink + "/teams/" + t . LowerName )
}
func DeleteTeam ( ctx * middleware . Context ) {
if err := models . DeleteTeam ( ctx . Org . Team ) ; err != nil {
2015-11-22 09:32:09 +03:00
ctx . Flash . Error ( "DeleteTeam: " + err . Error ( ) )
} else {
ctx . Flash . Success ( ctx . Tr ( "org.teams.delete_team_success" ) )
2014-08-24 17:09:05 +04:00
}
2015-11-22 09:32:09 +03:00
ctx . JSON ( 200 , map [ string ] interface { } {
"redirect" : ctx . Org . OrgLink + "/teams" ,
} )
2014-07-07 14:13:42 +04:00
}