mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-11-04 04:14:01 +01:00 
			
		
		
		
	We have some instances that only allow using an external authentication source for authentication. In this case, users changing their email, password, or linked OpenID connections will not have any effect, and we'd like to prevent showing that to them to prevent confusion. Included in this are several changes to support this: * A new setting to disable user managed authentication credentials (email, password & OpenID connections) * A new setting to disable user managed MFA (2FA codes & WebAuthn) * Fix an issue where some templates had separate logic for determining if a feature was disabled since it didn't check the globally disabled features * Hide more user setting pages in the navbar when their settings aren't enabled --------- Co-authored-by: Kyle D <kdumontnu@gmail.com>
		
			
				
	
	
		
			126 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			126 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// Copyright 2022 The Gitea Authors. All rights reserved.
 | 
						|
// SPDX-License-Identifier: MIT
 | 
						|
 | 
						|
package setting
 | 
						|
 | 
						|
import (
 | 
						|
	"net/http"
 | 
						|
	"strings"
 | 
						|
 | 
						|
	user_model "code.gitea.io/gitea/models/user"
 | 
						|
	"code.gitea.io/gitea/modules/base"
 | 
						|
	chef_module "code.gitea.io/gitea/modules/packages/chef"
 | 
						|
	"code.gitea.io/gitea/modules/setting"
 | 
						|
	"code.gitea.io/gitea/modules/util"
 | 
						|
	shared "code.gitea.io/gitea/routers/web/shared/packages"
 | 
						|
	"code.gitea.io/gitea/services/context"
 | 
						|
)
 | 
						|
 | 
						|
const (
 | 
						|
	tplSettingsPackages            base.TplName = "user/settings/packages"
 | 
						|
	tplSettingsPackagesRuleEdit    base.TplName = "user/settings/packages_cleanup_rules_edit"
 | 
						|
	tplSettingsPackagesRulePreview base.TplName = "user/settings/packages_cleanup_rules_preview"
 | 
						|
)
 | 
						|
 | 
						|
func Packages(ctx *context.Context) {
 | 
						|
	ctx.Data["Title"] = ctx.Tr("packages.title")
 | 
						|
	ctx.Data["PageIsSettingsPackages"] = true
 | 
						|
	ctx.Data["UserDisabledFeatures"] = user_model.DisabledFeaturesWithLoginType(ctx.Doer)
 | 
						|
 | 
						|
	shared.SetPackagesContext(ctx, ctx.Doer)
 | 
						|
 | 
						|
	ctx.HTML(http.StatusOK, tplSettingsPackages)
 | 
						|
}
 | 
						|
 | 
						|
func PackagesRuleAdd(ctx *context.Context) {
 | 
						|
	ctx.Data["Title"] = ctx.Tr("packages.title")
 | 
						|
	ctx.Data["PageIsSettingsPackages"] = true
 | 
						|
	ctx.Data["UserDisabledFeatures"] = user_model.DisabledFeaturesWithLoginType(ctx.Doer)
 | 
						|
 | 
						|
	shared.SetRuleAddContext(ctx)
 | 
						|
 | 
						|
	ctx.HTML(http.StatusOK, tplSettingsPackagesRuleEdit)
 | 
						|
}
 | 
						|
 | 
						|
func PackagesRuleEdit(ctx *context.Context) {
 | 
						|
	ctx.Data["Title"] = ctx.Tr("packages.title")
 | 
						|
	ctx.Data["PageIsSettingsPackages"] = true
 | 
						|
	ctx.Data["UserDisabledFeatures"] = user_model.DisabledFeaturesWithLoginType(ctx.Doer)
 | 
						|
 | 
						|
	shared.SetRuleEditContext(ctx, ctx.Doer)
 | 
						|
 | 
						|
	ctx.HTML(http.StatusOK, tplSettingsPackagesRuleEdit)
 | 
						|
}
 | 
						|
 | 
						|
