Skip to content

Commit

Permalink
made web-js URI replacement work without a fixed URI object and also …
Browse files Browse the repository at this point in the history
…mocked the values for the test enviornment
  • Loading branch information
niftyvictor committed Oct 8, 2024
1 parent 1d66e2a commit aab570b
Show file tree
Hide file tree
Showing 2 changed files with 45 additions and 60 deletions.
15 changes: 1 addition & 14 deletions v2/src/components/api/webJs.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,20 +5,7 @@ const URL = API_URL + "/frontend/web-js";
const VERSION = 0;

export default async function getURI(): Promise<{
uri: {
dateprovider: string;
emailpassword: string;
emailverification: string;
multifactorauth: string;
multitenancy: string;
passwordless: string;
session: string;
supertokens: string;
thirdparty: string;
totp: string;
userroles: string;
website: string;
};
uri: Record<string, string>;
}> {
let options: httpNetworking.GETRequestConfig = {
timeout: 50000,
Expand Down
90 changes: 44 additions & 46 deletions v2/src/components/webJsInjector/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,24 +3,26 @@ import { recursiveMap } from "../utils";
import getURI from "../api/webJs";
import { MOCK_ENABLED } from "../constants";

type Uri = {
dateprovider: string;
emailpassword: string;
emailverification: string;
multifactorauth: string;
multitenancy: string;
passwordless: string;
session: string;
supertokens: string;
thirdparty: string;
totp: string;
userroles: string;
website: string;
};
type Uri = Record<string, string>;

type State = {
uri: Uri | undefined;
};

function matchAll(pattern: RegExp, haystack: string) {
const regex = new RegExp(pattern, "g");
const matches: any[] = [];

const match_result = haystack.match(regex);

for (const index in match_result) {
const item = match_result[index as unknown as number];
matches[index as unknown as number] = item.match(new RegExp(pattern));
}

return matches;
}

export default class WebJsInjector extends React.PureComponent<
PropsWithChildren<{}>,
State
Expand All @@ -40,14 +42,22 @@ export default class WebJsInjector extends React.PureComponent<
return value.replace(/\^\{jsdeliver_webjs_[^}]+\}/g, "");
}

const uri = this.state.uri;
return Object.keys(uri).reduce((acc, key) => {
acc = acc.replace(
// get all the keys from the mentions
const keys = matchAll(/\^\{jsdeliver_webjs_([^}]+)\}/, value).map(
(match) => {
return match[1];
}
);

// replace all the mentions with the corresponding uri
keys.forEach((key) => {
value = value.replace(
new RegExp(`\\^\\{jsdeliver_webjs_${key}\\}`, "g"),
uri[key as keyof State["uri"]]
this.state.uri?.[key] || ""
);
return acc;
}, value);
});

return value;
}

render() {
Expand All @@ -63,38 +73,26 @@ export default class WebJsInjector extends React.PureComponent<

async componentDidMount() {
if (typeof window != "undefined") {
if (MOCK_ENABLED) {
if (MOCK_ENABLED || window.location.hostname === "test.supertokens.com") {
if (this.isUnmounting) {
return;
}

const proxy = new Proxy(
{},
{
get(target, name, receiver) {
return `https://cdn.jsdelivr.net/gh/supertokens/[email protected]/bundle/${String(
name
)}.test.js`;
},
}
);

this.setState((oldState) => {
return {
...oldState,
uri: {
dateprovider:
"https://cdn.jsdelivr.net/gh/supertokens/[email protected]/bundle/dateprovider.test.js",
emailpassword:
"https://cdn.jsdelivr.net/gh/supertokens/[email protected]/bundle/emailpassword.test.js",
emailverification:
"https://cdn.jsdelivr.net/gh/supertokens/[email protected]/bundle/emailverification.test.js",
multifactorauth:
"https://cdn.jsdelivr.net/gh/supertokens/[email protected]/bundle/multifactorauth.test.js",
multitenancy:
"https://cdn.jsdelivr.net/gh/supertokens/[email protected]/bundle/multitenancy.test.js",
passwordless:
"https://cdn.jsdelivr.net/gh/supertokens/[email protected]/bundle/passwordless.test.js",
session:
"https://cdn.jsdelivr.net/gh/supertokens/[email protected]/bundle/session.test.js",
supertokens:
"https://cdn.jsdelivr.net/gh/supertokens/[email protected]/bundle/supertokens.test.js",
thirdparty:
"https://cdn.jsdelivr.net/gh/supertokens/[email protected]/bundle/thirdparty.test.js",
totp: "https://cdn.jsdelivr.net/gh/supertokens/[email protected]/bundle/totp.test.js",
userroles:
"https://cdn.jsdelivr.net/gh/supertokens/[email protected]/bundle/userroles.test.js",
website:
"https://cdn.jsdelivr.net/gh/supertokens/[email protected]/bundle/website.test.js",
},
uri: proxy,
};
});
} else {
Expand Down

0 comments on commit aab570b

Please sign in to comment.