From 4c37beebb16a2415fe14e7ef7585a3c7bfcf55ea Mon Sep 17 00:00:00 2001 From: Denys Konovalov Date: Tue, 14 Mar 2023 13:20:48 +0100 Subject: [PATCH] fix(auth): swap popup for new tab (#648) --- packages/core/src/lib/auth/netlify-auth.ts | 40 +++------------------- 1 file changed, 5 insertions(+), 35 deletions(-) diff --git a/packages/core/src/lib/auth/netlify-auth.ts b/packages/core/src/lib/auth/netlify-auth.ts index 680b5011..7ae5d6b2 100644 --- a/packages/core/src/lib/auth/netlify-auth.ts +++ b/packages/core/src/lib/auth/netlify-auth.ts @@ -18,29 +18,6 @@ export class NetlifyError { } } -const PROVIDERS = { - github: { - width: 960, - height: 600, - }, - gitlab: { - width: 960, - height: 600, - }, - gitea: { - width: 960, - height: 600, - }, - bitbucket: { - width: 960, - height: 500, - }, - email: { - width: 500, - height: 400, - }, -} as const; - class Authenticator { private site_id: string | null; private base_url: string; @@ -55,7 +32,7 @@ class Authenticator { } handshakeCallback( - options: { provider?: keyof typeof PROVIDERS }, + options: { provider?: string | undefined }, cb: (error: Error | NetlifyError | null, data?: User) => void, ) { const fn = (e: { data: string; origin: string }) => { @@ -69,7 +46,7 @@ class Authenticator { } authorizeCallback( - options: { provider?: keyof typeof PROVIDERS }, + options: { provider?: string | undefined }, cb: (error: Error | NetlifyError | null, data?: User) => void, ) { const fn = (e: { data: string; origin: string }) => { @@ -109,7 +86,7 @@ class Authenticator { authenticate( options: { - provider?: keyof typeof PROVIDERS; + provider?: string | undefined; scope?: string; login?: boolean; beta_invite?: string; @@ -137,9 +114,6 @@ class Authenticator { ); } - const conf = PROVIDERS[provider] || PROVIDERS.github; - const left = screen.width / 2 - conf.width / 2; - const top = screen.height / 2 - conf.height / 2; window.addEventListener('message', this.handshakeCallback(options, cb), false); let url = `${this.base_url}/${this.auth_endpoint}?provider=${options.provider}&site_id=${siteID}`; if (options.scope) { @@ -154,17 +128,13 @@ class Authenticator { if (options.invite_code) { url += '&invite_code=' + options.invite_code; } - this.authWindow = window.open( - url, - 'Netlify Authorization', - `width=${conf.width}, height=${conf.height}, top=${top}, left=${left}`, - ); + this.authWindow = window.open(url, 'Netlify Authorization'); this.authWindow?.focus(); } refresh( options: { - provider: keyof typeof PROVIDERS; + provider: string; refresh_token?: string; }, cb?: (error: Error | NetlifyError | null, data?: User) => void,