func PackagesRuleAddPost(ctx *context.Context) {
 | 
						|
	ctx.Data["Title"] = ctx.Tr("settings")
 | 
						|
	ctx.Data["PageIsSettingsPackages"] = true
 | 
						|
	ctx.Data["UserDisabledFeatures"] = user_model.DisabledFeaturesWithLoginType(ctx.Doer)
 | 
						|
 | 
						|
	shared.PerformRuleAddPost(
 | 
						|
		ctx,
 | 
						|
		ctx.Doer,
 | 
						|
		setting.AppSubURL+"/user/settings/packages",
 | 
						|
		tplSettingsPackagesRuleEdit,
 | 
						|
	)
 | 
						|
}
 | 
						|
 | 
						|
func PackagesRuleEditPost(ctx *context.Context) {
 | 
						|
	ctx.Data["Title"] = ctx.Tr("packages.title")
 | 
						|
	ctx.Data["PageIsSettingsPackages"] = true
 | 
						|
	ctx.Data["UserDisabledFeatures"] = user_model.DisabledFeaturesWithLoginType(ctx.Doer)
 | 
						|
 | 
						|
	shared.PerformRuleEditPost(
 | 
						|
		ctx,
 | 
						|
		ctx.Doer,
 | 
						|
		setting.AppSubURL+"/user/settings/packages",
 | 
						|
		tplSettingsPackagesRuleEdit,
 | 
						|
	)
 | 
						|
}
 | 
						|
 | 
						|
func PackagesRulePreview(ctx *context.Context) {
 | 
						|
	ctx.Data["Title"] = ctx.Tr("packages.title")
 | 
						|
	ctx.Data["PageIsSettingsPackages"] = true
 | 
						|
	ctx.Data["UserDisabledFeatures"] = user_model.DisabledFeaturesWithLoginType(ctx.Doer)
 | 
						|
 | 
						|
	shared.SetRulePreviewContext(ctx, ctx.Doer)
 | 
						|
 | 
						|
	ctx.HTML(http.StatusOK, tplSettingsPackagesRulePreview)
 | 
						|
}
 | 
						|
 | 
						|
func InitializeCargoIndex(ctx *context.Context) {
 | 
						|
	ctx.Data["Title"] = ctx.Tr("packages.title")
 | 
						|
	ctx.Data["PageIsSettingsPackages"] = true
 | 
						|
 | 
						|
	shared.InitializeCargoIndex(ctx, ctx.Doer)
 | 
						|
 | 
						|
	ctx.Redirect(setting.AppSubURL + "/user/settings/packages")
 | 
						|
}
 | 
						|
 | 
						|
func RebuildCargoIndex(ctx *context.Context) {
 | 
						|
	ctx.Data["Title"] = ctx.Tr("packages.title")
 | 
						|
	ctx.Data["PageIsSettingsPackages"] = true
 | 
						|
 | 
						|
	shared.RebuildCargoIndex(ctx, ctx.Doer)
 | 
						|
 | 
						|
	ctx.Redirect(setting.AppSubURL + "/user/settings/packages")
 | 
						|
}
 | 
						|
 | 
						|
func RegenerateChefKeyPair(ctx *context.Context) {
 | 
						|
	priv, pub, err := util.GenerateKeyPair(chef_module.KeyBits)
 | 
						|
	if err != nil {
 | 
						|
		ctx.ServerError("GenerateKeyPair", err)
 | 
						|
		return
 | 
						|
	}
 | 
						|
 | 
						|
	if err := user_model.SetUserSetting(ctx, ctx.Doer.ID, chef_module.SettingPublicPem, pub); err != nil {
 | 
						|
		ctx.ServerError("SetUserSetting", err)
 | 
						|
		return
 | 
						|
	}
 | 
						|
 | 
						|
	ctx.ServeContent(strings.NewReader(priv), &context.ServeHeaderOptions{
 | 
						|
		ContentType: "application/x-pem-file",
 | 
						|
		Filename:    ctx.Doer.Name + ".priv",
 | 
						|
	})
 | 
						|
}
 |