2014-08-14 14:12:21 +08: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 middleware
import (
"github.com/Unknwon/macaron"
"github.com/gogits/gogs/models"
2014-08-24 21:09:05 +08:00
"github.com/gogits/gogs/modules/log"
2014-09-14 19:35:22 +02:00
"github.com/gogits/gogs/modules/setting"
2014-08-14 14:12:21 +08:00
)
func OrgAssignment ( redirect bool , args ... bool ) macaron . Handler {
return func ( ctx * Context ) {
var (
2014-08-15 18:29:41 +08:00
requireMember bool
requireOwner bool
requireAdminTeam bool
2014-08-14 14:12:21 +08:00
)
if len ( args ) >= 1 {
requireMember = args [ 0 ]
}
if len ( args ) >= 2 {
requireOwner = args [ 1 ]
}
2014-08-15 18:29:41 +08:00
if len ( args ) >= 3 {
requireAdminTeam = args [ 2 ]
}
2014-08-14 14:12:21 +08:00
orgName := ctx . Params ( ":org" )
var err error
ctx . Org . Organization , err = models . GetUserByName ( orgName )
if err != nil {
2015-08-05 11:14:17 +08:00
if models . IsErrUserNotExist ( err ) {
2014-08-14 14:12:21 +08:00
ctx . Handle ( 404 , "GetUserByName" , err )
} else if redirect {
2014-08-24 21:09:05 +08:00
log . Error ( 4 , "GetUserByName" , err )
2014-09-19 20:11:34 -04:00
ctx . Redirect ( setting . AppSubUrl + "/" )
2014-08-14 14:12:21 +08:00
} else {
ctx . Handle ( 500 , "GetUserByName" , err )
}
return
}
2014-08-16 16:21:17 +08:00
org := ctx . Org . Organization
ctx . Data [ "Org" ] = org
2014-08-14 14:12:21 +08:00
2015-07-26 19:22:17 +08:00
// Force redirection when username is actually a user.
if ! org . IsOrganization ( ) {
ctx . Redirect ( "/" + org . Name )
return
}
2014-08-14 14:12:21 +08:00
if ctx . IsSigned {
2014-12-12 20:30:32 -05:00
ctx . Org . IsOwner = org . IsOwnedBy ( ctx . User . Id )
2014-08-14 14:12:21 +08:00
if ctx . Org . IsOwner {
ctx . Org . IsMember = true
2014-08-15 18:29:41 +08:00
ctx . Org . IsAdminTeam = true
2014-08-14 14:12:21 +08:00
} else {
2014-08-16 16:21:17 +08:00
if org . IsOrgMember ( ctx . User . Id ) {
2014-08-15 18:29:41 +08:00
ctx . Org . IsMember = true
}
2014-08-14 14:12:21 +08:00
}
2014-08-27 16:39:36 +08:00
} else {
// Fake data.
ctx . Data [ "SignedUser" ] = & models . User { }
2014-08-14 14:12:21 +08:00
}
2014-08-15 18:29:41 +08:00
if ( requireMember && ! ctx . Org . IsMember ) ||
2014-08-24 21:09:05 +08:00
( requireOwner && ! ctx . Org . IsOwner ) {
2014-08-14 14:12:21 +08:00
ctx . Handle ( 404 , "OrgAssignment" , err )
return
}
2014-08-15 18:29:41 +08:00
ctx . Data [ "IsOrganizationOwner" ] = ctx . Org . IsOwner
2014-09-19 20:11:34 -04:00
ctx . Org . OrgLink = setting . AppSubUrl + "/org/" + org . Name
2014-08-15 18:29:41 +08:00
ctx . Data [ "OrgLink" ] = ctx . Org . OrgLink
2014-08-16 16:21:17 +08:00
// Team.
teamName := ctx . Params ( ":team" )
if len ( teamName ) > 0 {
ctx . Org . Team , err = org . GetTeam ( teamName )
if err != nil {
if err == models . ErrTeamNotExist {
ctx . Handle ( 404 , "GetTeam" , err )
} else if redirect {
2014-08-24 21:09:05 +08:00
log . Error ( 4 , "GetTeam" , err )
2014-09-19 20:11:34 -04:00
ctx . Redirect ( setting . AppSubUrl + "/" )
2014-08-16 16:21:17 +08:00
} else {
ctx . Handle ( 500 , "GetTeam" , err )
}
return
}
ctx . Data [ "Team" ] = ctx . Org . Team
2015-02-09 13:36:33 +02:00
ctx . Org . IsAdminTeam = ctx . Org . Team . IsOwnerTeam ( ) || ctx . Org . Team . Authorize >= models . ACCESS_MODE_ADMIN
2014-08-24 21:09:05 +08:00
}
ctx . Data [ "IsAdminTeam" ] = ctx . Org . IsAdminTeam
if requireAdminTeam && ! ctx . Org . IsAdminTeam {
ctx . Handle ( 404 , "OrgAssignment" , err )
return
2014-08-16 16:21:17 +08:00
}
2014-08-14 14:12:21 +08:00
}
}