mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-06 22:40:14 -05:00
Added integrity token to signup-form package
ref KTLO-1
This commit is contained in:
parent
ef4f79370f
commit
ebc87002ce
4 changed files with 32 additions and 3 deletions
|
@ -45,6 +45,13 @@ const Preview: React.FC<SignupFormOptions & {
|
|||
}
|
||||
|
||||
return;
|
||||
},
|
||||
getIntegrityToken: async () => {
|
||||
await new Promise((resolve) => {
|
||||
setTimeout(resolve, 500);
|
||||
});
|
||||
|
||||
return 'testtoken';
|
||||
}
|
||||
},
|
||||
t: i18n.t,
|
||||
|
|
|
@ -21,7 +21,8 @@ export const FormPage: React.FC = () => {
|
|||
setLoading(true);
|
||||
|
||||
try {
|
||||
await api.sendMagicLink({email, labels: options.labels});
|
||||
const integrityToken = await api.getIntegrityToken();
|
||||
await api.sendMagicLink({email, labels: options.labels, integrityToken});
|
||||
|
||||
if (minimal) {
|
||||
// Don't go to the success page, but show the success state in the form
|
||||
|
|
|
@ -12,14 +12,31 @@ export const setupGhostApi = ({siteUrl}: {siteUrl: string}) => {
|
|||
}
|
||||
|
||||
return {
|
||||
sendMagicLink: async ({email, labels}: {email: string, labels: string[]}) => {
|
||||
getIntegrityToken: async (): Promise<string> => {
|
||||
const url = endpointFor({type: 'members', resource: 'integrity-token'});
|
||||
|
||||
const response = await fetch(url, {
|
||||
headers: {
|
||||
'app-pragma': 'no-cache',
|
||||
'x-ghost-version': '5.90'
|
||||
}
|
||||
});
|
||||
|
||||
if (response.status < 200 || response.status >= 300) {
|
||||
throw new Error(response.statusText);
|
||||
}
|
||||
|
||||
return response.text();
|
||||
},
|
||||
sendMagicLink: async ({email, integrityToken, labels}: {email: string, labels: string[], integrityToken: string}) => {
|
||||
const url = endpointFor({type: 'members', resource: 'send-magic-link'});
|
||||
|
||||
const payload = JSON.stringify({
|
||||
email,
|
||||
emailType: 'signup',
|
||||
labels,
|
||||
urlHistory: getUrlHistory({siteUrl})
|
||||
urlHistory: getUrlHistory({siteUrl}),
|
||||
integrityToken
|
||||
});
|
||||
|
||||
const response = await fetch(url, {
|
||||
|
|
|
@ -65,5 +65,9 @@ export async function mockApi({page, status = 200}: {page: any, status?: number}
|
|||
await route.abort('addressunreachable');
|
||||
});
|
||||
|
||||
await page.route(`${MOCKED_SITE_URL}/members/api/integrity-token/`, async (route) => {
|
||||
await route.fulfill('testtoken');
|
||||
});
|
||||
|
||||
return lastApiRequest;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue