Skip to content

Commit

Permalink
feat: better URL concat
Browse files Browse the repository at this point in the history
Remove instructions to not end URLs with "/"

Signed-off-by: Eric Dobbertin <[email protected]>
  • Loading branch information
aldeed committed Feb 28, 2020
1 parent c683f43 commit 653a7ad
Show file tree
Hide file tree
Showing 5 changed files with 25 additions and 14 deletions.
8 changes: 4 additions & 4 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -32,10 +32,10 @@ Calls Hydra's endpoints to request an access token that can be used to request d
Options:
-r,--raw Return the raw access token string, for piping or programmatic use
-p,--public-url <url> A Hydra public OAuth URL that can be accessed from this computer. Must NOT end with a `/`.
Default is http://localhost:4444
-a,--admin-url <url> A Hydra private admin URL that can be accessed from this computer. Must NOT end with a `/`.
Default is http://localhost:4445
-p,--public-url <url> A Hydra public OAuth URL that can be accessed from this computer. Default is
http://localhost:4444
-a,--admin-url <url> A Hydra private admin URL that can be accessed from this computer. Default is
http://localhost:4445
-h, --help output usage information
```

Expand Down
4 changes: 2 additions & 2 deletions src/cli.js
Original file line number Diff line number Diff line change
Expand Up @@ -18,8 +18,8 @@ program
.command("get <userId>")
.description("Calls Hydra's endpoints to request an access token that can be used to request data from the GraphQL API authenticated as this user.")
.option("-r,--raw", "Return the raw access token string, for piping or programmatic use")
.option("-p,--public-url <url>", "A Hydra public OAuth URL that can be accessed from this computer. Must NOT end with a `/`. Default is http://localhost:4444")
.option("-a,--admin-url <url>", "A Hydra private admin URL that can be accessed from this computer. Must NOT end with a `/`. Default is http://localhost:4445")
.option("-p,--public-url <url>", "A Hydra public OAuth URL that can be accessed from this computer. Default is http://localhost:4444")
.option("-a,--admin-url <url>", "A Hydra private admin URL that can be accessed from this computer. Default is http://localhost:4445")
.action((userId, options) => {
getAccessToken(userId, {
hydraAdminUrl: options.adminUrl,
Expand Down
7 changes: 1 addition & 6 deletions src/ensureHydraClient.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
/* eslint-disable no-console */

const { URL } = require("url");
const fetch = require("node-fetch");
const makeAbsolute = require("./makeAbsolute");

const OAUTH2_CLIENT_ID = "get-token-dev-script";
const OAUTH2_CLIENT_SECRET = "get-token-dev-script-secret";
Expand All @@ -20,11 +20,6 @@ const hydraClient = {
};
/* eslint-enable camelcase */

const makeAbsolute = (relativeUrl, baseUrl) => {
const url = new URL(relativeUrl, baseUrl);
return url.href;
};

/**
* @summary Calls Hydra's endpoint to create an OAuth client for this application
* if one does not already exist. This works because the Hydra admin port
Expand Down
5 changes: 3 additions & 2 deletions src/getAccessToken.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ const { URL } = require("url");
const fetch = require("node-fetch");
const simpleOAuth2 = require("simple-oauth2");
const ensureHydraClient = require("./ensureHydraClient");
const makeAbsolute = require("./makeAbsolute");

const HYDRA_OAUTH_URL = "http://localhost:4444";
const HYDRA_ADMIN_URL = "http://localhost:4445";
Expand Down Expand Up @@ -62,7 +63,7 @@ async function getAccessToken(userId, options) {
const challenge = redirect1Parsed.searchParams.get("login_challenge");
const cookie = startLoginResult.headers.get("set-cookie");

const acceptLoginResult = await fetch(`${hydraAdminUrl}/oauth2/auth/requests/login/accept?login_challenge=${challenge}`, {
const acceptLoginResult = await fetch(`${makeAbsolute("/oauth2/auth/requests/login/accept", hydraAdminUrl)}?login_challenge=${challenge}`, {
method: "PUT",
body: JSON.stringify({
subject: userId,
Expand Down Expand Up @@ -91,7 +92,7 @@ async function getAccessToken(userId, options) {
const consentChallenge = redirect3Parsed.searchParams.get("consent_challenge");
const nextCookies = continueLoginResult.headers.raw()["set-cookie"];

const consentResult = await fetch(`${hydraAdminUrl}/oauth2/auth/requests/consent/accept?consent_challenge=${consentChallenge}`, {
const consentResult = await fetch(`${makeAbsolute("/oauth2/auth/requests/consent/accept", hydraAdminUrl)}?consent_challenge=${consentChallenge}`, {
method: "PUT",
body: JSON.stringify({
grant_scope: ["openid"], // eslint-disable-line camelcase
Expand Down
15 changes: 15 additions & 0 deletions src/makeAbsolute.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
const { URL } = require("url");

/**
* @summary Combine a relative URL with a base URL in a way that
* will gracefully handle extra slashes and such
* @param {String} relativeUrl Relative URL path
* @param {String} baseUrl Base URL path
* @return {String} full URL
*/
function makeAbsolute(relativeUrl, baseUrl) {
const url = new URL(relativeUrl, baseUrl);
return url.href;
}

module.exports = makeAbsolute;

0 comments on commit 653a7ad

Please sign in to comment.