2016-06-05 01:52:18 -07:00
|
|
|
const NETLIFY_API = 'https://api.netlify.com';
|
|
|
|
|
|
|
|
class NetlifyError {
|
|
|
|
constructor(err) {
|
|
|
|
this.err = err;
|
|
|
|
}
|
|
|
|
toString() {
|
|
|
|
return this.err && this.err.message;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
const PROVIDERS = {
|
|
|
|
github: {
|
|
|
|
width: 960,
|
|
|
|
height: 600
|
|
|
|
},
|
|
|
|
gitlab: {
|
|
|
|
width: 960,
|
|
|
|
height: 600
|
|
|
|
},
|
|
|
|
bitbucket: {
|
|
|
|
width: 960,
|
|
|
|
height: 500
|
|
|
|
},
|
|
|
|
email: {
|
|
|
|
width: 500,
|
|
|
|
height: 400
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
class Authenticator {
|
2016-07-20 13:46:52 -03:00
|
|
|
constructor(config = {}) {
|
|
|
|
this.site_id = config.site_id || null;
|
2016-06-05 01:52:18 -07:00
|
|
|
this.base_url = config.base_url || NETLIFY_API;
|
|
|
|
}
|
|
|
|
|
|
|
|
handshakeCallback(options, cb) {
|
|
|
|
const fn = (e) => {
|
|
|
|
if (e.data === ('authorizing:' + options.provider) && e.origin === this.base_url) {
|
|
|
|
window.removeEventListener('message', fn, false);
|
|
|
|
window.addEventListener('message', this.authorizeCallback(options, cb), false);
|
|
|
|
return this.authWindow.postMessage(e.data, e.origin);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
return fn;
|
|
|
|
}
|
|
|
|
|
|
|
|
authorizeCallback(options, cb) {
|
|
|
|
const fn = (e) => {
|
|
|
|
var data, err;
|
|
|
|
if (e.origin !== this.base_url) { return; }
|
|
|
|
if (e.data.indexOf('authorization:' + options.provider + ':success:') === 0) {
|
|
|
|
data = JSON.parse(e.data.match(new RegExp('^authorization:' + options.provider + ':success:(.+)$'))[1]);
|
|
|
|
window.removeEventListener('message', fn, false);
|
|
|
|
this.authWindow.close();
|
|
|
|
cb(null, data);
|
|
|
|
}
|
|
|
|
if (e.data.indexOf('authorization:' + options.provider + ':error:') === 0) {
|
|
|
|
console.log('Got authorization error');
|
|
|
|
err = JSON.parse(e.data.match(new RegExp('^authorization:' + options.provider + ':error:(.+)$'))[1]);
|
|
|
|
window.removeEventListener('message', fn, false);
|
|
|
|
this.authWindow.close();
|
|
|
|
cb(new NetlifyError(err));
|
|
|
|
}
|
|
|
|
};
|
|
|
|
return fn;
|
|
|
|
}
|
|
|
|
|
|
|
|
getSiteID() {
|
|
|
|
if (this.site_id) {
|
|
|
|
return this.site_id;
|
|
|
|
}
|
|
|
|
const host = document.location.host.split(':')[0];
|
|
|
|
return host === 'localhost' ? null : host;
|
|
|
|
}
|
|
|
|
|
|
|
|
authenticate(options, cb) {
|
|
|
|
var left, top, url,
|
|
|
|
siteID = this.getSiteID(),
|
|
|
|
provider = options.provider;
|
|
|
|
if (!provider) {
|
|
|
|
return cb(new NetlifyError({
|
|
|
|
message: 'You must specify a provider when calling netlify.authenticate'
|
|
|
|
}));
|
|
|
|
}
|
|
|
|
if (!siteID) {
|
|
|
|
return cb(new NetlifyError({
|
|
|
|
message: 'You must set a site_id with netlify.configure({site_id: \'your-site-id\'}) to make authentication work from localhost'
|
|
|
|
}));
|
|
|
|
}
|
|
|
|
|
|
|
|
const conf = PROVIDERS[provider] || PROVIDERS.github;
|
|
|
|
left = (screen.width / 2) - (conf.width / 2);
|
|
|
|
top = (screen.height / 2) - (conf.height / 2);
|
|
|
|
window.addEventListener('message', this.handshakeCallback(options, cb), false);
|
|
|
|
url = this.base_url + '/auth?provider=' + options.provider + '&site_id=' + siteID;
|
|
|
|
if (options.scope) {
|
|
|
|
url += '&scope=' + options.scope;
|
|
|
|
}
|
|
|
|
if (options.login === true) {
|
|
|
|
url += '&login=true';
|
|
|
|
}
|
|
|
|
if (options.beta_invite) {
|
|
|
|
url += '&beta_invite=' + options.beta_invite;
|
|
|
|
}
|
|
|
|
if (options.invite_code) {
|
|
|
|
url += '&invite_code=' + options.invite_code;
|
|
|
|
}
|
|
|
|
this.authWindow = window.open(
|
|
|
|
url,
|
|
|
|
'Netlify Authorization',
|
|
|
|
'toolbar=no, location=no, directories=no, status=no, menubar=no, scrollbars=no, resizable=no, copyhistory=no, ' +
|
|
|
|
('width=' + conf.width + ', height=' + conf.height + ', top=' + top + ', left=' + left + ');')
|
|
|
|
);
|
|
|
|
this.authWindow.focus();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default Authenticator;
|