From 059127224cafb946b02d5fb2ce85bb528b956486 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Nils=20Gustav=20Str=C3=A5b=C3=B8?= Date: Fri, 12 Apr 2024 12:41:21 +0200 Subject: [PATCH] replace device code login with interactive login --- pkg/client/auth/client.go | 5 +---- pkg/client/auth/msal_provider.go | 27 ++++++++++++--------------- 2 files changed, 13 insertions(+), 19 deletions(-) diff --git a/pkg/client/auth/client.go b/pkg/client/auth/client.go index 7b8ffe2..d9c2327 100644 --- a/pkg/client/auth/client.go +++ b/pkg/client/auth/client.go @@ -1,17 +1,14 @@ package auth import ( - "fmt" - "github.com/AzureAD/microsoft-authentication-library-for-go/apps/public" radixconfig "github.com/equinor/radix-cli/pkg/config" ) // newPublicClient creates a new authentication client -func newPublicClient(radixConfig *radixconfig.RadixConfig, clientID, tenantID string) (*public.Client, error) { +func newPublicClient(radixConfig *radixconfig.RadixConfig, clientID, authority string) (*public.Client, error) { cacheAccessor := NewTokenCache(radixConfig) cache := public.WithCache(cacheAccessor) - authority := fmt.Sprintf("https://login.microsoftonline.com/%s", tenantID) client, err := public.New(clientID, cache, public.WithAuthority(authority)) if err != nil { return nil, err diff --git a/pkg/client/auth/msal_provider.go b/pkg/client/auth/msal_provider.go index 6c65294..436a904 100644 --- a/pkg/client/auth/msal_provider.go +++ b/pkg/client/auth/msal_provider.go @@ -20,17 +20,20 @@ type MSALAuthProvider interface { // NewMSALAuthProvider creates a new MSALAuthProvider func NewMSALAuthProvider(radixConfig *radixconfig.RadixConfig, clientID, tenantID string) (MSALAuthProvider, error) { - client, err := newPublicClient(radixConfig, clientID, tenantID) + authority := fmt.Sprintf("https://login.microsoftonline.com/%s", tenantID) + client, err := newPublicClient(radixConfig, clientID, authority) if err != nil { return nil, err } return &msalAuthProvider{ - client: client, + client: client, + authority: authority, }, nil } type msalAuthProvider struct { - client *public.Client + authority string + client *public.Client } func (provider *msalAuthProvider) AuthenticateRequest(r runtime.ClientRequest, _ strfmt.Registry) error { @@ -44,7 +47,7 @@ func (provider *msalAuthProvider) AuthenticateRequest(r runtime.ClientRequest, _ // Login allows the plugin to initialize its configuration. It must not // require direct user interaction. func (provider *msalAuthProvider) Login(ctx context.Context) error { - _, err := provider.loginWithDeviceCode(ctx) + _, err := provider.loginInteractive(ctx) return err } @@ -80,20 +83,14 @@ func (provider *msalAuthProvider) GetToken(ctx context.Context) (string, error) // either there was no cached account/token or the call to AcquireTokenSilent() failed // make a new request to AAD - return provider.loginWithDeviceCode(ctx) + return provider.loginInteractive(ctx) } -func (provider *msalAuthProvider) loginWithDeviceCode(ctx context.Context) (string, error) { - ctx, cancel := context.WithTimeout(ctx, 100*time.Second) +func (provider *msalAuthProvider) loginInteractive(ctx context.Context) (string, error) { + ctx, cancel := context.WithTimeout(ctx, 10*time.Second) defer cancel() - devCode, err := provider.client.AcquireTokenByDeviceCode(ctx, getScopes()) - if err != nil { - return "", fmt.Errorf("got error while waiting for user to input the device code: %s", err) - } - - fmt.Println(devCode.Result.Message) // show authentication link with device code - - result, err := devCode.AuthenticationResult(ctx) + fmt.Printf("A web browser has been opened at %s/oauth2/v2.0/authorize. Please continue the login in the web browser.\n", provider.authority) + result, err := provider.client.AcquireTokenInteractive(ctx, getScopes()) if err != nil { return "", err }