WIP started trying some things with scope discovery.
This commit is contained in:
parent
e6fa1d5314
commit
1e459ce186
|
@ -294,7 +294,11 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
, urls: {
|
, urls: {
|
||||||
discover: function (providerUri, opts) {
|
scope: function (directives, opts) {
|
||||||
|
var uri = directives.grants.url;
|
||||||
|
uri.replace("/:sub", );
|
||||||
|
}
|
||||||
|
, discover: function (providerUri, opts) {
|
||||||
if (!providerUri) {
|
if (!providerUri) {
|
||||||
throw new Error("cannot discover without providerUri");
|
throw new Error("cannot discover without providerUri");
|
||||||
}
|
}
|
||||||
|
@ -658,9 +662,43 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
, discoverGrants: function (providerUri, opts) {
|
||||||
|
if (!providerUri) {
|
||||||
|
throw new Error('oauth3.discoverGrants(providerUri, opts) received providerUri as :', providerUri);
|
||||||
|
}
|
||||||
|
|
||||||
|
var opts = opts || {};
|
||||||
|
var err;
|
||||||
|
if(!opts.sub && (!opts.token || !opts.token.sub)) {
|
||||||
|
err = new Error('We need a sub in order to discover grants for.');
|
||||||
|
err.code = 'E_NO_SUB';
|
||||||
|
throw err;
|
||||||
|
}
|
||||||
|
if(!
|
||||||
|
|
||||||
|
|
||||||
|
console.warn(!opts.scopes) {
|
||||||
|
var firstDo;
|
||||||
|
|
||||||
|
if (directives && directives.issuer) {
|
||||||
|
firstDo = OAUTH3.PromiseA.resolve(directives);
|
||||||
|
} else {
|
||||||
|
firstDo = this.discover(providerUri, opts);
|
||||||
|
}
|
||||||
|
|
||||||
|
return firstDo.then(function(directives) {
|
||||||
|
var grantPromises = [];
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
return OAUTH3._disoverHelper(providerUri, "grants", opts);
|
||||||
|
}).then(function() {
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
, discover: function (providerUri, opts) {
|
, discover: function (providerUri, opts) {
|
||||||
if (!providerUri) {
|
if (!providerUri) {
|
||||||
throw new Error('oauth3.discover(providerUri, opts) received providerUri as ' + providerUri);
|
throw new Error('oauth3.discover(providerUri, opts) received providerUri as :', providerUri);
|
||||||
}
|
}
|
||||||
|
|
||||||
return OAUTH3.hooks.directives.get(providerUri).then(function (directives) {
|
return OAUTH3.hooks.directives.get(providerUri).then(function (directives) {
|
||||||
|
@ -668,7 +706,7 @@
|
||||||
return directives;
|
return directives;
|
||||||
}
|
}
|
||||||
|
|
||||||
return OAUTH3._discoverHelper(providerUri, opts).then(function (directives) {
|
return OAUTH3._discoverHelper(providerUri, "directives", opts).then(function (directives) {
|
||||||
directives.azp = directives.azp || OAUTH3.url.normalize(providerUri);
|
directives.azp = directives.azp || OAUTH3.url.normalize(providerUri);
|
||||||
directives.issuer = directives.issuer || OAUTH3.url.normalize(providerUri);
|
directives.issuer = directives.issuer || OAUTH3.url.normalize(providerUri);
|
||||||
directives.api = OAUTH3.url.normalize((directives.api||':hostname').replace(/:hostname/, OAUTH3.uri.normalize(directives.issuer) || OAUTH3.uri.normalize(providerUri)));
|
directives.api = OAUTH3.url.normalize((directives.api||':hostname').replace(/:hostname/, OAUTH3.uri.normalize(directives.issuer) || OAUTH3.uri.normalize(providerUri)));
|
||||||
|
@ -677,8 +715,8 @@
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
, _discoverHelper: function(providerUri, opts) {
|
, _discoverHelper: function(providerUri, type, opts) {
|
||||||
return OAUTH3._browser.discover(providerUri, opts);
|
return OAUTH3._browser.discover(providerUri, type, opts);
|
||||||
}
|
}
|
||||||
, request: function (preq, opts) {
|
, request: function (preq, opts) {
|
||||||
function fetch() {
|
function fetch() {
|
||||||
|
@ -859,7 +897,7 @@
|
||||||
, _browser: {
|
, _browser: {
|
||||||
window: 'undefined' !== typeof window ? window : null
|
window: 'undefined' !== typeof window ? window : null
|
||||||
// TODO we don't need to include this if we're using jQuery or angular
|
// TODO we don't need to include this if we're using jQuery or angular
|
||||||
, discover: function(providerUri, opts) {
|
, discover: function(providerUri, type, opts) {
|
||||||
opts = opts || {};
|
opts = opts || {};
|
||||||
providerUri = OAUTH3.url.normalize(providerUri);
|
providerUri = OAUTH3.url.normalize(providerUri);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue