| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990 |
- // 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")
- 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
|