// Copyright 2022 The Gitea Authors. All rights reserved. // SPDX-License-Identifier: MIT package org import ( "fmt" "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" shared_user "code.gitea.io/gitea/routers/web/shared/user" user_setting "code.gitea.io/gitea/routers/web/user/setting" "code.gitea.io/gitea/services/context" ) const ( tplSettingsApplications templates.TplName = "org/settings/applications" tplSettingsOAuthApplicationEdit templates.TplName = "org/settings/applications_oauth2_edit" ) func newOAuth2CommonHandlers(org *context.Organization) *user_setting.OAuth2CommonHandlers { return &user_setting.OAuth2CommonHandlers{ OwnerID: org.Organization.ID, BasePathList: fmt.Sprintf("%s/org/%s/settings/applications", setting.AppSubURL, org.Organization.Name), BasePathEditPrefix: fmt.Sprintf("%s/org/%s/settings/applications/oauth2", setting.AppSubURL, org.Organization.Name), TplAppEdit: tplSettingsOAuthApplicationEdit, } } // 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["PageIsOrgSettings"] = true ctx.Data["PageIsSettingsApplications"] = true apps, err := db.Find[auth.OAuth2Application](ctx, auth.FindOAuth2ApplicationsOptions{ OwnerID: ctx.Org.Organization.ID, }) if err != nil { ctx.ServerError("GetOAuth2ApplicationsByUserID", err) return } ctx.Data["Applications"] = apps err = shared_user.LoadHeaderCount(ctx) if err != nil { ctx.ServerError("LoadHeaderCount", err) return } ctx.HTML(http.StatusOK, tplSettingsApplications) } // OAuthApplicationsPost response for adding an oauth2 application func OAuthApplicationsPost(ctx *context.Context) { ctx.Data["Title"] = ctx.Tr("settings.applications") ctx.Data["PageIsOrgSettings"] = true ctx.Data["PageIsSettingsApplications"] = true oa := newOAuth2CommonHandlers(ctx.Org) oa.AddApp(ctx) } // OAuth2ApplicationShow displays the given application func OAuth2ApplicationShow(ctx *context.Context) { ctx.Data["PageIsOrgSettings"] = true ctx.Data["PageIsSettingsApplications"] = true oa := newOAuth2CommonHandlers(ctx.Org) oa.EditShow(ctx) } // OAuth2ApplicationEdit response for editing oauth2 application func OAuth2ApplicationEdit(ctx *context.Context) { ctx.Data["Title"] = ctx.Tr("settings.applications") ctx.Data["PageIsOrgSettings"] = true ctx.Data["PageIsSettingsApplications"] = true oa := newOAuth2CommonHandlers(ctx.Org) oa.EditSave(ctx) } // OAuthApplicationsRegenerateSecret handles the post request for regenerating the secret func OAuthApplicationsRegenerateSecret(ctx *context.Context) { ctx.Data["Title"] = ctx.Tr("settings") ctx.Data["PageIsOrgSettings"] = true ctx.Data["PageIsSettingsApplications"] = true oa := newOAuth2CommonHandlers(ctx.Org) oa.RegenerateSecret(ctx) } // DeleteOAuth2Application deletes the given oauth2 application func DeleteOAuth2Application(ctx *context.Context) { oa := newOAuth2CommonHandlers(ctx.Org) oa.DeleteApp(ctx) } // TODO: revokes the grant with the given id