Compare commits
71 Commits
@nhost/rea
...
@nhost/has
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
11b4d12f12 | ||
|
|
12301e6551 | ||
|
|
74e52cac2d | ||
|
|
f17823760a | ||
|
|
bb8803a1e3 | ||
|
|
b846291331 | ||
|
|
2b2fb94f00 | ||
|
|
551760c4f0 | ||
|
|
5ae5a8e77d | ||
|
|
56aae0c964 | ||
|
|
a0e093d77b | ||
|
|
5e82e1b3da | ||
|
|
e618b705e7 | ||
|
|
a232c9f0f6 | ||
|
|
bf4644ea10 | ||
|
|
0aca907ea4 | ||
|
|
394f4c4174 | ||
|
|
8fef08a150 | ||
|
|
1bd2c37301 | ||
|
|
5cdb70bd81 | ||
|
|
1a5f80e1b6 | ||
|
|
59e0cb00c5 | ||
|
|
406b0f2cb7 | ||
|
|
d329b6218f | ||
|
|
335b58670e | ||
|
|
efa2d89067 | ||
|
|
77ce4bd738 | ||
|
|
017adea700 | ||
|
|
378284faa8 | ||
|
|
e5e2d114b1 | ||
|
|
5e3dbdeb7d | ||
|
|
98b777491a | ||
|
|
71de870cb0 | ||
|
|
74d4deba28 | ||
|
|
cb248f0d30 | ||
|
|
09e4f1eb34 | ||
|
|
19818e2b59 | ||
|
|
6e1f03eaee | ||
|
|
b3eeec82ef | ||
|
|
34ff254696 | ||
|
|
867c807699 | ||
|
|
1c4806bf51 | ||
|
|
2fb82ec97d | ||
|
|
d0673d7825 | ||
|
|
106f23dcfa | ||
|
|
0c994a9651 | ||
|
|
83ef755822 | ||
|
|
b7703ffd70 | ||
|
|
4713cecfc2 | ||
|
|
340ea5b115 | ||
|
|
f79eebadbf | ||
|
|
ac174b5e51 | ||
|
|
dc9ddfc9ae | ||
|
|
3bdd9f570c | ||
|
|
94477be998 | ||
|
|
568577e8ca | ||
|
|
e93b06ab8f | ||
|
|
c75bf46ba1 | ||
|
|
63a1fd09b5 | ||
|
|
630d44ad6e | ||
|
|
d7db521974 | ||
|
|
90e4053f0a | ||
|
|
8e9d5d1b38 | ||
|
|
43c86fef14 | ||
|
|
6b97340cf4 | ||
|
|
1605756362 | ||
|
|
ce4b655c55 | ||
|
|
dc57d31ec9 | ||
|
|
ea29fd6b73 | ||
|
|
d8e4073957 | ||
|
|
3f399a54a3 |
20
.github/workflows/ci.yaml
vendored
20
.github/workflows/ci.yaml
vendored
@@ -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:
|
||||||
@@ -128,12 +129,27 @@ jobs:
|
|||||||
- name: Install Nhost CLI
|
- name: Install Nhost CLI
|
||||||
if: hashFiles(format('{0}/nhost/config.yaml', matrix.package.path)) != ''
|
if: hashFiles(format('{0}/nhost/config.yaml', matrix.package.path)) != ''
|
||||||
uses: ./.github/actions/nhost-cli
|
uses: ./.github/actions/nhost-cli
|
||||||
|
- name: Fetch Dashboard Preview URL
|
||||||
|
id: fetch-dashboard-preview-url
|
||||||
|
uses: zentered/vercel-preview-url@v1.1.9
|
||||||
|
if: github.ref_name != 'main'
|
||||||
|
env:
|
||||||
|
VERCEL_TOKEN: ${{ secrets.DASHBOARD_VERCEL_DEPLOY_TOKEN }}
|
||||||
|
GITHUB_REF: ${{ github.ref_name }}
|
||||||
|
GITHUB_REPOSITORY: ${{ github.repository }}
|
||||||
|
with:
|
||||||
|
vercel_team_id: ${{ secrets.DASHBOARD_VERCEL_TEAM_ID }}
|
||||||
|
vercel_project_id: ${{ secrets.DASHBOARD_STAGING_VERCEL_PROJECT_ID }}
|
||||||
|
vercel_state: BUILDING,READY,INITIALIZING
|
||||||
|
- name: Set Dashboard Preview URL
|
||||||
|
if: steps.fetch-dashboard-preview-url.outputs.preview_url != ''
|
||||||
|
run: echo "NHOST_TEST_DASHBOARD_URL=https://${{ steps.fetch-dashboard-preview-url.outputs.preview_url }}" >> $GITHUB_ENV
|
||||||
# * Run the `ci` script of the current package of the matrix. Dependencies build is cached by Turborepo
|
# * Run the `ci` script of the current package of the matrix. Dependencies build is cached by Turborepo
|
||||||
- name: Run e2e test
|
- name: Run e2e tests
|
||||||
run: pnpm --filter="${{ matrix.package.name }}" run e2e
|
run: pnpm --filter="${{ matrix.package.name }}" run e2e
|
||||||
- id: file-name
|
- id: file-name
|
||||||
if: ${{ failure() }}
|
if: ${{ failure() }}
|
||||||
name: Tranform package name into a valid file name
|
name: Transform package name into a valid file name
|
||||||
run: |
|
run: |
|
||||||
PACKAGE_FILE_NAME=$(echo "${{ matrix.package.name }}" | sed 's/@//g; s/\//-/g')
|
PACKAGE_FILE_NAME=$(echo "${{ matrix.package.name }}" | sed 's/@//g; s/\//-/g')
|
||||||
echo "fileName=$PACKAGE_FILE_NAME" >> $GITHUB_OUTPUT
|
echo "fileName=$PACKAGE_FILE_NAME" >> $GITHUB_OUTPUT
|
||||||
|
|||||||
@@ -1,5 +1,34 @@
|
|||||||
# @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
|
||||||
|
|
||||||
|
### Patch Changes
|
||||||
|
|
||||||
|
- e93b06ab: fix(dashboard): remove left margin from workspace list on mobile
|
||||||
|
- 1c4806bf: chore(deps): bump `sharp` to 0.32.0
|
||||||
|
- @nhost/react-apollo@5.0.14
|
||||||
|
- @nhost/nextjs@1.13.18
|
||||||
|
|
||||||
## 0.13.9
|
## 0.13.9
|
||||||
|
|
||||||
### Patch Changes
|
### Patch Changes
|
||||||
|
|||||||
@@ -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
|
||||||
|
|
||||||
|
|||||||
@@ -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>
|
||||||
```
|
```
|
||||||
|
|||||||
@@ -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,
|
||||||
165
dashboard/e2e/database/delete-table.test.ts
Normal file
165
dashboard/e2e/database/delete-table.test.ts
Normal file
@@ -0,0 +1,165 @@
|
|||||||
|
import {
|
||||||
|
TEST_PROJECT_NAME,
|
||||||
|
TEST_PROJECT_SLUG,
|
||||||
|
TEST_WORKSPACE_SLUG,
|
||||||
|
} from '@/e2e/env';
|
||||||
|
import { deleteTable, openProject, prepareTable } from '@/e2e/utils';
|
||||||
|
import { faker } from '@faker-js/faker';
|
||||||
|
import type { Page } from '@playwright/test';
|
||||||
|
import { expect, test } from '@playwright/test';
|
||||||
|
import { snakeCase } from 'snake-case';
|
||||||
|
|
||||||
|
let page: Page;
|
||||||
|
|
||||||
|
test.beforeAll(async ({ browser }) => {
|
||||||
|
page = await browser.newPage();
|
||||||
|
});
|
||||||
|
|
||||||
|
test.beforeEach(async () => {
|
||||||
|
await page.goto('/');
|
||||||
|
|
||||||
|
await openProject({
|
||||||
|
page,
|
||||||
|
projectName: TEST_PROJECT_NAME,
|
||||||
|
workspaceSlug: TEST_WORKSPACE_SLUG,
|
||||||
|
projectSlug: TEST_PROJECT_SLUG,
|
||||||
|
});
|
||||||
|
|
||||||
|
await page
|
||||||
|
.getByRole('navigation', { name: /main navigation/i })
|
||||||
|
.getByRole('link', { name: /database/i })
|
||||||
|
.click();
|
||||||
|
});
|
||||||
|
|
||||||
|
test.afterAll(async () => {
|
||||||
|
await page.close();
|
||||||
|
});
|
||||||
|
|
||||||
|
test('should delete a table', async () => {
|
||||||
|
const tableName = snakeCase(faker.lorem.words(3));
|
||||||
|
|
||||||
|
await page.getByRole('button', { name: /new table/i }).click();
|
||||||
|
|
||||||
|
await prepareTable({
|
||||||
|
page,
|
||||||
|
name: tableName,
|
||||||
|
primaryKey: 'id',
|
||||||
|
columns: [
|
||||||
|
{ name: 'id', type: 'uuid', defaultValue: 'gen_random_uuid()' },
|
||||||
|
{ name: 'title', type: 'text' },
|
||||||
|
],
|
||||||
|
});
|
||||||
|
|
||||||
|
await page.getByRole('button', { name: /create/i }).click();
|
||||||
|
|
||||||
|
await page.waitForURL(
|
||||||
|
`/${TEST_WORKSPACE_SLUG}/${TEST_PROJECT_SLUG}/database/browser/default/public/${tableName}`,
|
||||||
|
);
|
||||||
|
|
||||||
|
await deleteTable({
|
||||||
|
page,
|
||||||
|
name: tableName,
|
||||||
|
});
|
||||||
|
|
||||||
|
// navigate to next URL
|
||||||
|
await page.waitForURL(
|
||||||
|
`/${TEST_WORKSPACE_SLUG}/${TEST_PROJECT_SLUG}/database/browser/default/public/**`,
|
||||||
|
);
|
||||||
|
|
||||||
|
await expect(
|
||||||
|
page.getByRole('link', { name: tableName, exact: true }),
|
||||||
|
).not.toBeVisible();
|
||||||
|
});
|
||||||
|
|
||||||
|
test('should not be able to delete a table if other tables have foreign keys referencing it', async () => {
|
||||||
|
await page.getByRole('button', { name: /new table/i }).click();
|
||||||
|
await expect(page.getByText(/create a new table/i)).toBeVisible();
|
||||||
|
|
||||||
|
const firstTableName = snakeCase(faker.lorem.words(3));
|
||||||
|
|
||||||
|
await prepareTable({
|
||||||
|
page,
|
||||||
|
name: firstTableName,
|
||||||
|
primaryKey: 'id',
|
||||||
|
columns: [
|
||||||
|
{ name: 'id', type: 'uuid', defaultValue: 'gen_random_uuid()' },
|
||||||
|
{ name: 'name', type: 'text' },
|
||||||
|
],
|
||||||
|
});
|
||||||
|
|
||||||
|
// create table
|
||||||
|
await page.getByRole('button', { name: /create/i }).click();
|
||||||
|
|
||||||
|
await page.waitForURL(
|
||||||
|
`/${TEST_WORKSPACE_SLUG}/${TEST_PROJECT_SLUG}/database/browser/default/public/${firstTableName}`,
|
||||||
|
);
|
||||||
|
|
||||||
|
await page.getByRole('button', { name: /new table/i }).click();
|
||||||
|
await expect(page.getByText(/create a new table/i)).toBeVisible();
|
||||||
|
|
||||||
|
const secondTableName = snakeCase(faker.lorem.words(3));
|
||||||
|
|
||||||
|
await prepareTable({
|
||||||
|
page,
|
||||||
|
name: secondTableName,
|
||||||
|
primaryKey: 'id',
|
||||||
|
columns: [
|
||||||
|
{ name: 'id', type: 'uuid', defaultValue: 'gen_random_uuid()' },
|
||||||
|
{ name: 'title', type: 'text' },
|
||||||
|
{ name: 'author_id', type: 'uuid' },
|
||||||
|
],
|
||||||
|
});
|
||||||
|
|
||||||
|
await page.getByRole('button', { name: /add foreign key/i }).click();
|
||||||
|
|
||||||
|
// select column in current table
|
||||||
|
await page
|
||||||
|
.getByRole('button', { name: /column/i })
|
||||||
|
.first()
|
||||||
|
.click();
|
||||||
|
await page.getByRole('option', { name: /author_id/i }).click();
|
||||||
|
|
||||||
|
// select reference schema
|
||||||
|
await page.getByRole('button', { name: /schema/i }).click();
|
||||||
|
await page.getByRole('option', { name: /public/i }).click();
|
||||||
|
|
||||||
|
// select reference table
|
||||||
|
await page.getByRole('button', { name: /table/i }).click();
|
||||||
|
await page.getByRole('option', { name: firstTableName, exact: true }).click();
|
||||||
|
|
||||||
|
// select reference column
|
||||||
|
await page
|
||||||
|
.getByRole('button', { name: /column/i })
|
||||||
|
.nth(1)
|
||||||
|
.click();
|
||||||
|
await page.getByRole('option', { name: /id/i }).click();
|
||||||
|
|
||||||
|
await page.getByRole('button', { name: /add/i }).click();
|
||||||
|
|
||||||
|
await expect(
|
||||||
|
page.getByText(`public.${firstTableName}.id`, { exact: true }),
|
||||||
|
).toBeVisible();
|
||||||
|
|
||||||
|
// create table
|
||||||
|
await page.getByRole('button', { name: /create/i }).click();
|
||||||
|
|
||||||
|
await page.waitForURL(
|
||||||
|
`/${TEST_WORKSPACE_SLUG}/${TEST_PROJECT_SLUG}/database/browser/default/public/${secondTableName}`,
|
||||||
|
);
|
||||||
|
|
||||||
|
await expect(
|
||||||
|
page.getByRole('link', { name: secondTableName, exact: true }),
|
||||||
|
).toBeVisible();
|
||||||
|
|
||||||
|
// try to delete the first table that is referenced by the second table
|
||||||
|
await deleteTable({
|
||||||
|
page,
|
||||||
|
name: firstTableName,
|
||||||
|
});
|
||||||
|
|
||||||
|
await expect(
|
||||||
|
page.getByText(
|
||||||
|
/constraint [a-zA-Z_]+ on table [a-zA-Z_]+ depends on table [a-zA-Z_]+/i,
|
||||||
|
),
|
||||||
|
).toBeVisible();
|
||||||
|
});
|
||||||
@@ -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.
|
||||||
*/
|
*/
|
||||||
|
|||||||
@@ -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();
|
||||||
|
}
|
||||||
|
|||||||
@@ -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();
|
||||||
|
|||||||
66
dashboard/global-teardown.ts
Normal file
66
dashboard/global-teardown.ts
Normal 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;
|
||||||
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@nhost/dashboard",
|
"name": "@nhost/dashboard",
|
||||||
"version": "0.13.9",
|
"version": "0.14.1",
|
||||||
"private": true,
|
"private": true,
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"preinstall": "npx only-allow pnpm",
|
"preinstall": "npx only-allow pnpm",
|
||||||
@@ -71,7 +71,7 @@
|
|||||||
"react-merge-refs": "^1.1.0",
|
"react-merge-refs": "^1.1.0",
|
||||||
"react-syntax-highlighter": "^15.4.5",
|
"react-syntax-highlighter": "^15.4.5",
|
||||||
"react-table": "^7.8.0",
|
"react-table": "^7.8.0",
|
||||||
"sharp": "^0.31.2",
|
"sharp": "^0.32.0",
|
||||||
"slugify": "^1.6.5",
|
"slugify": "^1.6.5",
|
||||||
"stripe": "^10.17.0",
|
"stripe": "^10.17.0",
|
||||||
"tailwind-merge": "^1.8.0",
|
"tailwind-merge": "^1.8.0",
|
||||||
@@ -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",
|
||||||
|
|||||||
@@ -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',
|
||||||
|
|||||||
12
dashboard/public/assets/brands/azuread.svg
Normal file
12
dashboard/public/assets/brands/azuread.svg
Normal file
File diff suppressed because one or more lines are too long
|
After Width: | Height: | Size: 16 KiB |
@@ -7,7 +7,7 @@ import Link from 'next/link';
|
|||||||
|
|
||||||
export default function Sidebar() {
|
export default function Sidebar() {
|
||||||
return (
|
return (
|
||||||
<div className="grid grid-flow-row gap-8 mt-2 ml-10 w-full md:grid md:w-workspaceSidebar content-start">
|
<div className="mt-2 grid w-full grid-flow-row content-start gap-8 md:ml-10 md:grid md:w-workspaceSidebar">
|
||||||
<WorkspaceSection />
|
<WorkspaceSection />
|
||||||
<Resources />
|
<Resources />
|
||||||
|
|
||||||
|
|||||||
@@ -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>
|
||||||
|
);
|
||||||
|
}
|
||||||
@@ -0,0 +1 @@
|
|||||||
|
export { default } from './AzureADProviderSettings';
|
||||||
@@ -100,6 +100,12 @@ query GetSignInMethods($appId: uuid!) {
|
|||||||
connection
|
connection
|
||||||
organization
|
organization
|
||||||
}
|
}
|
||||||
|
azuread {
|
||||||
|
enabled
|
||||||
|
clientId
|
||||||
|
clientSecret
|
||||||
|
tenant
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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 />
|
||||||
|
|||||||
181
dashboard/src/utils/__generated__/graphql.ts
generated
181
dashboard/src/utils/__generated__/graphql.ts
generated
@@ -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
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -16,9 +16,9 @@
|
|||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@algolia/client-search": "^4.9.1",
|
"@algolia/client-search": "^4.9.1",
|
||||||
"@docusaurus/core": "2.3.1",
|
"@docusaurus/core": "2.4.0",
|
||||||
"@docusaurus/plugin-sitemap": "2.3.1",
|
"@docusaurus/plugin-sitemap": "2.4.0",
|
||||||
"@docusaurus/preset-classic": "2.3.1",
|
"@docusaurus/preset-classic": "2.4.0",
|
||||||
"@mdx-js/react": "^1.6.22",
|
"@mdx-js/react": "^1.6.22",
|
||||||
"clsx": "^1.2.1",
|
"clsx": "^1.2.1",
|
||||||
"docusaurus-plugin-image-zoom": "^0.1.1",
|
"docusaurus-plugin-image-zoom": "^0.1.1",
|
||||||
@@ -30,7 +30,7 @@
|
|||||||
"unist-util-visit": "^2.0.0"
|
"unist-util-visit": "^2.0.0"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@docusaurus/module-type-aliases": "2.3.1",
|
"@docusaurus/module-type-aliases": "2.4.0",
|
||||||
"@tsconfig/docusaurus": "^1.0.6",
|
"@tsconfig/docusaurus": "^1.0.6",
|
||||||
"typescript": "^4.8.4"
|
"typescript": "^4.8.4"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -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:
|
||||||
|
|||||||
@@ -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:
|
||||||
|
|||||||
@@ -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:
|
||||||
|
|||||||
@@ -1,5 +1,18 @@
|
|||||||
# @nhost/apollo
|
# @nhost/apollo
|
||||||
|
|
||||||
|
## 5.2.0
|
||||||
|
|
||||||
|
### Patch Changes
|
||||||
|
|
||||||
|
- Updated dependencies [a0e093d7]
|
||||||
|
- @nhost/nhost-js@2.2.0
|
||||||
|
|
||||||
|
## 5.1.3
|
||||||
|
|
||||||
|
### Patch Changes
|
||||||
|
|
||||||
|
- @nhost/nhost-js@2.1.2
|
||||||
|
|
||||||
## 5.1.2
|
## 5.1.2
|
||||||
|
|
||||||
### Patch Changes
|
### Patch Changes
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@nhost/apollo",
|
"name": "@nhost/apollo",
|
||||||
"version": "5.1.2",
|
"version": "5.2.0",
|
||||||
"description": "Nhost Apollo Client library",
|
"description": "Nhost Apollo Client library",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"keywords": [
|
"keywords": [
|
||||||
|
|||||||
@@ -1,5 +1,19 @@
|
|||||||
# @nhost/react-apollo
|
# @nhost/react-apollo
|
||||||
|
|
||||||
|
## 5.0.15
|
||||||
|
|
||||||
|
### Patch Changes
|
||||||
|
|
||||||
|
- @nhost/apollo@5.2.0
|
||||||
|
- @nhost/react@2.0.13
|
||||||
|
|
||||||
|
## 5.0.14
|
||||||
|
|
||||||
|
### Patch Changes
|
||||||
|
|
||||||
|
- @nhost/apollo@5.1.3
|
||||||
|
- @nhost/react@2.0.12
|
||||||
|
|
||||||
## 5.0.13
|
## 5.0.13
|
||||||
|
|
||||||
### Patch Changes
|
### Patch Changes
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@nhost/react-apollo",
|
"name": "@nhost/react-apollo",
|
||||||
"version": "5.0.13",
|
"version": "5.0.15",
|
||||||
"description": "Nhost React Apollo client",
|
"description": "Nhost React Apollo client",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"keywords": [
|
"keywords": [
|
||||||
|
|||||||
@@ -1,5 +1,17 @@
|
|||||||
# @nhost/react-urql
|
# @nhost/react-urql
|
||||||
|
|
||||||
|
## 2.0.13
|
||||||
|
|
||||||
|
### Patch Changes
|
||||||
|
|
||||||
|
- @nhost/react@2.0.13
|
||||||
|
|
||||||
|
## 2.0.12
|
||||||
|
|
||||||
|
### Patch Changes
|
||||||
|
|
||||||
|
- @nhost/react@2.0.12
|
||||||
|
|
||||||
## 2.0.11
|
## 2.0.11
|
||||||
|
|
||||||
### Patch Changes
|
### Patch Changes
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@nhost/react-urql",
|
"name": "@nhost/react-urql",
|
||||||
"version": "2.0.11",
|
"version": "2.0.13",
|
||||||
"description": "Nhost React URQL client",
|
"description": "Nhost React URQL client",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"keywords": [
|
"keywords": [
|
||||||
|
|||||||
@@ -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",
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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",
|
||||||
|
|||||||
@@ -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'
|
||||||
|
|||||||
@@ -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 }
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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 = {
|
||||||
|
|||||||
@@ -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) {
|
||||||
|
|||||||
@@ -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 }
|
||||||
|
|||||||
@@ -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'
|
||||||
|
|||||||
@@ -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 }
|
||||||
|
|||||||
@@ -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'
|
||||||
|
|||||||
@@ -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>
|
||||||
|
|
||||||
|
|||||||
@@ -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'
|
||||||
|
|||||||
@@ -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 }
|
||||||
|
|||||||
@@ -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'
|
||||||
|
|||||||
@@ -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 }
|
||||||
|
|||||||
@@ -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'
|
||||||
|
|||||||
@@ -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 }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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>,
|
||||||
|
|||||||
@@ -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>,
|
||||||
|
|||||||
@@ -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
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -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>,
|
||||||
|
|||||||
@@ -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 = (
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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,
|
||||||
|
|||||||
@@ -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,
|
||||||
|
|||||||
@@ -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) => {
|
||||||
|
|||||||
@@ -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) => {
|
||||||
|
|||||||
@@ -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.
|
||||||
*/
|
*/
|
||||||
|
|||||||
@@ -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,
|
||||||
|
|||||||
@@ -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,
|
||||||
|
|||||||
@@ -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,
|
||||||
|
|||||||
@@ -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,
|
||||||
|
|||||||
@@ -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) */
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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 */
|
||||||
|
|||||||
@@ -1,5 +1,21 @@
|
|||||||
# @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
|
||||||
|
|
||||||
|
### Patch Changes
|
||||||
|
|
||||||
|
- 43c86fef: chore: improve presignedUrl test
|
||||||
|
|
||||||
## 2.0.4
|
## 2.0.4
|
||||||
|
|
||||||
### Patch Changes
|
### Patch Changes
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@nhost/hasura-storage-js",
|
"name": "@nhost/hasura-storage-js",
|
||||||
"version": "2.0.4",
|
"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",
|
||||||
@@ -66,6 +67,7 @@
|
|||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@nhost/docgen": "workspace:*",
|
"@nhost/docgen": "workspace:*",
|
||||||
|
"@types/uuid": "^9.0.1",
|
||||||
"jpeg-js": "^0.4.4",
|
"jpeg-js": "^0.4.4",
|
||||||
"pixelmatch": "^5.3.0",
|
"pixelmatch": "^5.3.0",
|
||||||
"start-server-and-test": "^1.15.2",
|
"start-server-and-test": "^1.15.2",
|
||||||
|
|||||||
@@ -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' }
|
||||||
|
|
||||||
|
|||||||
@@ -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.
|
||||||
*/
|
*/
|
||||||
|
|||||||
@@ -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¶m2=test_data')
|
||||||
|
).toBe('https://example.com/?param1=test_data¶m2=test_data')
|
||||||
|
expect(appendImageTransformationParameters('https://example.com/')).toBe('https://example.com/')
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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 */
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -1,24 +1,27 @@
|
|||||||
import fs from 'fs'
|
|
||||||
import { describe, expect, it } from 'vitest'
|
|
||||||
import { v4 as uuidv4 } from 'uuid'
|
|
||||||
|
|
||||||
import { storage } from './utils/helpers'
|
|
||||||
import FormData from 'form-data'
|
import FormData from 'form-data'
|
||||||
|
import fs from 'fs'
|
||||||
|
import fetch from 'isomorphic-unfetch'
|
||||||
|
import { v4 as uuidv4 } from 'uuid'
|
||||||
|
import { describe, expect, it } from 'vitest'
|
||||||
|
import { storage } from './utils/helpers'
|
||||||
|
|
||||||
describe('test get presigned url of file', () => {
|
describe('test get presigned url of file', () => {
|
||||||
it('should be able to get presigned url of file', async () => {
|
it('should be able to get presigned url of file', async () => {
|
||||||
const fd = new FormData()
|
const formData = new FormData()
|
||||||
fd.append('file', fs.createReadStream('./tests/assets/sample.pdf'))
|
formData.append('file', fs.createReadStream('./tests/assets/sample.pdf'))
|
||||||
|
|
||||||
const { fileMetadata } = await storage.upload({
|
const { fileMetadata } = await storage.upload({ formData })
|
||||||
formData: fd
|
|
||||||
})
|
|
||||||
|
|
||||||
const { error } = await storage.getPresignedUrl({
|
const { presignedUrl, error } = await storage.getPresignedUrl({
|
||||||
fileId: fileMetadata?.id as string
|
fileId: fileMetadata?.id as string
|
||||||
})
|
})
|
||||||
|
|
||||||
|
expect(presignedUrl).not.toBeNull()
|
||||||
expect(error).toBeNull()
|
expect(error).toBeNull()
|
||||||
|
|
||||||
|
const imageResponse = await fetch(presignedUrl!.url)
|
||||||
|
|
||||||
|
expect(imageResponse.ok).toBeTruthy()
|
||||||
})
|
})
|
||||||
|
|
||||||
it('should fail to get presigned url of file that does not exist', async () => {
|
it('should fail to get presigned url of file that does not exist', async () => {
|
||||||
|
|||||||
@@ -1,5 +1,17 @@
|
|||||||
# @nhost/nextjs
|
# @nhost/nextjs
|
||||||
|
|
||||||
|
## 1.13.19
|
||||||
|
|
||||||
|
### Patch Changes
|
||||||
|
|
||||||
|
- @nhost/react@2.0.13
|
||||||
|
|
||||||
|
## 1.13.18
|
||||||
|
|
||||||
|
### Patch Changes
|
||||||
|
|
||||||
|
- @nhost/react@2.0.12
|
||||||
|
|
||||||
## 1.13.17
|
## 1.13.17
|
||||||
|
|
||||||
### Patch Changes
|
### Patch Changes
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@nhost/nextjs",
|
"name": "@nhost/nextjs",
|
||||||
"version": "1.13.17",
|
"version": "1.13.19",
|
||||||
"description": "Nhost NextJS library",
|
"description": "Nhost NextJS library",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"keywords": [
|
"keywords": [
|
||||||
|
|||||||
@@ -1,5 +1,25 @@
|
|||||||
# @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
|
||||||
|
|
||||||
|
### Patch Changes
|
||||||
|
|
||||||
|
- Updated dependencies [43c86fef]
|
||||||
|
- @nhost/hasura-storage-js@2.0.5
|
||||||
|
|
||||||
## 2.1.1
|
## 2.1.1
|
||||||
|
|
||||||
### Patch Changes
|
### Patch Changes
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@nhost/nhost-js",
|
"name": "@nhost/nhost-js",
|
||||||
"version": "2.1.1",
|
"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",
|
||||||
|
|||||||
@@ -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'
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -1,5 +1,18 @@
|
|||||||
# @nhost/react
|
# @nhost/react
|
||||||
|
|
||||||
|
## 2.0.13
|
||||||
|
|
||||||
|
### Patch Changes
|
||||||
|
|
||||||
|
- Updated dependencies [a0e093d7]
|
||||||
|
- @nhost/nhost-js@2.2.0
|
||||||
|
|
||||||
|
## 2.0.12
|
||||||
|
|
||||||
|
### Patch Changes
|
||||||
|
|
||||||
|
- @nhost/nhost-js@2.1.2
|
||||||
|
|
||||||
## 2.0.11
|
## 2.0.11
|
||||||
|
|
||||||
### Patch Changes
|
### Patch Changes
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@nhost/react",
|
"name": "@nhost/react",
|
||||||
"version": "2.0.11",
|
"version": "2.0.13",
|
||||||
"description": "Nhost React library",
|
"description": "Nhost React library",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"keywords": [
|
"keywords": [
|
||||||
|
|||||||
@@ -1,5 +1,11 @@
|
|||||||
# @nhost/sync-versions
|
# @nhost/sync-versions
|
||||||
|
|
||||||
|
## 0.0.7
|
||||||
|
|
||||||
|
### Patch Changes
|
||||||
|
|
||||||
|
- 4713cecf: chore(deps): bump `@pnpm/find-workspace-dir` to v6
|
||||||
|
|
||||||
## 0.0.6
|
## 0.0.6
|
||||||
|
|
||||||
### Patch Changes
|
### Patch Changes
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
"name": "@nhost/sync-versions",
|
"name": "@nhost/sync-versions",
|
||||||
"description": "Sync the versions of Nhost services in each of the packages of a pnpm workspace",
|
"description": "Sync the versions of Nhost services in each of the packages of a pnpm workspace",
|
||||||
"private": true,
|
"private": true,
|
||||||
"version": "0.0.6",
|
"version": "0.0.7",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"main": "dist/index.cjs.js",
|
"main": "dist/index.cjs.js",
|
||||||
"types": "dist/index.d.ts",
|
"types": "dist/index.d.ts",
|
||||||
@@ -33,7 +33,7 @@
|
|||||||
"typescript": "^4.8.4"
|
"typescript": "^4.8.4"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@pnpm/find-workspace-dir": "^5.0.0",
|
"@pnpm/find-workspace-dir": "^6.0.0",
|
||||||
"glob": "^9.0.0",
|
"glob": "^9.0.0",
|
||||||
"object-path": "^0.11.8",
|
"object-path": "^0.11.8",
|
||||||
"yaml": "^2.1.1"
|
"yaml": "^2.1.1"
|
||||||
|
|||||||
@@ -1,5 +1,18 @@
|
|||||||
# @nhost/vue
|
# @nhost/vue
|
||||||
|
|
||||||
|
## 1.13.19
|
||||||
|
|
||||||
|
### Patch Changes
|
||||||
|
|
||||||
|
- Updated dependencies [a0e093d7]
|
||||||
|
- @nhost/nhost-js@2.2.0
|
||||||
|
|
||||||
|
## 1.13.18
|
||||||
|
|
||||||
|
### Patch Changes
|
||||||
|
|
||||||
|
- @nhost/nhost-js@2.1.2
|
||||||
|
|
||||||
## 1.13.17
|
## 1.13.17
|
||||||
|
|
||||||
### Patch Changes
|
### Patch Changes
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@nhost/vue",
|
"name": "@nhost/vue",
|
||||||
"version": "1.13.17",
|
"version": "1.13.19",
|
||||||
"description": "Nhost Vue library",
|
"description": "Nhost Vue library",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"keywords": [
|
"keywords": [
|
||||||
|
|||||||
711
pnpm-lock.yaml
generated
711
pnpm-lock.yaml
generated
File diff suppressed because it is too large
Load Diff
Reference in New Issue
Block a user