123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133 |
- // 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 org
- import (
- log "unknwon.dev/clog/v2"
- "gogs.io/gogs/internal/auth"
- "gogs.io/gogs/internal/conf"
- "gogs.io/gogs/internal/context"
- "gogs.io/gogs/internal/db"
- "gogs.io/gogs/internal/form"
- "gogs.io/gogs/internal/route/user"
- )
- const (
- SETTINGS_OPTIONS = "org/settings/options"
- SETTINGS_DELETE = "org/settings/delete"
- )
- func Settings(c *context.Context) {
- c.Title("org.settings")
- c.Data["PageIsSettingsOptions"] = true
- c.Success(SETTINGS_OPTIONS)
- }
- func SettingsPost(c *context.Context, f form.UpdateOrgSetting) {
- c.Title("org.settings")
- c.Data["PageIsSettingsOptions"] = true
- if c.HasError() {
- c.Success(SETTINGS_OPTIONS)
- return
- }
- org := c.Org.Organization
- // Check if the organization username (including cases) had been changed
- if org.Name != f.Name {
- err := db.Users.ChangeUsername(c.Req.Context(), c.Org.Organization.ID, f.Name)
- if err != nil {
- c.Data["OrgName"] = true
- var msg string
- switch {
- case db.IsErrUserAlreadyExist(err):
- msg = c.Tr("form.username_been_taken")
- case db.IsErrNameNotAllowed(err):
- msg = c.Tr("user.form.name_not_allowed", err.(db.ErrNameNotAllowed).Value())
- default:
- c.Error(err, "change organization name")
- return
- }
- c.RenderWithErr(msg, SETTINGS_OPTIONS, &f)
- return
- }
- // reset c.org.OrgLink with new name
- c.Org.OrgLink = conf.Server.Subpath + "/org/" + f.Name
- log.Trace("Organization name changed: %s -> %s", org.Name, f.Name)
- }
- opts := db.UpdateUserOptions{
- FullName: &f.FullName,
- Website: &f.Website,
- Location: &f.Location,
- Description: &f.Description,
- }
- if c.User.IsAdmin {
- opts.MaxRepoCreation = &f.MaxRepoCreation
- }
- err := db.Users.Update(c.Req.Context(), c.Org.Organization.ID, opts)
- if err != nil {
- c.Error(err, "update organization")
- return
- }
- c.Flash.Success(c.Tr("org.settings.update_setting_success"))
- c.Redirect(c.Org.OrgLink + "/settings")
- }
- func SettingsAvatar(c *context.Context, f form.Avatar) {
- f.Source = form.AvatarLocal
- if err := user.UpdateAvatarSetting(c, f, c.Org.Organization); err != nil {
- c.Flash.Error(err.Error())
- } else {
- c.Flash.Success(c.Tr("org.settings.update_avatar_success"))
- }
- c.Redirect(c.Org.OrgLink + "/settings")
- }
- func SettingsDeleteAvatar(c *context.Context) {
- if err := db.Users.DeleteCustomAvatar(c.Req.Context(), c.Org.Organization.ID); err != nil {
- c.Flash.Error(err.Error())
- }
- c.Redirect(c.Org.OrgLink + "/settings")
- }
- func SettingsDelete(c *context.Context) {
- c.Title("org.settings")
- c.PageIs("SettingsDelete")
- org := c.Org.Organization
- if c.Req.Method == "POST" {
- if _, err := db.Users.Authenticate(c.Req.Context(), c.User.Name, c.Query("password"), c.User.LoginSource); err != nil {
- if auth.IsErrBadCredentials(err) {
- c.RenderWithErr(c.Tr("form.enterred_invalid_password"), SETTINGS_DELETE, nil)
- } else {
- c.Error(err, "authenticate user")
- }
- return
- }
- if err := db.DeleteOrganization(org); err != nil {
- if db.IsErrUserOwnRepos(err) {
- c.Flash.Error(c.Tr("form.org_still_own_repo"))
- c.Redirect(c.Org.OrgLink + "/settings/delete")
- } else {
- c.Error(err, "delete organization")
- }
- } else {
- log.Trace("Organization deleted: %s", org.Name)
- c.Redirect(conf.Server.Subpath + "/")
- }
- return
- }
- c.Success(SETTINGS_DELETE)
- }
|