From 081a8b131c3a4292d6be5fbc9e828c22cc77f764 Mon Sep 17 00:00:00 2001 From: Distopico Date: Wed, 15 Apr 2020 22:59:16 -0500 Subject: [PATCH] Destroy host credentials if are invalid If a user reinstall your instance but keeping the same domain/host and when try to login with a remote instance previously logined will get a error and will be impossible to use again the same domain/instance. --- lib/model/host.js | 19 +++++++++++++++++++ routes/web.js | 12 +++++++++--- 2 files changed, 28 insertions(+), 3 deletions(-) diff --git a/lib/model/host.js b/lib/model/host.js index bd9474030..fc0a1ec90 100644 --- a/lib/model/host.js +++ b/lib/model/host.js @@ -124,6 +124,25 @@ Host.ensureHost = function(hostname, callback) { ); }; +Host.prototype.destroyHost = function(callback) { + + var host = this; + + Step( + function() { + Credentials.getForHost(URLMaker.hostname, host, this); + }, + function(err, cred) { + if (err) throw err; + cred.del(this); + }, + function(err) { + host.del(this); + }, + callback + ); +}; + Host.discover = function(hostname, callback) { var props = { diff --git a/routes/web.js b/routes/web.js index 045fd3320..1a67b7cce 100644 --- a/routes/web.js +++ b/routes/web.js @@ -250,10 +250,16 @@ var handleRemote = function(req, res, next) { host.getRequestToken(this); }, function(err, rt) { - if (err) { - next(err); - } else { + if (!err) { res.redirect(host.authorizeURL(rt)); + } else if (err.statusCode) { + if (host && err.statusCode === 400) { + req.log.warn("Invalid or old host credentials", err); + host.destroyHost(req.log.error); + } + next(new HTTPError(err.data, err.statusCode)); + } else { + next(err); } } );