mirror of
https://github.com/status-im/consul.git
synced 2025-01-09 21:35:52 +00:00
ed6918c6c2
This commit tries to make the development experience of working on our OIDC support a little more realistic, essentially by creating our own OIDC provider in our application (only during development builds). You can still provide a real OIDC provider to work with via our dev time environment/cookie variables as before, just now we default to the behaviour in this commit. Overall this makes it much easier to verify our OIDC support in the UI, and also opens up avenues for us to be able to test more scenarios that we couldn't before (for example not only successful logins, but also erroneous, potentially with multiple error reasons).
40 lines
1.0 KiB
JavaScript
40 lines
1.0 KiB
JavaScript
import OAuth2CodeProvider from 'torii/providers/oauth2-code';
|
|
import { runInDebug } from '@ember/debug';
|
|
|
|
export default class OAuth2CodeWithURLProvider extends OAuth2CodeProvider {
|
|
|
|
name = 'oidc-with-url';
|
|
|
|
buildUrl() {
|
|
return this.baseUrl;
|
|
}
|
|
|
|
open(options) {
|
|
const name = this.get('name'),
|
|
url = this.buildUrl(),
|
|
responseParams = ['state', 'code'],
|
|
responseType = 'code';
|
|
return this.get('popup')
|
|
.open(url, responseParams, options)
|
|
.then(function(authData) {
|
|
// the same as the parent class but with an authorizationState added
|
|
const creds = {
|
|
authorizationState: authData.state,
|
|
authorizationCode: decodeURIComponent(authData[responseType]),
|
|
provider: name,
|
|
};
|
|
runInDebug(_ => console.log('Retrieved the following creds from the OAuth Provider', creds))
|
|
return creds;
|
|
});
|
|
}
|
|
|
|
close() {
|
|
const popup = this.get('popup.remote') || {};
|
|
if (typeof popup.close === 'function') {
|
|
return popup.close();
|
|
}
|
|
}
|
|
|
|
}
|
|
|