forgejo-federation/routers/org/org.go

192 lines
4.7 KiB
Go
Raw Normal View History

2014-06-25 10:14:48 +05:30
// 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-07 10:57:24 +05:30
package org
import (
"github.com/gogits/gogs/models"
2014-06-25 10:14:48 +05:30
"github.com/gogits/gogs/modules/auth"
"github.com/gogits/gogs/modules/base"
"github.com/gogits/gogs/modules/log"
2014-06-07 10:57:24 +05:30
"github.com/gogits/gogs/modules/middleware"
2014-06-25 10:14:48 +05:30
)
const (
2014-06-29 01:13:25 +05:30
HOME base.TplName = "org/home"
CREATE base.TplName = "org/create"
2014-06-27 13:07:01 +05:30
SETTINGS base.TplName = "org/settings"
2014-06-07 10:57:24 +05:30
)
func Home(ctx *middleware.Context) {
ctx.Data["Title"] = "Organization " + ctx.Params(":org")
2014-06-29 01:13:25 +05:30
org, err := models.GetUserByName(ctx.Params(":org"))
2014-06-29 01:13:25 +05:30
if err != nil {
if err == models.ErrUserNotExist {
ctx.Handle(404, "org.Home(GetUserByName)", err)
} else {
ctx.Handle(500, "org.Home(GetUserByName)", err)
}
return
}
ctx.Data["Org"] = org
ctx.Data["Repos"], err = models.GetRepositories(org.Id,
2014-06-30 02:00:41 +05:30
ctx.IsSigned && org.IsOrgMember(ctx.User.Id))
2014-06-29 01:13:25 +05:30
if err != nil {
ctx.Handle(500, "org.Home(GetRepositories)", err)
return
}
if err = org.GetMembers(); err != nil {
ctx.Handle(500, "org.Home(GetMembers)", err)
return
}
ctx.Data["Members"] = org.Members
if err = org.GetTeams(); err != nil {
ctx.Handle(500, "org.Home(GetTeams)", err)
return
}
ctx.Data["Teams"] = org.Teams
ctx.HTML(200, HOME)
2014-06-07 10:57:24 +05:30
}
2014-06-22 14:23:46 +05:30
func Create(ctx *middleware.Context) {
ctx.Data["Title"] = ctx.Tr("new_org")
ctx.HTML(200, CREATE)
2014-06-25 10:14:48 +05:30
}
func CreatePost(ctx *middleware.Context, form auth.CreateOrgForm) {
ctx.Data["Title"] = ctx.Tr("new_org")
2014-06-25 10:14:48 +05:30
if ctx.HasError() {
ctx.HTML(200, CREATE)
2014-06-25 10:14:48 +05:30
return
}
org := &models.User{
Name: form.OrgName,
Email: form.Email,
IsActive: true,
2014-06-25 10:14:48 +05:30
Type: models.ORGANIZATION,
}
var err error
if org, err = models.CreateOrganization(org, ctx.User); err != nil {
switch err {
case models.ErrUserAlreadyExist:
ctx.Data["Err_OrgName"] = true
ctx.RenderWithErr(ctx.Tr("form.org_name_been_taken"), CREATE, &form)
2014-06-25 10:14:48 +05:30
case models.ErrEmailAlreadyUsed:
ctx.Data["Err_Email"] = true
ctx.RenderWithErr(ctx.Tr("form.email_been_used"), CREATE, &form)
2014-06-25 10:14:48 +05:30
case models.ErrUserNameIllegal:
ctx.Data["Err_OrgName"] = true
ctx.RenderWithErr(ctx.Tr("form.illegal_org_name"), CREATE, &form)
2014-06-25 10:14:48 +05:30
default:
ctx.Handle(500, "CreateUser", err)
2014-06-25 10:14:48 +05:30
}
return
}
log.Trace("Organization created: %s", org.Name)
2014-06-25 10:14:48 +05:30
ctx.Redirect("/org/" + form.OrgName + "/dashboard")
2014-06-23 09:10:49 +05:30
}
2014-06-23 09:38:53 +05:30
func Settings(ctx *middleware.Context) {
2014-06-27 13:07:01 +05:30
ctx.Data["Title"] = "Settings"
org, err := models.GetUserByName(ctx.Params(":org"))
2014-06-27 13:07:01 +05:30
if err != nil {
if err == models.ErrUserNotExist {
ctx.Handle(404, "org.Settings(GetUserByName)", err)
} else {
ctx.Handle(500, "org.Settings(GetUserByName)", err)
}
return
}
ctx.Data["Org"] = org
ctx.HTML(200, SETTINGS)
}
func SettingsPost(ctx *middleware.Context, form auth.OrgSettingForm) {
2014-06-27 13:07:01 +05:30
ctx.Data["Title"] = "Settings"
org, err := models.GetUserByName(ctx.Params(":org"))
2014-06-27 13:07:01 +05:30
if err != nil {
if err == models.ErrUserNotExist {
ctx.Handle(404, "org.SettingsPost(GetUserByName)", err)
} else {
ctx.Handle(500, "org.SettingsPost(GetUserByName)", err)
}
return
}
ctx.Data["Org"] = org
if ctx.HasError() {
ctx.HTML(200, SETTINGS)
return
}
org.FullName = form.DisplayName
org.Email = form.Email
org.Description = form.Description
org.Website = form.Website
org.Location = form.Location
if err = models.UpdateUser(org); err != nil {
ctx.Handle(500, "org.SettingsPost(UpdateUser)", err)
return
}
log.Trace("%s Organization setting updated: %s", ctx.Req.RequestURI, org.LowerName)
ctx.Flash.Success("Organization profile has been successfully updated.")
ctx.Redirect("/org/" + org.Name + "/settings")
2014-06-23 16:41:20 +05:30
}
2014-06-28 10:10:07 +05:30
func DeletePost(ctx *middleware.Context) {
2014-06-28 10:10:07 +05:30
ctx.Data["Title"] = "Settings"
org, err := models.GetUserByName(ctx.Params(":org"))
2014-06-28 10:10:07 +05:30
if err != nil {
if err == models.ErrUserNotExist {
ctx.Handle(404, "org.DeletePost(GetUserByName)", err)
} else {
ctx.Handle(500, "org.DeletePost(GetUserByName)", err)
}
return
}
ctx.Data["Org"] = org
2014-06-30 02:00:41 +05:30
if !org.IsOrgOwner(ctx.User.Id) {
2014-06-28 10:10:07 +05:30
ctx.Error(403)
return
}
tmpUser := models.User{
Passwd: ctx.Query("password"),
Salt: ctx.User.Salt,
}
tmpUser.EncodePasswd()
if tmpUser.Passwd != ctx.User.Passwd {
ctx.Flash.Error("Password is not correct. Make sure you are owner of this account.")
} else {
if err := models.DeleteOrganization(org); err != nil {
switch err {
case models.ErrUserOwnRepos:
ctx.Flash.Error("This organization still have ownership of repository, you have to delete or transfer them first.")
default:
ctx.Handle(500, "org.DeletePost(DeleteOrganization)", err)
return
}
} else {
ctx.Redirect("/")
return
}
}
ctx.Redirect("/org/" + org.Name + "/settings")
}