Compare commits

...

48 Commits

Author SHA1 Message Date
Szilárd Dóró
11b4d12f12 Merge pull request #1794 from nhost/changeset-release/main
chore: update versions
2023-03-30 19:56:33 +02:00
Szilárd Dóró
12301e6551 fix: use correct @nhost/apollo version 2023-03-30 15:57:43 +02:00
github-actions[bot]
74e52cac2d chore: update versions 2023-03-30 09:07:41 +00:00
Szilárd Dóró
f17823760a Merge pull request #1795 from nhost/fix/presigned-urls
fix: don't alter URLs when no transformation parameters are available
2023-03-30 11:06:32 +02:00
Szilárd Dóró
bb8803a1e3 fix: don't alter URLs 2023-03-30 10:41:57 +02:00
Szilárd Dóró
b846291331 Merge pull request #1793 from nhost/fix/export-issue
fix: don't use conflicting names
2023-03-30 10:07:24 +02:00
Szilárd Dóró
2b2fb94f00 chore: add type checking step 2023-03-30 09:42:23 +02:00
Szilárd Dóró
551760c4f0 fix: don't break builds 2023-03-30 09:37:39 +02:00
Szilárd Dóró
5ae5a8e77d fix: don't break builds 2023-03-30 09:31:54 +02:00
Szilárd Dóró
56aae0c964 fix: don't break builds 2023-03-30 09:28:34 +02:00
Szilárd Dóró
a0e093d77b fix: don't use conflicting names 2023-03-30 09:16:30 +02:00
Szilárd Dóró
5e82e1b3da Merge pull request #1784 from nhost/changeset-release/main
chore: update versions
2023-03-29 09:20:48 +02:00
github-actions[bot]
e618b705e7 chore: update versions 2023-03-28 15:52:47 +00:00
Szilárd Dóró
a232c9f0f6 Merge pull request #1789 from nhost/fix/azuread-description
fix(dashboard): use correct description for Azure AD
2023-03-28 17:50:51 +02:00
Szilárd Dóró
bf4644ea10 fix: use correct description for Azure AD 2023-03-28 16:52:54 +02:00
Szilárd Dóró
0aca907ea4 Merge pull request #1788 from nhost/fix/azuread-provider-name
fix: correct typos in Azure AD
2023-03-28 16:25:59 +02:00
Szilárd Dóró
394f4c4174 fix: correct typos in Azure AD 2023-03-28 16:25:26 +02:00
Szilárd Dóró
8fef08a150 Merge pull request #1786 from nhost/renovate/turbo-1.x
chore(deps): update dependency turbo to v1.8.6
2023-03-28 16:16:57 +02:00
Szilárd Dóró
1bd2c37301 chore: bump turbo in the Dockerfile 2023-03-28 15:54:37 +02:00
renovate[bot]
5cdb70bd81 chore(deps): update dependency turbo to v1.8.6 2023-03-28 12:01:36 +00:00
Szilárd Dóró
1a5f80e1b6 Merge pull request #1785 from nhost/renovate/react-monorepo
chore(deps): update dependency @types/react to v18.0.30
2023-03-28 13:59:29 +02:00
Szilárd Dóró
59e0cb00c5 Merge pull request #1787 from nhost/feat/azuread-provider 2023-03-28 12:25:42 +02:00
Szilárd Dóró
406b0f2cb7 Merge pull request #1163 from dipakparmar/feat/dashboard-azuread-settings
feat(dashboard): add azure ad provider settings
2023-03-28 10:52:17 +02:00
Szilárd Dóró
d329b6218f chore: add changeset 2023-03-28 10:46:50 +02:00
Szilárd Dóró
335b58670e Merge branch 'renovate/react-monorepo' of https://github.com/nhost/nhost into renovate/react-monorepo 2023-03-28 10:43:08 +02:00
renovate[bot]
efa2d89067 chore(deps): update dependency @types/react to v18.0.30 2023-03-28 08:35:55 +00:00
Szilárd Dóró
77ce4bd738 Merge pull request #1783 from nhost/fix/random-words
fix(tests): avoid name collision in database tests
2023-03-28 10:33:33 +02:00
Szilárd Dóró
017adea700 chore: update comment 2023-03-28 10:04:38 +02:00
Dipak Parmar
378284faa8 chore(dashboard): remove docs and title for now from azuread component
Signed-off-by: Dipak Parmar <hi@dipak.tech>
2023-03-27 23:44:40 -07:00
renovate[bot]
e5e2d114b1 chore(deps): update dependency @types/react to v18.0.30 2023-03-27 19:03:37 +00:00
Szilárd Dóró
5e3dbdeb7d Merge pull request #1781 from nhost/renovate/react-monorepo
chore(deps): update dependency @types/react to v18.0.29
2023-03-27 20:55:47 +02:00
Szilárd Dóró
98b777491a fix: improve flaky tests 2023-03-27 18:13:10 +02:00
Szilárd Dóró
71de870cb0 fix: use admin secret as env var 2023-03-27 17:29:09 +02:00
Szilárd Dóró
74d4deba28 feat: cleanup public schema after tests 2023-03-27 17:00:07 +02:00
Szilárd Dóró
cb248f0d30 chore: add changeset 2023-03-27 15:44:08 +02:00
Szilárd Dóró
09e4f1eb34 fix: avoid duplicate table names in tests 2023-03-27 15:16:40 +02:00
Szilárd Dóró
6e1f03eaee chore: accomodate changes to API 2023-03-27 11:57:24 +02:00
Szilárd Dóró
867c807699 chore: add changeset 2023-03-27 11:21:42 +02:00
renovate[bot]
d0673d7825 chore(deps): update dependency @types/react to v18.0.29 2023-03-27 07:50:19 +00:00
Dipak Parmar
106f23dcfa fixdashboard-settings): remove extra whitespace azuread provider import in settings
Signed-off-by: Dipak Parmar <hi@dipak.tech>
2023-03-27 00:48:56 -07:00
Dipak Parmar
83ef755822 feat(dashboard-settings): update azuread provider settings component
Signed-off-by: Dipak Parmar <hi@dipak.tech>
2023-03-27 00:47:09 -07:00
Dipak Parmar
b7703ffd70 feat(graphql): add azuread to signinmethods query
Signed-off-by: Dipak Parmar <hi@dipak.tech>
2023-03-27 00:46:30 -07:00
Dipak Parmar
340ea5b115 chore: merge branch 'main' into feat/dashboard-azuread-settings
* main: (1322 commits)
  chore(ci): adjust preview fetcher
  chore: add changeset
  fix: fetch valid previews only
  fix: use correct Vercel token
  fix: use staging project ID
  chore: use dynamic test URL
  fix(deps): update docusaurus monorepo to v2.4.0
  chore(hasura-storage-js): improve presignedUrl test
  fix: remove test.only call
  chore: add tests for table deletion
  chore: update versions
  fix: potential subscription fix
  Fix import in docs
  fix: remove `test.only` call
  chore: add remaining table creation tests
  chore: add foreign key constraint test
  chore: add extra database UI tests
  chore: restructure tests, add basic table creation test
  chore: update versions
  chore: add changeset
  ...

Signed-off-by: Dipak Parmar <hi@dipak.tech>
2023-03-26 19:16:40 -07:00
Dipak Parmar
ce4b655c55 fix: correct typos 2022-11-22 19:47:21 -08:00
Dipak Parmar
dc57d31ec9 fix: correct extra space in azureadprovidersettings dir 2022-11-22 19:45:38 -08:00
Dipak Parmar
ea29fd6b73 feat(dashboard-settings): add azuread provider to settings 2022-11-21 20:30:53 -08:00
Dipak Parmar
d8e4073957 feat(dashboard-settings): add azuread provider settings component 2022-11-21 20:29:34 -08:00
Dipak Parmar
3f399a54a3 feat(graphql): add azuread to signinmethods query 2022-11-21 20:28:50 -08:00
82 changed files with 964 additions and 342 deletions

View File

@@ -24,6 +24,7 @@ env:
NHOST_TEST_PROJECT_NAME: ${{ vars.NHOST_TEST_PROJECT_NAME }} NHOST_TEST_PROJECT_NAME: ${{ vars.NHOST_TEST_PROJECT_NAME }}
NHOST_TEST_USER_EMAIL: ${{ secrets.NHOST_TEST_USER_EMAIL }} NHOST_TEST_USER_EMAIL: ${{ secrets.NHOST_TEST_USER_EMAIL }}
NHOST_TEST_USER_PASSWORD: ${{ secrets.NHOST_TEST_USER_PASSWORD }} NHOST_TEST_USER_PASSWORD: ${{ secrets.NHOST_TEST_USER_PASSWORD }}
NHOST_TEST_PROJECT_ADMIN_SECRET: ${{ secrets.NHOST_TEST_PROJECT_ADMIN_SECRET }}
jobs: jobs:
build: build:

View File

@@ -1,5 +1,25 @@
# @nhost/dashboard # @nhost/dashboard
## 0.14.1
### Patch Changes
- @nhost/react-apollo@5.0.15
- @nhost/nextjs@1.13.19
## 0.14.0
### Minor Changes
- 6e1f03ea: feat(dashboard): add support for the Azure AD provider
### Patch Changes
- 1bd2c373: chore(deps): bump `turbo` to 1.8.6
- d329b621: chore(deps): bump `@types/react` to 18.0.30
- cb248f0d: fix(tests): avoid name collision in database tests
- 867c8076: chore(deps): bump `@types/react` to 18.0.29
## 0.13.10 ## 0.13.10
### Patch Changes ### Patch Changes

View File

@@ -3,7 +3,7 @@ RUN apk add --no-cache libc6-compat
RUN apk update RUN apk update
WORKDIR /app WORKDIR /app
RUN yarn global add turbo@1.8.3 RUN yarn global add turbo@1.8.6
COPY . . COPY . .
RUN turbo prune --scope="@nhost/dashboard" --docker RUN turbo prune --scope="@nhost/dashboard" --docker

View File

@@ -128,4 +128,5 @@ NHOST_TEST_USER_EMAIL=<test_user_email>
NHOST_TEST_USER_PASSWORD=<test_user_password> NHOST_TEST_USER_PASSWORD=<test_user_password>
NHOST_TEST_WORKSPACE_NAME=<test_workspace_name> NHOST_TEST_WORKSPACE_NAME=<test_workspace_name>
NHOST_TEST_PROJECT_NAME=<test_project_name> NHOST_TEST_PROJECT_NAME=<test_project_name>
NHOST_TEST_PROJECT_ADMIN_SECRET=<test_project_admin_secret>
``` ```

View File

