Ensure referrer link is shown while navigating
Fixes: #27622 Signed-off-by: Hynek Mlnarik <hmlnarik@redhat.com>
This commit is contained in:
parent
9038353629
commit
2f0a9ba547
4 changed files with 79 additions and 11 deletions
|
@ -34,6 +34,10 @@ export type Environment = {
|
||||||
locale: string;
|
locale: string;
|
||||||
/** Feature flags */
|
/** Feature flags */
|
||||||
features: Feature;
|
features: Feature;
|
||||||
|
/** Client id of the application to add back link */
|
||||||
|
referrer?: string;
|
||||||
|
/** URI to the referrer application in the back link */
|
||||||
|
referrer_uri?: string;
|
||||||
};
|
};
|
||||||
|
|
||||||
// Detect the current realm from the URL.
|
// Detect the current realm from the URL.
|
||||||
|
@ -78,18 +82,26 @@ export { environment };
|
||||||
function getInjectedEnvironment(): Record<string, string | number | boolean> {
|
function getInjectedEnvironment(): Record<string, string | number | boolean> {
|
||||||
const element = document.getElementById("environment");
|
const element = document.getElementById("environment");
|
||||||
|
|
||||||
// If the element cannot be found, return an empty record.
|
let env = {} as Record<string, string | number | boolean>;
|
||||||
if (!element?.textContent) {
|
|
||||||
return {};
|
|
||||||
}
|
|
||||||
|
|
||||||
// Attempt to parse the contents as JSON and return its value.
|
// Attempt to parse the contents as JSON and return its value.
|
||||||
try {
|
try {
|
||||||
return JSON.parse(element.textContent);
|
// If the element cannot be found, return an empty record.
|
||||||
|
if (element?.textContent) {
|
||||||
|
env = JSON.parse(element.textContent);
|
||||||
|
}
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
console.error("Unable to parse environment variables.");
|
console.error("Unable to parse environment variables.");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const searchParams = new URLSearchParams(location.search);
|
||||||
|
if (searchParams.has("referrer_uri")) {
|
||||||
|
env["referrer_uri"] = searchParams.get("referrer_uri")!;
|
||||||
|
}
|
||||||
|
if (searchParams.has("referrer")) {
|
||||||
|
env["referrer"] = searchParams.get("referrer")!;
|
||||||
|
}
|
||||||
|
|
||||||
// Otherwise, return an empty record.
|
// Otherwise, return an empty record.
|
||||||
return {};
|
return env;
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,22 +13,22 @@ import { ExternalLinkSquareAltIcon } from "@patternfly/react-icons";
|
||||||
import { Button } from "@patternfly/react-core";
|
import { Button } from "@patternfly/react-core";
|
||||||
|
|
||||||
import style from "./header.module.css";
|
import style from "./header.module.css";
|
||||||
|
import { environment } from "../environment";
|
||||||
|
|
||||||
const ReferrerLink = () => {
|
const ReferrerLink = () => {
|
||||||
const { t } = useTranslation();
|
const { t } = useTranslation();
|
||||||
const searchParams = new URLSearchParams(location.search);
|
|
||||||
|
|
||||||
return searchParams.has("referrer_uri") ? (
|
return environment.referrer_uri ? (
|
||||||
<Button
|
<Button
|
||||||
data-testid="referrer-link"
|
data-testid="referrer-link"
|
||||||
component="a"
|
component="a"
|
||||||
href={searchParams.get("referrer_uri")!.replace("_hash_", "#")}
|
href={environment.referrer_uri!.replace("_hash_", "#")}
|
||||||
variant="link"
|
variant="link"
|
||||||
icon={<ExternalLinkSquareAltIcon />}
|
icon={<ExternalLinkSquareAltIcon />}
|
||||||
iconPosition="right"
|
iconPosition="right"
|
||||||
isInline
|
isInline
|
||||||
>
|
>
|
||||||
{t("backTo", { app: searchParams.get("referrer") })}
|
{t("backTo", { app: environment.referrer })}
|
||||||
</Button>
|
</Button>
|
||||||
) : null;
|
) : null;
|
||||||
};
|
};
|
||||||
|
|
|
@ -7,8 +7,11 @@ export const login = async (
|
||||||
username: string,
|
username: string,
|
||||||
password: string,
|
password: string,
|
||||||
realm = DEFAULT_REALM,
|
realm = DEFAULT_REALM,
|
||||||
|
queryParams?: Record<string, string>,
|
||||||
) => {
|
) => {
|
||||||
const rootPath = getRootPath(realm);
|
const rootPath =
|
||||||
|
getRootPath(realm) +
|
||||||
|
(queryParams ? "?" + new URLSearchParams(queryParams) : "");
|
||||||
|
|
||||||
await page.goto(rootPath);
|
await page.goto(rootPath);
|
||||||
await page.getByLabel("Username").fill(username);
|
await page.getByLabel("Username").fill(username);
|
||||||
|
|
53
js/apps/account-ui/test/referrer.spec.ts
Normal file
53
js/apps/account-ui/test/referrer.spec.ts
Normal file
|
@ -0,0 +1,53 @@
|
||||||
|
import { expect, test } from "@playwright/test";
|
||||||
|
import { login } from "./login";
|
||||||
|
|
||||||
|
test.describe("Signing in with referrer link", () => {
|
||||||
|
// Tests for keycloak account console, section Signing in in Account security
|
||||||
|
test("Should see referrer", async ({ page }) => {
|
||||||
|
const queryParams = {
|
||||||
|
referrer: "my-app",
|
||||||
|
referrer_uri: "http://localhost:3000",
|
||||||
|
};
|
||||||
|
await login(page, "jdoe", "jdoe", "groups", queryParams);
|
||||||
|
|
||||||
|
await expect(page.getByTestId("referrer-link")).toContainText("my-app");
|
||||||
|
await page.getByTestId("accountSecurity").click();
|
||||||
|
await expect(page.getByTestId("account-security/signing-in")).toBeVisible();
|
||||||
|
await expect(page.getByTestId("referrer-link")).toContainText("my-app");
|
||||||
|
});
|
||||||
|
|
||||||
|
// Tests for keycloak account console, section Signing in in Account security
|
||||||
|
test("Should see no referrer", async ({ page }) => {
|
||||||
|
const queryParams = {};
|
||||||
|
await login(page, "jdoe", "jdoe", "groups", queryParams);
|
||||||
|
|
||||||
|
await expect(page.getByTestId("referrer-link")).toBeHidden();
|
||||||
|
await page.getByTestId("accountSecurity").click();
|
||||||
|
await expect(page.getByTestId("account-security/signing-in")).toBeVisible();
|
||||||
|
await expect(page.getByTestId("referrer-link")).toBeHidden();
|
||||||
|
});
|
||||||
|
|
||||||
|
test("Should see no referrer after relogin", async ({ page }) => {
|
||||||
|
const queryParams = {
|
||||||
|
referrer: "my-app",
|
||||||
|
referrer_uri: "http://localhost:3000",
|
||||||
|
};
|
||||||
|
await login(page, "jdoe", "jdoe", "groups", queryParams);
|
||||||
|
|
||||||
|
await expect(page.getByTestId("referrer-link")).toContainText("my-app");
|
||||||
|
await page.getByTestId("accountSecurity").click();
|
||||||
|
await expect(page.getByTestId("account-security/signing-in")).toBeVisible();
|
||||||
|
await expect(page.getByTestId("referrer-link")).toContainText("my-app");
|
||||||
|
|
||||||
|
await page.getByTestId("options").click();
|
||||||
|
await page.getByRole("menuitem", { name: "Sign out" }).click();
|
||||||
|
|
||||||
|
const queryParamsNoReferrer = {};
|
||||||
|
await login(page, "jdoe", "jdoe", "groups", queryParamsNoReferrer);
|
||||||
|
|
||||||
|
await expect(page.getByTestId("referrer-link")).toBeHidden();
|
||||||
|
await page.getByTestId("accountSecurity").click();
|
||||||
|
await expect(page.getByTestId("account-security/signing-in")).toBeVisible();
|
||||||
|
await expect(page.getByTestId("referrer-link")).toBeHidden();
|
||||||
|
});
|
||||||
|
});
|
Loading…
Reference in a new issue