2016-08-14 04:41:52 +05:30
// Copyright 2016 The Gogs Authors. All rights reserved.
2016-12-21 17:43:17 +05:30
// Copyright 2016 The Gitea Authors. All rights reserved.
2022-11-27 23:50:29 +05:30
// SPDX-License-Identifier: MIT
2016-08-14 04:41:52 +05:30
package cmd
import (
2018-10-31 03:04:25 +05:30
"errors"
2016-08-14 04:41:52 +05:30
"fmt"
2023-03-10 11:44:43 +05:30
"net/url"
2018-09-12 20:16:02 +05:30
"os"
2020-12-17 13:27:32 +05:30
"strings"
2018-09-12 20:16:02 +05:30
"text/tabwriter"
2016-08-14 04:41:52 +05:30
2021-12-10 13:44:24 +05:30
asymkey_model "code.gitea.io/gitea/models/asymkey"
2022-08-25 08:01:57 +05:30
auth_model "code.gitea.io/gitea/models/auth"
2021-09-24 17:02:56 +05:30
"code.gitea.io/gitea/models/db"
2022-06-06 13:31:49 +05:30
repo_model "code.gitea.io/gitea/models/repo"
2019-03-27 15:03:00 +05:30
"code.gitea.io/gitea/modules/git"
2020-01-21 01:31:19 +05:30
"code.gitea.io/gitea/modules/graceful"
2017-12-31 20:15:46 +05:30
"code.gitea.io/gitea/modules/log"
2020-01-21 01:31:19 +05:30
repo_module "code.gitea.io/gitea/modules/repository"
2022-04-30 01:08:11 +05:30
"code.gitea.io/gitea/modules/util"
2021-09-24 17:02:56 +05:30
auth_service "code.gitea.io/gitea/services/auth"
2021-07-24 15:46:34 +05:30
"code.gitea.io/gitea/services/auth/source/oauth2"
2022-01-13 04:24:53 +05:30
"code.gitea.io/gitea/services/auth/source/smtp"
2021-11-17 20:47:31 +05:30
repo_service "code.gitea.io/gitea/services/repository"
2017-04-12 13:14:54 +05:30
2023-07-21 14:58:19 +05:30
"github.com/urfave/cli/v2"
2016-08-14 04:41:52 +05:30
)
var (
2016-11-04 17:12:18 +05:30
// CmdAdmin represents the available admin sub-command.
2023-07-21 14:58:19 +05:30
CmdAdmin = & cli . Command {
2016-08-14 04:41:52 +05:30
Name : "admin" ,
2018-01-13 03:46:49 +05:30
Usage : "Command line interface to perform common administrative operations" ,
2023-07-21 14:58:19 +05:30
Subcommands : [ ] * cli . Command {
2020-10-16 08:18:38 +05:30
subcmdUser ,
2017-12-31 20:15:46 +05:30
subcmdRepoSyncReleases ,
2018-05-17 07:05:07 +05:30
subcmdRegenerate ,
2018-09-12 20:16:02 +05:30
subcmdAuth ,
2020-10-25 02:08:14 +05:30
subcmdSendMail ,
2016-08-14 04:41:52 +05:30
} ,
}
2023-07-21 14:58:19 +05:30
subcmdRepoSyncReleases = & cli . Command {
2017-12-31 20:15:46 +05:30
Name : "repo-sync-releases" ,
Usage : "Synchronize repository releases with tags" ,
Action : runRepoSyncReleases ,
}
2018-05-17 07:05:07 +05:30
2023-07-21 14:58:19 +05:30
subcmdRegenerate = & cli . Command {
2018-05-17 07:05:07 +05:30
Name : "regenerate" ,
Usage : "Regenerate specific files" ,
2023-07-21 14:58:19 +05:30
Subcommands : [ ] * cli . Command {
2018-05-17 07:05:07 +05:30
microcmdRegenHooks ,
microcmdRegenKeys ,
} ,
}
2023-07-21 14:58:19 +05:30
microcmdRegenHooks = & cli . Command {
2018-05-17 07:05:07 +05:30
Name : "hooks" ,
Usage : "Regenerate git-hooks" ,
Action : runRegenerateHooks ,
}
2023-07-21 14:58:19 +05:30
microcmdRegenKeys = & cli . Command {
2018-05-17 07:05:07 +05:30
Name : "keys" ,
Usage : "Regenerate authorized_keys file" ,
Action : runRegenerateKeys ,
}
2018-09-12 20:16:02 +05:30
2023-07-21 14:58:19 +05:30
subcmdAuth = & cli . Command {
2018-09-12 20:16:02 +05:30
Name : "auth" ,
Usage : "Modify external auth providers" ,
2023-07-21 14:58:19 +05:30
Subcommands : [ ] * cli . Command {
2018-09-12 20:16:02 +05:30
microcmdAuthAddOauth ,
microcmdAuthUpdateOauth ,
2019-06-18 00:02:20 +05:30
cmdAuthAddLdapBindDn ,
cmdAuthUpdateLdapBindDn ,
cmdAuthAddLdapSimpleAuth ,
cmdAuthUpdateLdapSimpleAuth ,
2022-01-13 04:24:53 +05:30
microcmdAuthAddSMTP ,
microcmdAuthUpdateSMTP ,
2018-09-12 20:16:02 +05:30
microcmdAuthList ,
microcmdAuthDelete ,
} ,
}
2023-07-21 14:58:19 +05:30
microcmdAuthList = & cli . Command {
2018-09-12 20:16:02 +05:30
Name : "list" ,
Usage : "List auth sources" ,
Action : runListAuth ,
2020-03-28 02:56:43 +05:30
Flags : [ ] cli . Flag {
2023-07-21 14:58:19 +05:30
& cli . IntFlag {
2020-03-28 02:56:43 +05:30
Name : "min-width" ,
Usage : "Minimal cell width including any padding for the formatted table" ,
Value : 0 ,
} ,
2023-07-21 14:58:19 +05:30
& cli . IntFlag {
2020-03-28 02:56:43 +05:30
Name : "tab-width" ,
Usage : "width of tab characters in formatted table (equivalent number of spaces)" ,
Value : 8 ,
} ,
2023-07-21 14:58:19 +05:30
& cli . IntFlag {
2020-03-28 02:56:43 +05:30
Name : "padding" ,
Usage : "padding added to a cell before computing its width" ,
Value : 1 ,
} ,
2023-07-21 14:58:19 +05:30
& cli . StringFlag {
2020-03-28 02:56:43 +05:30
Name : "pad-char" ,
Usage : ` ASCII char used for padding if padchar == '\\t', the Writer will assume that the width of a '\\t' in the formatted output is tabwidth, and cells are left-aligned independent of align_left (for correct-looking results, tabwidth must correspond to the tab width in the viewer displaying the result) ` ,
Value : "\t" ,
} ,
2023-07-21 14:58:19 +05:30
& cli . BoolFlag {
2020-03-28 02:56:43 +05:30
Name : "vertical-bars" ,
Usage : "Set to true to print vertical bars between columns" ,
} ,
} ,
2018-09-12 20:16:02 +05:30
}
2023-07-21 14:58:19 +05:30
idFlag = & cli . Int64Flag {
2018-09-12 20:16:02 +05:30
Name : "id" ,
2019-06-18 00:02:20 +05:30
Usage : "ID of authentication source" ,
2018-09-12 20:16:02 +05:30
}
2023-07-21 14:58:19 +05:30
microcmdAuthDelete = & cli . Command {
2018-09-12 20:16:02 +05:30
Name : "delete" ,
Usage : "Delete specific auth source" ,
2020-01-08 05:11:16 +05:30
Flags : [ ] cli . Flag { idFlag } ,
2018-09-12 20:16:02 +05:30
Action : runDeleteAuth ,
}
oauthCLIFlags = [ ] cli . Flag {
2023-07-21 14:58:19 +05:30
& cli . StringFlag {
2018-09-12 20:16:02 +05:30
Name : "name" ,
Value : "" ,
Usage : "Application Name" ,
} ,
2023-07-21 14:58:19 +05:30
& cli . StringFlag {
2018-09-12 20:16:02 +05:30
Name : "provider" ,
Value : "" ,
Usage : "OAuth2 Provider" ,
} ,
2023-07-21 14:58:19 +05:30
& cli . StringFlag {
2018-09-12 20:16:02 +05:30
Name : "key" ,
Value : "" ,
Usage : "Client ID (Key)" ,
} ,
2023-07-21 14:58:19 +05:30
& cli . StringFlag {
2018-09-12 20:16:02 +05:30
Name : "secret" ,
Value : "" ,
Usage : "Client Secret" ,
} ,
2023-07-21 14:58:19 +05:30
& cli . StringFlag {
2018-09-12 20:16:02 +05:30
Name : "auto-discover-url" ,
Value : "" ,
Usage : "OpenID Connect Auto Discovery URL (only required when using OpenID Connect as provider)" ,
} ,
2023-07-21 14:58:19 +05:30
& cli . StringFlag {
2018-09-12 20:16:02 +05:30
Name : "use-custom-urls" ,
Value : "false" ,
Usage : "Use custom URLs for GitLab/GitHub OAuth endpoints" ,
} ,
2023-07-21 14:58:19 +05:30
& cli . StringFlag {
2023-02-06 09:42:13 +05:30
Name : "custom-tenant-id" ,
Value : "" ,
Usage : "Use custom Tenant ID for OAuth endpoints" ,
} ,
2023-07-21 14:58:19 +05:30
& cli . StringFlag {
2018-09-12 20:16:02 +05:30
Name : "custom-auth-url" ,
Value : "" ,
Usage : "Use a custom Authorization URL (option for GitLab/GitHub)" ,
} ,
2023-07-21 14:58:19 +05:30
& cli . StringFlag {
2018-09-12 20:16:02 +05:30
Name : "custom-token-url" ,
Value : "" ,
Usage : "Use a custom Token URL (option for GitLab/GitHub)" ,
} ,
2023-07-21 14:58:19 +05:30
& cli . StringFlag {
2018-09-12 20:16:02 +05:30
Name : "custom-profile-url" ,
Value : "" ,
Usage : "Use a custom Profile URL (option for GitLab/GitHub)" ,
} ,
2023-07-21 14:58:19 +05:30
& cli . StringFlag {
2018-09-12 20:16:02 +05:30
Name : "custom-email-url" ,
Value : "" ,
Usage : "Use a custom Email URL (option for GitHub)" ,
} ,
2023-07-21 14:58:19 +05:30
& cli . StringFlag {
2020-12-28 14:09:12 +05:30
Name : "icon-url" ,
Value : "" ,
Usage : "Custom icon URL for OAuth2 login source" ,
} ,
2023-07-21 14:58:19 +05:30
& cli . BoolFlag {
2021-09-10 22:07:57 +05:30
Name : "skip-local-2fa" ,
Usage : "Set to true to skip local 2fa for users authenticated by this source" ,
} ,
2023-07-21 14:58:19 +05:30
& cli . StringSliceFlag {
2021-12-14 14:07:11 +05:30
Name : "scopes" ,
Value : nil ,
Usage : "Scopes to request when to authenticate against this OAuth2 source" ,
} ,
2023-07-21 14:58:19 +05:30
& cli . StringFlag {
2021-12-14 14:07:11 +05:30
Name : "required-claim-name" ,
Value : "" ,
Usage : "Claim name that has to be set to allow users to login with this source" ,
} ,
2023-07-21 14:58:19 +05:30
& cli . StringFlag {
2021-12-14 14:07:11 +05:30
Name : "required-claim-value" ,
Value : "" ,
Usage : "Claim value that has to be set to allow users to login with this source" ,
} ,
2023-07-21 14:58:19 +05:30
& cli . StringFlag {
2021-12-14 14:07:11 +05:30
Name : "group-claim-name" ,
Value : "" ,
Usage : "Claim name providing group names for this source" ,
} ,
2023-07-21 14:58:19 +05:30
& cli . StringFlag {
2021-12-14 14:07:11 +05:30
Name : "admin-group" ,
Value : "" ,
Usage : "Group Claim value for administrator users" ,
} ,
2023-07-21 14:58:19 +05:30
& cli . StringFlag {
2021-12-14 14:07:11 +05:30
Name : "restricted-group" ,
Value : "" ,
Usage : "Group Claim value for restricted users" ,
} ,
2023-07-21 14:58:19 +05:30
& cli . StringFlag {
2023-02-08 12:14:42 +05:30
Name : "group-team-map" ,
Value : "" ,
Usage : "JSON mapping between groups and org teams" ,
} ,
2023-07-21 14:58:19 +05:30
& cli . BoolFlag {
2023-02-08 12:14:42 +05:30
Name : "group-team-map-removal" ,
Usage : "Activate automatic team membership removal depending on groups" ,
} ,
2018-09-12 20:16:02 +05:30
}
2023-07-21 14:58:19 +05:30
microcmdAuthUpdateOauth = & cli . Command {
2018-09-12 20:16:02 +05:30
Name : "update-oauth" ,
Usage : "Update existing Oauth authentication source" ,
Action : runUpdateOauth ,
Flags : append ( oauthCLIFlags [ : 1 ] , append ( [ ] cli . Flag { idFlag } , oauthCLIFlags [ 1 : ] ... ) ... ) ,
}
2023-07-21 14:58:19 +05:30
microcmdAuthAddOauth = & cli . Command {
2018-09-12 20:16:02 +05:30
Name : "add-oauth" ,
Usage : "Add new Oauth authentication source" ,
Action : runAddOauth ,
Flags : oauthCLIFlags ,
}
2020-10-25 02:08:14 +05:30
2023-07-21 14:58:19 +05:30
subcmdSendMail = & cli . Command {
2020-10-25 02:08:14 +05:30
Name : "sendmail" ,
Usage : "Send a message to all users" ,
Action : runSendMail ,
Flags : [ ] cli . Flag {
2023-07-21 14:58:19 +05:30
& cli . StringFlag {
2020-10-25 02:08:14 +05:30
Name : "title" ,
Usage : ` a title of a message ` ,
Value : "" ,
} ,
2023-07-21 14:58:19 +05:30
& cli . StringFlag {
2020-10-25 02:08:14 +05:30
Name : "content" ,
Usage : "a content of a message" ,
Value : "" ,
} ,
2023-07-21 14:58:19 +05:30
& cli . BoolFlag {
Name : "force" ,
Aliases : [ ] string { "f" } ,
Usage : "A flag to bypass a confirmation step" ,
2020-10-25 02:08:14 +05:30
} ,
} ,
}
2022-01-13 04:24:53 +05:30
smtpCLIFlags = [ ] cli . Flag {
2023-07-21 14:58:19 +05:30
& cli . StringFlag {
2022-01-13 04:24:53 +05:30
Name : "name" ,
Value : "" ,
Usage : "Application Name" ,
} ,
2023-07-21 14:58:19 +05:30
& cli . StringFlag {
2022-01-13 04:24:53 +05:30
Name : "auth-type" ,
Value : "PLAIN" ,
Usage : "SMTP Authentication Type (PLAIN/LOGIN/CRAM-MD5) default PLAIN" ,
} ,
2023-07-21 14:58:19 +05:30
& cli . StringFlag {
2022-11-11 02:42:23 +05:30
Name : "host" ,
2022-01-13 04:24:53 +05:30
Value : "" ,
2022-11-11 02:42:23 +05:30
Usage : "SMTP Host" ,
2022-01-13 04:24:53 +05:30
} ,
2023-07-21 14:58:19 +05:30
& cli . IntFlag {
2022-01-13 04:24:53 +05:30
Name : "port" ,
Usage : "SMTP Port" ,
} ,
2023-07-21 14:58:19 +05:30
& cli . BoolFlag {
2022-01-13 04:24:53 +05:30
Name : "force-smtps" ,
Usage : "SMTPS is always used on port 465. Set this to force SMTPS on other ports." ,
} ,
2023-07-21 14:58:19 +05:30
& cli . BoolFlag {
2022-01-13 04:24:53 +05:30
Name : "skip-verify" ,
Usage : "Skip TLS verify." ,
} ,
2023-07-21 14:58:19 +05:30
& cli . StringFlag {
2022-01-13 04:24:53 +05:30
Name : "helo-hostname" ,
Value : "" ,
Usage : "Hostname sent with HELO. Leave blank to send current hostname" ,
} ,
2023-07-21 14:58:19 +05:30
& cli . BoolFlag {
2022-01-13 04:24:53 +05:30
Name : "disable-helo" ,
Usage : "Disable SMTP helo." ,
} ,
2023-07-21 14:58:19 +05:30
& cli . StringFlag {
2022-01-13 04:24:53 +05:30
Name : "allowed-domains" ,
Value : "" ,
Usage : "Leave empty to allow all domains. Separate multiple domains with a comma (',')" ,
} ,
2023-07-21 14:58:19 +05:30
& cli . BoolFlag {
2022-01-13 04:24:53 +05:30
Name : "skip-local-2fa" ,
Usage : "Skip 2FA to log on." ,
} ,
2023-07-21 14:58:19 +05:30
& cli . BoolFlag {
2022-01-13 04:24:53 +05:30
Name : "active" ,
Usage : "This Authentication Source is Activated." ,
} ,
}
2023-07-21 14:58:19 +05:30
microcmdAuthAddSMTP = & cli . Command {
2022-01-13 04:24:53 +05:30
Name : "add-smtp" ,
Usage : "Add new SMTP authentication source" ,
Action : runAddSMTP ,
Flags : smtpCLIFlags ,
}
2023-07-21 14:58:19 +05:30
microcmdAuthUpdateSMTP = & cli . Command {
2022-01-13 04:24:53 +05:30
Name : "update-smtp" ,
Usage : "Update existing SMTP authentication source" ,
Action : runUpdateSMTP ,
Flags : append ( smtpCLIFlags [ : 1 ] , append ( [ ] cli . Flag { idFlag } , smtpCLIFlags [ 1 : ] ... ) ... ) ,
}
2016-08-14 04:41:52 +05:30
)
2021-04-09 13:10:34 +05:30
func runRepoSyncReleases ( _ * cli . Context ) error {
2021-11-07 08:41:27 +05:30
ctx , cancel := installSignals ( )
defer cancel ( )
if err := initDB ( ctx ) ; err != nil {
2018-01-13 03:46:49 +05:30
return err
2017-12-31 20:15:46 +05:30
}
log . Trace ( "Synchronizing repository releases (this may take a while)" )
for page := 1 ; ; page ++ {
2022-11-19 13:42:33 +05:30
repos , count , err := repo_model . SearchRepositoryByName ( ctx , & repo_model . SearchRepoOptions {
2021-09-24 17:02:56 +05:30
ListOptions : db . ListOptions {
2022-06-06 13:31:49 +05:30
PageSize : repo_model . RepositoryListDefaultPageSize ,
2020-01-25 00:30:29 +05:30
Page : page ,
} ,
Private : true ,
2017-12-31 20:15:46 +05:30
} )
if err != nil {
2022-10-25 00:59:17 +05:30
return fmt . Errorf ( "SearchRepositoryByName: %w" , err )
2017-12-31 20:15:46 +05:30
}
if len ( repos ) == 0 {
break
}
log . Trace ( "Processing next %d repos of %d" , len ( repos ) , count )
for _ , repo := range repos {
log . Trace ( "Synchronizing repo %s with path %s" , repo . FullName ( ) , repo . RepoPath ( ) )
2022-03-30 00:43:41 +05:30
gitRepo , err := git . OpenRepository ( ctx , repo . RepoPath ( ) )
2017-12-31 20:15:46 +05:30
if err != nil {
log . Warn ( "OpenRepository: %v" , err )
continue
}
2018-01-13 03:46:49 +05:30
oldnum , err := getReleaseCount ( repo . ID )
2017-12-31 20:15:46 +05:30
if err != nil {
log . Warn ( " GetReleaseCountByRepoID: %v" , err )
}
log . Trace ( " currentNumReleases is %d, running SyncReleasesWithTags" , oldnum )
2020-01-21 01:31:19 +05:30
if err = repo_module . SyncReleasesWithTags ( repo , gitRepo ) ; err != nil {
2017-12-31 20:15:46 +05:30
log . Warn ( " SyncReleasesWithTags: %v" , err )
2019-11-13 12:31:19 +05:30
gitRepo . Close ( )
2017-12-31 20:15:46 +05:30
continue
}
2018-01-13 03:46:49 +05:30
count , err = getReleaseCount ( repo . ID )
2017-12-31 20:15:46 +05:30
if err != nil {
log . Warn ( " GetReleaseCountByRepoID: %v" , err )
2019-11-13 12:31:19 +05:30
gitRepo . Close ( )
2017-12-31 20:15:46 +05:30
continue
}
log . Trace ( " repo %s releases synchronized to tags: from %d to %d" ,
repo . FullName ( ) , oldnum , count )
2019-11-13 12:31:19 +05:30
gitRepo . Close ( )
2017-12-31 20:15:46 +05:30
}
}
return nil
}
2018-01-13 03:46:49 +05:30
func getReleaseCount ( id int64 ) ( int64 , error ) {
2022-08-25 08:01:57 +05:30
return repo_model . GetReleaseCountByRepoID (
2022-12-10 08:16:31 +05:30
db . DefaultContext ,
2018-01-13 03:46:49 +05:30
id ,
2022-08-25 08:01:57 +05:30
repo_model . FindReleasesOptions {
2018-01-13 03:46:49 +05:30
IncludeTags : true ,
} ,
)
}
2018-05-17 07:05:07 +05:30
2021-04-09 13:10:34 +05:30
func runRegenerateHooks ( _ * cli . Context ) error {
2021-11-07 08:41:27 +05:30
ctx , cancel := installSignals ( )
defer cancel ( )
if err := initDB ( ctx ) ; err != nil {
2018-05-17 07:05:07 +05:30
return err
}
2021-11-17 20:47:31 +05:30
return repo_service . SyncRepositoryHooks ( graceful . GetManager ( ) . ShutdownContext ( ) )
2018-05-17 07:05:07 +05:30
}
2021-04-09 13:10:34 +05:30
func runRegenerateKeys ( _ * cli . Context ) error {
2021-11-07 08:41:27 +05:30
ctx , cancel := installSignals ( )
defer cancel ( )
if err := initDB ( ctx ) ; err != nil {
2018-05-17 07:05:07 +05:30
return err
}
2021-12-10 13:44:24 +05:30
return asymkey_model . RewriteAllPublicKeys ( )
2018-05-17 07:05:07 +05:30
}
2018-09-12 20:16:02 +05:30
2021-07-24 15:46:34 +05:30
func parseOAuth2Config ( c * cli . Context ) * oauth2 . Source {
2018-09-12 20:16:02 +05:30
var customURLMapping * oauth2 . CustomURLMapping
if c . IsSet ( "use-custom-urls" ) {
customURLMapping = & oauth2 . CustomURLMapping {
TokenURL : c . String ( "custom-token-url" ) ,
AuthURL : c . String ( "custom-auth-url" ) ,
ProfileURL : c . String ( "custom-profile-url" ) ,
EmailURL : c . String ( "custom-email-url" ) ,
2023-02-06 09:42:13 +05:30
Tenant : c . String ( "custom-tenant-id" ) ,
2018-09-12 20:16:02 +05:30
}
} else {
customURLMapping = nil
}
2021-07-24 15:46:34 +05:30
return & oauth2 . Source {
2018-09-12 20:16:02 +05:30
Provider : c . String ( "provider" ) ,
ClientID : c . String ( "key" ) ,
ClientSecret : c . String ( "secret" ) ,
OpenIDConnectAutoDiscoveryURL : c . String ( "auto-discover-url" ) ,
CustomURLMapping : customURLMapping ,
2020-12-28 14:09:12 +05:30
IconURL : c . String ( "icon-url" ) ,
2021-09-10 22:07:57 +05:30
SkipLocalTwoFA : c . Bool ( "skip-local-2fa" ) ,
2021-12-14 14:07:11 +05:30
Scopes : c . StringSlice ( "scopes" ) ,
RequiredClaimName : c . String ( "required-claim-name" ) ,
RequiredClaimValue : c . String ( "required-claim-value" ) ,
GroupClaimName : c . String ( "group-claim-name" ) ,
AdminGroup : c . String ( "admin-group" ) ,
RestrictedGroup : c . String ( "restricted-group" ) ,
2023-02-08 12:14:42 +05:30
GroupTeamMap : c . String ( "group-team-map" ) ,
GroupTeamMapRemoval : c . Bool ( "group-team-map-removal" ) ,
2018-09-12 20:16:02 +05:30
}
}
func runAddOauth ( c * cli . Context ) error {
2021-11-07 08:41:27 +05:30
ctx , cancel := installSignals ( )
defer cancel ( )
if err := initDB ( ctx ) ; err != nil {
2018-09-12 20:16:02 +05:30
return err
}
2023-03-10 11:44:43 +05:30
config := parseOAuth2Config ( c )
if config . Provider == "openidConnect" {
discoveryURL , err := url . Parse ( config . OpenIDConnectAutoDiscoveryURL )
if err != nil || ( discoveryURL . Scheme != "http" && discoveryURL . Scheme != "https" ) {
return fmt . Errorf ( "invalid Auto Discovery URL: %s (this must be a valid URL starting with http:// or https://)" , config . OpenIDConnectAutoDiscoveryURL )
}
}
2022-08-25 08:01:57 +05:30
return auth_model . CreateSource ( & auth_model . Source {
Type : auth_model . OAuth2 ,
2021-07-24 15:46:34 +05:30
Name : c . String ( "name" ) ,
IsActive : true ,
2023-03-10 11:44:43 +05:30
Cfg : config ,
2018-10-18 10:21:07 +05:30
} )
2018-09-12 20:16:02 +05:30
}
func runUpdateOauth ( c * cli . Context ) error {
if ! c . IsSet ( "id" ) {
return fmt . Errorf ( "--id flag is missing" )
}
2021-11-07 08:41:27 +05:30
ctx , cancel := installSignals ( )
defer cancel ( )
if err := initDB ( ctx ) ; err != nil {
2018-09-12 20:16:02 +05:30
return err
}
2022-08-25 08:01:57 +05:30
source , err := auth_model . GetSourceByID ( c . Int64 ( "id" ) )
2018-09-12 20:16:02 +05:30
if err != nil {
return err
}
2021-07-24 15:46:34 +05:30
oAuth2Config := source . Cfg . ( * oauth2 . Source )
2018-09-12 20:16:02 +05:30
if c . IsSet ( "name" ) {
source . Name = c . String ( "name" )
}
if c . IsSet ( "provider" ) {
oAuth2Config . Provider = c . String ( "provider" )
}
if c . IsSet ( "key" ) {
oAuth2Config . ClientID = c . String ( "key" )
}
if c . IsSet ( "secret" ) {
oAuth2Config . ClientSecret = c . String ( "secret" )
}
if c . IsSet ( "auto-discover-url" ) {
oAuth2Config . OpenIDConnectAutoDiscoveryURL = c . String ( "auto-discover-url" )
}
2020-12-28 14:09:12 +05:30
if c . IsSet ( "icon-url" ) {
oAuth2Config . IconURL = c . String ( "icon-url" )
}
2021-12-14 14:07:11 +05:30
if c . IsSet ( "scopes" ) {
oAuth2Config . Scopes = c . StringSlice ( "scopes" )
}
if c . IsSet ( "required-claim-name" ) {
oAuth2Config . RequiredClaimName = c . String ( "required-claim-name" )
}
if c . IsSet ( "required-claim-value" ) {
oAuth2Config . RequiredClaimValue = c . String ( "required-claim-value" )
}
if c . IsSet ( "group-claim-name" ) {
oAuth2Config . GroupClaimName = c . String ( "group-claim-name" )
}
if c . IsSet ( "admin-group" ) {
oAuth2Config . AdminGroup = c . String ( "admin-group" )
}
if c . IsSet ( "restricted-group" ) {
oAuth2Config . RestrictedGroup = c . String ( "restricted-group" )
}
2023-02-08 12:14:42 +05:30
if c . IsSet ( "group-team-map" ) {
oAuth2Config . GroupTeamMap = c . String ( "group-team-map" )
}
if c . IsSet ( "group-team-map-removal" ) {
oAuth2Config . GroupTeamMapRemoval = c . Bool ( "group-team-map-removal" )
}
2021-12-14 14:07:11 +05:30
2018-09-12 20:16:02 +05:30
// update custom URL mapping
2022-01-20 23:16:10 +05:30
customURLMapping := & oauth2 . CustomURLMapping { }
2018-09-12 20:16:02 +05:30
if oAuth2Config . CustomURLMapping != nil {
customURLMapping . TokenURL = oAuth2Config . CustomURLMapping . TokenURL
customURLMapping . AuthURL = oAuth2Config . CustomURLMapping . AuthURL
customURLMapping . ProfileURL = oAuth2Config . CustomURLMapping . ProfileURL
customURLMapping . EmailURL = oAuth2Config . CustomURLMapping . EmailURL
2023-02-06 09:42:13 +05:30
customURLMapping . Tenant = oAuth2Config . CustomURLMapping . Tenant
2018-09-12 20:16:02 +05:30
}
if c . IsSet ( "use-custom-urls" ) && c . IsSet ( "custom-token-url" ) {
customURLMapping . TokenURL = c . String ( "custom-token-url" )
}
if c . IsSet ( "use-custom-urls" ) && c . IsSet ( "custom-auth-url" ) {
customURLMapping . AuthURL = c . String ( "custom-auth-url" )
}
if c . IsSet ( "use-custom-urls" ) && c . IsSet ( "custom-profile-url" ) {
customURLMapping . ProfileURL = c . String ( "custom-profile-url" )
}
if c . IsSet ( "use-custom-urls" ) && c . IsSet ( "custom-email-url" ) {
customURLMapping . EmailURL = c . String ( "custom-email-url" )
}
2023-02-06 09:42:13 +05:30
if c . IsSet ( "use-custom-urls" ) && c . IsSet ( "custom-tenant-id" ) {
customURLMapping . Tenant = c . String ( "custom-tenant-id" )
}
2018-09-12 20:16:02 +05:30
oAuth2Config . CustomURLMapping = customURLMapping
source . Cfg = oAuth2Config
2022-08-25 08:01:57 +05:30
return auth_model . UpdateSource ( source )
2018-09-12 20:16:02 +05:30
}
2022-01-13 04:24:53 +05:30
func parseSMTPConfig ( c * cli . Context , conf * smtp . Source ) error {
if c . IsSet ( "auth-type" ) {
conf . Auth = c . String ( "auth-type" )
validAuthTypes := [ ] string { "PLAIN" , "LOGIN" , "CRAM-MD5" }
Improve utils of slices (#22379)
- Move the file `compare.go` and `slice.go` to `slice.go`.
- Fix `ExistsInSlice`, it's buggy
- It uses `sort.Search`, so it assumes that the input slice is sorted.
- It passes `func(i int) bool { return slice[i] == target })` to
`sort.Search`, that's incorrect, check the doc of `sort.Search`.
- Conbine `IsInt64InSlice(int64, []int64)` and `ExistsInSlice(string,
[]string)` to `SliceContains[T]([]T, T)`.
- Conbine `IsSliceInt64Eq([]int64, []int64)` and `IsEqualSlice([]string,
[]string)` to `SliceSortedEqual[T]([]T, T)`.
- Add `SliceEqual[T]([]T, T)` as a distinction from
`SliceSortedEqual[T]([]T, T)`.
- Redesign `RemoveIDFromList([]int64, int64) ([]int64, bool)` to
`SliceRemoveAll[T]([]T, T) []T`.
- Add `SliceContainsFunc[T]([]T, func(T) bool)` and
`SliceRemoveAllFunc[T]([]T, func(T) bool)` for general use.
- Add comments to explain why not `golang.org/x/exp/slices`.
- Add unit tests.
2023-01-11 11:01:16 +05:30
if ! util . SliceContainsString ( validAuthTypes , strings . ToUpper ( c . String ( "auth-type" ) ) ) {
2022-01-13 04:24:53 +05:30
return errors . New ( "Auth must be one of PLAIN/LOGIN/CRAM-MD5" )
}
conf . Auth = c . String ( "auth-type" )
}
2022-11-11 02:42:23 +05:30
if c . IsSet ( "host" ) {
conf . Host = c . String ( "host" )
2022-01-13 04:24:53 +05:30
}
if c . IsSet ( "port" ) {
conf . Port = c . Int ( "port" )
}
if c . IsSet ( "allowed-domains" ) {
conf . AllowedDomains = c . String ( "allowed-domains" )
}
if c . IsSet ( "force-smtps" ) {
2023-07-21 14:58:19 +05:30
conf . ForceSMTPS = c . Bool ( "force-smtps" )
2022-01-13 04:24:53 +05:30
}
if c . IsSet ( "skip-verify" ) {
2023-07-21 14:58:19 +05:30
conf . SkipVerify = c . Bool ( "skip-verify" )
2022-01-13 04:24:53 +05:30
}
if c . IsSet ( "helo-hostname" ) {
conf . HeloHostname = c . String ( "helo-hostname" )
}
if c . IsSet ( "disable-helo" ) {
2023-07-21 14:58:19 +05:30
conf . DisableHelo = c . Bool ( "disable-helo" )
2022-01-13 04:24:53 +05:30
}
if c . IsSet ( "skip-local-2fa" ) {
2023-07-21 14:58:19 +05:30
conf . SkipLocalTwoFA = c . Bool ( "skip-local-2fa" )
2022-01-13 04:24:53 +05:30
}
return nil
}
func runAddSMTP ( c * cli . Context ) error {
ctx , cancel := installSignals ( )
defer cancel ( )
if err := initDB ( ctx ) ; err != nil {
return err
}
if ! c . IsSet ( "name" ) || len ( c . String ( "name" ) ) == 0 {
return errors . New ( "name must be set" )
}
if ! c . IsSet ( "host" ) || len ( c . String ( "host" ) ) == 0 {
return errors . New ( "host must be set" )
}
if ! c . IsSet ( "port" ) {
return errors . New ( "port must be set" )
}
2022-01-20 23:16:10 +05:30
active := true
2022-01-13 04:24:53 +05:30
if c . IsSet ( "active" ) {
2023-07-21 14:58:19 +05:30
active = c . Bool ( "active" )
2022-01-13 04:24:53 +05:30
}
var smtpConfig smtp . Source
if err := parseSMTPConfig ( c , & smtpConfig ) ; err != nil {
return err
}
// If not set default to PLAIN
if len ( smtpConfig . Auth ) == 0 {
smtpConfig . Auth = "PLAIN"
}
2022-08-25 08:01:57 +05:30
return auth_model . CreateSource ( & auth_model . Source {
Type : auth_model . SMTP ,
2022-01-13 04:24:53 +05:30
Name : c . String ( "name" ) ,
IsActive : active ,
Cfg : & smtpConfig ,
} )
}
func runUpdateSMTP ( c * cli . Context ) error {
if ! c . IsSet ( "id" ) {
return fmt . Errorf ( "--id flag is missing" )
}
ctx , cancel := installSignals ( )
defer cancel ( )
if err := initDB ( ctx ) ; err != nil {
return err
}
2022-08-25 08:01:57 +05:30
source , err := auth_model . GetSourceByID ( c . Int64 ( "id" ) )
2022-01-13 04:24:53 +05:30
if err != nil {
return err
}
smtpConfig := source . Cfg . ( * smtp . Source )
if err := parseSMTPConfig ( c , smtpConfig ) ; err != nil {
return err
}
if c . IsSet ( "name" ) {
source . Name = c . String ( "name" )
}
if c . IsSet ( "active" ) {
2023-07-21 14:58:19 +05:30
source . IsActive = c . Bool ( "active" )
2022-01-13 04:24:53 +05:30
}
source . Cfg = smtpConfig
2022-08-25 08:01:57 +05:30
return auth_model . UpdateSource ( source )
2022-01-13 04:24:53 +05:30
}
2018-09-12 20:16:02 +05:30
func runListAuth ( c * cli . Context ) error {
2021-11-07 08:41:27 +05:30
ctx , cancel := installSignals ( )
defer cancel ( )
if err := initDB ( ctx ) ; err != nil {
2018-09-12 20:16:02 +05:30
return err
}
2022-08-25 08:01:57 +05:30
authSources , err := auth_model . Sources ( )
2018-09-12 20:16:02 +05:30
if err != nil {
return err
}
2020-03-28 02:56:43 +05:30
flags := tabwriter . AlignRight
if c . Bool ( "vertical-bars" ) {
flags |= tabwriter . Debug
}
padChar := byte ( '\t' )
if len ( c . String ( "pad-char" ) ) > 0 {
padChar = c . String ( "pad-char" ) [ 0 ]
}
2018-09-12 20:16:02 +05:30
// loop through each source and print
2020-03-28 02:56:43 +05:30
w := tabwriter . NewWriter ( os . Stdout , c . Int ( "min-width" ) , c . Int ( "tab-width" ) , c . Int ( "padding" ) , padChar , flags )
2020-01-08 05:11:16 +05:30
fmt . Fprintf ( w , "ID\tName\tType\tEnabled\n" )
2022-01-02 18:42:35 +05:30
for _ , source := range authSources {
2021-09-24 17:02:56 +05:30
fmt . Fprintf ( w , "%d\t%s\t%s\t%t\n" , source . ID , source . Name , source . Type . String ( ) , source . IsActive )
2018-09-12 20:16:02 +05:30
}
w . Flush ( )
return nil
}
func runDeleteAuth ( c * cli . Context ) error {
if ! c . IsSet ( "id" ) {
return fmt . Errorf ( "--id flag is missing" )
}
2021-11-07 08:41:27 +05:30
ctx , cancel := installSignals ( )
defer cancel ( )
if err := initDB ( ctx ) ; err != nil {
2018-09-12 20:16:02 +05:30
return err
}
2022-08-25 08:01:57 +05:30
source , err := auth_model . GetSourceByID ( c . Int64 ( "id" ) )
2018-09-12 20:16:02 +05:30
if err != nil {
return err
}
2022-01-02 18:42:35 +05:30
return auth_service . DeleteSource ( source )
2018-09-12 20:16:02 +05:30
}