mirror of
https://github.com/go-gitea/gitea.git
synced 2025-12-22 16:24:59 +01:00
Migrate from the current INI format to JSON for translations. JSON is widely supported, including by platforms such as Crowdin and Weblate.
90 lines
2.6 KiB
Go
90 lines
2.6 KiB
Go
// Copyright 2022 The Gitea Authors. All rights reserved.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package admin
|
|
|
|
import (
|
|
"net/http"
|
|
|
|
"code.gitea.io/gitea/models/auth"
|
|
"code.gitea.io/gitea/models/db"
|
|
"code.gitea.io/gitea/modules/setting"
|
|
"code.gitea.io/gitea/modules/templates"
|
|
user_setting "code.gitea.io/gitea/routers/web/user/setting"
|
|
"code.gitea.io/gitea/services/context"
|
|
)
|
|
|
|
var (
|
|
tplSettingsApplications templates.TplName = "admin/applications/list"
|
|
tplSettingsOauth2ApplicationEdit templates.TplName = "admin/applications/oauth2_edit"
|
|
)
|
|
|
|
func newOAuth2CommonHandlers() *user_setting.OAuth2CommonHandlers {
|
|
return &user_setting.OAuth2CommonHandlers{
|
|
OwnerID: 0,
|
|
BasePathList: setting.AppSubURL + "/-/admin/applications",
|
|
BasePathEditPrefix: setting.AppSubURL + "/-/admin/applications/oauth2",
|
|
TplAppEdit: tplSettingsOauth2ApplicationEdit,
|
|
}
|
|
}
|
|
|
|
// Applications render org applications page (for org, at the moment, there are only OAuth2 applications)
|
|
func Applications(ctx *context.Context) {
|
|
ctx.Data["Title"] = ctx.Tr("settings.applications")
|
|
ctx.Data["PageIsAdminApplications"] = true
|
|
|
|
apps, err := db.Find[auth.OAuth2Application](ctx, auth.FindOAuth2ApplicationsOptions{
|
|
IsGlobal: true,
|
|
})
|
|
if err != nil {
|
|
ctx.ServerError("GetOAuth2ApplicationsByUserID", err)
|
|
return
|
|
}
|
|
ctx.Data["Applications"] = apps
|
|
ctx.Data["BuiltinApplications"] = auth.BuiltinApplications()
|
|
ctx.HTML(http.StatusOK, tplSettingsApplications)
|
|
}
|
|
|
|
// ApplicationsPost response for adding an oauth2 application
|
|
func ApplicationsPost(ctx *context.Context) {
|
|
ctx.Data["Title"] = ctx.Tr("settings.applications")
|
|
ctx.Data["PageIsAdminApplications"] = true
|
|
|
|
oa := newOAuth2CommonHandlers()
|
|
oa.AddApp(ctx)
|
|
}
|
|
|
|
// EditApplication displays the given application
|
|
func EditApplication(ctx *context.Context) {
|
|
ctx.Data["PageIsAdminApplications"] = true
|
|
|
|
oa := newOAuth2CommonHandlers()
|
|
oa.EditShow(ctx)
|
|
}
|
|
|
|
// EditApplicationPost response for editing oauth2 application
|
|
func EditApplicationPost(ctx *context.Context) {
|
|
ctx.Data["Title"] = ctx.Tr("settings.applications")
|
|
ctx.Data["PageIsAdminApplications"] = true
|
|
|
|
oa := newOAuth2CommonHandlers()
|
|
oa.EditSave(ctx)
|
|
}
|
|
|
|
// ApplicationsRegenerateSecret handles the post request for regenerating the secret
|
|
func ApplicationsRegenerateSecret(ctx *context.Context) {
|
|
ctx.Data["Title"] = ctx.Tr("settings_title")
|
|
ctx.Data["PageIsAdminApplications"] = true
|
|
|
|
oa := newOAuth2CommonHandlers()
|
|
oa.RegenerateSecret(ctx)
|
|
}
|
|
|
|
// DeleteApplication deletes the given oauth2 application
|
|
func DeleteApplication(ctx *context.Context) {
|
|
oa := newOAuth2CommonHandlers()
|
|
oa.DeleteApp(ctx)
|
|
}
|
|
|
|
// TODO: revokes the grant with the given id
|