@@ -7,11 +7,15 @@ import { openProject, prepareTable } from '@/e2e/utils';
import { faker } from '@faker-js/faker'; import { faker } from '@faker-js/faker';
import type { Page } from '@playwright/test'; import type { Page } from '@playwright/test';
import { expect, test } from '@playwright/test'; import { expect, test } from '@playwright/test';
import { snakeCase } from 'snake-case';
let page: Page; let page: Page;
test.beforeAll(async ({ browser }) => { test.beforeAll(async ({ browser }) => {
page = await browser.newPage(); page = await browser.newPage();
});
test.beforeEach(async () => {
await page.goto('/'); await page.goto('/');
await openProject({ await openProject({
@@ -35,7 +39,7 @@ test('should create a simple table', async () => {
await page.getByRole('button', { name: /new table/i }).click(); await page.getByRole('button', { name: /new table/i }).click();
await expect(page.getByText(/create a new table/i)).toBeVisible(); await expect(page.getByText(/create a new table/i)).toBeVisible();
const tableName = faker.random.word().toLowerCase(); const tableName = snakeCase(faker.lorem.words(3));
await prepareTable({ await prepareTable({
page, page,
@@ -63,7 +67,7 @@ test('should create a table with unique constraints', async () => {
await page.getByRole('button', { name: /new table/i }).click(); await page.getByRole('button', { name: /new table/i }).click();
await expect(page.getByText(/create a new table/i)).toBeVisible(); await expect(page.getByText(/create a new table/i)).toBeVisible();
const tableName = faker.random.word().toLowerCase(); const tableName = snakeCase(faker.lorem.words(3));
await prepareTable({ await prepareTable({
page, page,
@@ -92,7 +96,7 @@ test('should create a table with nullable columns', async () => {
await page.getByRole('button', { name: /new table/i }).click(); await page.getByRole('button', { name: /new table/i }).click();
await expect(page.getByText(/create a new table/i)).toBeVisible(); await expect(page.getByText(/create a new table/i)).toBeVisible();
const tableName = faker.random.word().toLowerCase(); const tableName = snakeCase(faker.lorem.words(3));
await prepareTable({ await prepareTable({
page, page,
@@ -121,7 +125,7 @@ test('should create a table with an identity column', async () => {
await page.getByRole('button', { name: /new table/i }).click(); await page.getByRole('button', { name: /new table/i }).click();
await expect(page.getByText(/create a new table/i)).toBeVisible(); await expect(page.getByText(/create a new table/i)).toBeVisible();
const tableName = faker.random.word().toLowerCase(); const tableName = snakeCase(faker.lorem.words(3));
await prepareTable({ await prepareTable({
page, page,
@@ -153,7 +157,7 @@ test('should create table with foreign key constraint', async () => {
await page.getByRole('button', { name: /new table/i }).click(); await page.getByRole('button', { name: /new table/i }).click();
await expect(page.getByText(/create a new table/i)).toBeVisible(); await expect(page.getByText(/create a new table/i)).toBeVisible();
const firstTableName = faker.random.word().toLowerCase(); const firstTableName = snakeCase(faker.lorem.words(3));
await prepareTable({ await prepareTable({
page, page,
@@ -175,7 +179,7 @@ test('should create table with foreign key constraint', async () => {
await page.getByRole('button', { name: /new table/i }).click(); await page.getByRole('button', { name: /new table/i }).click();
await expect(page.getByText(/create a new table/i)).toBeVisible(); await expect(page.getByText(/create a new table/i)).toBeVisible();
const secondTableName = faker.random.word().toLowerCase(); const secondTableName = snakeCase(faker.lorem.words(3));
await prepareTable({ await prepareTable({
page, page,
@@ -234,7 +238,7 @@ test('should not be able to create a table with a name that already exists', asy
await page.getByRole('button', { name: /new table/i }).click(); await page.getByRole('button', { name: /new table/i }).click();
await expect(page.getByText(/create a new table/i)).toBeVisible(); await expect(page.getByText(/create a new table/i)).toBeVisible();
const tableName = faker.random.word().toLowerCase(); const tableName = snakeCase(faker.lorem.words(3));
await prepareTable({ await prepareTable({
page, page,

View File

@@ -3,15 +3,19 @@ import {
TEST_PROJECT_SLUG, TEST_PROJECT_SLUG,
TEST_WORKSPACE_SLUG, TEST_WORKSPACE_SLUG,
} from '@/e2e/env'; } from '@/e2e/env';
import { openProject, prepareTable } from '@/e2e/utils'; import { deleteTable, openProject, prepareTable } from '@/e2e/utils';
import { faker } from '@faker-js/faker'; import { faker } from '@faker-js/faker';
import type { Page } from '@playwright/test'; import type { Page } from '@playwright/test';
import { expect, test } from '@playwright/test'; import { expect, test } from '@playwright/test';
import { snakeCase } from 'snake-case';
let page: Page; let page: Page;
test.beforeAll(async ({ browser }) => { test.beforeAll(async ({ browser }) => {
page = await browser.newPage(); page = await browser.newPage();
});
test.beforeEach(async () => {
await page.goto('/'); await page.goto('/');
await openProject({ await openProject({
@@ -32,7 +36,7 @@ test.afterAll(async () => {
}); });
test('should delete a table', async () => { test('should delete a table', async () => {
const tableName = faker.random.word().toLowerCase(); const tableName = snakeCase(faker.lorem.words(3));
await page.getByRole('button', { name: /new table/i }).click(); await page.getByRole('button', { name: /new table/i }).click();
@@ -52,26 +56,11 @@ test('should delete a table', async () => {
`/${TEST_WORKSPACE_SLUG}/${TEST_PROJECT_SLUG}/database/browser/default/public/${tableName}`, `/${TEST_WORKSPACE_SLUG}/${TEST_PROJECT_SLUG}/database/browser/default/public/${tableName}`,
); );
const tableLink = page.getByRole('link', { await deleteTable({
page,
name: tableName, name: tableName,
exact: true,
}); });
await tableLink.hover();
await page
.getByRole('listitem')
.filter({ hasText: tableName })
.getByRole('button')
.click();
await page.getByRole('menuitem', { name: /delete table/i }).click();
await expect(
page.getByRole('heading', { name: /delete table/i }),
).toBeVisible();
await page.getByRole('button', { name: /delete/i }).click();
// navigate to next URL // navigate to next URL
await page.waitForURL( await page.waitForURL(
`/${TEST_WORKSPACE_SLUG}/${TEST_PROJECT_SLUG}/database/browser/default/public/**`, `/${TEST_WORKSPACE_SLUG}/${TEST_PROJECT_SLUG}/database/browser/default/public/**`,
@@ -86,7 +75,7 @@ test('should not be able to delete a table if other tables have foreign keys ref
await page.getByRole('button', { name: /new table/i }).click(); await page.getByRole('button', { name: /new table/i }).click();
await expect(page.getByText(/create a new table/i)).toBeVisible(); await expect(page.getByText(/create a new table/i)).toBeVisible();
const firstTableName = faker.random.word().toLowerCase(); const firstTableName = snakeCase(faker.lorem.words(3));
await prepareTable({ await prepareTable({
page, page,
@@ -108,7 +97,7 @@ test('should not be able to delete a table if other tables have foreign keys ref
await page.getByRole('button', { name: /new table/i }).click(); await page.getByRole('button', { name: /new table/i }).click();
await expect(page.getByText(/create a new table/i)).toBeVisible(); await expect(page.getByText(/create a new table/i)).toBeVisible();
const secondTableName = faker.random.word().toLowerCase(); const secondTableName = snakeCase(faker.lorem.words(3));
await prepareTable({ await prepareTable({
page, page,
@@ -163,26 +152,11 @@ test('should not be able to delete a table if other tables have foreign keys ref
).toBeVisible(); ).toBeVisible();
// try to delete the first table that is referenced by the second table // try to delete the first table that is referenced by the second table
const tableLink = page.getByRole('link', { await deleteTable({
page,
name: firstTableName, name: firstTableName,
exact: true,
}); });
await tableLink.hover();
await page
.getByRole('listitem')
.filter({ hasText: firstTableName })
.getByRole('button')
.click();
await page.getByRole('menuitem', { name: /delete table/i }).click();
await expect(
page.getByRole('heading', { name: /delete table/i }),
).toBeVisible();
await page.getByRole('button', { name: /delete/i }).click();
await expect( await expect(
page.getByText( page.getByText(
/constraint [a-zA-Z_]+ on table [a-zA-Z_]+ depends on table [a-zA-Z_]+/i, /constraint [a-zA-Z_]+ on table [a-zA-Z_]+ depends on table [a-zA-Z_]+/i,

View File

@@ -31,6 +31,12 @@ export const TEST_PROJECT_SLUG = slugify(TEST_PROJECT_NAME, {
strict: true, strict: true,
}); });
/**
* Hasura admin secret of the test project to use.
*/
export const TEST_PROJECT_ADMIN_SECRET =
process.env.NHOST_TEST_PROJECT_ADMIN_SECRET;
/** /**
* Email of the test account to use. * Email of the test account to use.
*/ */

View File

@@ -66,18 +66,25 @@ export async function prepareTable({
// set type // set type
await page await page
.getByRole('table')
.getByRole('combobox', { name: /type/i }) .getByRole('combobox', { name: /type/i })
.nth(index) .nth(index)
.fill(type); .type(type);
await page.getByRole('option', { name: type }).first().click(); await page
.getByRole('table')
.getByRole('option', { name: type })
.first()
.click();
// optionally set default value // optionally set default value
if (defaultValue) { if (defaultValue) {
await page await page
.getByRole('table')
.getByRole('combobox', { name: /default value/i }) .getByRole('combobox', { name: /default value/i })
.first() .nth(index)
.fill(defaultValue); .type(defaultValue);
await page await page
.getByRole('table')
.getByRole('option', { name: defaultValue }) .getByRole('option', { name: defaultValue })
.first() .first()
.click(); .click();
@@ -111,3 +118,33 @@ export async function prepareTable({
await page.getByRole('button', { name: /primary key/i }).click(); await page.getByRole('button', { name: /primary key/i }).click();
await page.getByRole('option', { name: primaryKey, exact: true }).click(); await page.getByRole('option', { name: primaryKey, exact: true }).click();
} }
/**
* Deletes a table with the given name.
*
* @param page - The Playwright page object.
* @param name - The name of the table to delete.
* @returns A promise that resolves when the table is deleted.
*/
export async function deleteTable({
page,
name,
}: {
page: Page;
name: string;
}) {
const tableLink = page.getByRole('link', {
name,
exact: true,
});
await tableLink.hover();
await page
.getByRole('listitem')
.filter({ hasText: name })
.getByRole('button')
.click();
await page.getByRole('menuitem', { name: /delete table/i }).click();
await page.getByRole('button', { name: /delete/i }).click();
}

View File

@@ -1,19 +1,19 @@
import { chromium } from '@playwright/test';
import { import {
TEST_DASHBOARD_URL, TEST_DASHBOARD_URL,
TEST_USER_EMAIL, TEST_USER_EMAIL,
TEST_USER_PASSWORD, TEST_USER_PASSWORD,
} from './e2e/env'; } from '@/e2e/env';
import { chromium } from '@playwright/test';
async function globalSetup() { async function globalSetup() {
const browser = await chromium.launch(); const browser = await chromium.launch();
const page = await browser.newPage(); const page = await browser.newPage({ baseURL: TEST_DASHBOARD_URL });
await page.goto(TEST_DASHBOARD_URL); await page.goto('/');
await page.waitForURL(`${TEST_DASHBOARD_URL}/signin`); await page.waitForURL('/signin');
await page.getByRole('link', { name: /continue with email/i }).click(); await page.getByRole('link', { name: /continue with email/i }).click();
await page.waitForURL(`${TEST_DASHBOARD_URL}/signin/email`); await page.waitForURL('/signin/email');
await page.getByLabel('Email').fill(TEST_USER_EMAIL); await page.getByLabel('Email').fill(TEST_USER_EMAIL);
await page.getByLabel('Password').fill(TEST_USER_PASSWORD); await page.getByLabel('Password').fill(TEST_USER_PASSWORD);
await page.getByRole('button', { name: /sign in/i }).click(); await page.getByRole('button', { name: /sign in/i }).click();

View File

@@ -0,0 +1,66 @@
import {
TEST_DASHBOARD_URL,
TEST_PROJECT_ADMIN_SECRET,
TEST_PROJECT_NAME,
TEST_PROJECT_SLUG,
TEST_WORKSPACE_SLUG,
} from '@/e2e/env';
import { openProject } from '@/e2e/utils';
import { chromium } from '@playwright/test';
async function globalTeardown() {
const browser = await chromium.launch();
const context = await browser.newContext({
baseURL: TEST_DASHBOARD_URL,
storageState: 'storageState.json',
});
const page = await context.newPage();
await page.goto('/');
await openProject({
page,
projectName: TEST_PROJECT_NAME,
workspaceSlug: TEST_WORKSPACE_SLUG,
projectSlug: TEST_PROJECT_SLUG,
});
const pagePromise = context.waitForEvent('page');
await page.getByRole('link', { name: /hasura/i }).click();
await page.getByRole('link', { name: /open hasura/i }).click();
const hasuraPage = await pagePromise;
await hasuraPage.waitForLoadState();
const adminSecretInput = hasuraPage.getByPlaceholder(/enter admin-secret/i);
// note: a more ideal way would be to paste from clipboard, but Playwright
// doesn't support that yet
await adminSecretInput.fill(TEST_PROJECT_ADMIN_SECRET);
await adminSecretInput.press('Enter');
// note: getByRole doesn't work here
await hasuraPage.locator('a', { hasText: /data/i }).click();
await hasuraPage.getByRole('link', { name: /sql/i }).click();
await hasuraPage.getByRole('textbox').fill(`
DO $$ DECLARE
tablename text;
BEGIN
FOR tablename IN
SELECT table_name FROM information_schema.tables
WHERE table_schema = 'public'
LOOP
EXECUTE 'DROP TABLE IF EXISTS public.' || quote_ident(tablename) || ' CASCADE';
END LOOP;
END $$;
`);
await hasuraPage.getByRole('button', { name: /run!/i }).click();
await hasuraPage.getByText(/sql executed!/i).waitFor();
}
export default globalTeardown;

View File

@@ -1,6 +1,6 @@
{ {
"name": "@nhost/dashboard", "name": "@nhost/dashboard",
"version": "0.13.10", "version": "0.14.1",
"private": true, "private": true,
"scripts": { "scripts": {
"preinstall": "npx only-allow pnpm", "preinstall": "npx only-allow pnpm",
@@ -106,7 +106,7 @@
"@types/lodash.debounce": "^4.0.7", "@types/lodash.debounce": "^4.0.7",
"@types/node": "^16.11.7", "@types/node": "^16.11.7",
"@types/pluralize": "^0.0.29", "@types/pluralize": "^0.0.29",
"@types/react": "18.0.28", "@types/react": "18.0.30",
"@types/react-dom": "18.0.11", "@types/react-dom": "18.0.11",
"@types/react-table": "^7.7.12", "@types/react-table": "^7.7.12",
"@types/testing-library__jest-dom": "^5.14.5", "@types/testing-library__jest-dom": "^5.14.5",
@@ -141,6 +141,7 @@
"prettier-plugin-tailwindcss": "^0.2.0", "prettier-plugin-tailwindcss": "^0.2.0",
"react-date-fns-hooks": "^0.9.4", "react-date-fns-hooks": "^0.9.4",
"require-from-string": "^2.0.2", "require-from-string": "^2.0.2",
"snake-case": "^3.0.4",
"storybook-addon-next-router": "^4.0.1", "storybook-addon-next-router": "^4.0.1",
"tailwindcss": "^3.1.2", "tailwindcss": "^3.1.2",
"ts-node": "^10.9.1", "ts-node": "^10.9.1",

View File

@@ -17,6 +17,7 @@ export default defineConfig({
workers: process.env.CI ? 1 : undefined, workers: process.env.CI ? 1 : undefined,
reporter: 'html', reporter: 'html',
globalSetup: require.resolve('./global-setup'), globalSetup: require.resolve('./global-setup'),
globalTeardown: require.resolve('./global-teardown'),
use: { use: {
actionTimeout: 0, actionTimeout: 0,
trace: 'on-first-retry', trace: 'on-first-retry',

File diff suppressed because one or more lines are too long

After

Width:  |  Height:  |  Size: 16 KiB

View File

@@ -0,0 +1,201 @@
import Form from '@/components/common/Form';
import SettingsContainer from '@/components/settings/SettingsContainer';
import BaseProviderSettings from '@/components/settings/signInMethods/BaseProviderSettings';
import { useUI } from '@/context/UIContext';
import {
GetSignInMethodsDocument,
useGetSignInMethodsQuery,
useUpdateConfigMutation,
} from '@/generated/graphql';
import { useCurrentWorkspaceAndApplication } from '@/hooks/useCurrentWorkspaceAndApplication';
import ActivityIndicator from '@/ui/v2/ActivityIndicator';
import IconButton from '@/ui/v2/IconButton';
import CopyIcon from '@/ui/v2/icons/CopyIcon';
import Input from '@/ui/v2/Input';
import InputAdornment from '@/ui/v2/InputAdornment';
import generateAppServiceUrl from '@/utils/common/generateAppServiceUrl';
import { copy } from '@/utils/copy';
import getServerError from '@/utils/settings/getServerError';
import { getToastStyleProps } from '@/utils/settings/settingsConstants';
import { yupResolver } from '@hookform/resolvers/yup';
import { FormProvider, useForm } from 'react-hook-form';
import { toast } from 'react-hot-toast';
import { twMerge } from 'tailwind-merge';
import * as Yup from 'yup';
const validationSchema = Yup.object({
clientId: Yup.string()
.label('Client ID')
.when('enabled', {
is: true,
then: (schema) => schema.required(),
}),
clientSecret: Yup.string()
.label('Client Secret')
.when('enabled', {
is: true,
then: (schema) => schema.required(),
}),
tenant: Yup.string()
.label('Tenant')
.when('enabled', {
is: true,
then: (schema) => schema.required(),
}),
enabled: Yup.boolean(),
});
export type AzureADProviderFormValues = Yup.InferType<typeof validationSchema>;
export default function AzureADProviderSettings() {
const { maintenanceActive } = useUI();
const { currentApplication } = useCurrentWorkspaceAndApplication();
const [updateConfig] = useUpdateConfigMutation({
refetchQueries: [GetSignInMethodsDocument],
});
const { data, loading, error } = useGetSignInMethodsQuery({
variables: { appId: currentApplication?.id },
fetchPolicy: 'cache-only',
});
const { clientId, clientSecret, tenant, enabled } =
data?.config?.auth?.method?.oauth?.azuread || {};
const form = useForm<AzureADProviderFormValues>({
reValidateMode: 'onSubmit',
defaultValues: {
clientId: clientId || '',
clientSecret: clientSecret || '',
tenant: tenant || '',
enabled: enabled || false,
},
resolver: yupResolver(validationSchema),
});
if (loading) {
return (
<ActivityIndicator
delay={1000}
label="Loading settings for Azure AD..."
className="justify-center"
/>
);
}
if (error) {
throw error;
}
const { register, formState, watch } = form;
const authEnabled = watch('enabled');
const handleProviderUpdate = async (values: AzureADProviderFormValues) => {
const updateConfigPromise = updateConfig({
variables: {
appId: currentApplication.id,
config: {
auth: {
method: {
oauth: {
azuread: values,
},
},
},
},
},
});
try {
await toast.promise(
updateConfigPromise,
{
loading: `Azure AD settings are being updated...`,
success: `Azure AD settings have been updated successfully.`,
error: getServerError(
`An error occurred while trying to update the project's Azure AD settings.`,
),
},
getToastStyleProps(),
);
form.reset(values);
} catch {
// Note: The toast will handle the error.
}
};
return (
<FormProvider {...form}>
<Form onSubmit={handleProviderUpdate}>
<SettingsContainer
title="Azure AD"
description="Allow users to sign in with Azure AD."
slotProps={{
submitButton: {
disabled: !formState.isDirty || maintenanceActive,
loading: formState.isSubmitting,
},
}}
icon="/assets/brands/azuread.svg"
switchId="enabled"
showSwitch
className={twMerge(
'grid grid-flow-row grid-cols-2 gap-y-4 gap-x-3 px-4 py-2',
!authEnabled && 'hidden',
)}
>
<BaseProviderSettings providerName="azuread" />
<Input
{...register('tenant')}
name="tenant"
id="tenant"
label="Tenant ID"
placeholder="Tenant ID"
className="col-span-2"
fullWidth
hideEmptyHelperText
error={!!formState.errors?.tenant}
helperText={formState.errors?.tenant?.message}
/>
<Input
name="redirectUrl"
id="redirectUrl"
defaultValue={`${generateAppServiceUrl(
currentApplication.subdomain,
currentApplication.region.awsName,
'auth',
)}/signin/provider/azuread/callback`}
className="col-span-2"
fullWidth
hideEmptyHelperText
label="Redirect URL"
disabled
endAdornment={
<InputAdornment position="end" className="absolute right-2">
<IconButton
sx={{ minWidth: 0, padding: 0 }}
color="secondary"
variant="borderless"
onClick={(e) => {
e.stopPropagation();
copy(
`${generateAppServiceUrl(
currentApplication.subdomain,
currentApplication.region.awsName,
'auth',
)}/signin/provider/azuread/callback`,
'Redirect URL',
);
}}
>
<CopyIcon className="h-4 w-4" />
</IconButton>
</InputAdornment>
}
/>
</SettingsContainer>
</Form>
</FormProvider>
);
}

View File

@@ -0,0 +1 @@
export { default } from './AzureADProviderSettings';

View File

@@ -100,6 +100,12 @@ query GetSignInMethods($appId: uuid!) {
connection connection
organization organization
} }
azuread {
enabled
clientId
clientSecret
tenant
}
} }
} }
} }

View File

@@ -2,6 +2,7 @@ import Container from '@/components/layout/Container';
import SettingsLayout from '@/components/settings/SettingsLayout'; import SettingsLayout from '@/components/settings/SettingsLayout';
import AnonymousSignInSettings from '@/components/settings/signInMethods/AnonymousSignInSettings'; import AnonymousSignInSettings from '@/components/settings/signInMethods/AnonymousSignInSettings';
import AppleProviderSettings from '@/components/settings/signInMethods/AppleProviderSettings'; import AppleProviderSettings from '@/components/settings/signInMethods/AppleProviderSettings';
import AzureADProviderSettings from '@/components/settings/signInMethods/AzureADProviderSettings';
import DiscordProviderSettings from '@/components/settings/signInMethods/DiscordProviderSettings'; import DiscordProviderSettings from '@/components/settings/signInMethods/DiscordProviderSettings';
import EmailAndPasswordSettings from '@/components/settings/signInMethods/EmailAndPasswordSettings'; import EmailAndPasswordSettings from '@/components/settings/signInMethods/EmailAndPasswordSettings';
import FacebookProviderSettings from '@/components/settings/signInMethods/FacebookProviderSettings'; import FacebookProviderSettings from '@/components/settings/signInMethods/FacebookProviderSettings';
@@ -56,6 +57,7 @@ export default function SettingsSignInMethodsPage() {
<SMSSettings /> <SMSSettings />
{!currentApplication.providersUpdated && <ProvidersUpdatedAlert />} {!currentApplication.providersUpdated && <ProvidersUpdatedAlert />}
<AppleProviderSettings /> <AppleProviderSettings />
<AzureADProviderSettings />
<DiscordProviderSettings /> <DiscordProviderSettings />
<FacebookProviderSettings /> <FacebookProviderSettings />
<GitHubProviderSettings /> <GitHubProviderSettings />

View File

@@ -25,7 +25,9 @@ export type Scalars = {
bpchar: any; bpchar: any;
bytea: any; bytea: any;
citext: any; citext: any;
float64: any;
jsonb: any; jsonb: any;
labels: any;
smallint: any; smallint: any;
timestamp: any; timestamp: any;
timestamptz: any; timestamptz: any;
@@ -1035,7 +1037,9 @@ export type ConfigGlobalUpdateInput = {
export type ConfigHasura = { export type ConfigHasura = {
__typename?: 'ConfigHasura'; __typename?: 'ConfigHasura';
adminSecret: Scalars['String']; adminSecret: Scalars['String'];
events?: Maybe<ConfigHasuraEvents>;
jwtSecrets?: Maybe<Array<ConfigJwtSecret>>; jwtSecrets?: Maybe<Array<ConfigJwtSecret>>;
logs?: Maybe<ConfigHasuraLogs>;
resources?: Maybe<ConfigResources>; resources?: Maybe<ConfigResources>;
settings?: Maybe<ConfigHasuraSettings>; settings?: Maybe<ConfigHasuraSettings>;
version?: Maybe<Scalars['String']>; version?: Maybe<Scalars['String']>;
@@ -1047,22 +1051,66 @@ export type ConfigHasuraComparisonExp = {
_not?: InputMaybe<ConfigHasuraComparisonExp>; _not?: InputMaybe<ConfigHasuraComparisonExp>;
_or?: InputMaybe<Array<ConfigHasuraComparisonExp>>; _or?: InputMaybe<Array<ConfigHasuraComparisonExp>>;
adminSecret?: InputMaybe<ConfigStringComparisonExp>; adminSecret?: InputMaybe<ConfigStringComparisonExp>;
events?: InputMaybe<ConfigHasuraEventsComparisonExp>;
jwtSecrets?: InputMaybe<ConfigJwtSecretComparisonExp>; jwtSecrets?: InputMaybe<ConfigJwtSecretComparisonExp>;
logs?: InputMaybe<ConfigHasuraLogsComparisonExp>;
resources?: InputMaybe<ConfigResourcesComparisonExp>; resources?: InputMaybe<ConfigResourcesComparisonExp>;
settings?: InputMaybe<ConfigHasuraSettingsComparisonExp>; settings?: InputMaybe<ConfigHasuraSettingsComparisonExp>;
version?: InputMaybe<ConfigStringComparisonExp>; version?: InputMaybe<ConfigStringComparisonExp>;
webhookSecret?: InputMaybe<ConfigStringComparisonExp>; webhookSecret?: InputMaybe<ConfigStringComparisonExp>;
}; };
export type ConfigHasuraEvents = {
__typename?: 'ConfigHasuraEvents';
httpPoolSize?: Maybe<Scalars['ConfigUint32']>;
};
export type ConfigHasuraEventsComparisonExp = {
_and?: InputMaybe<Array<ConfigHasuraEventsComparisonExp>>;
_not?: InputMaybe<ConfigHasuraEventsComparisonExp>;
_or?: InputMaybe<Array<ConfigHasuraEventsComparisonExp>>;
httpPoolSize?: InputMaybe<ConfigUint32ComparisonExp>;
};
export type ConfigHasuraEventsInsertInput = {
httpPoolSize?: InputMaybe<Scalars['ConfigUint32']>;
};
export type ConfigHasuraEventsUpdateInput = {
httpPoolSize?: InputMaybe<Scalars['ConfigUint32']>;
};
export type ConfigHasuraInsertInput = { export type ConfigHasuraInsertInput = {
adminSecret: Scalars['String']; adminSecret: Scalars['String'];
events?: InputMaybe<ConfigHasuraEventsInsertInput>;
jwtSecrets?: InputMaybe<Array<ConfigJwtSecretInsertInput>>; jwtSecrets?: InputMaybe<Array<ConfigJwtSecretInsertInput>>;
logs?: InputMaybe<ConfigHasuraLogsInsertInput>;
resources?: InputMaybe<ConfigResourcesInsertInput>; resources?: InputMaybe<ConfigResourcesInsertInput>;
settings?: InputMaybe<ConfigHasuraSettingsInsertInput>; settings?: InputMaybe<ConfigHasuraSettingsInsertInput>;
version?: InputMaybe<Scalars['String']>; version?: InputMaybe<Scalars['String']>;
webhookSecret: Scalars['String']; webhookSecret: Scalars['String'];
}; };
export type ConfigHasuraLogs = {
__typename?: 'ConfigHasuraLogs';
level?: Maybe<Scalars['String']>;
};
export type ConfigHasuraLogsComparisonExp = {
_and?: InputMaybe<Array<ConfigHasuraLogsComparisonExp>>;
_not?: InputMaybe<ConfigHasuraLogsComparisonExp>;
_or?: InputMaybe<Array<ConfigHasuraLogsComparisonExp>>;
level?: InputMaybe<ConfigStringComparisonExp>;
};
export type ConfigHasuraLogsInsertInput = {
level?: InputMaybe<Scalars['String']>;
};
export type ConfigHasuraLogsUpdateInput = {
level?: InputMaybe<Scalars['String']>;
};
export type ConfigHasuraSettings = { export type ConfigHasuraSettings = {
__typename?: 'ConfigHasuraSettings'; __typename?: 'ConfigHasuraSettings';
enableRemoteSchemaPermissions?: Maybe<Scalars['Boolean']>; enableRemoteSchemaPermissions?: Maybe<Scalars['Boolean']>;
@@ -1085,7 +1133,9 @@ export type ConfigHasuraSettingsUpdateInput = {
export type ConfigHasuraUpdateInput = { export type ConfigHasuraUpdateInput = {
adminSecret?: InputMaybe<Scalars['String']>; adminSecret?: InputMaybe<Scalars['String']>;
events?: InputMaybe<ConfigHasuraEventsUpdateInput>;
jwtSecrets?: InputMaybe<Array<ConfigJwtSecretUpdateInput>>; jwtSecrets?: InputMaybe<Array<ConfigJwtSecretUpdateInput>>;
logs?: InputMaybe<ConfigHasuraLogsUpdateInput>;
resources?: InputMaybe<ConfigResourcesUpdateInput>; resources?: InputMaybe<ConfigResourcesUpdateInput>;
settings?: InputMaybe<ConfigHasuraSettingsUpdateInput>; settings?: InputMaybe<ConfigHasuraSettingsUpdateInput>;
version?: InputMaybe<Scalars['String']>; version?: InputMaybe<Scalars['String']>;
@@ -1639,6 +1689,24 @@ export type Log = {
timestamp: Scalars['Timestamp']; timestamp: Scalars['Timestamp'];
}; };
export type Metrics = {
__typename?: 'Metrics';
rows: Array<RowMetric>;
};
export type RowMetric = {
__typename?: 'RowMetric';
labels?: Maybe<Scalars['labels']>;
time: Scalars['Timestamp'];
value?: Maybe<Scalars['float64']>;
};
export type StatsLiveApps = {
__typename?: 'StatsLiveApps';
appID: Array<Scalars['uuid']>;
count: Scalars['Int'];
};
/** Boolean expression to compare columns of type "String". All fields are combined with logical 'AND'. */ /** Boolean expression to compare columns of type "String". All fields are combined with logical 'AND'. */
export type String_Comparison_Exp = { export type String_Comparison_Exp = {
_eq?: InputMaybe<Scalars['String']>; _eq?: InputMaybe<Scalars['String']>;
@@ -4878,6 +4946,7 @@ export type Backups = {
appId: Scalars['uuid']; appId: Scalars['uuid'];
completedAt?: Maybe<Scalars['timestamptz']>; completedAt?: Maybe<Scalars['timestamptz']>;
createdAt: Scalars['timestamptz']; createdAt: Scalars['timestamptz'];
expiresAt?: Maybe<Scalars['timestamptz']>;
id: Scalars['uuid']; id: Scalars['uuid'];
size: Scalars['bigint']; size: Scalars['bigint'];
}; };
@@ -4965,6 +5034,7 @@ export type Backups_Bool_Exp = {
appId?: InputMaybe<Uuid_Comparison_Exp>; appId?: InputMaybe<Uuid_Comparison_Exp>;
completedAt?: InputMaybe<Timestamptz_Comparison_Exp>; completedAt?: InputMaybe<Timestamptz_Comparison_Exp>;
createdAt?: InputMaybe<Timestamptz_Comparison_Exp>; createdAt?: InputMaybe<Timestamptz_Comparison_Exp>;
expiresAt?: InputMaybe<Timestamptz_Comparison_Exp>;
id?: InputMaybe<Uuid_Comparison_Exp>; id?: InputMaybe<Uuid_Comparison_Exp>;
size?: InputMaybe<Bigint_Comparison_Exp>; size?: InputMaybe<Bigint_Comparison_Exp>;
}; };
@@ -4986,6 +5056,7 @@ export type Backups_Insert_Input = {
appId?: InputMaybe<Scalars['uuid']>; appId?: InputMaybe<Scalars['uuid']>;
completedAt?: InputMaybe<Scalars['timestamptz']>; completedAt?: InputMaybe<Scalars['timestamptz']>;
createdAt?: InputMaybe<Scalars['timestamptz']>; createdAt?: InputMaybe<Scalars['timestamptz']>;
expiresAt?: InputMaybe<Scalars['timestamptz']>;
id?: InputMaybe<Scalars['uuid']>; id?: InputMaybe<Scalars['uuid']>;
size?: InputMaybe<Scalars['bigint']>; size?: InputMaybe<Scalars['bigint']>;
}; };
@@ -4996,6 +5067,7 @@ export type Backups_Max_Fields = {
appId?: Maybe<Scalars['uuid']>; appId?: Maybe<Scalars['uuid']>;
completedAt?: Maybe<Scalars['timestamptz']>; completedAt?: Maybe<Scalars['timestamptz']>;
createdAt?: Maybe<Scalars['timestamptz']>; createdAt?: Maybe<Scalars['timestamptz']>;
expiresAt?: Maybe<Scalars['timestamptz']>;
id?: Maybe<Scalars['uuid']>; id?: Maybe<Scalars['uuid']>;
size?: Maybe<Scalars['bigint']>; size?: Maybe<Scalars['bigint']>;
}; };
@@ -5005,6 +5077,7 @@ export type Backups_Max_Order_By = {
appId?: InputMaybe<Order_By>; appId?: InputMaybe<Order_By>;
completedAt?: InputMaybe<Order_By>; completedAt?: InputMaybe<Order_By>;
createdAt?: InputMaybe<Order_By>; createdAt?: InputMaybe<Order_By>;
expiresAt?: InputMaybe<Order_By>;
id?: InputMaybe<Order_By>; id?: InputMaybe<Order_By>;
size?: InputMaybe<Order_By>; size?: InputMaybe<Order_By>;
}; };
@@ -5015,6 +5088,7 @@ export type Backups_Min_Fields = {
appId?: Maybe<Scalars['uuid']>; appId?: Maybe<Scalars['uuid']>;
completedAt?: Maybe<Scalars['timestamptz']>; completedAt?: Maybe<Scalars['timestamptz']>;
createdAt?: Maybe<Scalars['timestamptz']>; createdAt?: Maybe<Scalars['timestamptz']>;
expiresAt?: Maybe<Scalars['timestamptz']>;
id?: Maybe<Scalars['uuid']>; id?: Maybe<Scalars['uuid']>;
size?: Maybe<Scalars['bigint']>; size?: Maybe<Scalars['bigint']>;
}; };
@@ -5024,6 +5098,7 @@ export type Backups_Min_Order_By = {
appId?: InputMaybe<Order_By>; appId?: InputMaybe<Order_By>;
completedAt?: InputMaybe<Order_By>; completedAt?: InputMaybe<Order_By>;
createdAt?: InputMaybe<Order_By>; createdAt?: InputMaybe<Order_By>;
expiresAt?: InputMaybe<Order_By>;
id?: InputMaybe<Order_By>; id?: InputMaybe<Order_By>;
size?: InputMaybe<Order_By>; size?: InputMaybe<Order_By>;
}; };
@@ -5050,6 +5125,7 @@ export type Backups_Order_By = {
appId?: InputMaybe<Order_By>; appId?: InputMaybe<Order_By>;
completedAt?: InputMaybe<Order_By>; completedAt?: InputMaybe<Order_By>;
createdAt?: InputMaybe<Order_By>; createdAt?: InputMaybe<Order_By>;
expiresAt?: InputMaybe<Order_By>;
id?: InputMaybe<Order_By>; id?: InputMaybe<Order_By>;
size?: InputMaybe<Order_By>; size?: InputMaybe<Order_By>;
}; };
@@ -5068,6 +5144,8 @@ export enum Backups_Select_Column {
/** column name */ /** column name */
CreatedAt = 'createdAt', CreatedAt = 'createdAt',
/** column name */ /** column name */
ExpiresAt = 'expiresAt',
/** column name */
Id = 'id', Id = 'id',
/** column name */ /** column name */
Size = 'size' Size = 'size'
@@ -5078,6 +5156,7 @@ export type Backups_Set_Input = {
appId?: InputMaybe<Scalars['uuid']>; appId?: InputMaybe<Scalars['uuid']>;
completedAt?: InputMaybe<Scalars['timestamptz']>; completedAt?: InputMaybe<Scalars['timestamptz']>;
createdAt?: InputMaybe<Scalars['timestamptz']>; createdAt?: InputMaybe<Scalars['timestamptz']>;
expiresAt?: InputMaybe<Scalars['timestamptz']>;
id?: InputMaybe<Scalars['uuid']>; id?: InputMaybe<Scalars['uuid']>;
size?: InputMaybe<Scalars['bigint']>; size?: InputMaybe<Scalars['bigint']>;
}; };
@@ -5128,6 +5207,7 @@ export type Backups_Stream_Cursor_Value_Input = {
appId?: InputMaybe<Scalars['uuid']>; appId?: InputMaybe<Scalars['uuid']>;
completedAt?: InputMaybe<Scalars['timestamptz']>; completedAt?: InputMaybe<Scalars['timestamptz']>;
createdAt?: InputMaybe<Scalars['timestamptz']>; createdAt?: InputMaybe<Scalars['timestamptz']>;
expiresAt?: InputMaybe<Scalars['timestamptz']>;
id?: InputMaybe<Scalars['uuid']>; id?: InputMaybe<Scalars['uuid']>;
size?: InputMaybe<Scalars['bigint']>; size?: InputMaybe<Scalars['bigint']>;
}; };
@@ -5152,6 +5232,8 @@ export enum Backups_Update_Column {
/** column name */ /** column name */
CreatedAt = 'createdAt', CreatedAt = 'createdAt',
/** column name */ /** column name */
ExpiresAt = 'expiresAt',
/** column name */
Id = 'id', Id = 'id',
/** column name */ /** column name */
Size = 'size' Size = 'size'
@@ -9150,6 +9232,7 @@ export type Mutation_Root = {
/** insert a single row into the table: "regions" */ /** insert a single row into the table: "regions" */
insert_regions_one?: Maybe<Regions>; insert_regions_one?: Maybe<Regions>;
migrateRDSToPostgres: Scalars['Boolean']; migrateRDSToPostgres: Scalars['Boolean'];
pauseInactiveApps: Array<Scalars['String']>;
resetPostgresPassword: Scalars['Boolean']; resetPostgresPassword: Scalars['Boolean'];
restoreApplicationDatabase: Scalars['Boolean']; restoreApplicationDatabase: Scalars['Boolean'];
/** update single row of the table: "apps" */ /** update single row of the table: "apps" */
@@ -9338,9 +9421,16 @@ export type Mutation_Root = {
}; };
/** mutation root */
export type Mutation_RootBackupAllApplicationsDatabaseArgs = {
expireInDays?: InputMaybe<Scalars['Int']>;
};
/** mutation root */ /** mutation root */
export type Mutation_RootBackupApplicationDatabaseArgs = { export type Mutation_RootBackupApplicationDatabaseArgs = {
appID: Scalars['String']; appID: Scalars['String'];
expireInDays?: InputMaybe<Scalars['Int']>;
}; };
@@ -11947,6 +12037,41 @@ export type Query_Root = {
files: Array<Files>; files: Array<Files>;
/** fetch aggregated fields from the table: "storage.files" */ /** fetch aggregated fields from the table: "storage.files" */
filesAggregate: Files_Aggregate; filesAggregate: Files_Aggregate;
/**
* Returns CPU metrics for a given application.
* If `from` and `to` are not provided, they default to an hour ago and now, respectively.
*
* CPU usage is calculated as the average CPU usage over the period of 1m.
*
* Unit returned is millicores.
*/
getCPUMetrics: Metrics;
/**
* Returns memory metrics for a given application.
* If `from` and `to` are not provided, they default to an hour ago and now, respectively.
*
* Memory usage is returned in MiB.
*/
getMemoryMetrics: Metrics;
/**
* Returns disk capacity for the volume used by postgres to store the database.
* If `from` and `to` are not provided, they default to an hour ago and now, respectively.
*
* Disk usage is returned in MiB.
*/
getPostgresVolumeCapacity: Metrics;
/**
* Returns disk usage for the volume used by postgres to store the database.
* If `from` and `to` are not provided, they default to an hour ago and now, respectively.
*
* Disk usage is returned in MiB.
*/
getPostgresVolumeUsage: Metrics;
/**
* Return requests per second for a given application by service.
* If `from` and `to` are not provided, they default to an hour ago and now, respectively.
*/
getRequestsPerSecond: Metrics;
/** fetch data from the table: "github_app_installations" using primary key columns */ /** fetch data from the table: "github_app_installations" using primary key columns */
githubAppInstallation?: Maybe<GithubAppInstallations>; githubAppInstallation?: Maybe<GithubAppInstallations>;
/** fetch data from the table: "github_app_installations" */ /** fetch data from the table: "github_app_installations" */
@@ -11982,6 +12107,13 @@ export type Query_Root = {
regions_aggregate: Regions_Aggregate; regions_aggregate: Regions_Aggregate;
/** fetch data from the table: "regions" using primary key columns */ /** fetch data from the table: "regions" using primary key columns */
regions_by_pk?: Maybe<Regions>; regions_by_pk?: Maybe<Regions>;
/**
* Returns lists of apps that have some live traffic in the give time range.
* From defaults to 24 hours ago and to defaults to now.
*
* Requests that returned a 4xx or 5xx status code are not counted as live traffic.
*/
statsLiveApps: StatsLiveApps;
systemConfig?: Maybe<ConfigSystemConfig>; systemConfig?: Maybe<ConfigSystemConfig>;
systemConfigs: Array<ConfigAppSystemConfig>; systemConfigs: Array<ConfigAppSystemConfig>;
/** fetch data from the table: "auth.users" using primary key columns */ /** fetch data from the table: "auth.users" using primary key columns */
@@ -12511,6 +12643,41 @@ export type Query_RootFilesAggregateArgs = {
}; };
export type Query_RootGetCpuMetricsArgs = {
appID: Scalars['String'];
from?: InputMaybe<Scalars['Timestamp']>;
to?: InputMaybe<Scalars['Timestamp']>;
};
export type Query_RootGetMemoryMetricsArgs = {
appID: Scalars['String'];
from?: InputMaybe<Scalars['Timestamp']>;
to?: InputMaybe<Scalars['Timestamp']>;
};
export type Query_RootGetPostgresVolumeCapacityArgs = {
appID: Scalars['String'];
from?: InputMaybe<Scalars['Timestamp']>;
to?: InputMaybe<Scalars['Timestamp']>;
};
export type Query_RootGetPostgresVolumeUsageArgs = {
appID: Scalars['String'];
from?: InputMaybe<Scalars['Timestamp']>;
to?: InputMaybe<Scalars['Timestamp']>;
};
export type Query_RootGetRequestsPerSecondArgs = {
appID: Scalars['String'];
from?: InputMaybe<Scalars['Timestamp']>;
to?: InputMaybe<Scalars['Timestamp']>;
};
export type Query_RootGithubAppInstallationArgs = { export type Query_RootGithubAppInstallationArgs = {
id: Scalars['uuid']; id: Scalars['uuid'];
}; };
@@ -12634,6 +12801,12 @@ export type Query_RootRegions_By_PkArgs = {
}; };
export type Query_RootStatsLiveAppsArgs = {
from?: InputMaybe<Scalars['Timestamp']>;
to?: InputMaybe<Scalars['Timestamp']>;
};
export type Query_RootSystemConfigArgs = { export type Query_RootSystemConfigArgs = {
appID: Scalars['uuid']; appID: Scalars['uuid'];
}; };
@@ -16480,7 +16653,7 @@ export type GetSignInMethodsQueryVariables = Exact<{
}>; }>;
export type GetSignInMethodsQuery = { __typename?: 'query_root', config?: { __typename: 'ConfigConfig', id: 'ConfigConfig', provider?: { __typename: 'ConfigProvider', id: 'ConfigProvider', sms?: { __typename?: 'ConfigSms', accountSid: string, authToken: string, messagingServiceId: string, provider?: string | null } | null } | null, auth?: { __typename: 'ConfigAuth', id: 'ConfigAuth', method?: { __typename?: 'ConfigAuthMethod', emailPassword?: { __typename?: 'ConfigAuthMethodEmailPassword', emailVerificationRequired?: boolean | null, hibpEnabled?: boolean | null } | null, emailPasswordless?: { __typename?: 'ConfigAuthMethodEmailPasswordless', enabled?: boolean | null } | null, smsPasswordless?: { __typename?: 'ConfigAuthMethodSmsPasswordless', enabled?: boolean | null } | null, anonymous?: { __typename?: 'ConfigAuthMethodAnonymous', enabled?: boolean | null } | null, webauthn?: { __typename?: 'ConfigAuthMethodWebauthn', enabled?: boolean | null } | null, oauth?: { __typename?: 'ConfigAuthMethodOauth', apple?: { __typename?: 'ConfigAuthMethodOauthApple', enabled?: boolean | null, clientId?: string | null, keyId?: string | null, teamId?: string | null, privateKey?: string | null } | null, discord?: { __typename?: 'ConfigStandardOauthProviderWithScope', enabled?: boolean | null, clientId?: string | null, clientSecret?: string | null, scope?: Array<string> | null } | null, facebook?: { __typename?: 'ConfigStandardOauthProviderWithScope', enabled?: boolean | null, clientId?: string | null, clientSecret?: string | null, scope?: Array<string> | null } | null, github?: { __typename?: 'ConfigStandardOauthProviderWithScope', enabled?: boolean | null, clientId?: string | null, clientSecret?: string | null, scope?: Array<string> | null } | null, google?: { __typename?: 'ConfigStandardOauthProviderWithScope', enabled?: boolean | null, clientId?: string | null, clientSecret?: string | null, scope?: Array<string> | null } | null, linkedin?: { __typename?: 'ConfigStandardOauthProviderWithScope', enabled?: boolean | null, clientId?: string | null, clientSecret?: string | null, scope?: Array<string> | null } | null, spotify?: { __typename?: 'ConfigStandardOauthProviderWithScope', enabled?: boolean | null, clientId?: string | null, clientSecret?: string | null, scope?: Array<string> | null } | null, twitch?: { __typename?: 'ConfigStandardOauthProviderWithScope', enabled?: boolean | null, clientId?: string | null, clientSecret?: string | null, scope?: Array<string> | null } | null, twitter?: { __typename?: 'ConfigAuthMethodOauthTwitter', enabled?: boolean | null, consumerKey?: string | null, consumerSecret?: string | null } | null, windowslive?: { __typename?: 'ConfigStandardOauthProviderWithScope', enabled?: boolean | null, clientId?: string | null, clientSecret?: string | null, scope?: Array<string> | null } | null, workos?: { __typename?: 'ConfigAuthMethodOauthWorkos', enabled?: boolean | null, clientId?: string | null, clientSecret?: string | null, connection?: string | null, organization?: string | null } | null } | null } | null } | null } | null }; export type GetSignInMethodsQuery = { __typename?: 'query_root', config?: { __typename: 'ConfigConfig', id: 'ConfigConfig', provider?: { __typename: 'ConfigProvider', id: 'ConfigProvider', sms?: { __typename?: 'ConfigSms', accountSid: string, authToken: string, messagingServiceId: string, provider?: string | null } | null } | null, auth?: { __typename: 'ConfigAuth', id: 'ConfigAuth', method?: { __typename?: 'ConfigAuthMethod', emailPassword?: { __typename?: 'ConfigAuthMethodEmailPassword', emailVerificationRequired?: boolean | null, hibpEnabled?: boolean | null } | null, emailPasswordless?: { __typename?: 'ConfigAuthMethodEmailPasswordless', enabled?: boolean | null } | null, smsPasswordless?: { __typename?: 'ConfigAuthMethodSmsPasswordless', enabled?: boolean | null } | null, anonymous?: { __typename?: 'ConfigAuthMethodAnonymous', enabled?: boolean | null } | null, webauthn?: { __typename?: 'ConfigAuthMethodWebauthn', enabled?: boolean | null } | null, oauth?: { __typename?: 'ConfigAuthMethodOauth', apple?: { __typename?: 'ConfigAuthMethodOauthApple', enabled?: boolean | null, clientId?: string | null, keyId?: string | null, teamId?: string | null, privateKey?: string | null } | null, discord?: { __typename?: 'ConfigStandardOauthProviderWithScope', enabled?: boolean | null, clientId?: string | null, clientSecret?: string | null, scope?: Array<string> | null } | null, facebook?: { __typename?: 'ConfigStandardOauthProviderWithScope', enabled?: boolean | null, clientId?: string | null, clientSecret?: string | null, scope?: Array<string> | null } | null, github?: { __typename?: 'ConfigStandardOauthProviderWithScope', enabled?: boolean | null, clientId?: string | null, clientSecret?: string | null, scope?: Array<string> | null } | null, google?: { __typename?: 'ConfigStandardOauthProviderWithScope', enabled?: boolean | null, clientId?: string | null, clientSecret?: string | null, scope?: Array<string> | null } | null, linkedin?: { __typename?: 'ConfigStandardOauthProviderWithScope', enabled?: boolean | null, clientId?: string | null, clientSecret?: string | null, scope?: Array<string> | null } | null, spotify?: { __typename?: 'ConfigStandardOauthProviderWithScope', enabled?: boolean | null, clientId?: string | null, clientSecret?: string | null, scope?: Array<string> | null } | null, twitch?: { __typename?: 'ConfigStandardOauthProviderWithScope', enabled?: boolean | null, clientId?: string | null, clientSecret?: string | null, scope?: Array<string> | null } | null, twitter?: { __typename?: 'ConfigAuthMethodOauthTwitter', enabled?: boolean | null, consumerKey?: string | null, consumerSecret?: string | null } | null, windowslive?: { __typename?: 'ConfigStandardOauthProviderWithScope', enabled?: boolean | null, clientId?: string | null, clientSecret?: string | null, scope?: Array<string> | null } | null, workos?: { __typename?: 'ConfigAuthMethodOauthWorkos', enabled?: boolean | null, clientId?: string | null, clientSecret?: string | null, connection?: string | null, organization?: string | null } | null, azuread?: { __typename?: 'ConfigAuthMethodOauthAzuread', enabled?: boolean | null, clientId?: string | null, clientSecret?: string | null, tenant?: string | null } | null } | null } | null } | null } | null };
export type GetSmtpSettingsQueryVariables = Exact<{ export type GetSmtpSettingsQueryVariables = Exact<{
appId: Scalars['uuid']; appId: Scalars['uuid'];
@@ -18282,6 +18455,12 @@ export const GetSignInMethodsDocument = gql`
connection connection
organization organization
} }
azuread {
enabled
clientId
clientSecret
tenant
}
} }
} }
} }

View File

@@ -13,7 +13,7 @@ services:
postgres_password: postgres postgres_password: postgres
postgres_user: postgres postgres_user: postgres
auth: auth:
image: nhost/hasura-auth:0.16.1 image: nhost/hasura-auth:0.16.2
storage: storage:
image: nhost/hasura-storage:0.3.0 image: nhost/hasura-storage:0.3.0
auth: auth:

View File

@@ -13,7 +13,7 @@ services:
postgres_password: postgres postgres_password: postgres
postgres_user: postgres postgres_user: postgres
auth: auth:
image: nhost/hasura-auth:0.16.1 image: nhost/hasura-auth:0.16.2
storage: storage:
image: nhost/hasura-storage:0.3.0 image: nhost/hasura-storage:0.3.0
auth: auth:

View File

@@ -13,7 +13,7 @@ services:
postgres_password: postgres postgres_password: postgres
postgres_user: postgres postgres_user: postgres
auth: auth:
image: nhost/hasura-auth:0.16.1 image: nhost/hasura-auth:0.16.2
storage: storage:
image: nhost/hasura-storage:0.3.0 image: nhost/hasura-storage:0.3.0
auth: auth:

View File

@@ -1,5 +1,12 @@
# @nhost/apollo # @nhost/apollo
## 5.2.0
### Patch Changes
- Updated dependencies [a0e093d7]
- @nhost/nhost-js@2.2.0
## 5.1.3 ## 5.1.3
### Patch Changes ### Patch Changes

View File

@@ -1,6 +1,6 @@
{ {
"name": "@nhost/apollo", "name": "@nhost/apollo",
"version": "5.1.3", "version": "5.2.0",
"description": "Nhost Apollo Client library", "description": "Nhost Apollo Client library",
"license": "MIT", "license": "MIT",
"keywords": [ "keywords": [

View File

@@ -1,5 +1,12 @@
# @nhost/react-apollo # @nhost/react-apollo
## 5.0.15
### Patch Changes
- @nhost/apollo@5.2.0
- @nhost/react@2.0.13
## 5.0.14 ## 5.0.14
### Patch Changes ### Patch Changes

View File

@@ -1,6 +1,6 @@
{ {
"name": "@nhost/react-apollo", "name": "@nhost/react-apollo",
"version": "5.0.14", "version": "5.0.15",
"description": "Nhost React Apollo client", "description": "Nhost React Apollo client",
"license": "MIT", "license": "MIT",
"keywords": [ "keywords": [

View File

@@ -1,5 +1,11 @@
# @nhost/react-urql # @nhost/react-urql
## 2.0.13
### Patch Changes
- @nhost/react@2.0.13
## 2.0.12 ## 2.0.12
### Patch Changes ### Patch Changes

View File

@@ -1,6 +1,6 @@
{ {
"name": "@nhost/react-urql", "name": "@nhost/react-urql",
"version": "2.0.12", "version": "2.0.13",
"description": "Nhost React URQL client", "description": "Nhost React URQL client",
"license": "MIT", "license": "MIT",
"keywords": [ "keywords": [

View File

@@ -76,7 +76,7 @@
"husky": "^8.0.1", "husky": "^8.0.1",
"npm-run-all": "^4.1.5", "npm-run-all": "^4.1.5",
"prettier": "^2.7.1", "prettier": "^2.7.1",
"turbo": "1.8.5", "turbo": "1.8.6",
"typedoc": "^0.22.18", "typedoc": "^0.22.18",
"typescript": "4.9.5", "typescript": "4.9.5",
"vite": "^4.0.2", "vite": "^4.0.2",

View File

@@ -1,5 +1,11 @@
# @nhost/hasura-auth-js # @nhost/hasura-auth-js
## 2.1.0
### Minor Changes
- a0e093d7: fix(exports): don't use conflicting names in exports
## 2.0.2 ## 2.0.2
### Patch Changes ### Patch Changes

View File

@@ -1,6 +1,6 @@
{ {
"name": "@nhost/hasura-auth-js", "name": "@nhost/hasura-auth-js",
"version": "2.0.2", "version": "2.1.0",
"description": "Hasura-auth client", "description": "Hasura-auth client",
"license": "MIT", "license": "MIT",
"keywords": [ "keywords": [
@@ -43,7 +43,8 @@
}, },
"scripts": { "scripts": {
"dev": "vite build --config ./vite.dev.config.js", "dev": "vite build --config ./vite.dev.config.js",
"build": "run-p build:lib build:umd", "build": "run-p typecheck build:lib build:umd",
"typecheck": "tsc --noEmit",
"build:lib": "vite build", "build:lib": "vite build",
"build:umd": "vite build --config ../../config/vite.lib.umd.config.js", "build:umd": "vite build --config ../../config/vite.lib.umd.config.js",
"test": "vitest run", "test": "vitest run",

View File

@@ -1,4 +1,4 @@
import { ErrorPayload } from './types' import { AuthErrorPayload } from './types'
export const NETWORK_ERROR_CODE = 0 export const NETWORK_ERROR_CODE = 0
export const OTHER_ERROR_CODE = 1 export const OTHER_ERROR_CODE = 1
@@ -12,8 +12,8 @@ export const STATE_ERROR_CODE = 20
* See https://github.com/statelyai/xstate/issues/3037 * See https://github.com/statelyai/xstate/issues/3037
*/ */
export class CodifiedError extends Error { export class CodifiedError extends Error {
error: ErrorPayload error: AuthErrorPayload
constructor(original: Error | ErrorPayload) { constructor(original: Error | AuthErrorPayload) {
super(original.message) super(original.message)
Error.captureStackTrace(this, this.constructor) Error.captureStackTrace(this, this.constructor)
if (original instanceof Error) { if (original instanceof Error) {
@@ -30,95 +30,95 @@ export class CodifiedError extends Error {
} }
} }
export type ValidationErrorPayload = ErrorPayload & { status: typeof VALIDATION_ERROR_CODE } export type ValidationAuthErrorPayload = AuthErrorPayload & { status: typeof VALIDATION_ERROR_CODE }
// TODO share with hasura-auth // TODO share with hasura-auth
export const INVALID_EMAIL_ERROR: ValidationErrorPayload = { export const INVALID_EMAIL_ERROR: ValidationAuthErrorPayload = {
status: VALIDATION_ERROR_CODE, status: VALIDATION_ERROR_CODE,
error: 'invalid-email', error: 'invalid-email',
message: 'Email is incorrectly formatted' message: 'Email is incorrectly formatted'
} }
export const INVALID_MFA_TYPE_ERROR: ValidationErrorPayload = { export const INVALID_MFA_TYPE_ERROR: ValidationAuthErrorPayload = {
status: VALIDATION_ERROR_CODE, status: VALIDATION_ERROR_CODE,
error: 'invalid-mfa-type', error: 'invalid-mfa-type',
message: 'MFA type is invalid' message: 'MFA type is invalid'
} }
export const INVALID_MFA_CODE_ERROR: ValidationErrorPayload = { export const INVALID_MFA_CODE_ERROR: ValidationAuthErrorPayload = {
status: VALIDATION_ERROR_CODE, status: VALIDATION_ERROR_CODE,
error: 'invalid-mfa-code', error: 'invalid-mfa-code',
message: 'MFA code is invalid' message: 'MFA code is invalid'
} }
export const INVALID_PASSWORD_ERROR: ValidationErrorPayload = { export const INVALID_PASSWORD_ERROR: ValidationAuthErrorPayload = {
status: VALIDATION_ERROR_CODE, status: VALIDATION_ERROR_CODE,
error: 'invalid-password', error: 'invalid-password',
message: 'Password is incorrectly formatted' message: 'Password is incorrectly formatted'
} }
export const INVALID_PHONE_NUMBER_ERROR: ValidationErrorPayload = { export const INVALID_PHONE_NUMBER_ERROR: ValidationAuthErrorPayload = {
status: VALIDATION_ERROR_CODE, status: VALIDATION_ERROR_CODE,
error: 'invalid-phone-number', error: 'invalid-phone-number',
message: 'Phone number is incorrectly formatted' message: 'Phone number is incorrectly formatted'
} }
export const INVALID_MFA_TICKET_ERROR: ValidationErrorPayload = { export const INVALID_MFA_TICKET_ERROR: ValidationAuthErrorPayload = {
status: VALIDATION_ERROR_CODE, status: VALIDATION_ERROR_CODE,
error: 'invalid-mfa-ticket', error: 'invalid-mfa-ticket',
message: 'MFA ticket is invalid' message: 'MFA ticket is invalid'
} }
export const NO_MFA_TICKET_ERROR: ValidationErrorPayload = { export const NO_MFA_TICKET_ERROR: ValidationAuthErrorPayload = {
status: VALIDATION_ERROR_CODE, status: VALIDATION_ERROR_CODE,
error: 'no-mfa-ticket', error: 'no-mfa-ticket',
message: 'No MFA ticket has been provided' message: 'No MFA ticket has been provided'
} }
export const NO_REFRESH_TOKEN: ValidationErrorPayload = { export const NO_REFRESH_TOKEN: ValidationAuthErrorPayload = {
status: VALIDATION_ERROR_CODE, status: VALIDATION_ERROR_CODE,
error: 'no-refresh-token', error: 'no-refresh-token',
message: 'No refresh token has been provided' message: 'No refresh token has been provided'
} }
export const TOKEN_REFRESHER_RUNNING_ERROR: ErrorPayload = { export const TOKEN_REFRESHER_RUNNING_ERROR: AuthErrorPayload = {
status: STATE_ERROR_CODE, status: STATE_ERROR_CODE,
error: 'refresher-already-running', error: 'refresher-already-running',
message: message:
'The token refresher is already running. You must wait until is has finished before submitting a new token.' 'The token refresher is already running. You must wait until is has finished before submitting a new token.'
} }
export const USER_ALREADY_SIGNED_IN: ErrorPayload = { export const USER_ALREADY_SIGNED_IN: AuthErrorPayload = {
status: STATE_ERROR_CODE, status: STATE_ERROR_CODE,
error: 'already-signed-in', error: 'already-signed-in',
message: 'User is already signed in' message: 'User is already signed in'
} }
export const USER_UNAUTHENTICATED: ErrorPayload = { export const USER_UNAUTHENTICATED: AuthErrorPayload = {
status: STATE_ERROR_CODE, status: STATE_ERROR_CODE,
error: 'unauthenticated-user', error: 'unauthenticated-user',
message: 'User is not authenticated' message: 'User is not authenticated'
} }
export const USER_NOT_ANONYMOUS: ErrorPayload = { export const USER_NOT_ANONYMOUS: AuthErrorPayload = {
status: STATE_ERROR_CODE, status: STATE_ERROR_CODE,
error: 'user-not-anonymous', error: 'user-not-anonymous',
message: 'User is not anonymous' message: 'User is not anonymous'
} }
export const EMAIL_NEEDS_VERIFICATION: ErrorPayload = { export const EMAIL_NEEDS_VERIFICATION: AuthErrorPayload = {
status: STATE_ERROR_CODE, status: STATE_ERROR_CODE,
error: 'unverified-user', error: 'unverified-user',
message: 'Email needs verification' message: 'Email needs verification'
} }
export const INVALID_REFRESH_TOKEN = { export const INVALID_REFRESH_TOKEN: AuthErrorPayload = {
status: VALIDATION_ERROR_CODE, status: VALIDATION_ERROR_CODE,
error: 'invalid-refresh-token', error: 'invalid-refresh-token',
message: 'Invalid or expired refresh token' message: 'Invalid or expired refresh token'
} }
export const INVALID_SIGN_IN_METHOD = { export const INVALID_SIGN_IN_METHOD: AuthErrorPayload = {
status: OTHER_ERROR_CODE, status: OTHER_ERROR_CODE,
error: 'invalid-sign-in-method', error: 'invalid-sign-in-method',
message: 'Invalid sign-in method' message: 'Invalid sign-in method'

View File

@@ -34,13 +34,13 @@ import {
} from './promises' } from './promises'
import { import {
AuthChangedFunction, AuthChangedFunction,
AuthErrorPayload,
ChangeEmailParams, ChangeEmailParams,
ChangeEmailResponse, ChangeEmailResponse,
ChangePasswordParams, ChangePasswordParams,
ChangePasswordResponse, ChangePasswordResponse,
DeanonymizeParams, DeanonymizeParams,
DeanonymizeResponse, DeanonymizeResponse,
ErrorPayload,
JWTClaims, JWTClaims,
JWTHasuraClaims, JWTHasuraClaims,
NhostAuthConstructorParams, NhostAuthConstructorParams,
@@ -411,7 +411,7 @@ export class HasuraAuthClient {
*/ */
async addSecurityKey( async addSecurityKey(
nickname?: string nickname?: string
): Promise<{ error: ErrorPayload | null; key?: SecurityKey }> { ): Promise<{ error: AuthErrorPayload | null; key?: SecurityKey }> {
const { error, key } = await addSecurityKeyPromise(this._client, nickname) const { error, key } = await addSecurityKeyPromise(this._client, nickname)
return { error, key } return { error, key }
} }

View File

@@ -1,4 +1,4 @@
import { ErrorPayload, User } from '../../types' import { AuthErrorPayload, User } from '../../types'
export type StateErrorTypes = 'registration' | 'authentication' | 'signout' export type StateErrorTypes = 'registration' | 'authentication' | 'signout'
@@ -21,7 +21,7 @@ export type AuthContext = {
} }
/** Number of times the user tried to get an access token from a refresh token but got a network error */ /** Number of times the user tried to get an access token from a refresh token but got a network error */
importTokenAttempts: number importTokenAttempts: number
errors: Partial<Record<StateErrorTypes, ErrorPayload>> errors: Partial<Record<StateErrorTypes, AuthErrorPayload>>
} }
export const INITIAL_MACHINE_CONTEXT: AuthContext = { export const INITIAL_MACHINE_CONTEXT: AuthContext = {

View File

@@ -24,9 +24,9 @@ import {
} from '../../errors' } from '../../errors'
import { localStorageGetter, localStorageSetter } from '../../local-storage' import { localStorageGetter, localStorageSetter } from '../../local-storage'
import { import {
AuthErrorPayload,
AuthOptions, AuthOptions,
DeanonymizeResponse, DeanonymizeResponse,
ErrorPayload,
NhostSession, NhostSession,
NhostSessionResponse, NhostSessionResponse,
PasswordlessEmailResponse, PasswordlessEmailResponse,
@@ -856,7 +856,7 @@ export const createAuthMachine = ({
error: null error: null
} }
} }
let error: ErrorPayload | null = null let error: AuthErrorPayload | null = null
if (autoSignIn) { if (autoSignIn) {
const urlToken = getParameterByName('refreshToken') || null const urlToken = getParameterByName('refreshToken') || null
if (urlToken) { if (urlToken) {
@@ -866,7 +866,7 @@ export const createAuthMachine = ({
}) })
return { session, error: null } return { session, error: null }
} catch (exception) { } catch (exception) {
error = (exception as { error: ErrorPayload }).error error = (exception as { error: AuthErrorPayload }).error
} }
} else { } else {
const error = getParameterByName('error') const error = getParameterByName('error')
@@ -890,7 +890,7 @@ export const createAuthMachine = ({
}) })
return { session, error: null } return { session, error: null }
} catch (exception) { } catch (exception) {
error = (exception as { error: ErrorPayload }).error error = (exception as { error: AuthErrorPayload }).error
} }
} }
if (error) { if (error) {

View File

@@ -1,12 +1,12 @@
import { assign, createMachine, send } from 'xstate' import { assign, createMachine, send } from 'xstate'
import { INVALID_EMAIL_ERROR } from '../errors' import { INVALID_EMAIL_ERROR } from '../errors'
import { AuthClient } from '../internal-client' import { AuthClient } from '../internal-client'
import { ChangeEmailOptions, ChangeEmailResponse, ErrorPayload } from '../types' import { AuthErrorPayload, ChangeEmailOptions, ChangeEmailResponse } from '../types'
import { postFetch, rewriteRedirectTo } from '../utils' import { postFetch, rewriteRedirectTo } from '../utils'
import { isValidEmail } from '../utils/validators' import { isValidEmail } from '../utils/validators'
export type ChangeEmailContext = { export type ChangeEmailContext = {
error: ErrorPayload | null error: AuthErrorPayload | null
} }
export type ChangeEmailEvents = export type ChangeEmailEvents =
@@ -16,7 +16,7 @@ export type ChangeEmailEvents =
options?: ChangeEmailOptions options?: ChangeEmailOptions
} }
| { type: 'SUCCESS' } | { type: 'SUCCESS' }
| { type: 'ERROR'; error: ErrorPayload | null } | { type: 'ERROR'; error: AuthErrorPayload | null }
export type ChangeEmailServices = { export type ChangeEmailServices = {
request: { data: ChangeEmailResponse } request: { data: ChangeEmailResponse }

View File

@@ -16,9 +16,9 @@ export interface Typegen0 {
} }
missingImplementations: { missingImplementations: {
actions: never actions: never
services: never
guards: never
delays: never delays: never
guards: never
services: never
} }
eventsCausingActions: { eventsCausingActions: {
reportError: 'error.platform.requestChange' reportError: 'error.platform.requestChange'
@@ -26,13 +26,13 @@ export interface Typegen0 {
saveInvalidEmailError: 'REQUEST' saveInvalidEmailError: 'REQUEST'
saveRequestError: 'error.platform.requestChange' saveRequestError: 'error.platform.requestChange'
} }
eventsCausingServices: { eventsCausingDelays: {}
requestChange: 'REQUEST'
}
eventsCausingGuards: { eventsCausingGuards: {
invalidEmail: 'REQUEST' invalidEmail: 'REQUEST'
} }
eventsCausingDelays: {} eventsCausingServices: {
requestChange: 'REQUEST'
}
matchesStates: matchesStates:
| 'idle' | 'idle'
| 'idle.error' | 'idle.error'

View File

@@ -1,12 +1,12 @@
import { assign, createMachine, send } from 'xstate' import { assign, createMachine, send } from 'xstate'
import { INVALID_PASSWORD_ERROR } from '../errors' import { INVALID_PASSWORD_ERROR } from '../errors'
import { AuthClient } from '../internal-client' import { AuthClient } from '../internal-client'
import { ChangePasswordResponse, ErrorPayload } from '../types' import { AuthErrorPayload, ChangePasswordResponse } from '../types'
import { postFetch } from '../utils' import { postFetch } from '../utils'
import { isValidPassword } from '../utils/validators' import { isValidPassword } from '../utils/validators'
export type ChangePasswordContext = { export type ChangePasswordContext = {
error: ErrorPayload | null error: AuthErrorPayload | null
} }
export type ChangePasswordEvents = export type ChangePasswordEvents =
| { | {
@@ -15,7 +15,7 @@ export type ChangePasswordEvents =
ticket?: string ticket?: string
} }
| { type: 'SUCCESS' } | { type: 'SUCCESS' }
| { type: 'ERROR'; error: ErrorPayload | null } | { type: 'ERROR'; error: AuthErrorPayload | null }
export type ChangePasswordServices = { export type ChangePasswordServices = {
requestChange: { data: ChangePasswordResponse } requestChange: { data: ChangePasswordResponse }

View File

@@ -16,9 +16,9 @@ export interface Typegen0 {
} }
missingImplementations: { missingImplementations: {
actions: never actions: never
services: never
guards: never
delays: never delays: never
guards: never
services: never
} }
eventsCausingActions: { eventsCausingActions: {
reportError: 'error.platform.requestChange' reportError: 'error.platform.requestChange'
@@ -26,13 +26,13 @@ export interface Typegen0 {
saveInvalidPasswordError: 'REQUEST' saveInvalidPasswordError: 'REQUEST'
saveRequestError: 'error.platform.requestChange' saveRequestError: 'error.platform.requestChange'
} }
eventsCausingServices: { eventsCausingDelays: {}
requestChange: 'REQUEST'
}
eventsCausingGuards: { eventsCausingGuards: {
invalidPassword: 'REQUEST' invalidPassword: 'REQUEST'
} }
eventsCausingDelays: {} eventsCausingServices: {
requestChange: 'REQUEST'
}
matchesStates: matchesStates:
| 'idle' | 'idle'
| 'idle.error' | 'idle.error'

View File

@@ -1,11 +1,11 @@
import { assign, createMachine, send } from 'xstate' import { assign, createMachine, send } from 'xstate'
import { INVALID_MFA_CODE_ERROR, INVALID_MFA_TYPE_ERROR } from '../errors' import { INVALID_MFA_CODE_ERROR, INVALID_MFA_TYPE_ERROR } from '../errors'
import { AuthClient } from '../internal-client' import { AuthClient } from '../internal-client'
import { ErrorPayload } from '../types' import { AuthErrorPayload } from '../types'
import { getFetch, postFetch } from '../utils' import { getFetch, postFetch } from '../utils'
export type EnableMfaContext = { export type EnableMfaContext = {
error: ErrorPayload | null error: AuthErrorPayload | null
imageUrl: string | null imageUrl: string | null
secret: string | null secret: string | null
} }
@@ -20,9 +20,9 @@ export type EnableMfaEvents =
activeMfaType: 'totp' activeMfaType: 'totp'
} }
| { type: 'GENERATED' } | { type: 'GENERATED' }
| { type: 'GENERATED_ERROR'; error: ErrorPayload | null } | { type: 'GENERATED_ERROR'; error: AuthErrorPayload | null }
| { type: 'SUCCESS' } | { type: 'SUCCESS' }
| { type: 'ERROR'; error: ErrorPayload | null } | { type: 'ERROR'; error: AuthErrorPayload | null }
export type EnableMfadMachine = ReturnType<typeof createEnableMfaMachine> export type EnableMfadMachine = ReturnType<typeof createEnableMfaMachine>

View File

@@ -23,9 +23,9 @@ export interface Typegen0 {
} }
missingImplementations: { missingImplementations: {
actions: never actions: never
services: never
guards: never
delays: never delays: never
guards: never
services: never
} }
eventsCausingActions: { eventsCausingActions: {
reportError: 'error.platform.activate' reportError: 'error.platform.activate'
@@ -37,15 +37,15 @@ export interface Typegen0 {
saveInvalidMfaCodeError: 'ACTIVATE' saveInvalidMfaCodeError: 'ACTIVATE'
saveInvalidMfaTypeError: 'ACTIVATE' saveInvalidMfaTypeError: 'ACTIVATE'
} }
eventsCausingServices: { eventsCausingDelays: {}
activate: 'ACTIVATE'
generate: 'GENERATE'
}
eventsCausingGuards: { eventsCausingGuards: {
invalidMfaCode: 'ACTIVATE' invalidMfaCode: 'ACTIVATE'
invalidMfaType: 'ACTIVATE' invalidMfaType: 'ACTIVATE'
} }
eventsCausingDelays: {} eventsCausingServices: {
activate: 'ACTIVATE'
generate: 'GENERATE'
}
matchesStates: matchesStates:
| 'generated' | 'generated'
| 'generated.activated' | 'generated.activated'

View File

@@ -1,12 +1,12 @@
import { assign, createMachine, send } from 'xstate' import { assign, createMachine, send } from 'xstate'
import { INVALID_EMAIL_ERROR } from '../errors' import { INVALID_EMAIL_ERROR } from '../errors'
import { AuthClient } from '../internal-client' import { AuthClient } from '../internal-client'
import { ErrorPayload, ResetPasswordOptions, ResetPasswordResponse } from '../types' import { AuthErrorPayload, ResetPasswordOptions, ResetPasswordResponse } from '../types'
import { postFetch, rewriteRedirectTo } from '../utils' import { postFetch, rewriteRedirectTo } from '../utils'
import { isValidEmail } from '../utils/validators' import { isValidEmail } from '../utils/validators'
export type ResetPasswordContext = { export type ResetPasswordContext = {
error: ErrorPayload | null error: AuthErrorPayload | null
} }
export type ResetPasswordEvents = export type ResetPasswordEvents =
| { | {
@@ -15,7 +15,7 @@ export type ResetPasswordEvents =
options?: ResetPasswordOptions options?: ResetPasswordOptions
} }
| { type: 'SUCCESS' } | { type: 'SUCCESS' }
| { type: 'ERROR'; error: ErrorPayload | null } | { type: 'ERROR'; error: AuthErrorPayload | null }
export type ResetPasswordServices = { export type ResetPasswordServices = {
requestChange: { data: ResetPasswordResponse } requestChange: { data: ResetPasswordResponse }

View File

@@ -16,9 +16,9 @@ export interface Typegen0 {
} }
missingImplementations: { missingImplementations: {
actions: never actions: never
services: never
guards: never
delays: never delays: never
guards: never
services: never
} }
eventsCausingActions: { eventsCausingActions: {
reportError: 'error.platform.requestChange' reportError: 'error.platform.requestChange'
@@ -26,13 +26,13 @@ export interface Typegen0 {
saveInvalidEmailError: 'REQUEST' saveInvalidEmailError: 'REQUEST'
saveRequestError: 'error.platform.requestChange' saveRequestError: 'error.platform.requestChange'
} }
eventsCausingServices: { eventsCausingDelays: {}
requestChange: 'REQUEST'
}
eventsCausingGuards: { eventsCausingGuards: {
invalidEmail: 'REQUEST' invalidEmail: 'REQUEST'
} }
eventsCausingDelays: {} eventsCausingServices: {
requestChange: 'REQUEST'
}
matchesStates: matchesStates:
| 'idle' | 'idle'
| 'idle.error' | 'idle.error'

View File

@@ -1,12 +1,16 @@
import { assign, createMachine, send } from 'xstate' import { assign, createMachine, send } from 'xstate'
import { INVALID_EMAIL_ERROR } from '../errors' import { INVALID_EMAIL_ERROR } from '../errors'
import { AuthClient } from '../internal-client' import { AuthClient } from '../internal-client'
import { ErrorPayload, SendVerificationEmailOptions, SendVerificationEmailResponse } from '../types' import {
AuthErrorPayload,
SendVerificationEmailOptions,
SendVerificationEmailResponse
} from '../types'
import { postFetch, rewriteRedirectTo } from '../utils' import { postFetch, rewriteRedirectTo } from '../utils'
import { isValidEmail } from '../utils/validators' import { isValidEmail } from '../utils/validators'
export type SendVerificationEmailContext = { export type SendVerificationEmailContext = {
error: ErrorPayload | null error: AuthErrorPayload | null
} }
export type SendVerificationEmailEvents = export type SendVerificationEmailEvents =
@@ -16,7 +20,7 @@ export type SendVerificationEmailEvents =
options?: SendVerificationEmailOptions options?: SendVerificationEmailOptions
} }
| { type: 'SUCCESS' } | { type: 'SUCCESS' }
| { type: 'ERROR'; error: ErrorPayload | null } | { type: 'ERROR'; error: AuthErrorPayload | null }
export type SendVerificationEmailServices = { export type SendVerificationEmailServices = {
request: { data: SendVerificationEmailResponse } request: { data: SendVerificationEmailResponse }

View File

@@ -16,9 +16,9 @@ export interface Typegen0 {
} }
missingImplementations: { missingImplementations: {
actions: never actions: never
services: never
guards: never
delays: never delays: never
guards: never
services: never
} }
eventsCausingActions: { eventsCausingActions: {
reportError: 'error.platform.request' reportError: 'error.platform.request'
@@ -26,13 +26,13 @@ export interface Typegen0 {
saveInvalidEmailError: 'REQUEST' saveInvalidEmailError: 'REQUEST'
saveRequestError: 'error.platform.request' saveRequestError: 'error.platform.request'
} }
eventsCausingServices: { eventsCausingDelays: {}
request: 'REQUEST'
}
eventsCausingGuards: { eventsCausingGuards: {
invalidEmail: 'REQUEST' invalidEmail: 'REQUEST'
} }
eventsCausingDelays: {} eventsCausingServices: {
request: 'REQUEST'
}
matchesStates: matchesStates:
| 'idle' | 'idle'
| 'idle.error' | 'idle.error'

View File

@@ -6,14 +6,14 @@ import {
import { postFetch } from '..' import { postFetch } from '..'
import { CodifiedError } from '../errors' import { CodifiedError } from '../errors'
import { AuthClient } from '../internal-client' import { AuthClient } from '../internal-client'
import { ErrorPayload, SecurityKey } from '../types' import { AuthErrorPayload, SecurityKey } from '../types'
import { ActionErrorState, ActionLoadingState, ActionSuccessState } from './types' import { AuthActionErrorState, AuthActionLoadingState, AuthActionSuccessState } from './types'
export interface AddSecurityKeyHandlerResult extends ActionErrorState, ActionSuccessState { export interface AddSecurityKeyHandlerResult extends AuthActionErrorState, AuthActionSuccessState {
key?: SecurityKey key?: SecurityKey
} }
export interface AddSecurityKeyState extends AddSecurityKeyHandlerResult, ActionLoadingState {} export interface AddSecurityKeyState extends AddSecurityKeyHandlerResult, AuthActionLoadingState {}
export const addSecurityKeyPromise = async ( export const addSecurityKeyPromise = async (
{ backendUrl, interpreter }: AuthClient, { backendUrl, interpreter }: AuthClient,
@@ -38,7 +38,7 @@ export const addSecurityKeyPromise = async (
) )
return { key, isError: false, error: null, isSuccess: true } return { key, isError: false, error: null, isSuccess: true }
} catch (e) { } catch (e) {
const { error } = e as { error: ErrorPayload } const { error } = e as { error: AuthErrorPayload }
return { isError: true, error, isSuccess: false } return { isError: true, error, isSuccess: false }
} }
} }

View File

@@ -3,10 +3,12 @@ import { InterpreterFrom } from 'xstate'
import { ChangeEmailMachine } from '../machines' import { ChangeEmailMachine } from '../machines'
import { ChangeEmailOptions } from '../types' import { ChangeEmailOptions } from '../types'
import { ActionErrorState, ActionLoadingState, NeedsEmailVerificationState } from './types' import { AuthActionErrorState, AuthActionLoadingState, NeedsEmailVerificationState } from './types'
export interface ChangeEmailHandlerResult extends ActionErrorState, NeedsEmailVerificationState {} export interface ChangeEmailHandlerResult
extends AuthActionErrorState,
NeedsEmailVerificationState {}
export interface ChangeEmailState extends ChangeEmailHandlerResult, ActionLoadingState {} export interface ChangeEmailState extends ChangeEmailHandlerResult, AuthActionLoadingState {}
export const changeEmailPromise = async ( export const changeEmailPromise = async (
interpreter: InterpreterFrom<ChangeEmailMachine>, interpreter: InterpreterFrom<ChangeEmailMachine>,

View File

@@ -2,11 +2,11 @@ import { InterpreterFrom } from 'xstate'
import { ChangePasswordMachine } from '../machines' import { ChangePasswordMachine } from '../machines'
import { ActionErrorState, ActionLoadingState, ActionSuccessState } from './types' import { AuthActionErrorState, AuthActionLoadingState, AuthActionSuccessState } from './types'
export interface ChangePasswordState extends ChangePasswordHandlerResult, ActionLoadingState {} export interface ChangePasswordState extends ChangePasswordHandlerResult, AuthActionLoadingState {}
export interface ChangePasswordHandlerResult extends ActionErrorState, ActionSuccessState {} export interface ChangePasswordHandlerResult extends AuthActionErrorState, AuthActionSuccessState {}
export const changePasswordPromise = async ( export const changePasswordPromise = async (
interpreter: InterpreterFrom<ChangePasswordMachine>, interpreter: InterpreterFrom<ChangePasswordMachine>,

View File

@@ -2,9 +2,9 @@ import { InterpreterFrom } from 'xstate'
import { EnableMfadMachine } from '../machines' import { EnableMfadMachine } from '../machines'
import { ActionErrorState } from './types' import { AuthActionErrorState } from './types'
export interface GenerateQrCodeHandlerResult extends ActionErrorState { export interface GenerateQrCodeHandlerResult extends AuthActionErrorState {
qrCodeDataUrl: string qrCodeDataUrl: string
isGenerated: boolean isGenerated: boolean
} }
@@ -12,7 +12,7 @@ export interface GenerateQrCodeHandlerResult extends ActionErrorState {
export interface GenerateQrCodeState extends GenerateQrCodeHandlerResult { export interface GenerateQrCodeState extends GenerateQrCodeHandlerResult {
isGenerating: boolean isGenerating: boolean
} }
export interface ActivateMfaHandlerResult extends ActionErrorState { export interface ActivateMfaHandlerResult extends AuthActionErrorState {
isActivated: boolean isActivated: boolean
} }

View File

@@ -3,14 +3,14 @@ import { InterpreterFrom } from 'xstate'
import { ResetPasswordMachine } from '../machines' import { ResetPasswordMachine } from '../machines'
import { ResetPasswordOptions } from '../types' import { ResetPasswordOptions } from '../types'
import { ActionErrorState, ActionLoadingState } from './types' import { AuthActionErrorState, AuthActionLoadingState } from './types'
export interface ResetPasswordHandlerResult extends ActionErrorState { export interface ResetPasswordHandlerResult extends AuthActionErrorState {
/** Returns `true` when an email to reset the password has been sent */ /** Returns `true` when an email to reset the password has been sent */
isSent: boolean isSent: boolean
} }
export interface ResetPasswordState extends ResetPasswordHandlerResult, ActionLoadingState {} export interface ResetPasswordState extends ResetPasswordHandlerResult, AuthActionLoadingState {}
export const resetPasswordPromise = async ( export const resetPasswordPromise = async (
interpreter: InterpreterFrom<ResetPasswordMachine>, interpreter: InterpreterFrom<ResetPasswordMachine>,

View File

@@ -3,15 +3,15 @@ import { InterpreterFrom } from 'xstate'
import { SendVerificationEmailMachine } from '../machines' import { SendVerificationEmailMachine } from '../machines'
import { SendVerificationEmailOptions } from '../types' import { SendVerificationEmailOptions } from '../types'
import { ActionErrorState, ActionLoadingState } from './types' import { AuthActionErrorState, AuthActionLoadingState } from './types'
export interface SendVerificationEmailHandlerResult extends ActionErrorState { export interface SendVerificationEmailHandlerResult extends AuthActionErrorState {
/** Returns `true` when a new verification email has been sent */ /** Returns `true` when a new verification email has been sent */
isSent: boolean isSent: boolean
} }
export interface SendVerificationEmailState export interface SendVerificationEmailState
extends ActionLoadingState, extends AuthActionLoadingState,
SendVerificationEmailHandlerResult {} SendVerificationEmailHandlerResult {}
export const sendVerificationEmailPromise = ( export const sendVerificationEmailPromise = (

View File

@@ -1,10 +1,12 @@
import { USER_ALREADY_SIGNED_IN } from '../errors' import { USER_ALREADY_SIGNED_IN } from '../errors'
import { AuthInterpreter } from '../machines' import { AuthInterpreter } from '../machines'
import { ActionLoadingState, SessionActionHandlerResult } from './types' import { AuthActionLoadingState, SessionActionHandlerResult } from './types'
export interface SignInAnonymousHandlerResult extends SessionActionHandlerResult {} export interface SignInAnonymousHandlerResult extends SessionActionHandlerResult {}
export interface SignInAnonymousState extends SignInAnonymousHandlerResult, ActionLoadingState {} export interface SignInAnonymousState
extends SignInAnonymousHandlerResult,
AuthActionLoadingState {}
export const signInAnonymousPromise = ( export const signInAnonymousPromise = (
interpreter: AuthInterpreter interpreter: AuthInterpreter

View File

@@ -2,7 +2,7 @@ import { USER_ALREADY_SIGNED_IN } from '../errors'
import { AuthInterpreter } from '../machines' import { AuthInterpreter } from '../machines'
import { import {
ActionLoadingState, AuthActionLoadingState,
NeedsEmailVerificationState, NeedsEmailVerificationState,
SessionActionHandlerResult SessionActionHandlerResult
} from './types' } from './types'
@@ -18,7 +18,7 @@ export interface SignInEmailPasswordHandlerResult
export interface SignInEmailPasswordState export interface SignInEmailPasswordState
extends SignInEmailPasswordHandlerResult, extends SignInEmailPasswordHandlerResult,
ActionLoadingState {} AuthActionLoadingState {}
export const signInEmailPasswordPromise = ( export const signInEmailPasswordPromise = (
interpreter: AuthInterpreter, interpreter: AuthInterpreter,

View File

@@ -2,13 +2,13 @@ import { USER_ALREADY_SIGNED_IN } from '../errors'
import { AuthInterpreter } from '../machines' import { AuthInterpreter } from '../machines'
import { PasswordlessOptions } from '../types' import { PasswordlessOptions } from '../types'
import { ActionErrorState, ActionLoadingState, ActionSuccessState } from './types' import { AuthActionErrorState, AuthActionLoadingState, AuthActionSuccessState } from './types'
export interface SignInEmailPasswordlessHandlerResult export interface SignInEmailPasswordlessHandlerResult
extends ActionErrorState, extends AuthActionErrorState,
ActionSuccessState {} AuthActionSuccessState {}
export interface SignInEmailPasswordlessState export interface SignInEmailPasswordlessState
extends SignInEmailPasswordlessHandlerResult, extends SignInEmailPasswordlessHandlerResult,
ActionLoadingState {} AuthActionLoadingState {}
export const signInEmailPasswordlessPromise = ( export const signInEmailPasswordlessPromise = (
interpreter: AuthInterpreter, interpreter: AuthInterpreter,

View File

@@ -2,7 +2,7 @@ import { USER_ALREADY_SIGNED_IN } from '../errors'
import { AuthInterpreter } from '../machines' import { AuthInterpreter } from '../machines'
import { import {
ActionLoadingState, AuthActionLoadingState,
NeedsEmailVerificationState, NeedsEmailVerificationState,
SessionActionHandlerResult SessionActionHandlerResult
} from './types' } from './types'
@@ -13,7 +13,7 @@ export interface SignInSecurityKeyPasswordlessHandlerResult
export interface SignInSecurityKeyPasswordlessState export interface SignInSecurityKeyPasswordlessState
extends SignInSecurityKeyPasswordlessHandlerResult, extends SignInSecurityKeyPasswordlessHandlerResult,
ActionLoadingState {} AuthActionLoadingState {}
export const signInEmailSecurityKeyPromise = (interpreter: AuthInterpreter, email: string) => export const signInEmailSecurityKeyPromise = (interpreter: AuthInterpreter, email: string) =>
new Promise<SignInSecurityKeyPasswordlessHandlerResult>((resolve) => { new Promise<SignInSecurityKeyPasswordlessHandlerResult>((resolve) => {

View File

@@ -1,11 +1,11 @@
import { USER_ALREADY_SIGNED_IN } from '../errors' import { USER_ALREADY_SIGNED_IN } from '../errors'
import { AuthInterpreter } from '../machines' import { AuthInterpreter } from '../machines'
import { ActionLoadingState, SessionActionHandlerResult } from './types' import { AuthActionLoadingState, SessionActionHandlerResult } from './types'
export interface SignInMfaTotpHandlerResult extends SessionActionHandlerResult {} export interface SignInMfaTotpHandlerResult extends SessionActionHandlerResult {}
export interface SignInMfaTotpState extends SignInMfaTotpHandlerResult, ActionLoadingState {} export interface SignInMfaTotpState extends SignInMfaTotpHandlerResult, AuthActionLoadingState {}
export const signInMfaTotpPromise = (interpreter: AuthInterpreter, otp: string, ticket?: string) => export const signInMfaTotpPromise = (interpreter: AuthInterpreter, otp: string, ticket?: string) =>
new Promise<SignInMfaTotpHandlerResult>((resolve) => { new Promise<SignInMfaTotpHandlerResult>((resolve) => {

View File

@@ -2,13 +2,15 @@ import { USER_ALREADY_SIGNED_IN } from '../errors'
import { AuthInterpreter } from '../machines' import { AuthInterpreter } from '../machines'
import { PasswordlessOptions } from '../types' import { PasswordlessOptions } from '../types'
import { ActionErrorState, ActionLoadingState, ActionSuccessState } from './types' import { AuthActionErrorState, AuthActionLoadingState, AuthActionSuccessState } from './types'
export interface SignInSmsPasswordlessState export interface SignInSmsPasswordlessState
extends SignInSmsPasswordlessHandlerResult, extends SignInSmsPasswordlessHandlerResult,
ActionLoadingState {} AuthActionLoadingState {}
export interface SignInSmsPasswordlessHandlerResult extends ActionErrorState, ActionSuccessState { export interface SignInSmsPasswordlessHandlerResult
extends AuthActionErrorState,
AuthActionSuccessState {
/** /**
* Returns true when the one-time password has been sent over by SMS, and the user needs to send it back to complete sign-in. * Returns true when the one-time password has been sent over by SMS, and the user needs to send it back to complete sign-in.
*/ */

View File

@@ -1,12 +1,12 @@
import { USER_ALREADY_SIGNED_IN } from '../errors' import { USER_ALREADY_SIGNED_IN } from '../errors'
import { AuthInterpreter } from '../machines' import { AuthInterpreter } from '../machines'
import { ActionLoadingState, SessionActionHandlerResult } from './types' import { AuthActionLoadingState, SessionActionHandlerResult } from './types'
export interface SignInSmsPasswordlessOtpHandlerResult extends SessionActionHandlerResult {} export interface SignInSmsPasswordlessOtpHandlerResult extends SessionActionHandlerResult {}
export interface SignInSmsPasswordlessOtpState export interface SignInSmsPasswordlessOtpState
extends SignInSmsPasswordlessOtpHandlerResult, extends SignInSmsPasswordlessOtpHandlerResult,
ActionLoadingState {} AuthActionLoadingState {}
export const signInSmsPasswordlessOtpPromise = ( export const signInSmsPasswordlessOtpPromise = (
interpreter: AuthInterpreter, interpreter: AuthInterpreter,

View File

@@ -1,10 +1,10 @@
import { USER_UNAUTHENTICATED } from '../errors' import { USER_UNAUTHENTICATED } from '../errors'
import { AuthInterpreter } from '../machines' import { AuthInterpreter } from '../machines'
import { ActionErrorState, ActionLoadingState, ActionSuccessState } from './types' import { AuthActionErrorState, AuthActionLoadingState, AuthActionSuccessState } from './types'
export interface SignOutlessHandlerResult extends ActionErrorState, ActionSuccessState {} export interface SignOutlessHandlerResult extends AuthActionErrorState, AuthActionSuccessState {}
export interface SignOutlessState extends SignOutlessHandlerResult, ActionLoadingState {} export interface SignOutlessState extends SignOutlessHandlerResult, AuthActionLoadingState {}
export const signOutPromise = async ( export const signOutPromise = async (
interpreter: AuthInterpreter, interpreter: AuthInterpreter,

View File

@@ -3,7 +3,7 @@ import { AuthInterpreter } from '../machines'
import { SignUpOptions } from '../types' import { SignUpOptions } from '../types'
import { import {
ActionLoadingState, AuthActionLoadingState,
NeedsEmailVerificationState, NeedsEmailVerificationState,
SessionActionHandlerResult SessionActionHandlerResult
} from './types' } from './types'
@@ -14,7 +14,7 @@ export interface SignUpEmailPasswordHandlerResult
export interface SignUpEmailPasswordState export interface SignUpEmailPasswordState
extends SignUpEmailPasswordHandlerResult, extends SignUpEmailPasswordHandlerResult,
ActionLoadingState {} AuthActionLoadingState {}
export const signUpEmailPasswordPromise = ( export const signUpEmailPasswordPromise = (
interpreter: AuthInterpreter, interpreter: AuthInterpreter,

View File

@@ -3,7 +3,7 @@ import { AuthInterpreter } from '../machines'
import { SignUpSecurityKeyOptions } from '../types' import { SignUpSecurityKeyOptions } from '../types'
import { import {
ActionLoadingState, AuthActionLoadingState,
NeedsEmailVerificationState, NeedsEmailVerificationState,
SessionActionHandlerResult SessionActionHandlerResult
} from './types' } from './types'
@@ -14,7 +14,7 @@ export interface SignUpSecurityKeyHandlerResult
export interface SignUpSecurityKeyState export interface SignUpSecurityKeyState
extends SignUpSecurityKeyHandlerResult, extends SignUpSecurityKeyHandlerResult,
ActionLoadingState {} AuthActionLoadingState {}
export const signUpEmailSecurityKeyPromise = ( export const signUpEmailSecurityKeyPromise = (
interpreter: AuthInterpreter, interpreter: AuthInterpreter,

View File

@@ -1,28 +1,28 @@
import { ErrorPayload, User } from '../types' import { AuthErrorPayload, User } from '../types'
export interface ActionErrorState { export interface AuthActionErrorState {
/** /**
* @return `true` if an error occurred * @return `true` if an error occurred
* @depreacted use `!isSuccess` or `!!error` instead * @depreacted use `!isSuccess` or `!!error` instead
* */ * */
isError: boolean isError: boolean
/** Provides details about the error */ /** Provides details about the error */
error: ErrorPayload | null error: AuthErrorPayload | null
} }
export interface ActionLoadingState { export interface AuthActionLoadingState {
/** /**
* @return `true` when the action is executing, `false` when it finished its execution. * @return `true` when the action is executing, `false` when it finished its execution.
*/ */
isLoading: boolean isLoading: boolean
} }
export interface ActionSuccessState { export interface AuthActionSuccessState {
/** Returns `true` if the action is successful. */ /** Returns `true` if the action is successful. */
isSuccess: boolean isSuccess: boolean
} }
export interface SessionActionHandlerResult extends ActionSuccessState, ActionErrorState { export interface SessionActionHandlerResult extends AuthActionSuccessState, AuthActionErrorState {
/** User information */ /** User information */
user: User | null user: User | null
/** Access token (JWT) */ /** Access token (JWT) */

View File

@@ -1,5 +1,5 @@
// TODO shared with other packages // TODO shared with other packages
export type ErrorPayload = { export type AuthErrorPayload = {
error: string error: string
status: number status: number
message: string message: string

View File

@@ -1,13 +1,13 @@
import { ErrorPayload, NhostSession } from './common' import { AuthErrorPayload, NhostSession } from './common'
// Hasura-auth API response types // Hasura-auth API response types
export interface NullableErrorResponse { export interface NullableErrorResponse {
error: ErrorPayload | null error: AuthErrorPayload | null
} }
/** session payload from common hasura-auth responses */ /** session payload from common hasura-auth responses */
export type NhostSessionResponse = export type NhostSessionResponse =
| { session: null; error: ErrorPayload } | { session: null; error: AuthErrorPayload }
| { session: NhostSession | null; error: null } | { session: NhostSession | null; error: null }
/** payload from hasura-auth endpoint /signin/email-password */ /** payload from hasura-auth endpoint /signin/email-password */
@@ -16,7 +16,7 @@ export interface SignInResponse {
mfa: { mfa: {
ticket: string ticket: string
} | null } | null
error: ErrorPayload | null error: AuthErrorPayload | null
} }
/** payload from hasura-auth endpoint /signup/email-password */ /** payload from hasura-auth endpoint /signup/email-password */

View File

@@ -1,5 +1,15 @@
# @nhost/hasura-storage-js # @nhost/hasura-storage-js
## 2.1.0
### Minor Changes
- a0e093d7: fix(exports): don't use conflicting names in exports
### Patch Changes
- bb8803a1: fix(presigned-url): don't alter URL when no transformation params were provided
## 2.0.5 ## 2.0.5
### Patch Changes ### Patch Changes

View File

@@ -1,6 +1,6 @@
{ {
"name": "@nhost/hasura-storage-js", "name": "@nhost/hasura-storage-js",
"version": "2.0.5", "version": "2.1.0",
"description": "Hasura-storage client", "description": "Hasura-storage client",
"license": "MIT", "license": "MIT",
"keywords": [ "keywords": [
@@ -41,7 +41,8 @@
}, },
"scripts": { "scripts": {
"dev": "vite build --config ../../config/vite.lib.dev.config.js", "dev": "vite build --config ../../config/vite.lib.dev.config.js",
"build": "run-p build:lib build:umd", "build": "run-p typecheck build:lib build:umd",
"typecheck": "tsc --noEmit",
"build:lib": "vite build", "build:lib": "vite build",
"build:umd": "vite build --config ../../config/vite.lib.umd.config.js", "build:umd": "vite build --config ../../config/vite.lib.umd.config.js",
"e2e": "start-test e2e:backend http-get://localhost:9695 ci:test", "e2e": "start-test e2e:backend http-get://localhost:9695 ci:test",

View File

@@ -1,12 +1,12 @@
import FormData from 'form-data' import FormData from 'form-data'
import { assign, createMachine } from 'xstate' import { assign, createMachine } from 'xstate'
import { ErrorPayload, FileUploadConfig } from '../utils' import { FileUploadConfig, StorageErrorPayload } from '../utils'
import { fetchUpload } from '../utils/upload' import { fetchUpload } from '../utils/upload'
export type FileUploadContext = { export type FileUploadContext = {
progress: number | null progress: number | null
loaded: number loaded: number
error: ErrorPayload | null error: StorageErrorPayload | null
id?: string id?: string
bucketId?: string bucketId?: string
file?: File file?: File
@@ -24,7 +24,7 @@ export type FileUploadEvents =
} & FileUploadConfig) } & FileUploadConfig)
| { type: 'UPLOAD_PROGRESS'; progress: number; loaded: number; additions: number } | { type: 'UPLOAD_PROGRESS'; progress: number; loaded: number; additions: number }
| { type: 'UPLOAD_DONE'; id: string; bucketId: string } | { type: 'UPLOAD_DONE'; id: string; bucketId: string }
| { type: 'UPLOAD_ERROR'; error: ErrorPayload } | { type: 'UPLOAD_ERROR'; error: StorageErrorPayload }
| { type: 'CANCEL' } | { type: 'CANCEL' }
| { type: 'DESTROY' } | { type: 'DESTROY' }

View File

@@ -1,7 +1,7 @@
import { InterpreterFrom } from 'xstate' import { InterpreterFrom } from 'xstate'
import { FileItemRef, FileUploadMachine } from '../machines' import { FileItemRef, FileUploadMachine } from '../machines'
import { ActionErrorState, FileUploadConfig, StorageUploadFileParams } from '../utils' import { FileUploadConfig, StorageActionErrorState, StorageUploadFileParams } from '../utils'
export interface UploadProgressState { export interface UploadProgressState {
/** /**
@@ -14,7 +14,7 @@ export interface UploadProgressState {
progress: number | null progress: number | null
} }
export interface UploadFileHandlerResult extends ActionErrorState { export interface UploadFileHandlerResult extends StorageActionErrorState {
/** /**
* Returns `true` when the file has been successfully uploaded. * Returns `true` when the file has been successfully uploaded.
*/ */

View File

@@ -3,7 +3,7 @@ import appendImageTransformationParameters from './appendImageTransformationPara
test('should append image transformation parameters to a simple URL', () => { test('should append image transformation parameters to a simple URL', () => {
expect( expect(
appendImageTransformationParameters('https://example.com/', { appendImageTransformationParameters('https://example.com', {
width: 100, width: 100,
height: 100, height: 100,
blur: 50, blur: 50,
@@ -25,7 +25,7 @@ test('should append image transformation parameters to a URL with existing query
test('should not append falsy values', () => { test('should not append falsy values', () => {
expect( expect(
appendImageTransformationParameters('https://example.com/', { appendImageTransformationParameters('https://example.com', {
width: undefined, width: undefined,
height: 100, height: 100,
blur: undefined, blur: undefined,
@@ -35,7 +35,9 @@ test('should not append falsy values', () => {
}) })
test('should keep the original URL if no transformation parameters are provided', () => { test('should keep the original URL if no transformation parameters are provided', () => {
expect(appendImageTransformationParameters('https://example.com/', {})).toBe( expect(appendImageTransformationParameters('https://example.com')).toBe('https://example.com')
'https://example.com/' expect(
) appendImageTransformationParameters('https://example.com/?param1=test_data&param2=test_data')
).toBe('https://example.com/?param1=test_data&param2=test_data')
expect(appendImageTransformationParameters('https://example.com/')).toBe('https://example.com/')
}) })

View File

@@ -12,8 +12,12 @@ import { StorageImageTransformationParams } from '../types'
*/ */
export default function appendImageTransformationParameters( export default function appendImageTransformationParameters(
url: string, url: string,
params: StorageImageTransformationParams params?: StorageImageTransformationParams
): string { ): string {
if (!params || Object.keys(params).length === 0) {
return url
}
const urlObject = new URL(url) const urlObject = new URL(url)
// create an object with the transformation parameters by using the first // create an object with the transformation parameters by using the first

View File

@@ -1,21 +1,21 @@
import FormData from 'form-data' import FormData from 'form-data'
// TODO shared with other packages // TODO shared with other packages
export type ErrorPayload = { export type StorageErrorPayload = {
error: string error: string
status: number status: number
message: string message: string
} }
// TODO shared with other packages // TODO shared with other packages
export interface ActionErrorState { export interface StorageActionErrorState {
/** /**
* @return `true` if an error occurred * @return `true` if an error occurred
* @depreacted use `!isSuccess` or `!!error` instead * @depreacted use `!isSuccess` or `!!error` instead
* */ * */
isError: boolean isError: boolean
/** Provides details about the error */ /** Provides details about the error */
error: ErrorPayload | null error: StorageErrorPayload | null
} }
// * Avoid circular references and broken links in docusaurus generated docs // * Avoid circular references and broken links in docusaurus generated docs
@@ -46,7 +46,7 @@ export type StorageUploadParams = StorageUploadFileParams | StorageUploadFormDat
export type StorageUploadResponse = export type StorageUploadResponse =
| { fileMetadata: FileResponse; error: null } | { fileMetadata: FileResponse; error: null }
| { fileMetadata: null; error: ErrorPayload } | { fileMetadata: null; error: StorageErrorPayload }
export interface StorageImageTransformationParams { export interface StorageImageTransformationParams {
/** Image width, in pixels */ /** Image width, in pixels */

View File

@@ -1,6 +1,6 @@
import FormData from 'form-data' import FormData from 'form-data'
import fetch from 'isomorphic-unfetch' import fetch from 'isomorphic-unfetch'
import { ErrorPayload, StorageUploadResponse } from './types' import { StorageErrorPayload, StorageUploadResponse } from './types'
/** Convert any string into ISO-8859-1 */ /** Convert any string into ISO-8859-1 */
export const toIso88591 = (fileName: string) => { export const toIso88591 = (fileName: string) => {
@@ -59,7 +59,7 @@ export const fetchUpload = async (
}) })
if (!response.ok) { if (!response.ok) {
const error: ErrorPayload = { const error: StorageErrorPayload = {
status: response.status, status: response.status,
message: await response.text(), message: await response.text(),
// * errors from hasura-storage are not codified // * errors from hasura-storage are not codified
@@ -70,7 +70,7 @@ export const fetchUpload = async (
const fileMetadata = await response.json() const fileMetadata = await response.json()
return { fileMetadata, error: null } return { fileMetadata, error: null }
} catch (e) { } catch (e) {
const error: ErrorPayload = { const error: StorageErrorPayload = {
status: 0, status: 0,
message: (e as Error).message, message: (e as Error).message,
error: (e as Error).message error: (e as Error).message

View File

@@ -1,5 +1,11 @@
# @nhost/nextjs # @nhost/nextjs
## 1.13.19
### Patch Changes
- @nhost/react@2.0.13
## 1.13.18 ## 1.13.18
### Patch Changes ### Patch Changes

View File

@@ -1,6 +1,6 @@
{ {
"name": "@nhost/nextjs", "name": "@nhost/nextjs",
"version": "1.13.18", "version": "1.13.19",
"description": "Nhost NextJS library", "description": "Nhost NextJS library",
"license": "MIT", "license": "MIT",
"keywords": [ "keywords": [

View File

@@ -1,5 +1,18 @@
# @nhost/nhost-js # @nhost/nhost-js
## 2.2.0
### Minor Changes
- a0e093d7: fix(exports): don't use conflicting names in exports
### Patch Changes
- Updated dependencies [bb8803a1]
- Updated dependencies [a0e093d7]
- @nhost/hasura-storage-js@2.1.0
- @nhost/hasura-auth-js@2.1.0
## 2.1.2 ## 2.1.2
### Patch Changes ### Patch Changes

View File

@@ -1,6 +1,6 @@
{ {
"name": "@nhost/nhost-js", "name": "@nhost/nhost-js",
"version": "2.1.2", "version": "2.2.0",
"description": "Nhost JavaScript SDK", "description": "Nhost JavaScript SDK",
"license": "MIT", "license": "MIT",
"keywords": [ "keywords": [
@@ -44,7 +44,8 @@
}, },
"scripts": { "scripts": {
"dev": "vite build --config ../../config/vite.lib.dev.config.js", "dev": "vite build --config ../../config/vite.lib.dev.config.js",
"build": "run-p build:lib build:umd", "build": "run-p typecheck build:lib build:umd",
"typecheck": "tsc --noEmit",
"build:lib": "vite build", "build:lib": "vite build",
"build:umd": "vite build --config ../../config/vite.lib.umd.config.js", "build:umd": "vite build --config ../../config/vite.lib.umd.config.js",
"test": "vitest run", "test": "vitest run",

View File

@@ -1,10 +1,4 @@
export * from '@nhost/hasura-auth-js' export * from '@nhost/hasura-auth-js'
// ErrorPayload and ActionErrorState are two conflicting types, but these are
// the same in both packages, so this error is ignored for now.
// @ts-ignore
export * from '@nhost/hasura-storage-js' export * from '@nhost/hasura-storage-js'
export * from './clients' export * from './clients'
// ErrorPayload is conflicting types, but it is the same in both packages,
// so this error is ignored for now.
// @ts-ignore
export * from './utils/types' export * from './utils/types'

View File

@@ -1,11 +1,37 @@
import { NhostAuthConstructorParams } from '@nhost/hasura-auth-js' import { NhostAuthConstructorParams } from '@nhost/hasura-auth-js'
// TODO shared with other packages // TODO shared with other packages
export type ErrorPayload = { export interface ErrorPayload {
error: string error: string
status: number status: number
message: string message: string
} }
// TODO shared with other packages
export interface ActionErrorState {
/**
* @return `true` if an error occurred
* @depreacted use `!isSuccess` or `!!error` instead
* */
isError: boolean
/** Provides details about the error */
error: ErrorPayload | null
}
// TODO shared with other packages
export interface ActionLoadingState {
/**
* @return `true` when the action is executing, `false` when it finished its execution.
*/
isLoading: boolean
}
// TODO shared with other packages
export interface ActionSuccessState {
/** Returns `true` if the action is successful. */
isSuccess: boolean
}
export type BackendUrl = { export type BackendUrl = {
/** /**
* Nhost backend URL * Nhost backend URL

View File

@@ -1,5 +1,12 @@
# @nhost/react # @nhost/react
## 2.0.13
### Patch Changes
- Updated dependencies [a0e093d7]
- @nhost/nhost-js@2.2.0
## 2.0.12 ## 2.0.12
### Patch Changes ### Patch Changes

View File

@@ -1,6 +1,6 @@
{ {
"name": "@nhost/react", "name": "@nhost/react",
"version": "2.0.12", "version": "2.0.13",
"description": "Nhost React library", "description": "Nhost React library",
"license": "MIT", "license": "MIT",
"keywords": [ "keywords": [

View File

@@ -1,5 +1,12 @@
# @nhost/vue # @nhost/vue
## 1.13.19
### Patch Changes
- Updated dependencies [a0e093d7]
- @nhost/nhost-js@2.2.0
## 1.13.18 ## 1.13.18
### Patch Changes ### Patch Changes

View File

@@ -1,6 +1,6 @@
{ {
"name": "@nhost/vue", "name": "@nhost/vue",
"version": "1.13.18", "version": "1.13.19",
"description": "Nhost Vue library", "description": "Nhost Vue library",
"license": "MIT", "license": "MIT",
"keywords": [ "keywords": [

228
pnpm-lock.yaml generated
View File

@@ -32,7 +32,7 @@ importers:
husky: ^8.0.1 husky: ^8.0.1
npm-run-all: ^4.1.5 npm-run-all: ^4.1.5
prettier: ^2.7.1 prettier: ^2.7.1
turbo: 1.8.5 turbo: 1.8.6
typedoc: ^0.22.18 typedoc: ^0.22.18
typescript: 4.9.5 typescript: 4.9.5
vite: ^4.0.2 vite: ^4.0.2
@@ -65,7 +65,7 @@ importers:
husky: 8.0.1 husky: 8.0.1
npm-run-all: 4.1.5 npm-run-all: 4.1.5
prettier: 2.7.1 prettier: 2.7.1
turbo: 1.8.5 turbo: 1.8.6
typedoc: 0.22.18_typescript@4.9.5 typedoc: 0.22.18_typescript@4.9.5
typescript: 4.9.5 typescript: 4.9.5
vite: 4.0.2_@types+node@16.18.11 vite: 4.0.2_@types+node@16.18.11
@@ -126,7 +126,7 @@ importers:
'@types/lodash.debounce': ^4.0.7 '@types/lodash.debounce': ^4.0.7
'@types/node': ^16.11.7 '@types/node': ^16.11.7
'@types/pluralize': ^0.0.29 '@types/pluralize': ^0.0.29
'@types/react': 18.0.28 '@types/react': 18.0.30
'@types/react-dom': 18.0.11 '@types/react-dom': 18.0.11
'@types/react-table': ^7.7.12 '@types/react-table': ^7.7.12
'@types/testing-library__jest-dom': ^5.14.5 '@types/testing-library__jest-dom': ^5.14.5
@@ -190,6 +190,7 @@ importers:
require-from-string: ^2.0.2 require-from-string: ^2.0.2
sharp: ^0.32.0 sharp: ^0.32.0
slugify: ^1.6.5 slugify: ^1.6.5
snake-case: ^3.0.4
storybook-addon-next-router: ^4.0.1 storybook-addon-next-router: ^4.0.1
stripe: ^10.17.0 stripe: ^10.17.0
tailwind-merge: ^1.8.0 tailwind-merge: ^1.8.0
@@ -208,19 +209,19 @@ importers:
'@apollo/client': 3.7.10_xe4twbeoqswbn2uas4ov5melbq '@apollo/client': 3.7.10_xe4twbeoqswbn2uas4ov5melbq
'@codemirror/language': 6.3.1 '@codemirror/language': 6.3.1
'@emotion/cache': 11.10.5 '@emotion/cache': 11.10.5
'@emotion/react': 11.10.5_iznqm25yxu4trtkqop3zznseca '@emotion/react': 11.10.5_lzn74h6sajlbfmrxbix4okzmpi
'@emotion/server': 11.4.0 '@emotion/server': 11.4.0
'@emotion/styled': 11.10.5_4ahanhknrtlidghakifap67h7q '@emotion/styled': 11.10.5_4jddrkedmmycnrpdaatf3tfj3a
'@fontsource/inter': 4.5.14 '@fontsource/inter': 4.5.14
'@fontsource/roboto-mono': 4.5.8 '@fontsource/roboto-mono': 4.5.8
'@graphiql/react': 0.17.0_755ntyjuho6qjwic26h62or3by '@graphiql/react': 0.17.0_7bopqva7rdmx76dydi5rwteyri
'@graphiql/toolkit': 0.8.2_7fbl5omhlrpwpn5f5culy6mafe '@graphiql/toolkit': 0.8.2_7fbl5omhlrpwpn5f5culy6mafe
'@headlessui/react': 1.7.4_biqbaboplfbrettd7655fr4n2y '@headlessui/react': 1.7.4_biqbaboplfbrettd7655fr4n2y
'@heroicons/react': 1.0.6_react@18.2.0 '@heroicons/react': 1.0.6_react@18.2.0
'@hookform/resolvers': 3.0.0_react-hook-form@7.42.1 '@hookform/resolvers': 3.0.0_react-hook-form@7.42.1
'@mui/base': 5.0.0-alpha.106_zula6vjvt3wdocc4mwcxqa6nzi '@mui/base': 5.0.0-alpha.106_4qaawyptjkcgzqorucvhm3koke
'@mui/material': 5.10.14_acl7mc3llczqccvmbrsweq6vga '@mui/material': 5.10.14_ogvxv7hqfgg53da5eqs77qdqde
'@mui/system': 5.10.14_teoksulxetwanny5ohzazahldq '@mui/system': 5.10.14_yunkbz2mvya45l5iqzwl5ypfyq
'@mui/x-date-pickers': 5.0.8_p6r6qp7wldbu5ojdsmv4yukx2q '@mui/x-date-pickers': 5.0.8_p6r6qp7wldbu5ojdsmv4yukx2q
'@nhost/nextjs': link:../packages/nextjs '@nhost/nextjs': link:../packages/nextjs
'@nhost/react-apollo': link:../integrations/react-apollo '@nhost/react-apollo': link:../integrations/react-apollo
@@ -236,7 +237,7 @@ importers:
clsx: 1.2.1 clsx: 1.2.1
date-fns: 2.29.3 date-fns: 2.29.3
generate-password: 1.7.0 generate-password: 1.7.0
graphiql: 2.4.0_755ntyjuho6qjwic26h62or3by graphiql: 2.4.0_7bopqva7rdmx76dydi5rwteyri
graphql: 16.6.0 graphql: 16.6.0
graphql-request: 4.3.0_rjjjs2nwgns3bcvnnqb5eu5nry graphql-request: 4.3.0_rjjjs2nwgns3bcvnnqb5eu5nry
graphql-tag: 2.12.6_graphql@16.6.0 graphql-tag: 2.12.6_graphql@16.6.0
@@ -278,7 +279,7 @@ importers:
'@playwright/test': 1.31.2 '@playwright/test': 1.31.2
'@storybook/addon-actions': 6.5.14_biqbaboplfbrettd7655fr4n2y '@storybook/addon-actions': 6.5.14_biqbaboplfbrettd7655fr4n2y
'@storybook/addon-essentials': 6.5.14_2d2r642xwmvaauuvastzobrbwe '@storybook/addon-essentials': 6.5.14_2d2r642xwmvaauuvastzobrbwe
'@storybook/addon-interactions': 6.5.14_o2w7dvvbfxaohzk6den2xlbkgq '@storybook/addon-interactions': 6.5.14_hvoc3iuqa2ltaiia3y4i66hvou
'@storybook/addon-links': 6.5.14_biqbaboplfbrettd7655fr4n2y '@storybook/addon-links': 6.5.14_biqbaboplfbrettd7655fr4n2y
'@storybook/addon-postcss': 2.0.0_webpack@5.75.0 '@storybook/addon-postcss': 2.0.0_webpack@5.75.0
'@storybook/builder-webpack5': 6.5.14_uddrmzyyotmol3pts5dayjifei '@storybook/builder-webpack5': 6.5.14_uddrmzyyotmol3pts5dayjifei
@@ -292,7 +293,7 @@ importers:
'@types/lodash.debounce': 4.0.7 '@types/lodash.debounce': 4.0.7
'@types/node': 16.18.11 '@types/node': 16.18.11
'@types/pluralize': 0.0.29 '@types/pluralize': 0.0.29
'@types/react': 18.0.28 '@types/react': 18.0.30
'@types/react-dom': 18.0.11 '@types/react-dom': 18.0.11
'@types/react-table': 7.7.12 '@types/react-table': 7.7.12
'@types/testing-library__jest-dom': 5.14.5 '@types/testing-library__jest-dom': 5.14.5
@@ -327,6 +328,7 @@ importers:
prettier-plugin-tailwindcss: 0.2.0_prettier@2.7.1 prettier-plugin-tailwindcss: 0.2.0_prettier@2.7.1
react-date-fns-hooks: 0.9.4_3pf3ktbrffvgnzxoo2eotyjcpi react-date-fns-hooks: 0.9.4_3pf3ktbrffvgnzxoo2eotyjcpi
require-from-string: 2.0.2 require-from-string: 2.0.2
snake-case: 3.0.4
storybook-addon-next-router: 4.0.1_tu4orvw3rpr5ktbmb2kplp4vty storybook-addon-next-router: 4.0.1_tu4orvw3rpr5ktbmb2kplp4vty
tailwindcss: 3.2.1_v776zzvn44o7tpgzieipaairwm tailwindcss: 3.2.1_v776zzvn44o7tpgzieipaairwm
ts-node: 10.9.1_@types+node@16.18.11 ts-node: 10.9.1_@types+node@16.18.11
@@ -4541,7 +4543,7 @@ packages:
'@date-io/core': 2.16.0 '@date-io/core': 2.16.0
dev: false dev: false
/@design-systems/utils/2.12.0_zula6vjvt3wdocc4mwcxqa6nzi: /@design-systems/utils/2.12.0_4qaawyptjkcgzqorucvhm3koke:
resolution: {integrity: sha512-Y/d2Zzr+JJfN6u1gbuBUb1ufBuLMJJRZQk+dRmw8GaTpqKx5uf7cGUYGTwN02dIb3I+Tf+cW8jcGBTRiFxdYFg==} resolution: {integrity: sha512-Y/d2Zzr+JJfN6u1gbuBUb1ufBuLMJJRZQk+dRmw8GaTpqKx5uf7cGUYGTwN02dIb3I+Tf+cW8jcGBTRiFxdYFg==}
peerDependencies: peerDependencies:
'@types/react': '*' '@types/react': '*'
@@ -4549,7 +4551,7 @@ packages:
react-dom: '>= 16.8.6' react-dom: '>= 16.8.6'
dependencies: dependencies:
'@babel/runtime': 7.20.1 '@babel/runtime': 7.20.1
'@types/react': 18.0.28 '@types/react': 18.0.30
clsx: 1.2.1 clsx: 1.2.1
focus-lock: 0.8.1 focus-lock: 0.8.1
react: 18.2.0 react: 18.2.0
@@ -4557,15 +4559,15 @@ packages:
react-merge-refs: 1.1.0 react-merge-refs: 1.1.0
dev: true dev: true
/@devtools-ds/object-inspector/1.2.0_zula6vjvt3wdocc4mwcxqa6nzi: /@devtools-ds/object-inspector/1.2.0_4qaawyptjkcgzqorucvhm3koke:
resolution: {integrity: sha512-VztcwqVwScSvYdvJVZBJYsVO/2Pew3JPpFV3T9fuCHQLlHcLYOV3aU/kBS2ScuE2O1JN0ZbobLqFLa3vQF54Fw==} resolution: {integrity: sha512-VztcwqVwScSvYdvJVZBJYsVO/2Pew3JPpFV3T9fuCHQLlHcLYOV3aU/kBS2ScuE2O1JN0ZbobLqFLa3vQF54Fw==}
peerDependencies: peerDependencies:
react: '>= 16.8.6' react: '>= 16.8.6'
dependencies: dependencies:
'@babel/runtime': 7.7.2 '@babel/runtime': 7.7.2
'@devtools-ds/object-parser': 1.2.0 '@devtools-ds/object-parser': 1.2.0
'@devtools-ds/themes': 1.2.0_zula6vjvt3wdocc4mwcxqa6nzi '@devtools-ds/themes': 1.2.0_4qaawyptjkcgzqorucvhm3koke
'@devtools-ds/tree': 1.2.0_zula6vjvt3wdocc4mwcxqa6nzi '@devtools-ds/tree': 1.2.0_4qaawyptjkcgzqorucvhm3koke
clsx: 1.1.0 clsx: 1.1.0
react: 18.2.0 react: 18.2.0
transitivePeerDependencies: transitivePeerDependencies:
@@ -4579,13 +4581,13 @@ packages:
'@babel/runtime': 7.5.5 '@babel/runtime': 7.5.5
dev: true dev: true
/@devtools-ds/themes/1.2.0_zula6vjvt3wdocc4mwcxqa6nzi: /@devtools-ds/themes/1.2.0_4qaawyptjkcgzqorucvhm3koke:
resolution: {integrity: sha512-LimEITorE6yWZWWuMc6OiBfLQgPrQqWbyMEmfRUDPa3PHXoAY4SpDxczfg31fgyRDUNWnZhjaJH5bBbu8VEbIw==} resolution: {integrity: sha512-LimEITorE6yWZWWuMc6OiBfLQgPrQqWbyMEmfRUDPa3PHXoAY4SpDxczfg31fgyRDUNWnZhjaJH5bBbu8VEbIw==}
peerDependencies: peerDependencies:
react: '>= 16.8.6' react: '>= 16.8.6'
dependencies: dependencies:
'@babel/runtime': 7.5.5 '@babel/runtime': 7.5.5
'@design-systems/utils': 2.12.0_zula6vjvt3wdocc4mwcxqa6nzi '@design-systems/utils': 2.12.0_4qaawyptjkcgzqorucvhm3koke
clsx: 1.1.0 clsx: 1.1.0
react: 18.2.0 react: 18.2.0
transitivePeerDependencies: transitivePeerDependencies:
@@ -4593,13 +4595,13 @@ packages:
- react-dom - react-dom
dev: true dev: true
/@devtools-ds/tree/1.2.0_zula6vjvt3wdocc4mwcxqa6nzi: /@devtools-ds/tree/1.2.0_4qaawyptjkcgzqorucvhm3koke:
resolution: {integrity: sha512-hC4g4ocuo2eg7jsnzKdauxH0sDQiPW3KSM2+uK3kRgcmr9PzpBD5Kob+Y/WFSVKswFleftOGKL4BQLuRv0sPxA==} resolution: {integrity: sha512-hC4g4ocuo2eg7jsnzKdauxH0sDQiPW3KSM2+uK3kRgcmr9PzpBD5Kob+Y/WFSVKswFleftOGKL4BQLuRv0sPxA==}
peerDependencies: peerDependencies:
react: '>= 16.8.6' react: '>= 16.8.6'
dependencies: dependencies:
'@babel/runtime': 7.7.2 '@babel/runtime': 7.7.2
'@devtools-ds/themes': 1.2.0_zula6vjvt3wdocc4mwcxqa6nzi '@devtools-ds/themes': 1.2.0_4qaawyptjkcgzqorucvhm3koke
clsx: 1.1.0 clsx: 1.1.0
react: 18.2.0 react: 18.2.0
transitivePeerDependencies: transitivePeerDependencies:
@@ -4937,7 +4939,7 @@ packages:
'@docusaurus/react-loadable': 5.5.2_react@18.2.0 '@docusaurus/react-loadable': 5.5.2_react@18.2.0
'@docusaurus/types': 2.4.0_biqbaboplfbrettd7655fr4n2y '@docusaurus/types': 2.4.0_biqbaboplfbrettd7655fr4n2y
'@types/history': 4.7.11 '@types/history': 4.7.11
'@types/react': 18.0.28 '@types/react': 18.0.30
'@types/react-router-config': 5.0.6 '@types/react-router-config': 5.0.6
'@types/react-router-dom': 5.3.3 '@types/react-router-dom': 5.3.3
react: 18.2.0 react: 18.2.0
@@ -5283,7 +5285,7 @@ packages:
peerDependencies: peerDependencies:
react: '*' react: '*'
dependencies: dependencies:
'@types/react': 18.0.28 '@types/react': 18.0.30
prop-types: 15.8.1 prop-types: 15.8.1
react: 18.2.0 react: 18.2.0
@@ -5354,7 +5356,7 @@ packages:
'@docusaurus/utils': 2.4.0_@docusaurus+types@2.4.0 '@docusaurus/utils': 2.4.0_@docusaurus+types@2.4.0
'@docusaurus/utils-common': 2.4.0_@docusaurus+types@2.4.0 '@docusaurus/utils-common': 2.4.0_@docusaurus+types@2.4.0
'@types/history': 4.7.11 '@types/history': 4.7.11
'@types/react': 18.0.28 '@types/react': 18.0.30
'@types/react-router-config': 5.0.6 '@types/react-router-config': 5.0.6
clsx: 1.2.1 clsx: 1.2.1
parse-numeric-range: 1.3.0 parse-numeric-range: 1.3.0
@@ -5444,7 +5446,7 @@ packages:
react-dom: ^16.8.4 || ^17.0.0 react-dom: ^16.8.4 || ^17.0.0
dependencies: dependencies:
'@types/history': 4.7.11 '@types/history': 4.7.11
'@types/react': 18.0.28 '@types/react': 18.0.30
commander: 5.1.0 commander: 5.1.0
joi: 17.7.0 joi: 17.7.0
react: 18.2.0 react: 18.2.0
@@ -5684,7 +5686,7 @@ packages:
resolution: {integrity: sha512-G/YwXTkv7Den9mXDO7AhLWkE3q+I92B+VqAE+dYG4NGPaHZGvt3G8Q0p9vmE+sq7rTGphUbAvmQ9YpbfMQGGlA==} resolution: {integrity: sha512-G/YwXTkv7Den9mXDO7AhLWkE3q+I92B+VqAE+dYG4NGPaHZGvt3G8Q0p9vmE+sq7rTGphUbAvmQ9YpbfMQGGlA==}
dev: false dev: false
/@emotion/react/11.10.5_iznqm25yxu4trtkqop3zznseca: /@emotion/react/11.10.5_lzn74h6sajlbfmrxbix4okzmpi:
resolution: {integrity: sha512-TZs6235tCJ/7iF6/rvTaOH4oxQg2gMAcdHemjwLKIjKz4rRuYe1HJ2TQJKnAcRAfOUDdU8XoDadCe1rl72iv8A==} resolution: {integrity: sha512-TZs6235tCJ/7iF6/rvTaOH4oxQg2gMAcdHemjwLKIjKz4rRuYe1HJ2TQJKnAcRAfOUDdU8XoDadCe1rl72iv8A==}
peerDependencies: peerDependencies:
'@babel/core': ^7.0.0 '@babel/core': ^7.0.0
@@ -5704,7 +5706,7 @@ packages:
'@emotion/use-insertion-effect-with-fallbacks': 1.0.0_react@18.2.0 '@emotion/use-insertion-effect-with-fallbacks': 1.0.0_react@18.2.0
'@emotion/utils': 1.2.0 '@emotion/utils': 1.2.0
'@emotion/weak-memoize': 0.3.0 '@emotion/weak-memoize': 0.3.0
'@types/react': 18.0.28 '@types/react': 18.0.30
hoist-non-react-statics: 3.3.2 hoist-non-react-statics: 3.3.2
react: 18.2.0 react: 18.2.0
dev: false dev: false
@@ -5784,7 +5786,7 @@ packages:
resolution: {integrity: sha512-zxRBwl93sHMsOj4zs+OslQKg/uhF38MB+OMKoCrVuS0nyTkqnau+BM3WGEoOptg9Oz45T/aIGs1qbVAsEFo3nA==} resolution: {integrity: sha512-zxRBwl93sHMsOj4zs+OslQKg/uhF38MB+OMKoCrVuS0nyTkqnau+BM3WGEoOptg9Oz45T/aIGs1qbVAsEFo3nA==}
dev: false dev: false
/@emotion/styled/11.10.5_4ahanhknrtlidghakifap67h7q: /@emotion/styled/11.10.5_4jddrkedmmycnrpdaatf3tfj3a:
resolution: {integrity: sha512-8EP6dD7dMkdku2foLoruPCNkRevzdcBaY6q0l0OsbyJK+x8D9HWjX27ARiSIKNF634hY9Zdoedh8bJCiva8yZw==} resolution: {integrity: sha512-8EP6dD7dMkdku2foLoruPCNkRevzdcBaY6q0l0OsbyJK+x8D9HWjX27ARiSIKNF634hY9Zdoedh8bJCiva8yZw==}
peerDependencies: peerDependencies:
'@babel/core': ^7.0.0 '@babel/core': ^7.0.0
@@ -5801,11 +5803,11 @@ packages:
'@babel/runtime': 7.19.4 '@babel/runtime': 7.19.4
'@emotion/babel-plugin': 11.10.5_@babel+core@7.20.2 '@emotion/babel-plugin': 11.10.5_@babel+core@7.20.2
'@emotion/is-prop-valid': 1.2.0 '@emotion/is-prop-valid': 1.2.0
'@emotion/react': 11.10.5_iznqm25yxu4trtkqop3zznseca '@emotion/react': 11.10.5_lzn74h6sajlbfmrxbix4okzmpi
'@emotion/serialize': 1.1.1 '@emotion/serialize': 1.1.1
'@emotion/use-insertion-effect-with-fallbacks': 1.0.0_react@18.2.0 '@emotion/use-insertion-effect-with-fallbacks': 1.0.0_react@18.2.0
'@emotion/utils': 1.2.0 '@emotion/utils': 1.2.0
'@types/react': 18.0.28 '@types/react': 18.0.30
react: 18.2.0 react: 18.2.0
dev: false dev: false
@@ -6417,7 +6419,7 @@ packages:
/@gqty/utils/1.0.0: /@gqty/utils/1.0.0:
resolution: {integrity: sha512-QJMlzts//d0H5mlekOZgx1a4KsTYXfxmRhhx8g/8mvzdaNVPxhFzCsv3+ljTOzbW3A08qy4jXQPWAMoTefSJDQ==} resolution: {integrity: sha512-QJMlzts//d0H5mlekOZgx1a4KsTYXfxmRhhx8g/8mvzdaNVPxhFzCsv3+ljTOzbW3A08qy4jXQPWAMoTefSJDQ==}
/@graphiql/react/0.17.0_755ntyjuho6qjwic26h62or3by: /@graphiql/react/0.17.0_7bopqva7rdmx76dydi5rwteyri:
resolution: {integrity: sha512-mn8FfucLJzFLQQ5OoJ9U1Dvnva1smOxBL89D2TSM2B6mmDyQIRhFXmjzUTPdsqwpauFiqkDaQZiqX7T/ZPrg/w==} resolution: {integrity: sha512-mn8FfucLJzFLQQ5OoJ9U1Dvnva1smOxBL89D2TSM2B6mmDyQIRhFXmjzUTPdsqwpauFiqkDaQZiqX7T/ZPrg/w==}
peerDependencies: peerDependencies:
graphql: ^15.5.0 || ^16.0.0 graphql: ^15.5.0 || ^16.0.0
@@ -6426,7 +6428,7 @@ packages:
dependencies: dependencies:
'@graphiql/toolkit': 0.8.2_7fbl5omhlrpwpn5f5culy6mafe '@graphiql/toolkit': 0.8.2_7fbl5omhlrpwpn5f5culy6mafe
'@reach/combobox': 0.17.0_biqbaboplfbrettd7655fr4n2y '@reach/combobox': 0.17.0_biqbaboplfbrettd7655fr4n2y
'@reach/dialog': 0.17.0_zula6vjvt3wdocc4mwcxqa6nzi '@reach/dialog': 0.17.0_4qaawyptjkcgzqorucvhm3koke
'@reach/listbox': 0.17.0_biqbaboplfbrettd7655fr4n2y '@reach/listbox': 0.17.0_biqbaboplfbrettd7655fr4n2y
'@reach/menu-button': 0.17.0_7i5myeigehqah43i5u7wbekgba '@reach/menu-button': 0.17.0_7i5myeigehqah43i5u7wbekgba
'@reach/tooltip': 0.17.0_biqbaboplfbrettd7655fr4n2y '@reach/tooltip': 0.17.0_biqbaboplfbrettd7655fr4n2y
@@ -8687,7 +8689,7 @@ packages:
- supports-color - supports-color
dev: true dev: true
/@mui/base/5.0.0-alpha.106_zula6vjvt3wdocc4mwcxqa6nzi: /@mui/base/5.0.0-alpha.106_4qaawyptjkcgzqorucvhm3koke:
resolution: {integrity: sha512-xJQQtwPCPwr6hGWTBdvDwHYwExn3Bw7nPQkN8Fuz8kHpZqoMVWQvvaFS557AIkkI2AFLV3DxVIMjbCvrIntBWg==} resolution: {integrity: sha512-xJQQtwPCPwr6hGWTBdvDwHYwExn3Bw7nPQkN8Fuz8kHpZqoMVWQvvaFS557AIkkI2AFLV3DxVIMjbCvrIntBWg==}
engines: {node: '>=12.0.0'} engines: {node: '>=12.0.0'}
peerDependencies: peerDependencies:
@@ -8700,10 +8702,10 @@ packages:
dependencies: dependencies:
'@babel/runtime': 7.20.1 '@babel/runtime': 7.20.1
'@emotion/is-prop-valid': 1.2.0 '@emotion/is-prop-valid': 1.2.0
'@mui/types': 7.2.1_@types+react@18.0.28 '@mui/types': 7.2.1_@types+react@18.0.30
'@mui/utils': 5.10.14_react@18.2.0 '@mui/utils': 5.10.14_react@18.2.0
'@popperjs/core': 2.11.6 '@popperjs/core': 2.11.6
'@types/react': 18.0.28 '@types/react': 18.0.30
clsx: 1.2.1 clsx: 1.2.1
prop-types: 15.8.1 prop-types: 15.8.1
react: 18.2.0 react: 18.2.0
@@ -8715,7 +8717,7 @@ packages:
resolution: {integrity: sha512-qLgIJNOR9Dre8JiZ/neVzOf4jf88J6YtOkQqugtMrleLjbfRVUSS4LWl9CSOjNq76quYdmYWnSDgfQqOooT2cQ==} resolution: {integrity: sha512-qLgIJNOR9Dre8JiZ/neVzOf4jf88J6YtOkQqugtMrleLjbfRVUSS4LWl9CSOjNq76quYdmYWnSDgfQqOooT2cQ==}
dev: false dev: false
/@mui/material/5.10.14_acl7mc3llczqccvmbrsweq6vga: /@mui/material/5.10.14_ogvxv7hqfgg53da5eqs77qdqde:
resolution: {integrity: sha512-HWzKVAykePMx54WtxVwZyL1W4k3xlHYIqwMw0CaXAvgB3UE9yjABZuuGr8vG5Z6CSNWamzd+s1x8u7pQPFl9og==} resolution: {integrity: sha512-HWzKVAykePMx54WtxVwZyL1W4k3xlHYIqwMw0CaXAvgB3UE9yjABZuuGr8vG5Z6CSNWamzd+s1x8u7pQPFl9og==}
engines: {node: '>=12.0.0'} engines: {node: '>=12.0.0'}
peerDependencies: peerDependencies:
@@ -8733,14 +8735,14 @@ packages:
optional: true optional: true
dependencies: dependencies:
'@babel/runtime': 7.20.1 '@babel/runtime': 7.20.1
'@emotion/react': 11.10.5_iznqm25yxu4trtkqop3zznseca '@emotion/react': 11.10.5_lzn74h6sajlbfmrxbix4okzmpi
'@emotion/styled': 11.10.5_4ahanhknrtlidghakifap67h7q '@emotion/styled': 11.10.5_4jddrkedmmycnrpdaatf3tfj3a
'@mui/base': 5.0.0-alpha.106_zula6vjvt3wdocc4mwcxqa6nzi '@mui/base': 5.0.0-alpha.106_4qaawyptjkcgzqorucvhm3koke
'@mui/core-downloads-tracker': 5.10.14 '@mui/core-downloads-tracker': 5.10.14
'@mui/system': 5.10.14_teoksulxetwanny5ohzazahldq '@mui/system': 5.10.14_yunkbz2mvya45l5iqzwl5ypfyq
'@mui/types': 7.2.1_@types+react@18.0.28 '@mui/types': 7.2.1_@types+react@18.0.30
'@mui/utils': 5.10.14_react@18.2.0 '@mui/utils': 5.10.14_react@18.2.0
'@types/react': 18.0.28 '@types/react': 18.0.30
'@types/react-transition-group': 4.4.5 '@types/react-transition-group': 4.4.5
clsx: 1.2.1 clsx: 1.2.1
csstype: 3.1.1 csstype: 3.1.1
@@ -8751,7 +8753,7 @@ packages:
react-transition-group: 4.4.5_biqbaboplfbrettd7655fr4n2y react-transition-group: 4.4.5_biqbaboplfbrettd7655fr4n2y
dev: false dev: false
/@mui/private-theming/5.10.14_pmekkgnqduwlme35zpnqhenc34: /@mui/private-theming/5.10.14_2thlp7g7odiqm7dwhn3rlhxaa4:
resolution: {integrity: sha512-3aIBe8WK65CwAPDY8nB11hYnzE1CZMymi76UnaFrA/DdGDwl5Y8F6uB+StKrkVmsqF1po7Mp2odqVkHj320gXw==} resolution: {integrity: sha512-3aIBe8WK65CwAPDY8nB11hYnzE1CZMymi76UnaFrA/DdGDwl5Y8F6uB+StKrkVmsqF1po7Mp2odqVkHj320gXw==}
engines: {node: '>=12.0.0'} engines: {node: '>=12.0.0'}
peerDependencies: peerDependencies:
@@ -8763,7 +8765,7 @@ packages:
dependencies: dependencies:
'@babel/runtime': 7.20.1 '@babel/runtime': 7.20.1
'@mui/utils': 5.10.14_react@18.2.0 '@mui/utils': 5.10.14_react@18.2.0
'@types/react': 18.0.28 '@types/react': 18.0.30
prop-types: 15.8.1 prop-types: 15.8.1
react: 18.2.0 react: 18.2.0
dev: false dev: false
@@ -8783,14 +8785,14 @@ packages:
dependencies: dependencies:
'@babel/runtime': 7.20.1 '@babel/runtime': 7.20.1
'@emotion/cache': 11.10.5 '@emotion/cache': 11.10.5
'@emotion/react': 11.10.5_iznqm25yxu4trtkqop3zznseca '@emotion/react': 11.10.5_lzn74h6sajlbfmrxbix4okzmpi
'@emotion/styled': 11.10.5_4ahanhknrtlidghakifap67h7q '@emotion/styled': 11.10.5_4jddrkedmmycnrpdaatf3tfj3a
csstype: 3.1.1 csstype: 3.1.1
prop-types: 15.8.1 prop-types: 15.8.1
react: 18.2.0 react: 18.2.0
dev: false dev: false
/@mui/system/5.10.14_teoksulxetwanny5ohzazahldq: /@mui/system/5.10.14_yunkbz2mvya45l5iqzwl5ypfyq:
resolution: {integrity: sha512-2de7XCjRb1j8Od0Stmo0LwFMLpOMNT4wzfINuExXI1TVSuyxXIXUxiC5FEgJW3GMvf/a7SUR8VOiMoKlKWzukw==} resolution: {integrity: sha512-2de7XCjRb1j8Od0Stmo0LwFMLpOMNT4wzfINuExXI1TVSuyxXIXUxiC5FEgJW3GMvf/a7SUR8VOiMoKlKWzukw==}
engines: {node: '>=12.0.0'} engines: {node: '>=12.0.0'}
peerDependencies: peerDependencies:
@@ -8807,20 +8809,20 @@ packages:
optional: true optional: true
dependencies: dependencies:
'@babel/runtime': 7.20.1 '@babel/runtime': 7.20.1
'@emotion/react': 11.10.5_iznqm25yxu4trtkqop3zznseca '@emotion/react': 11.10.5_lzn74h6sajlbfmrxbix4okzmpi
'@emotion/styled': 11.10.5_4ahanhknrtlidghakifap67h7q '@emotion/styled': 11.10.5_4jddrkedmmycnrpdaatf3tfj3a
'@mui/private-theming': 5.10.14_pmekkgnqduwlme35zpnqhenc34 '@mui/private-theming': 5.10.14_2thlp7g7odiqm7dwhn3rlhxaa4
'@mui/styled-engine': 5.10.14_dovxhg2tvkkxkdnqyoum6wzcxm '@mui/styled-engine': 5.10.14_dovxhg2tvkkxkdnqyoum6wzcxm
'@mui/types': 7.2.1_@types+react@18.0.28 '@mui/types': 7.2.1_@types+react@18.0.30
'@mui/utils': 5.10.14_react@18.2.0 '@mui/utils': 5.10.14_react@18.2.0
'@types/react': 18.0.28 '@types/react': 18.0.30
clsx: 1.2.1 clsx: 1.2.1
csstype: 3.1.1 csstype: 3.1.1
prop-types: 15.8.1 prop-types: 15.8.1
react: 18.2.0 react: 18.2.0
dev: false dev: false
/@mui/types/7.2.1_@types+react@18.0.28: /@mui/types/7.2.1_@types+react@18.0.30:
resolution: {integrity: sha512-c5mSM7ivD8EsqK6HUi9hQPr5V7TJ/IRThUQ9nWNYPdhCGriTSQV4vL6DflT99LkM+wLiIS1rVjphpEWxERep7A==} resolution: {integrity: sha512-c5mSM7ivD8EsqK6HUi9hQPr5V7TJ/IRThUQ9nWNYPdhCGriTSQV4vL6DflT99LkM+wLiIS1rVjphpEWxERep7A==}
peerDependencies: peerDependencies:
'@types/react': '*' '@types/react': '*'
@@ -8828,7 +8830,7 @@ packages:
'@types/react': '@types/react':
optional: true optional: true
dependencies: dependencies:
'@types/react': 18.0.28 '@types/react': 18.0.30
dev: false dev: false
/@mui/utils/5.10.14_react@18.2.0: /@mui/utils/5.10.14_react@18.2.0:
@@ -8893,10 +8895,10 @@ packages:
'@date-io/dayjs': 2.16.0 '@date-io/dayjs': 2.16.0
'@date-io/luxon': 2.16.1 '@date-io/luxon': 2.16.1
'@date-io/moment': 2.16.1 '@date-io/moment': 2.16.1
'@emotion/react': 11.10.5_iznqm25yxu4trtkqop3zznseca '@emotion/react': 11.10.5_lzn74h6sajlbfmrxbix4okzmpi
'@emotion/styled': 11.10.5_4ahanhknrtlidghakifap67h7q '@emotion/styled': 11.10.5_4jddrkedmmycnrpdaatf3tfj3a
'@mui/material': 5.10.14_acl7mc3llczqccvmbrsweq6vga '@mui/material': 5.10.14_ogvxv7hqfgg53da5eqs77qdqde
'@mui/system': 5.10.14_teoksulxetwanny5ohzazahldq '@mui/system': 5.10.14_yunkbz2mvya45l5iqzwl5ypfyq
'@mui/utils': 5.10.9_react@18.2.0 '@mui/utils': 5.10.9_react@18.2.0
'@types/react-transition-group': 4.4.5 '@types/react-transition-group': 4.4.5
clsx: 1.2.1 clsx: 1.2.1
@@ -9662,7 +9664,7 @@ packages:
tslib: 2.5.0 tslib: 2.5.0
dev: false dev: false
/@reach/dialog/0.17.0_zula6vjvt3wdocc4mwcxqa6nzi: /@reach/dialog/0.17.0_4qaawyptjkcgzqorucvhm3koke:
resolution: {integrity: sha512-AnfKXugqDTGbeG3c8xDcrQDE4h9b/vnc27Sa118oQSquz52fneUeX9MeFb5ZEiBJK8T5NJpv7QUTBIKnFCAH5A==} resolution: {integrity: sha512-AnfKXugqDTGbeG3c8xDcrQDE4h9b/vnc27Sa118oQSquz52fneUeX9MeFb5ZEiBJK8T5NJpv7QUTBIKnFCAH5A==}
peerDependencies: peerDependencies:
react: ^16.8.0 || 17.x react: ^16.8.0 || 17.x
@@ -9673,8 +9675,8 @@ packages:
prop-types: 15.8.1 prop-types: 15.8.1
react: 18.2.0 react: 18.2.0
react-dom: 18.2.0_react@18.2.0 react-dom: 18.2.0_react@18.2.0
react-focus-lock: 2.9.2_pmekkgnqduwlme35zpnqhenc34 react-focus-lock: 2.9.2_2thlp7g7odiqm7dwhn3rlhxaa4
react-remove-scroll: 2.5.5_pmekkgnqduwlme35zpnqhenc34 react-remove-scroll: 2.5.5_2thlp7g7odiqm7dwhn3rlhxaa4
tslib: 2.5.0 tslib: 2.5.0
transitivePeerDependencies: transitivePeerDependencies:
- '@types/react' - '@types/react'
@@ -10193,7 +10195,7 @@ packages:
- webpack-command - webpack-command
dev: true dev: true
/@storybook/addon-interactions/6.5.14_o2w7dvvbfxaohzk6den2xlbkgq: /@storybook/addon-interactions/6.5.14_hvoc3iuqa2ltaiia3y4i66hvou:
resolution: {integrity: sha512-Stw/m3+T6ILrQPwyPgRNYtXZTBk9wE0KOSOUVrc6VixCcXm43nIYkUFiq4NL86lCBR4RKewfgl8U3Rn6chE8Tg==} resolution: {integrity: sha512-Stw/m3+T6ILrQPwyPgRNYtXZTBk9wE0KOSOUVrc6VixCcXm43nIYkUFiq4NL86lCBR4RKewfgl8U3Rn6chE8Tg==}
peerDependencies: peerDependencies:
react: ^16.8.0 || ^17.0.0 || ^18.0.0 react: ^16.8.0 || ^17.0.0 || ^18.0.0
@@ -10204,7 +10206,7 @@ packages:
react-dom: react-dom:
optional: true optional: true
dependencies: dependencies:
'@devtools-ds/object-inspector': 1.2.0_zula6vjvt3wdocc4mwcxqa6nzi '@devtools-ds/object-inspector': 1.2.0_4qaawyptjkcgzqorucvhm3koke
'@storybook/addons': 6.5.14_biqbaboplfbrettd7655fr4n2y '@storybook/addons': 6.5.14_biqbaboplfbrettd7655fr4n2y
'@storybook/api': 6.5.14_biqbaboplfbrettd7655fr4n2y '@storybook/api': 6.5.14_biqbaboplfbrettd7655fr4n2y
'@storybook/client-logger': 6.5.14 '@storybook/client-logger': 6.5.14
@@ -12473,7 +12475,7 @@ packages:
/@types/react-dom/18.0.11: /@types/react-dom/18.0.11:
resolution: {integrity: sha512-O38bPbI2CWtgw/OoQoY+BRelw7uysmXbWvw3nLWO21H1HSh+GOlqPuXshJfjmpNlKiiSDG9cc1JZAaMmVdcTlw==} resolution: {integrity: sha512-O38bPbI2CWtgw/OoQoY+BRelw7uysmXbWvw3nLWO21H1HSh+GOlqPuXshJfjmpNlKiiSDG9cc1JZAaMmVdcTlw==}
dependencies: dependencies:
'@types/react': 18.0.28 '@types/react': 18.0.30
dev: true dev: true
/@types/react-dom/18.0.9: /@types/react-dom/18.0.9:
@@ -12485,39 +12487,39 @@ packages:
/@types/react-is/17.0.3: /@types/react-is/17.0.3:
resolution: {integrity: sha512-aBTIWg1emtu95bLTLx0cpkxwGW3ueZv71nE2YFBpL8k/z5czEW8yYpOo8Dp+UUAFAtKwNaOsh/ioSeQnWlZcfw==} resolution: {integrity: sha512-aBTIWg1emtu95bLTLx0cpkxwGW3ueZv71nE2YFBpL8k/z5czEW8yYpOo8Dp+UUAFAtKwNaOsh/ioSeQnWlZcfw==}
dependencies: dependencies:
'@types/react': 18.0.28 '@types/react': 18.0.30
dev: false dev: false
/@types/react-router-config/5.0.6: /@types/react-router-config/5.0.6:
resolution: {integrity: sha512-db1mx37a1EJDf1XeX8jJN7R3PZABmJQXR8r28yUjVMFSjkmnQo6X6pOEEmNl+Tp2gYQOGPdYbFIipBtdElZ3Yg==} resolution: {integrity: sha512-db1mx37a1EJDf1XeX8jJN7R3PZABmJQXR8r28yUjVMFSjkmnQo6X6pOEEmNl+Tp2gYQOGPdYbFIipBtdElZ3Yg==}
dependencies: dependencies:
'@types/history': 4.7.11 '@types/history': 4.7.11
'@types/react': 18.0.28 '@types/react': 18.0.30
'@types/react-router': 5.1.18 '@types/react-router': 5.1.18
/@types/react-router-dom/5.3.3: /@types/react-router-dom/5.3.3:
resolution: {integrity: sha512-kpqnYK4wcdm5UaWI3fLcELopqLrHgLqNsdpHauzlQktfkHL3npOSwtj1Uz9oKBAzs7lFtVkV8j83voAz2D8fhw==} resolution: {integrity: sha512-kpqnYK4wcdm5UaWI3fLcELopqLrHgLqNsdpHauzlQktfkHL3npOSwtj1Uz9oKBAzs7lFtVkV8j83voAz2D8fhw==}
dependencies: dependencies:
'@types/history': 4.7.11 '@types/history': 4.7.11
'@types/react': 18.0.28 '@types/react': 18.0.30
'@types/react-router': 5.1.18 '@types/react-router': 5.1.18
/@types/react-router/5.1.18: /@types/react-router/5.1.18:
resolution: {integrity: sha512-YYknwy0D0iOwKQgz9v8nOzt2J6l4gouBmDnWqUUznltOTaon+r8US8ky8HvN0tXvc38U9m6z/t2RsVsnd1zM0g==} resolution: {integrity: sha512-YYknwy0D0iOwKQgz9v8nOzt2J6l4gouBmDnWqUUznltOTaon+r8US8ky8HvN0tXvc38U9m6z/t2RsVsnd1zM0g==}
dependencies: dependencies:
'@types/history': 4.7.11 '@types/history': 4.7.11
'@types/react': 18.0.28 '@types/react': 18.0.30
/@types/react-table/7.7.12: /@types/react-table/7.7.12:
resolution: {integrity: sha512-bRUent+NR/WwtDGwI/BqhZ8XnHghwHw0HUKeohzB5xN3K2qKWYE5w19e7GCuOkL1CXD9Gi1HFy7TIm2AvgWUHg==} resolution: {integrity: sha512-bRUent+NR/WwtDGwI/BqhZ8XnHghwHw0HUKeohzB5xN3K2qKWYE5w19e7GCuOkL1CXD9Gi1HFy7TIm2AvgWUHg==}
dependencies: dependencies:
'@types/react': 18.0.28 '@types/react': 18.0.30
dev: true dev: true
/@types/react-transition-group/4.4.5: /@types/react-transition-group/4.4.5:
resolution: {integrity: sha512-juKD/eiSM3/xZYzjuzH6ZwpP+/lejltmiS3QEzV/vmb/Q8+HfDmxu+Baga8UEMGBqV88Nbg4l2hY/K2DkyaLLA==} resolution: {integrity: sha512-juKD/eiSM3/xZYzjuzH6ZwpP+/lejltmiS3QEzV/vmb/Q8+HfDmxu+Baga8UEMGBqV88Nbg4l2hY/K2DkyaLLA==}
dependencies: dependencies:
'@types/react': 18.0.28 '@types/react': 18.0.30
dev: false dev: false
/@types/react/18.0.25: /@types/react/18.0.25:
@@ -12535,8 +12537,8 @@ packages:
csstype: 3.1.1 csstype: 3.1.1
dev: true dev: true
/@types/react/18.0.28: /@types/react/18.0.30:
resolution: {integrity: sha512-RD0ivG1kEztNBdoAK7lekI9M+azSnitIn85h4iOiaLjaTrMjzslhaqCGaI4IyCJ1RljWiLCEu4jyrLLgqxBTew==} resolution: {integrity: sha512-AnME2cHDH11Pxt/yYX6r0w448BfTwQOLEhQEjCdwB7QskEI7EKtxhGUsExTQe/MsY3D9D5rMtu62WRocw9A8FA==}
dependencies: dependencies:
'@types/prop-types': 15.7.5 '@types/prop-types': 15.7.5
'@types/scheduler': 0.16.2 '@types/scheduler': 0.16.2
@@ -20726,14 +20728,14 @@ packages:
resolution: {integrity: sha512-bzh50DW9kTPM00T8y4o8vQg89Di9oLJVLW/KaOGIXJWP/iqCN6WKYkbNOF04vFLJhwcpYUh9ydh/+5vpOqV4YQ==} resolution: {integrity: sha512-bzh50DW9kTPM00T8y4o8vQg89Di9oLJVLW/KaOGIXJWP/iqCN6WKYkbNOF04vFLJhwcpYUh9ydh/+5vpOqV4YQ==}
dev: true dev: true
/graphiql/2.4.0_755ntyjuho6qjwic26h62or3by: /graphiql/2.4.0_7bopqva7rdmx76dydi5rwteyri:
resolution: {integrity: sha512-lJ6OYDQkhAMZePrz8g6r9vMVmxa4SY9eEzzyJxsgE+jA+6PFKds2e8/tDAaCYfX0HNv84nc7W/th1vsHIdgYiA==} resolution: {integrity: sha512-lJ6OYDQkhAMZePrz8g6r9vMVmxa4SY9eEzzyJxsgE+jA+6PFKds2e8/tDAaCYfX0HNv84nc7W/th1vsHIdgYiA==}
peerDependencies: peerDependencies:
graphql: ^15.5.0 || ^16.0.0 graphql: ^15.5.0 || ^16.0.0
react: ^16.8.0 || ^17.0.0 || ^18.0.0 react: ^16.8.0 || ^17.0.0 || ^18.0.0
react-dom: ^16.8.0 || ^17.0.0 || ^18.0.0 react-dom: ^16.8.0 || ^17.0.0 || ^18.0.0
dependencies: dependencies:
'@graphiql/react': 0.17.0_755ntyjuho6qjwic26h62or3by '@graphiql/react': 0.17.0_7bopqva7rdmx76dydi5rwteyri
'@graphiql/toolkit': 0.8.2_7fbl5omhlrpwpn5f5culy6mafe '@graphiql/toolkit': 0.8.2_7fbl5omhlrpwpn5f5culy6mafe
entities: 2.2.0 entities: 2.2.0
graphql: 16.6.0 graphql: 16.6.0
@@ -26617,7 +26619,7 @@ packages:
/react-fast-compare/3.2.0: /react-fast-compare/3.2.0:
resolution: {integrity: sha512-rtGImPZ0YyLrscKI9xTpV8psd6I8VAtjKCzQDlzyDvqJA8XOW78TXYQwNRNd8g8JZnDu8q9Fu/1v4HPAVwVdHA==} resolution: {integrity: sha512-rtGImPZ0YyLrscKI9xTpV8psd6I8VAtjKCzQDlzyDvqJA8XOW78TXYQwNRNd8g8JZnDu8q9Fu/1v4HPAVwVdHA==}
/react-focus-lock/2.9.2_pmekkgnqduwlme35zpnqhenc34: /react-focus-lock/2.9.2_2thlp7g7odiqm7dwhn3rlhxaa4:
resolution: {integrity: sha512-5JfrsOKyA5Zn3h958mk7bAcfphr24jPoMoznJ8vaJF6fUrPQ8zrtEd3ILLOK8P5jvGxdMd96OxWNjDzATfR2qw==} resolution: {integrity: sha512-5JfrsOKyA5Zn3h958mk7bAcfphr24jPoMoznJ8vaJF6fUrPQ8zrtEd3ILLOK8P5jvGxdMd96OxWNjDzATfR2qw==}
peerDependencies: peerDependencies:
'@types/react': ^16.8.0 || ^17.0.0 || ^18.0.0 '@types/react': ^16.8.0 || ^17.0.0 || ^18.0.0
@@ -26627,13 +26629,13 @@ packages:
optional: true optional: true
dependencies: dependencies:
'@babel/runtime': 7.20.1 '@babel/runtime': 7.20.1
'@types/react': 18.0.28 '@types/react': 18.0.30
focus-lock: 0.11.3 focus-lock: 0.11.3
prop-types: 15.8.1 prop-types: 15.8.1
react: 18.2.0 react: 18.2.0
react-clientside-effect: 1.2.6_react@18.2.0 react-clientside-effect: 1.2.6_react@18.2.0
use-callback-ref: 1.3.0_pmekkgnqduwlme35zpnqhenc34 use-callback-ref: 1.3.0_2thlp7g7odiqm7dwhn3rlhxaa4
use-sidecar: 1.1.2_pmekkgnqduwlme35zpnqhenc34 use-sidecar: 1.1.2_2thlp7g7odiqm7dwhn3rlhxaa4
dev: false dev: false
/react-helmet-async/1.3.0_biqbaboplfbrettd7655fr4n2y: /react-helmet-async/1.3.0_biqbaboplfbrettd7655fr4n2y:
@@ -26775,7 +26777,7 @@ packages:
engines: {node: '>=0.10.0'} engines: {node: '>=0.10.0'}
dev: true dev: true
/react-remove-scroll-bar/2.3.4_pmekkgnqduwlme35zpnqhenc34: /react-remove-scroll-bar/2.3.4_2thlp7g7odiqm7dwhn3rlhxaa4:
resolution: {integrity: sha512-63C4YQBUt0m6ALadE9XV56hV8BgJWDmmTPY758iIJjfQKt2nYwoUrPk0LXRXcB/yIj82T1/Ixfdpdk68LwIB0A==} resolution: {integrity: sha512-63C4YQBUt0m6ALadE9XV56hV8BgJWDmmTPY758iIJjfQKt2nYwoUrPk0LXRXcB/yIj82T1/Ixfdpdk68LwIB0A==}
engines: {node: '>=10'} engines: {node: '>=10'}
peerDependencies: peerDependencies:
@@ -26785,13 +26787,13 @@ packages:
'@types/react': '@types/react':
optional: true optional: true
dependencies: dependencies:
'@types/react': 18.0.28 '@types/react': 18.0.30
react: 18.2.0 react: 18.2.0
react-style-singleton: 2.2.1_pmekkgnqduwlme35zpnqhenc34 react-style-singleton: 2.2.1_2thlp7g7odiqm7dwhn3rlhxaa4
tslib: 2.5.0 tslib: 2.5.0
dev: false dev: false
/react-remove-scroll/2.5.5_pmekkgnqduwlme35zpnqhenc34: /react-remove-scroll/2.5.5_2thlp7g7odiqm7dwhn3rlhxaa4:
resolution: {integrity: sha512-ImKhrzJJsyXJfBZ4bzu8Bwpka14c/fQt0k+cyFp/PBhTfyDnU5hjOtM4AG/0AMyy8oKzOTR0lDgJIM7pYXI0kw==} resolution: {integrity: sha512-ImKhrzJJsyXJfBZ4bzu8Bwpka14c/fQt0k+cyFp/PBhTfyDnU5hjOtM4AG/0AMyy8oKzOTR0lDgJIM7pYXI0kw==}
engines: {node: '>=10'} engines: {node: '>=10'}
peerDependencies: peerDependencies:
@@ -26801,13 +26803,13 @@ packages:
'@types/react': '@types/react':
optional: true optional: true
dependencies: dependencies:
'@types/react': 18.0.28 '@types/react': 18.0.30
react: 18.2.0 react: 18.2.0
react-remove-scroll-bar: 2.3.4_pmekkgnqduwlme35zpnqhenc34 react-remove-scroll-bar: 2.3.4_2thlp7g7odiqm7dwhn3rlhxaa4
react-style-singleton: 2.2.1_pmekkgnqduwlme35zpnqhenc34 react-style-singleton: 2.2.1_2thlp7g7odiqm7dwhn3rlhxaa4
tslib: 2.5.0 tslib: 2.5.0
use-callback-ref: 1.3.0_pmekkgnqduwlme35zpnqhenc34 use-callback-ref: 1.3.0_2thlp7g7odiqm7dwhn3rlhxaa4
use-sidecar: 1.1.2_pmekkgnqduwlme35zpnqhenc34 use-sidecar: 1.1.2_2thlp7g7odiqm7dwhn3rlhxaa4
dev: false dev: false
/react-router-config/5.1.1_rlw3ibuvnpt5jvejeevjcf4ije: /react-router-config/5.1.1_rlw3ibuvnpt5jvejeevjcf4ije:
@@ -26882,7 +26884,7 @@ packages:
react: 18.2.0 react: 18.2.0
dev: false dev: false
/react-style-singleton/2.2.1_pmekkgnqduwlme35zpnqhenc34: /react-style-singleton/2.2.1_2thlp7g7odiqm7dwhn3rlhxaa4:
resolution: {integrity: sha512-ZWj0fHEMyWkHzKYUr2Bs/4zU6XLmq9HsgBURm7g5pAVfyn49DgUiNgY2d4lXRlYSiCif9YBGpQleewkcqddc7g==} resolution: {integrity: sha512-ZWj0fHEMyWkHzKYUr2Bs/4zU6XLmq9HsgBURm7g5pAVfyn49DgUiNgY2d4lXRlYSiCif9YBGpQleewkcqddc7g==}
engines: {node: '>=10'} engines: {node: '>=10'}
peerDependencies: peerDependencies:
@@ -26892,7 +26894,7 @@ packages:
'@types/react': '@types/react':
optional: true optional: true
dependencies: dependencies:
'@types/react': 18.0.28 '@types/react': 18.0.30
get-nonce: 1.0.1 get-nonce: 1.0.1
invariant: 2.2.4 invariant: 2.2.4
react: 18.2.0 react: 18.2.0
@@ -29749,65 +29751,65 @@ packages:
safe-buffer: 5.2.1 safe-buffer: 5.2.1
dev: false dev: false
/turbo-darwin-64/1.8.5: /turbo-darwin-64/1.8.6:
resolution: {integrity: sha512-CAYh56bzeHfnh7jTm03r29bh8p5a/EjQo1Id5yLUH7hS7msTau/+YpxJWPodLbN0UQsUYivUqHQkglJ+eMJ7xA==} resolution: {integrity: sha512-VlXkQR0TEBAEyBRsvAXBax+fj1EdPKPliwBaCnRLiDUcA/8wYlKte/Kk6ubmj9E0n7U/B4keCxxHiJZqW/5Rqg==}
cpu: [x64] cpu: [x64]
os: [darwin] os: [darwin]
requiresBuild: true requiresBuild: true
dev: true dev: true
optional: true optional: true
/turbo-darwin-arm64/1.8.5: /turbo-darwin-arm64/1.8.6:
resolution: {integrity: sha512-R3jCPOv+lu3dcvMhj8b/Defv6dyUwX6W+tbX7d6YUCA46Plf/bGCQ8+MSbxmr/4E1GyGOVFsn1wRfiYk0us/Dg==} resolution: {integrity: sha512-w4L2QLj90ex68UXxTPoqtZPl8mWzc6a1RtPjQhoxAWtZf9T2WXi813dCzYEbVUVC09/DOW/VxZRN7sb2r0KP9A==}
cpu: [arm64] cpu: [arm64]
os: [darwin] os: [darwin]
requiresBuild: true requiresBuild: true
dev: true dev: true
optional: true optional: true
/turbo-linux-64/1.8.5: /turbo-linux-64/1.8.6:
resolution: {integrity: sha512-YRc/KNRZeUVvth11UO4SDQZR2IqGgl9MSsbzqoHuFz4B4Q5QXH7onHogv9aXWE/BZBBbcrSBTlwBSG0Gg+J8hg==} resolution: {integrity: sha512-eV245jefIhMAZskqQKalFwreC5UEdQcuHcBiWcgUk0py76fbwB7+1HfH5cmeJlb3a1sB6f3H0HHmGPmb34feCA==}
cpu: [x64] cpu: [x64]
os: [linux] os: [linux]
requiresBuild: true requiresBuild: true
dev: true dev: true
optional: true optional: true
/turbo-linux-arm64/1.8.5: /turbo-linux-arm64/1.8.6:
resolution: {integrity: sha512-8exVZb7XBl/V3gHSweuUyG2D9IzfWqwLvlXoeLWlVYSj61Ajgdv+WU7lvUmx+H2s+sSKqmIFmewA5Lw6YY37sg==} resolution: {integrity: sha512-Kiw3nyEvNU6Bpil4zE5FwhasPAOi59R4YdCmjJp0Sen6V9u+/Jij6SWwaoUdATORJLiYQBbhontWBH55B53VDw==}
cpu: [arm64] cpu: [arm64]
os: [linux] os: [linux]
requiresBuild: true requiresBuild: true
dev: true dev: true
optional: true optional: true
/turbo-windows-64/1.8.5: /turbo-windows-64/1.8.6:
resolution: {integrity: sha512-fA8PU5ZNoFnQkapG06WiEqfsVQ5wbIPkIqTwUsd/M2Lp+KgxE79SQbuEI+2vQ9SmwM5qoMi515IPjgvXAJXgCw==} resolution: {integrity: sha512-34BkAG9r4nE00xeMeVahaF82h8R6SO+IIOcD60fNr2p+Ch+YcQa+DbEWA/KUj3coUTIiNP5XnRCLRUYADdlxjQ==}
cpu: [x64] cpu: [x64]
os: [win32] os: [win32]
requiresBuild: true requiresBuild: true
dev: true dev: true
optional: true optional: true
/turbo-windows-arm64/1.8.5: /turbo-windows-arm64/1.8.6:
resolution: {integrity: sha512-SW/NvIdhckLsAWjU/iqBbCB0S8kXupKscUK3kEW1DZIr3MYcP/yIuaE/IdPuqcoF3VP0I3TLD4VTYCCKAo3tKA==} resolution: {integrity: sha512-4jWUaI7Lmonp2I3x81GruiCYd0aQsG/xDOYhuv9+j2yIgB/UHJFz/P8PWp/nziwPtGpRd/AheDlPzzyd9lWoqw==}
cpu: [arm64] cpu: [arm64]
os: [win32] os: [win32]
requiresBuild: true requiresBuild: true
dev: true dev: true
optional: true optional: true
/turbo/1.8.5: /turbo/1.8.6:
resolution: {integrity: sha512-UBnH2wIFb5g6OQCk8f34Ud15ZXV4xEMmugeDJTU5Ur2LpVRsNEny0isSCYdb3Iu3howoNyyXmtpaxWsAwNYkkg==} resolution: {integrity: sha512-6IOOaa8ytgjnSCTnp3LKAd2uGBZ/Kmx8ZPlI/YMWuKMUqvkXKLbh+w76ApMgMm+faUqti+QujVWovCu2kY6KuQ==}
hasBin: true hasBin: true
requiresBuild: true requiresBuild: true
optionalDependencies: optionalDependencies:
turbo-darwin-64: 1.8.5 turbo-darwin-64: 1.8.6
turbo-darwin-arm64: 1.8.5 turbo-darwin-arm64: 1.8.6
turbo-linux-64: 1.8.5 turbo-linux-64: 1.8.6
turbo-linux-arm64: 1.8.5 turbo-linux-arm64: 1.8.6
turbo-windows-64: 1.8.5 turbo-windows-64: 1.8.6
turbo-windows-arm64: 1.8.5 turbo-windows-arm64: 1.8.6
dev: true dev: true
/type-check/0.3.2: /type-check/0.3.2:
@@ -30387,7 +30389,7 @@ packages:
react: 18.2.0 react: 18.2.0
wonka: 6.1.1 wonka: 6.1.1
/use-callback-ref/1.3.0_pmekkgnqduwlme35zpnqhenc34: /use-callback-ref/1.3.0_2thlp7g7odiqm7dwhn3rlhxaa4:
resolution: {integrity: sha512-3FT9PRuRdbB9HfXhEq35u4oZkvpJ5kuYbpqhCfmiZyReuRgpnhDlbr2ZEnnuS0RrJAPn6l23xjFg9kpDM+Ms7w==} resolution: {integrity: sha512-3FT9PRuRdbB9HfXhEq35u4oZkvpJ5kuYbpqhCfmiZyReuRgpnhDlbr2ZEnnuS0RrJAPn6l23xjFg9kpDM+Ms7w==}
engines: {node: '>=10'} engines: {node: '>=10'}
peerDependencies: peerDependencies:
@@ -30397,7 +30399,7 @@ packages:
'@types/react': '@types/react':
optional: true optional: true
dependencies: dependencies:
'@types/react': 18.0.28 '@types/react': 18.0.30
react: 18.2.0 react: 18.2.0
tslib: 2.5.0 tslib: 2.5.0
dev: false dev: false
@@ -30462,7 +30464,7 @@ packages:
use-isomorphic-layout-effect: 1.1.2_react@18.2.0 use-isomorphic-layout-effect: 1.1.2_react@18.2.0
dev: false dev: false
/use-sidecar/1.1.2_pmekkgnqduwlme35zpnqhenc34: /use-sidecar/1.1.2_2thlp7g7odiqm7dwhn3rlhxaa4:
resolution: {integrity: sha512-epTbsLuzZ7lPClpz2TyryBfztm7m+28DlEv2ZCQ3MDr5ssiwyOwGH/e5F9CkfWjJ1t4clvI58yF822/GUkjjhw==} resolution: {integrity: sha512-epTbsLuzZ7lPClpz2TyryBfztm7m+28DlEv2ZCQ3MDr5ssiwyOwGH/e5F9CkfWjJ1t4clvI58yF822/GUkjjhw==}
engines: {node: '>=10'} engines: {node: '>=10'}
peerDependencies: peerDependencies:
@@ -30472,7 +30474,7 @@ packages:
'@types/react': '@types/react':
optional: true optional: true
dependencies: dependencies:
'@types/react': 18.0.28 '@types/react': 18.0.30
detect-node-es: 1.1.0 detect-node-es: 1.1.0
react: 18.2.0 react: 18.2.0
tslib: 2.5.0 tslib: 2.5.0