diff --git a/packages/classic-test-app/app/components/login-form.js b/packages/classic-test-app/app/components/login-form.js index c1ebbcd14..cb8d5abe3 100644 --- a/packages/classic-test-app/app/components/login-form.js +++ b/packages/classic-test-app/app/components/login-form.js @@ -1,53 +1,54 @@ import { inject as service } from '@ember/service'; import Component from '@ember/component'; import config from '../config/environment'; +import { action } from '@ember/object'; export default Component.extend({ session: service('session'), - actions: { - async authenticateWithOAuth2() { - try { - let { identification, password } = this; - await this.get('session').authenticate('authenticator:oauth2', identification, password); - - if (this.rememberMe) { - this.get('session').set('store.cookieExpirationTime', 60 * 60 * 24 * 14); - } - } catch (response) { - let responseBody = await response.clone().json(); - this.set('errorMessage', responseBody); + authenticateWithOAuth2: action(async function (e) { + e.preventDefault(); + try { + let { identification, password } = this; + await this.get('session').authenticate('authenticator:oauth2', identification, password); + + if (this.rememberMe) { + this.get('session').set('store.cookieExpirationTime', 60 * 60 * 24 * 14); } - }, - - authenticateWithFacebook() { - this.get('session').authenticate('authenticator:torii', 'facebook'); - }, - - authenticateWithGoogleImplicitGrant() { - let clientId = config.googleClientID; - let redirectURI = `${window.location.origin}/callback`; - let responseType = `token`; - let scope = `email`; - window.location.replace( - `https://accounts.google.com/o/oauth2/v2/auth?` + - `client_id=${clientId}` + - `&redirect_uri=${redirectURI}` + - `&response_type=${responseType}` + - `&scope=${scope}` - ); - }, - - updateIdentification(e) { - this.set('identification', e.target.value); - }, - - updatePassword(e) { - this.set('password', e.target.value); - }, - - updateRememberMe(e) { - this.set('rememberMe', e.target.checked); - }, - }, + } catch (response) { + this.set('errorMessage', response.toString()); + } + }), + + authenticateWithFacebook: action(function (e) { + e.preventDefault(); + this.get('session').authenticate('authenticator:torii', 'facebook'); + }), + + authenticateWithGoogleImplicitGrant: action(function (e) { + e.preventDefault(); + let clientId = config.googleClientID; + let redirectURI = `${window.location.origin}/callback`; + let responseType = `token`; + let scope = `email`; + window.location.replace( + `https://accounts.google.com/o/oauth2/v2/auth?` + + `client_id=${clientId}` + + `&redirect_uri=${redirectURI}` + + `&response_type=${responseType}` + + `&scope=${scope}` + ); + }), + + updateIdentification: action(function (e) { + this.set('identification', e.target.value); + }), + + updatePassword: action(function (e) { + this.set('password', e.target.value); + }), + + updateRememberMe: action(function (e) { + this.set('rememberMe', e.target.checked); + }), }); diff --git a/packages/classic-test-app/app/components/main-navigation.js b/packages/classic-test-app/app/components/main-navigation.js index e4c29afaa..fb6a07c5c 100644 --- a/packages/classic-test-app/app/components/main-navigation.js +++ b/packages/classic-test-app/app/components/main-navigation.js @@ -1,13 +1,12 @@ import { inject as service } from '@ember/service'; import Component from '@ember/component'; +import { action } from '@ember/object'; export default Component.extend({ session: service('session'), sessionAccount: service('session-account'), - actions: { - logout() { - this.get('session').invalidate(); - }, - }, + logout: action(function () { + this.get('session').invalidate(); + }), }); diff --git a/packages/classic-test-app/app/templates/components/login-form.hbs b/packages/classic-test-app/app/templates/components/login-form.hbs index 7d58eb50d..2df5adca5 100644 --- a/packages/classic-test-app/app/templates/components/login-form.hbs +++ b/packages/classic-test-app/app/templates/components/login-form.hbs @@ -1,7 +1,7 @@ {{! login form; the fields must be named "identification" and "password"; the controller action is "authenticate" }} Login with Facebook
-Login with Google (Implicit Grant) +Login with Google (Implicit Grant)

or login with OAuth 2.0 Resource Owner Password Credentials:

diff --git a/packages/classic-test-app/lib/my-engine/addon/controllers/index.js b/packages/classic-test-app/lib/my-engine/addon/controllers/index.js index 935eddc48..02ccd8249 100644 --- a/packages/classic-test-app/lib/my-engine/addon/controllers/index.js +++ b/packages/classic-test-app/lib/my-engine/addon/controllers/index.js @@ -1,12 +1,11 @@ import Controller from '@ember/controller'; import { inject as service } from '@ember/service'; +import { action } from '@ember/object'; export default Controller.extend({ session: service(), - actions: { - logout() { - this.get('session').invalidate(); - }, - }, + logout: action(function () { + this.get('session').invalidate(); + }), });