From d02d2f1522a30a5281822501e5a75db2e647201f Mon Sep 17 00:00:00 2001 From: "Michael Bradley, Jr" Date: Fri, 19 Oct 2018 18:40:56 -0500 Subject: [PATCH] make token stripping logic reusable --- embark-ui/src/containers/AppContainer.js | 16 ++++++++++------ 1 file changed, 10 insertions(+), 6 deletions(-) diff --git a/embark-ui/src/containers/AppContainer.js b/embark-ui/src/containers/AppContainer.js index f1119c21..cfb7793d 100644 --- a/embark-ui/src/containers/AppContainer.js +++ b/embark-ui/src/containers/AppContainer.js @@ -27,6 +27,15 @@ class AppContainer extends Component { return qs.parse(this.props.location.search, {ignoreQueryPrefix: true}).token; } + stripQueryToken(location) { + const _location = Object.assign({}, location); + _location.search = _location.search.replace( + /(\?|&?)(token=[\w-]*)(&?)/, + (_, p1, p2, p3) => (p2 ? (p3 === '&' ? p1 : '') : '') + ); + return _location; + } + queryStringAuthenticate() { if (this.props.credentials.authenticating) { return; @@ -62,12 +71,7 @@ class AppContainer extends Component { } if (this.getQueryToken() && this.props.credentials.authenticated) { - const loc = Object.assign({}, this.props.location); - loc.search = loc.search.replace( - /(\?|&?)(token=[\w-]*)(&?)/, - (_, p1, p2, p3) => (p2 ? (p3 === '&' ? p1 : '') : '') - ); - this.props.history.replace(loc); + this.props.history.replace(this.stripQueryToken(this.props.location)); } if (this.props.credentials.authenticated && !this.props.initialized) {