Compare commits

...

5 Commits

Author SHA1 Message Date
github-actions[bot]
c8a8d4fca3 chore: update versions (#2609)
This PR was opened by the [Changesets
release](https://github.com/changesets/action) GitHub action. When
you're ready to do a release, you can merge this and the packages will
be published to npm automatically. If you're not ready to do a release
yet, that's fine, whenever you add more changesets to main, this PR will
be updated.


# Releases
## @nhost/hasura-auth-js@2.4.0

### Minor Changes

- 311374e: fix: ensure that the user remains signed in even after being
redirected with an error following an attempt to connect with a social
provider

### Patch Changes

-   1623e9b: chore: update `@simplewebauthn/browser` to `9.0.1`

## @nhost/vue@2.4.0

### Minor Changes

-   311374e: feat: add `connect` param to `useProviderLink` hook

### Patch Changes

-   @nhost/nhost-js@3.0.10

## @nhost/apollo@6.1.2

### Patch Changes

-   @nhost/nhost-js@3.0.10

## @nhost/react-apollo@10.0.2

### Patch Changes

-   Updated dependencies [311374e]
    -   @nhost/react@3.3.2
    -   @nhost/apollo@6.1.2

## @nhost/react-urql@7.0.2

### Patch Changes

-   Updated dependencies [311374e]
    -   @nhost/react@3.3.2

## @nhost/nextjs@2.1.8

### Patch Changes

-   Updated dependencies [311374e]
    -   @nhost/react@3.3.2

## @nhost/nhost-js@3.0.10

### Patch Changes

-   Updated dependencies [1623e9b]
-   Updated dependencies [311374e]
    -   @nhost/hasura-auth-js@2.4.0

## @nhost/react@3.3.2

### Patch Changes

-   311374e: feat: add `connect` param to `useProviderLink` hook
    -   @nhost/nhost-js@3.0.10

## @nhost-examples/docker-compose@0.3.0

### Minor Changes

- e40a452: chore: clarification on greyed-out options in the dashboard
when self-hosting

## @nhost-examples/react-apollo@0.7.0

### Minor Changes

- 311374e: feat: add example of how to connect a social auth provider to
an existing account

### Patch Changes

-   Updated dependencies [311374e]
    -   @nhost/react@3.3.2
    -   @nhost/react-apollo@10.0.2

## @nhost-examples/vue-apollo@0.5.0

### Minor Changes

- 311374e: feat: add example of how to connect a social auth provider to
an existing account

### Patch Changes

-   Updated dependencies [311374e]
    -   @nhost/vue@2.4.0
    -   @nhost/nhost-js@3.0.10
    -   @nhost/apollo@6.1.2

## @nhost/dashboard@1.11.2

### Patch Changes

-   @nhost/react-apollo@10.0.2
-   @nhost/nextjs@2.1.8

## @nhost/docs@2.7.2

### Patch Changes

-   5c47e8e: feat: added hasura's stringifyNumericTypes setting

## @nhost-examples/cli@0.2.2

### Patch Changes

-   @nhost/nhost-js@3.0.10

## @nhost-examples/codegen-react-apollo@0.3.1

### Patch Changes

-   Updated dependencies [311374e]
    -   @nhost/react@3.3.2
    -   @nhost/react-apollo@10.0.2

## @nhost-examples/codegen-react-query@0.3.1

### Patch Changes

-   Updated dependencies [311374e]
    -   @nhost/react@3.3.2

## @nhost-examples/codegen-react-urql@0.2.1

### Patch Changes

-   Updated dependencies [311374e]
    -   @nhost/react@3.3.2
    -   @nhost/react-urql@7.0.2

## @nhost-examples/multi-tenant-one-to-many@2.1.2

### Patch Changes

-   @nhost/nhost-js@3.0.10

## @nhost-examples/nextjs@0.2.2

### Patch Changes

-   Updated dependencies [311374e]
    -   @nhost/react@3.3.2
    -   @nhost/react-apollo@10.0.2
    -   @nhost/nextjs@2.1.8

## @nhost-examples/node-storage@0.1.2

### Patch Changes

-   @nhost/nhost-js@3.0.10

## @nhost-examples/nextjs-server-components@0.3.2

### Patch Changes

-   @nhost/nhost-js@3.0.10

## @nhost-examples/react-gqty@1.1.2

### Patch Changes

-   Updated dependencies [311374e]
    -   @nhost/react@3.3.2

## @nhost-examples/vue-quickstart@0.1.2

### Patch Changes

-   Updated dependencies [311374e]
    -   @nhost/vue@2.4.0
    -   @nhost/apollo@6.1.2

Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>
2024-03-21 17:54:02 +01:00
Hassan Ben Jobrane
311374e3fb feat: react-apollo: add example of how to connect github to an existing account (#2615)
fixes https://github.com/nhost/nhost/issues/2582
2024-03-21 17:38:54 +01:00
Seth Deegan
e40a4529b4 chore (examples/docker-compose): clarification on greyed-out options in the dashboard when self-hosting (#2564) 2024-03-18 11:03:10 +01:00
Hassan Ben Jobrane
1623e9bd20 chore: hasura-auth-js: upgrade @simplewebauthn/browser to 9.0.1 (#2611)
fixes https://github.com/nhost/nhost/issues/2597
2024-03-13 17:25:29 +01:00
David Barroso
5c47e8e675 feat (docs): added hasura's stringifyNumericTypes setting (#2608) 2024-03-12 11:29:53 +01:00
64 changed files with 645 additions and 85 deletions

View File

@@ -1,5 +1,12 @@
# @nhost/dashboard
## 1.11.2
### Patch Changes
- @nhost/react-apollo@10.0.2
- @nhost/nextjs@2.1.8
## 1.11.1
### Patch Changes

View File

@@ -1,6 +1,6 @@
{
"name": "@nhost/dashboard",
"version": "1.11.1",
"version": "1.11.2",
"private": true,
"scripts": {
"preinstall": "npx only-allow pnpm",

View File

@@ -1,5 +1,11 @@
# @nhost/docs
## 2.7.2
### Patch Changes
- 5c47e8e: feat: added hasura's stringifyNumericTypes setting
## 2.7.1
### Patch Changes

View File

@@ -44,6 +44,9 @@ Below, you will find the official `CUE` schema and an example on how to configur
// HASURA_GRAPHQL_LIVE_QUERIES_MULTIPLEXED_REFETCH_INTERVAL
liveQueriesMultiplexedRefetchInterval: uint32 | *1000
// HASURA_GRAPHQL_STRINGIFY_NUMERIC_TYPES
stringifyNumericTypes: bool | *false
}
logs: {
@@ -83,6 +86,7 @@ enableConsole = true
enableRemoteSchemaPermissions = true
enabledAPIs = ['metadata']
liveQueriesMultiplexedRefetchInterval = 1000
stringifyNumericTypes = false
[hasura.logs]
level = 'warn'

View File

@@ -1,6 +1,6 @@
{
"name": "@nhost/docs",
"version": "2.7.1",
"version": "2.7.2",
"private": true,
"scripts": {
"start": "mintlify dev"

View File

@@ -1,5 +1,11 @@
# @nhost-examples/cli
## 0.2.2
### Patch Changes
- @nhost/nhost-js@3.0.10
## 0.2.1
### Patch Changes

View File

@@ -1,6 +1,6 @@
{
"name": "@nhost-examples/cli",
"version": "0.2.1",
"version": "0.2.2",
"main": "src/index.mjs",
"private": true,
"scripts": {

View File

@@ -1,5 +1,13 @@
# @nhost-examples/codegen-react-apollo
## 0.3.1
### Patch Changes
- Updated dependencies [311374e]
- @nhost/react@3.3.2
- @nhost/react-apollo@10.0.2
## 0.3.0
### Minor Changes

View File

@@ -1,6 +1,6 @@
{
"name": "@nhost-examples/codegen-react-apollo",
"version": "0.3.0",
"version": "0.3.1",
"private": true,
"scripts": {
"codegen": "graphql-codegen",

View File

@@ -1,5 +1,12 @@
# @nhost-examples/codegen-react-query
## 0.3.1
### Patch Changes
- Updated dependencies [311374e]
- @nhost/react@3.3.2
## 0.3.0
### Minor Changes

View File

@@ -1,6 +1,6 @@
{
"name": "@nhost-examples/codegen-react-query",
"version": "0.3.0",
"version": "0.3.1",
"private": true,
"scripts": {
"codegen": "graphql-codegen",

View File

@@ -1,5 +1,13 @@
# @nhost-examples/react-urql
## 0.2.1
### Patch Changes
- Updated dependencies [311374e]
- @nhost/react@3.3.2
- @nhost/react-urql@7.0.2
## 0.2.0
### Minor Changes

View File

@@ -1,7 +1,7 @@
{
"name": "@nhost-examples/codegen-react-urql",
"private": true,
"version": "0.2.0",
"version": "0.2.1",
"scripts": {
"dev": "vite",
"build": "tsc && vite build",

View File

@@ -1,5 +1,11 @@
# @nhost-examples/docker-compose
## 0.3.0
### Minor Changes
- e40a452: chore: clarification on greyed-out options in the dashboard when self-hosting
## 0.2.0
### Minor Changes

View File

@@ -2,6 +2,8 @@
Here is an example on how to reproduce the Nhost stack from a docker-compose file.
NOTE: You may notice that some options in the dashboard are greyed-out. These include additional services like CI integration, configuration management, etc., offered by the Nhost Cloud and therefore are not accessible when self-hosting.
## Configuration
```sh

View File

@@ -1,6 +1,6 @@
{
"name": "@nhost-examples/docker-compose",
"version": "0.2.0",
"version": "0.3.0",
"private": true,
"scripts": {
"e2e": "vitest run"

View File

@@ -1,5 +1,11 @@
# @nhost-examples/multi-tenant-one-to-many
## 2.1.2
### Patch Changes
- @nhost/nhost-js@3.0.10
## 2.1.1
### Patch Changes

View File

@@ -1,7 +1,7 @@
{
"name": "@nhost-examples/multi-tenant-one-to-many",
"private": true,
"version": "2.1.1",
"version": "2.1.2",
"description": "",
"main": "index.js",
"scripts": {},

View File

@@ -1,5 +1,14 @@
# @nhost-examples/nextjs
## 0.2.2
### Patch Changes
- Updated dependencies [311374e]
- @nhost/react@3.3.2
- @nhost/react-apollo@10.0.2
- @nhost/nextjs@2.1.8
## 0.2.1
### Patch Changes

View File

@@ -1,6 +1,6 @@
{
"name": "@nhost-examples/nextjs",
"version": "0.2.1",
"version": "0.2.2",
"private": true,
"scripts": {
"dev": "next dev",

View File

@@ -1,5 +1,11 @@
# @nhost-examples/node-storage
## 0.1.2
### Patch Changes
- @nhost/nhost-js@3.0.10
## 0.1.1
### Patch Changes

View File

@@ -1,6 +1,6 @@
{
"name": "@nhost-examples/node-storage",
"version": "0.1.1",
"version": "0.1.2",
"private": true,
"description": "This is an example of how to use the Storage with Node.js",
"main": "src/index.mjs",

View File

@@ -1,5 +1,11 @@
# @nhost-examples/nextjs-server-components
## 0.3.2
### Patch Changes
- @nhost/nhost-js@3.0.10
## 0.3.1
### Patch Changes

View File

@@ -1,6 +1,6 @@
{
"name": "@nhost-examples/nextjs-server-components",
"version": "0.3.1",
"version": "0.3.2",
"private": true,
"scripts": {
"dev": "next dev",

View File

@@ -1,5 +1,17 @@
# @nhost-examples/react-apollo
## 0.7.0
### Minor Changes
- 311374e: feat: add example of how to connect a social auth provider to an existing account
### Patch Changes
- Updated dependencies [311374e]
- @nhost/react@3.3.2
- @nhost/react-apollo@10.0.2
## 0.6.0
### Minor Changes

View File

@@ -46,3 +46,13 @@ object_relationships:
- name: user
using:
foreign_key_constraint_on: user_id
select_permissions:
- role: user
permission:
columns:
- id
- provider_id
filter:
user_id:
_eq: X-Hasura-User-Id
comment: ""

View File

@@ -29,7 +29,7 @@ httpPoolSize = 100
version = 18
[auth]
version = '0.27.0-beta13'
version = '0.28.0-beta2'
[auth.elevatedPrivileges]
mode = 'required'

View File

@@ -1,6 +1,6 @@
{
"name": "@nhost-examples/react-apollo",
"version": "0.6.0",
"version": "0.7.0",
"private": true,
"dependencies": {
"@apollo/client": "^3.9.5",

View File

@@ -201,6 +201,73 @@ export type AuthRefreshTokensStreamCursorValueInput = {
userId?: InputMaybe<Scalars['uuid']>;
};
/** Active providers for a given user. Don't modify its structure as Hasura Auth relies on it to function properly. */
export type AuthUserProviders = {
__typename?: 'authUserProviders';
id: Scalars['uuid'];
providerId: Scalars['String'];
/** An object relationship */
user: Users;
};
/** order by aggregate values of table "auth.user_providers" */
export type AuthUserProvidersAggregateOrderBy = {
count?: InputMaybe<OrderBy>;
max?: InputMaybe<AuthUserProvidersMaxOrderBy>;
min?: InputMaybe<AuthUserProvidersMinOrderBy>;
};
/** Boolean expression to filter rows from the table "auth.user_providers". All fields are combined with a logical 'AND'. */
export type AuthUserProvidersBoolExp = {
_and?: InputMaybe<Array<AuthUserProvidersBoolExp>>;
_not?: InputMaybe<AuthUserProvidersBoolExp>;
_or?: InputMaybe<Array<AuthUserProvidersBoolExp>>;
id?: InputMaybe<UuidComparisonExp>;
providerId?: InputMaybe<StringComparisonExp>;
user?: InputMaybe<UsersBoolExp>;
};
/** order by max() on columns of table "auth.user_providers" */
export type AuthUserProvidersMaxOrderBy = {
id?: InputMaybe<OrderBy>;
providerId?: InputMaybe<OrderBy>;
};
/** order by min() on columns of table "auth.user_providers" */
export type AuthUserProvidersMinOrderBy = {
id?: InputMaybe<OrderBy>;
providerId?: InputMaybe<OrderBy>;
};
/** Ordering options when selecting data from "auth.user_providers". */
export type AuthUserProvidersOrderBy = {
id?: InputMaybe<OrderBy>;
providerId?: InputMaybe<OrderBy>;
user?: InputMaybe<UsersOrderBy>;
};
/** select columns of table "auth.user_providers" */
export enum AuthUserProvidersSelectColumn {
/** column name */
Id = 'id',
/** column name */
ProviderId = 'providerId'
}
/** Streaming cursor of the table "authUserProviders" */
export type AuthUserProvidersStreamCursorInput = {
/** Stream column input with initial value */
initial_value: AuthUserProvidersStreamCursorValueInput;
/** cursor ordering */
ordering?: InputMaybe<CursorOrdering>;
};
/** Initial value of the column from where the streaming should start */
export type AuthUserProvidersStreamCursorValueInput = {
id?: InputMaybe<Scalars['uuid']>;
providerId?: InputMaybe<Scalars['String']>;
};
/** User webauthn security keys. Don't modify its structure as Hasura Auth relies on it to function properly. */
export type AuthUserSecurityKeys = {
__typename?: 'authUserSecurityKeys';
@@ -930,6 +997,10 @@ export type QueryRoot = {
authRefreshToken?: Maybe<AuthRefreshTokens>;
/** fetch data from the table: "auth.refresh_tokens" */
authRefreshTokens: Array<AuthRefreshTokens>;
/** fetch data from the table: "auth.user_providers" using primary key columns */
authUserProvider?: Maybe<AuthUserProviders>;
/** fetch data from the table: "auth.user_providers" */
authUserProviders: Array<AuthUserProviders>;
/** fetch data from the table: "auth.user_security_keys" using primary key columns */
authUserSecurityKey?: Maybe<AuthUserSecurityKeys>;
/** fetch data from the table: "auth.user_security_keys" */
@@ -971,6 +1042,20 @@ export type QueryRootAuthRefreshTokensArgs = {
};
export type QueryRootAuthUserProviderArgs = {
id: Scalars['uuid'];
};
export type QueryRootAuthUserProvidersArgs = {
distinct_on?: InputMaybe<Array<AuthUserProvidersSelectColumn>>;
limit?: InputMaybe<Scalars['Int']>;
offset?: InputMaybe<Scalars['Int']>;
order_by?: InputMaybe<Array<AuthUserProvidersOrderBy>>;
where?: InputMaybe<AuthUserProvidersBoolExp>;
};
export type QueryRootAuthUserSecurityKeyArgs = {
id: Scalars['uuid'];
};
@@ -1066,6 +1151,12 @@ export type SubscriptionRoot = {
authRefreshTokens: Array<AuthRefreshTokens>;
/** fetch data from the table in a streaming manner: "auth.refresh_tokens" */
authRefreshTokens_stream: Array<AuthRefreshTokens>;
/** fetch data from the table: "auth.user_providers" using primary key columns */
authUserProvider?: Maybe<AuthUserProviders>;
/** fetch data from the table: "auth.user_providers" */
authUserProviders: Array<AuthUserProviders>;
/** fetch data from the table in a streaming manner: "auth.user_providers" */
authUserProviders_stream: Array<AuthUserProviders>;
/** fetch data from the table: "auth.user_security_keys" using primary key columns */
authUserSecurityKey?: Maybe<AuthUserSecurityKeys>;
/** fetch data from the table: "auth.user_security_keys" */
@@ -1124,6 +1215,27 @@ export type SubscriptionRootAuthRefreshTokensStreamArgs = {
};
export type SubscriptionRootAuthUserProviderArgs = {
id: Scalars['uuid'];
};
export type SubscriptionRootAuthUserProvidersArgs = {
distinct_on?: InputMaybe<Array<AuthUserProvidersSelectColumn>>;
limit?: InputMaybe<Scalars['Int']>;
offset?: InputMaybe<Scalars['Int']>;
order_by?: InputMaybe<Array<AuthUserProvidersOrderBy>>;
where?: InputMaybe<AuthUserProvidersBoolExp>;
};
export type SubscriptionRootAuthUserProvidersStreamArgs = {
batch_size: Scalars['Int'];
cursor: Array<InputMaybe<AuthUserProvidersStreamCursorInput>>;
where?: InputMaybe<AuthUserProvidersBoolExp>;
};
export type SubscriptionRootAuthUserSecurityKeyArgs = {
id: Scalars['uuid'];
};
@@ -1444,6 +1556,8 @@ export type Users = {
/** An array relationship */
securityKeys: Array<AuthUserSecurityKeys>;
updatedAt: Scalars['timestamptz'];
/** An array relationship */
userProviders: Array<AuthUserProviders>;
};
@@ -1472,6 +1586,16 @@ export type UsersSecurityKeysArgs = {
where?: InputMaybe<AuthUserSecurityKeysBoolExp>;
};
/** User account information. Don't modify its structure as Hasura Auth relies on it to function properly. */
export type UsersUserProvidersArgs = {
distinct_on?: InputMaybe<Array<AuthUserProvidersSelectColumn>>;
limit?: InputMaybe<Scalars['Int']>;
offset?: InputMaybe<Scalars['Int']>;
order_by?: InputMaybe<Array<AuthUserProvidersOrderBy>>;
where?: InputMaybe<AuthUserProvidersBoolExp>;
};
/** Boolean expression to filter rows from the table "auth.users". All fields are combined with a logical 'AND'. */
export type UsersBoolExp = {
_and?: InputMaybe<Array<UsersBoolExp>>;
@@ -1498,6 +1622,7 @@ export type UsersBoolExp = {
refreshTokens?: InputMaybe<AuthRefreshTokensBoolExp>;
securityKeys?: InputMaybe<AuthUserSecurityKeysBoolExp>;
updatedAt?: InputMaybe<TimestamptzComparisonExp>;
userProviders?: InputMaybe<AuthUserProvidersBoolExp>;
};
/** Ordering options when selecting data from "auth.users". */
@@ -1523,6 +1648,7 @@ export type UsersOrderBy = {
refreshTokens_aggregate?: InputMaybe<AuthRefreshTokensAggregateOrderBy>;
securityKeys_aggregate?: InputMaybe<AuthUserSecurityKeysAggregateOrderBy>;
updatedAt?: InputMaybe<OrderBy>;
userProviders_aggregate?: InputMaybe<AuthUserProvidersAggregateOrderBy>;
};
/** select columns of table "auth.users" */

View File

@@ -0,0 +1,70 @@
import { gql } from '@apollo/client'
import { Card, Group, Title } from '@mantine/core'
import { useProviderLink } from '@nhost/react'
import { useAuthQuery } from '@nhost/react-apollo'
import { useEffect } from 'react'
import { FaGithub } from 'react-icons/fa'
import { useSearchParams } from 'react-router-dom'
import AuthLink from 'src/components/AuthLink'
import { AuthUserProviders } from 'src/generated'
import { showNotification } from '@mantine/notifications'
export const ConnectSocials: React.FC = () => {
let [searchParams, setSearchParams] = useSearchParams()
useEffect(() => {
const error = searchParams.get('error')
const errorDescription = searchParams.get('errorDescription')
if (error === 'bad-request' && errorDescription === 'social user already exists') {
showNotification({
color: 'red',
title: 'Bad request',
message: 'Social user already exists'
})
searchParams.delete('error')
searchParams.delete('errorDescription')
setSearchParams(searchParams)
}
}, [searchParams, setSearchParams])
const { github } = useProviderLink({
connect: true,
redirectTo: `${window.location.origin}/profile`
})
const AUTH_USER_PROVIDERS = gql`
query getAuthUserProviders {
authUserProviders {
id
providerId
}
}
`
const { data } = useAuthQuery<{
authUserProviders: AuthUserProviders[]
}>(AUTH_USER_PROVIDERS, {
pollInterval: 5000,
fetchPolicy: 'cache-and-network'
})
const isGithubConnected = data?.authUserProviders?.some((item) => item.providerId === 'github')
return (
<Card shadow="sm" p="lg" m="sm">
<Title style={{ marginBottom: '1rem' }}>Connect with social providers</Title>
{!isGithubConnected ? (
<AuthLink leftIcon={<FaGithub />} link={github} color="#333" disabled={isGithubConnected}>
Connect with GitHub
</AuthLink>
) : (
<Group>
<FaGithub /> <span>Github connected</span>
</Group>
)}
</Card>
)
}

View File

@@ -4,6 +4,7 @@ import { useHasuraClaims, useNhostClient, useUserData } from '@nhost/react'
import { ChangeEmail } from './change-email'
import { ChangePassword } from './change-password'
import { ConnectSocials } from './connect-socials'
import { Mfa } from './mfa'
import { SecurityKeys } from './security-keys'
@@ -14,6 +15,7 @@ export const ProfilePage: React.FC = () => {
return (
<Container>
<Title>Profile page</Title>
<ConnectSocials />
<SecurityKeys />
<Mfa />
<ChangeEmail />

View File

@@ -1,5 +1,12 @@
# @nhost-examples/react-gqty
## 1.1.2
### Patch Changes
- Updated dependencies [311374e]
- @nhost/react@3.3.2
## 1.1.1
### Patch Changes

View File

@@ -1,7 +1,7 @@
{
"name": "@nhost-examples/react-gqty",
"private": true,
"version": "1.1.1",
"version": "1.1.2",
"type": "module",
"scripts": {
"dev": "vite",

View File

@@ -1,5 +1,18 @@
# @nhost-examples/vue-apollo
## 0.5.0
### Minor Changes
- 311374e: feat: add example of how to connect a social auth provider to an existing account
### Patch Changes
- Updated dependencies [311374e]
- @nhost/vue@2.4.0
- @nhost/nhost-js@3.0.10
- @nhost/apollo@6.1.2
## 0.4.1
### Patch Changes

View File

@@ -46,3 +46,15 @@ object_relationships:
- name: user
using:
foreign_key_constraint_on: user_id
select_permissions:
- role: user
permission:
columns:
- access_token
- id
- provider_id
- refresh_token
filter:
user_id:
_eq: X-Hasura-User-Id
comment: ""

View File

@@ -1,7 +1,7 @@
{
"name": "@nhost-examples/vue-apollo",
"private": true,
"version": "0.4.1",
"version": "0.5.0",
"scripts": {
"dev": "vite",
"build": "vite build",

View File

@@ -1,10 +1,32 @@
<template>
<div className="d-flex align-center flex-column">
<v-card width="400">
<v-card width="400" class="mb-2">
<v-card-title>Profile page</v-card-title>
<v-card-text> {{ userEmail }} </v-card-text>
</v-card>
<v-card width="400">
<v-card-text>
<v-btn
class="my-1"
block
variant="text"
prepend-icon="mdi-github"
color="white"
style="background-color: #333"
:href="github"
v-if="!isGithubConnected"
>
Connect with GitHub
</v-btn>
<span v-if="isGithubConnected">
<v-icon>mdi-github</v-icon>
Github connected {{ isGithubConnected }}
</span>
</v-card-text>
</v-card>
<v-card width="400" class="mt-2 pa-4">
<v-card-title>Add Security Key</v-card-title>
@@ -83,6 +105,17 @@
>
<error-snack-bar v-model="showRemoveKeyError"></error-snack-bar>
<error-snack-bar v-model="showConnectProviderError" title="Bad request"
><span class="text-white"></span
></error-snack-bar>
<v-snackbar v-model="showConnectProviderError" vertical>
<div class="pb-2 text-subtitle-1">Bad request</div>
<p>Social user already exists</p>
</v-snackbar>
<v-snackbar v-model="showRemoveKeyError">
Could not remove key
<template #actions>
@@ -105,11 +138,27 @@ import {
} from '@nhost/vue'
import { useMutation, useQuery } from '@vue/apollo-composable'
import { ref, unref, computed } from 'vue'
import { useProviderLink } from '@nhost/vue'
import { useRoute, useRouter } from 'vue-router'
import { onMounted } from 'vue'
const email = ref('')
const password = ref('')
const nickname = ref('')
const successSnackBar = ref(false)
const showConnectProviderError = ref(false)
const router = useRouter()
const route = useRoute()
onMounted(() => {
const errorDescription = route.query.errorDescription
if (errorDescription === 'social user already exists') {
showConnectProviderError.value = true
router.replace({ query: undefined })
}
})
const userId = useUserId()
const userEmail = useUserEmail()
@@ -123,6 +172,19 @@ const { changeEmail, isLoading: isChangeEmailLoading } = useChangeEmail()
const { changePassword, isLoading: isChangePasswordLoading } = useChangePassword()
const { elevated, elevateEmailSecurityKey } = useElevateSecurityKeyEmail()
const { add } = useAddSecurityKey()
const { github } = useProviderLink({
connect: true,
redirectTo: `${window.location.origin}/profile`
})
const AUTH_USER_PROVIDERS = gql`
query getAuthUserProviders {
authUserProviders {
id
providerId
}
}
`
const SECURITY_KEYS_LIST = gql`
query securityKeys($userId: uuid!) {
@@ -141,6 +203,14 @@ const REMOVE_SECURITY_KEY = gql`
}
`
const { result: authUserProvidersQueryResult } = useQuery(AUTH_USER_PROVIDERS)
const isGithubConnected = computed(() =>
authUserProvidersQueryResult.value?.authUserProviders.some(
(item: any) => item.providerId === 'github'
)
)
const { result: securityKeys, refetch } = useQuery(SECURITY_KEYS_LIST, { userId }, {})
const { mutate: removeKey } = useMutation(REMOVE_SECURITY_KEY)

View File

@@ -1,5 +1,13 @@
# @nhost-examples/vue-quickstart
## 0.1.2
### Patch Changes
- Updated dependencies [311374e]
- @nhost/vue@2.4.0
- @nhost/apollo@6.1.2
## 0.1.1
### Patch Changes

View File

@@ -1,6 +1,6 @@
{
"name": "@nhost-examples/vue-quickstart",
"version": "0.1.1",
"version": "0.1.2",
"private": true,
"scripts": {
"build": "vite build",

View File

@@ -1,5 +1,11 @@
# @nhost/apollo
## 6.1.2
### Patch Changes
- @nhost/nhost-js@3.0.10
## 6.1.1
### Patch Changes

View File

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

View File

@@ -1,5 +1,13 @@
# @nhost/react-apollo
## 10.0.2
### Patch Changes
- Updated dependencies [311374e]
- @nhost/react@3.3.2
- @nhost/apollo@6.1.2
## 10.0.1
### Patch Changes

View File

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

View File

@@ -1,5 +1,12 @@
# @nhost/react-urql
## 7.0.2
### Patch Changes
- Updated dependencies [311374e]
- @nhost/react@3.3.2
## 7.0.1
### Patch Changes

View File

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

View File

@@ -135,7 +135,7 @@
"semver@<5.7.2": ">=5.7.2",
"semver@>=6.0.0 <6.3.1": ">=6.3.1",
"semver@>=7.0.0 <7.5.2": ">=7.5.2",
"follow-redirects@<1.15.4": ">=1.15.4"
"follow-redirects@>1.15.6": ">=1.15.6"
}
}
}

View File

@@ -1,5 +1,15 @@
# @nhost/hasura-auth-js
## 2.4.0
### Minor Changes
- 311374e: fix: ensure that the user remains signed in even after being redirected with an error following an attempt to connect with a social provider
### Patch Changes
- 1623e9b: chore: update `@simplewebauthn/browser` to `9.0.1`
## 2.3.1
### Patch Changes

View File

@@ -1,6 +1,6 @@
{
"name": "@nhost/hasura-auth-js",
"version": "2.3.1",
"version": "2.4.0",
"description": "Hasura-auth client",
"license": "MIT",
"keywords": [
@@ -64,7 +64,7 @@
"docgen": "pnpm typedoc && docgen --config ./auth.docgen.json"
},
"dependencies": {
"@simplewebauthn/browser": "^6.2.2",
"@simplewebauthn/browser": "^9.0.1",
"fetch-ponyfill": "^7.1.0",
"jose": "^5.2.2",
"js-cookie": "^3.0.5",

View File

@@ -19,11 +19,12 @@ import {
addSecurityKeyPromise,
changeEmailPromise,
changePasswordPromise,
elevateEmailSecurityKeyPromise,
resetPasswordPromise,
sendVerificationEmailPromise,
signInAnonymousPromise,
signInEmailPasswordPromise,
signInEmailPasswordlessPromise,
signInEmailPasswordPromise,
signInEmailSecurityKeyPromise,
signInMfaTotpPromise,
signInPATPromise,
@@ -31,8 +32,7 @@ import {
signInSmsPasswordlessPromise,
signOutPromise,
signUpEmailPasswordPromise,
signUpEmailSecurityKeyPromise,
elevateEmailSecurityKeyPromise
signUpEmailSecurityKeyPromise
} from './promises'
import { createPATPromise } from './promises/createPAT'
import {
@@ -42,6 +42,8 @@ import {
ChangeEmailResponse,
ChangePasswordParams,
ChangePasswordResponse,
ConnectProviderParams,
ConnectProviderResponse,
DeanonymizeParams,
DeanonymizeResponse,
JWTClaims,
@@ -54,8 +56,8 @@ import {
SecurityKey,
SendVerificationEmailParams,
SendVerificationEmailResponse,
SignInPATResponse,
SignInParams,
SignInPATResponse,
SignInResponse,
SignOutResponse,
SignUpParams,
@@ -132,6 +134,43 @@ export class HasuraAuthClient {
)
}
/**
* Use `nhost.auth.connectProvider` to connect a social authentication provider to an existing user account
*
* @example
* ### Connect an authentication provider to an existing user account
* ```ts
* nhost.auth.connectProvider({
* provider: 'github
* options: {
* redirectTo: window.location.href
* }
* })
* ```
*
* @docs https://docs.nhost.io/reference/javascript/auth/connect-provider
*/
async connectProvider(params: ConnectProviderParams): Promise<ConnectProviderResponse> {
const interpreter = await this.waitUntilReady()
const accessToken = interpreter.getSnapshot().context.accessToken.value
const { provider, options } = params
const providerUrl = encodeQueryParameters(
`${this._client.backendUrl}/signin/provider/${provider}`,
rewriteRedirectTo(this._client.clientUrl, {
...options,
connect: accessToken
} as any)
)
if (isBrowser()) {
window.location.href = providerUrl
}
return { providerUrl }
}
/**
* Use `nhost.auth.signIn` to sign in a user using email and password, passwordless (email or sms) or an external provider. `signIn` can be used to sign in a user in various ways depending on the parameters.
*

View File

@@ -960,15 +960,19 @@ export const createAuthMachine = ({
}
} else {
const error = getParameterByName('error')
const errorDescription = getParameterByName('errorDescription')
if (error) {
return Promise.reject<NhostSessionResponse>({
session: null,
error: {
status: VALIDATION_ERROR_CODE,
error,
message: getParameterByName('errorDescription') || error
}
})
if (errorDescription !== 'social user already exists') {
return Promise.reject<NhostSessionResponse>({
session: null,
error: {
status: VALIDATION_ERROR_CODE,
error,
message: errorDescription || error
}
})
}
}
}
}

View File

@@ -67,6 +67,8 @@ export type SignInWithProviderParams =
| { provider: Exclude<Provider, 'workos'>; options?: CommonProviderOptions }
| { provider: 'workos'; options?: WorkOsOptions }
export type ConnectProviderParams = SignInWithProviderParams
export type SignInParams =
| SignInEmailPasswordParams
| SignInEmailPasswordOtpParams

View File

@@ -60,3 +60,5 @@ export type PasswordlessSmsOtpResponse = NhostSessionResponse
/** payload from hasura-auth endpoint /signin/mfa/totp */
export type SignInMfaTotpResponse = NhostSessionResponse
export type ConnectProviderResponse = { providerUrl?: string }

View File

@@ -48,7 +48,9 @@ export interface DeanonymizeOptions extends RegistrationOptions {
password?: string
}
export interface CommonProviderOptions extends RegistrationOptions, RedirectOption {}
export interface CommonProviderOptions extends RegistrationOptions, RedirectOption {
connect?: boolean
}
export interface WorkOsOptions extends CommonProviderOptions {
connection?: string
organization?: string

View File

@@ -1,5 +1,12 @@
# @nhost/nextjs
## 2.1.8
### Patch Changes
- Updated dependencies [311374e]
- @nhost/react@3.3.2
## 2.1.7
### Patch Changes

View File

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

View File

@@ -1,5 +1,13 @@
# @nhost/nhost-js
## 3.0.10
### Patch Changes
- Updated dependencies [1623e9b]
- Updated dependencies [311374e]
- @nhost/hasura-auth-js@2.4.0
## 3.0.9
### Patch Changes

View File

@@ -1,6 +1,6 @@
{
"name": "@nhost/nhost-js",
"version": "3.0.9",
"version": "3.0.10",
"description": "Nhost JavaScript SDK",
"license": "MIT",
"keywords": [

View File

@@ -1,5 +1,12 @@
# @nhost/react
## 3.3.2
### Patch Changes
- 311374e: feat: add `connect` param to `useProviderLink` hook
- @nhost/nhost-js@3.0.10
## 3.3.1
### Patch Changes

View File

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

View File

@@ -6,6 +6,7 @@ import {
} from '@nhost/nhost-js'
import { useContext, useEffect, useState } from 'react'
import { NhostReactContext } from './provider'
import { useAccessToken } from './useAccessToken'
/**
* Use the hook `useProviderLink` to get an OAuth provider URL that can be used to sign in users.
@@ -39,6 +40,7 @@ export const useProviderLink = (options?: ProviderOptions): Record<Provider, str
* the React/Nextjs context.
*/
const [isSSR, setIsSSR] = useState(true)
const accessToken = useAccessToken()
useEffect(() => {
setIsSSR(false)
@@ -48,9 +50,16 @@ export const useProviderLink = (options?: ProviderOptions): Record<Provider, str
return new Proxy({} as Record<Provider, string>, {
get(_, provider: string) {
let providerLink = `${nhost.auth.client.backendUrl}/signin/provider/${provider}`
const connectOptions = options?.connect ? { connect: accessToken } : {}
return encodeQueryParameters(
`${nhost.auth.client.backendUrl}/signin/provider/${provider}`,
rewriteRedirectTo(isSSR ? undefined : nhost.auth.client.clientUrl, options as any)
providerLink,
rewriteRedirectTo(isSSR ? undefined : nhost.auth.client.clientUrl, {
...options,
...connectOptions
} as any)
)
}
})

View File

@@ -1,5 +1,15 @@
# @nhost/vue
## 2.4.0
### Minor Changes
- 311374e: feat: add `connect` param to `useProviderLink` hook
### Patch Changes
- @nhost/nhost-js@3.0.10
## 2.3.1
### Patch Changes

View File

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

View File

@@ -6,6 +6,7 @@ import {
} from '@nhost/nhost-js'
import { reactive } from 'vue'
import { NestedRefOfValue, nestedUnref } from './helpers'
import { useAccessToken } from './useAccessToken'
import { useNhostClient } from './useNhostClient'
/**
@@ -36,13 +37,21 @@ export const useProviderLink = (
options?: NestedRefOfValue<ProviderOptions | undefined>
): Record<Provider, string> => {
const { nhost } = useNhostClient()
const accessToken = useAccessToken()
return reactive(
new Proxy({} as Record<Provider, string>, {
get(_, provider: string) {
const optionsValue = nestedUnref(options)
const connectOptions = optionsValue?.connect ? { connect: accessToken.value } : {}
return encodeQueryParameters(
`${nhost.auth.client.backendUrl}/signin/provider/${provider}`,
rewriteRedirectTo(nhost.auth.client.clientUrl, optionsValue as any)
rewriteRedirectTo(nhost.auth.client.clientUrl, {
...optionsValue,
...connectOptions
} as any)
)
}
})

103
pnpm-lock.yaml generated
View File

@@ -40,7 +40,7 @@ overrides:
semver@<5.7.2: '>=5.7.2'
semver@>=6.0.0 <6.3.1: '>=6.3.1'
semver@>=7.0.0 <7.5.2: '>=7.5.2'
follow-redirects@<1.15.4: '>=1.15.4'
follow-redirects@>1.15.6: '>=1.15.6'
importers:
@@ -580,7 +580,7 @@ importers:
devDependencies:
mintlify:
specifier: ^4.0.128
version: 4.0.128
version: 4.0.133
examples/cli:
dependencies:
@@ -1592,8 +1592,8 @@ importers:
packages/hasura-auth-js:
dependencies:
'@simplewebauthn/browser':
specifier: ^6.2.2
version: 6.2.2
specifier: ^9.0.1
version: 9.0.1
fetch-ponyfill:
specifier: ^7.1.0
version: 7.1.0
@@ -2067,7 +2067,7 @@ packages:
resolution: {integrity: sha512-9anThAaj1dQr6IGmzBMcfzOQKTa5artjuPmw8NYK/fiGEMjADbSguBY2FMDykt+QhilR3wc9VA/3yVju7JHg7Q==}
hasBin: true
peerDependencies:
graphql: '>=16.8.1'
graphql: 16.8.1
dependencies:
'@babel/core': 7.24.0
'@babel/generator': 7.23.6
@@ -5885,7 +5885,7 @@ packages:
resolution: {integrity: sha512-FeKv9lKLMwqDu0pQjPpF59GY3HReUkWXKsMIuMuJQOKh9BETu7zPEFUELvcw8w+lwZkl4ileJsHXC9+AnsT2Lw==}
engines: {node: '>=16.0.0'}
peerDependencies:
graphql: '>=16.8.1'
graphql: 16.8.1
dependencies:
'@graphql-tools/utils': 10.1.0(graphql@16.8.1)
graphql: 16.8.1
@@ -6010,7 +6010,7 @@ packages:
resolution: {integrity: sha512-p28Oh9EcOna6i0yLaCFOnkcBDQECVf3SCexT6ktb86QNj9idnkhI+tCxnwZDh58Qvjd2nURdkbevvoZkvxzCog==}
engines: {node: '>=16.0.0'}
peerDependencies:
graphql: '>=16.8.1'
graphql: 16.8.1
dependencies:
'@graphql-tools/merge': 9.0.3(graphql@16.8.1)
'@graphql-tools/utils': 10.1.0(graphql@16.8.1)
@@ -6941,16 +6941,17 @@ packages:
resolution: {integrity: sha512-9b8mPpKrfeGRuhFH5iO1iwCLeIIsV6+H1sRfxbkoGXIyQE2BTsPd9zqSqQJ+pv5sJ/hT5M1zvOFL02MnEezFug==}
dev: true
/@mintlify/cli@4.0.128:
resolution: {integrity: sha512-20CArlOEZf9bxNXlnyl64/lPXvZA4YKBurrj0I0Lhed2vmOgT+p3crGHQHleZOkIEJ/IyH3ycB3Aw+NSt1L61w==}
/@mintlify/cli@4.0.133:
resolution: {integrity: sha512-RRsciqzgKeSXrw4XozTzfyhpX7zxsVGfh+Xdk4zTIKn12m5/sutmSD1W7axXpdWKTxNpvUyIFoU6M743FIB6jw==}
engines: {node: '>=18.0.0'}
hasBin: true
dependencies:
'@apidevtools/swagger-parser': 10.1.0(openapi-types@12.1.3)
'@mintlify/link-rot': 3.0.141
'@mintlify/models': 0.0.70
'@mintlify/prebuild': 1.0.141
'@mintlify/previewing': 4.0.125
'@mintlify/validation': 0.1.127
'@mintlify/link-rot': 3.0.144
'@mintlify/models': 0.0.72
'@mintlify/prebuild': 1.0.144
'@mintlify/previewing': 4.0.130
'@mintlify/validation': 0.1.129
chalk: 5.3.0
detect-port: 1.5.1
fs-extra: 11.2.0
@@ -6969,13 +6970,13 @@ packages:
- utf-8-validate
dev: true
/@mintlify/common@1.0.73:
resolution: {integrity: sha512-Aae5YJGL5xBx9NOYnOav3zm0YesUoGt0EEIvDVQqGj7LlDG6aR9KA1y031SsfVVyHeC4tbXNLf/5vmv20DnXrw==}
/@mintlify/common@1.0.76:
resolution: {integrity: sha512-aM+E0u5rLKu+6z64eoCKsvnAB0WziBx+wnRStFrbRdTCSt/LpsSbW+bNdz9AJOQADtiQdS39cLFPUVow7IPi7w==}
dependencies:
'@apidevtools/swagger-parser': 10.1.0(openapi-types@12.1.3)
'@mintlify/mdx': 0.0.44
'@mintlify/models': 0.0.70
'@mintlify/validation': 0.1.127
'@mintlify/models': 0.0.72
'@mintlify/validation': 0.1.129
'@sindresorhus/slugify': 2.2.1
acorn: 8.11.3
acorn-jsx: 5.3.2(acorn@8.11.3)
@@ -7018,13 +7019,13 @@ packages:
- supports-color
dev: true
/@mintlify/link-rot@3.0.141:
resolution: {integrity: sha512-twAehDvcPP0Y+hVJmPPjiFIxBi7dLpur3w2u2ioLFkviSMT3uQ7o00YyGJNnjbtOq5W+mi2a7CWmGtH72D3PZg==}
/@mintlify/link-rot@3.0.144:
resolution: {integrity: sha512-uWlQPVzrQN081y8fT+5OUToLijpcA0q8JU2mWPe3upAlX1h7IsREcv/rk4Ce4wg2Eg3aXPsAvoFnTzywhnXpMw==}
engines: {node: '>=18.0.0'}
dependencies:
'@apidevtools/swagger-parser': 10.1.0(openapi-types@12.1.3)
'@mintlify/common': 1.0.73
'@mintlify/prebuild': 1.0.141
'@mintlify/common': 1.0.76
'@mintlify/prebuild': 1.0.144
chalk: 5.3.0
fs-extra: 11.2.0
gray-matter: 4.0.3
@@ -7055,8 +7056,8 @@ packages:
- supports-color
dev: true
/@mintlify/models@0.0.70:
resolution: {integrity: sha512-xeb0UnXmZg+e55osf6NxNUN6pet8f2EJrPQ+1J8EFjlUXSkDRmqxrYfl7eJo40NPLZEhry84Hjcbm8xcgDRZdQ==}
/@mintlify/models@0.0.72:
resolution: {integrity: sha512-nwwC/PT2ieB7eDFzwB8p8j/rm35dmzvaLf2+1bZiuCmgi3xMcx39QY0HH83lgV98YgUzPs4EvBeAmpwdn4mkdQ==}
engines: {node: '>=18.0.0'}
dependencies:
axios: 1.6.7
@@ -7065,12 +7066,12 @@ packages:
- debug
dev: true
/@mintlify/prebuild@1.0.141:
resolution: {integrity: sha512-b7cQDUWZZwOTki1tdnjIrUQeqV7jEoNPq6lGik7HL/gBhQ6p4DMKWVwxQfvCk/1uydLNBZpMTv68rWiS/3C2yw==}
/@mintlify/prebuild@1.0.144:
resolution: {integrity: sha512-aEdNlK/vfyWQftYGgloDZy5c5G2SN3f3/2XMp1NBqipaG0Y6VQL0pGL1XP/Ksl8Ts+FlDeY+M+Z17qb05FzATA==}
dependencies:
'@apidevtools/swagger-parser': 10.1.0(openapi-types@12.1.3)
'@mintlify/common': 1.0.73
'@mintlify/validation': 0.1.127
'@mintlify/common': 1.0.76
'@mintlify/validation': 0.1.129
favicons: 7.1.5
fs-extra: 11.2.0
gray-matter: 4.0.3
@@ -7085,14 +7086,14 @@ packages:
- supports-color
dev: true
/@mintlify/previewing@4.0.125:
resolution: {integrity: sha512-Y/m5pxLr+QZPicecEwu9PBtfRv1ilwZUkE5GAVeORa1EFctfP7wrmeLq8xjOisqqAQfahdn328pQdjP86GjRtg==}
/@mintlify/previewing@4.0.130:
resolution: {integrity: sha512-BzVgKgQ+xG2CVUiIisQWOnqlq2XxCrpO5vzgoOar5ZBjOrsOVeyKxH06w+s05Zlu/dzX5gE7yc85sTt6BFY2PA==}
engines: {node: '>=18.0.0'}
dependencies:
'@apidevtools/swagger-parser': 10.1.0(openapi-types@12.1.3)
'@mintlify/common': 1.0.73
'@mintlify/prebuild': 1.0.141
'@mintlify/validation': 0.1.127
'@mintlify/common': 1.0.76
'@mintlify/prebuild': 1.0.144
'@mintlify/validation': 0.1.129
'@octokit/rest': 19.0.13
chalk: 5.3.0
chokidar: 3.6.0
@@ -7119,10 +7120,10 @@ packages:
- utf-8-validate
dev: true
/@mintlify/validation@0.1.127:
resolution: {integrity: sha512-unPdTch8pJO/ptxerTGbxVbl6o1KXzEX5n9vBcZX04XzbBcPXNqGVxKEnFkh7MSYG3Wv0WeTNKz3WWEaJjeMfg==}
/@mintlify/validation@0.1.129:
resolution: {integrity: sha512-xJ/G9rt0ryDwtRfcWuvkIeqHyfKdin/LEri/mRyS+caY/qACTWtRQBo/W99E++xPOq+ZRe/xppxmajXsTuU8Pg==}
dependencies:
'@mintlify/models': 0.0.70
'@mintlify/models': 0.0.72
lcm: 0.0.3
lodash: 4.17.21
openapi-types: 12.1.3
@@ -8753,6 +8754,17 @@ packages:
/@simplewebauthn/browser@6.2.2:
resolution: {integrity: sha512-VUtne7+s6BmW4usnbitjZEI1VNT/PNh6bYg+AI4OMdfpo5z+yAq+6iVAWBJlIUGVk5InetEQvTUp6OefBam8qg==}
dev: true
/@simplewebauthn/browser@9.0.1:
resolution: {integrity: sha512-wD2WpbkaEP4170s13/HUxPcAV5y4ZXaKo1TfNklS5zDefPinIgXOpgz1kpEvobAsaLPa2KeH7AKKX/od1mrBJw==}
dependencies:
'@simplewebauthn/types': 9.0.1
dev: false
/@simplewebauthn/types@9.0.1:
resolution: {integrity: sha512-tGSRP1QvsAvsJmnOlRQyw/mvK9gnPtjEc5fg2+m8n+QUa+D7rvrKkOYyfpy42GTs90X3RDOnqJgfHt+qO67/+w==}
dev: false
/@simplewebauthn/typescript-types@6.2.1:
resolution: {integrity: sha512-qScvkt0nP0Uy/xeeunlXAkJni9wtecsvxwLELSgiWRx/KRVZy1SGDHsKAfQowpIeDmLDyhWxUoN7qUgvgWCiAQ==}
@@ -12772,6 +12784,7 @@ packages:
/astring@1.8.6:
resolution: {integrity: sha512-ISvCdHdlTDlH5IpxQJIex7BWBywFWgjJSVdwst+/iQCoEYnyOaQ95+X1JGshuBjGp6nxKUy1jMgE3zPqN7fQdg==}
hasBin: true
dev: true
/async-each@1.0.6:
@@ -12878,7 +12891,7 @@ packages:
/axios@1.6.7:
resolution: {integrity: sha512-/hDJGff6/c7u0hDkvkGxR/oy6CbCs8ziCsC7SqmhjfozqiJGc8Z11wrv9z9lYfY4K8l+H9TpjcMDX0xOZmx+RA==}
dependencies:
follow-redirects: 1.15.5
follow-redirects: 1.15.6
form-data: 4.0.0
proxy-from-env: 1.1.0
transitivePeerDependencies:
@@ -14742,6 +14755,7 @@ packages:
/detect-port@1.5.1:
resolution: {integrity: sha512-aBzdj76lueB6uUst5iAs7+0H/oOjqI5D16XUWxlWMIMROhcM0rfsNVk93zTngq1dDNpoXRr++Sus7ETAExppAQ==}
hasBin: true
dependencies:
address: 1.2.2
debug: 4.3.4
@@ -16950,8 +16964,8 @@ packages:
tslib: 1.14.1
dev: true
/follow-redirects@1.15.5:
resolution: {integrity: sha512-vSFWUON1B+yAw1VN4xMfxgn5fTUiaOzAJCKBwIIgT/+7CuGy9+r+5gITvP62j3RmaD5Ph65UaERdOSRGUzZtgw==}
/follow-redirects@1.15.6:
resolution: {integrity: sha512-wWN62YITEaOpSK584EZXJafH1AGpO8RVgElfkuXbTOrPX4fIfOyEpW/CsiNd8JdYrAoOvafRTOEnvsO++qCqFA==}
engines: {node: '>=4.0'}
peerDependencies:
debug: '*'
@@ -18789,6 +18803,7 @@ packages:
/is-docker@2.2.1:
resolution: {integrity: sha512-F+i2BKsFrH66iaUFc0woD8sLy8getkwTwtOBjvs56Cx4CgJDeKQeqfz8wAYiSb8JOprWhHH5p77PbmYCvvUuXQ==}
engines: {node: '>=8'}
hasBin: true
dev: true
/is-dom@1.1.0:
@@ -19713,6 +19728,7 @@ packages:
/katex@0.16.9:
resolution: {integrity: sha512-fsSYjWS0EEOwvy81j3vRA8TEAhQhKiqO+FQaKWp0m39qwOzHVBgAUBIXWj1pB+O2W3fIpNa6Y9KSKCVbfPhyAQ==}
hasBin: true
dependencies:
commander: 8.3.0
dev: true
@@ -20729,6 +20745,7 @@ packages:
/mdast@3.0.0:
resolution: {integrity: sha512-xySmf8g4fPKMeC07jXGz971EkLbWAJ83s4US2Tj9lEdnZ142UP5grN73H1Xd3HzrdbU5o9GYYP/y8F9ZSwLE9g==}
deprecated: '`mdast` was renamed to `remark`'
dev: true
/mdn-data@2.0.30:
@@ -21616,11 +21633,12 @@ packages:
yallist: 4.0.0
dev: true
/mintlify@4.0.128:
resolution: {integrity: sha512-jqHjnQ7dvE5mV2Gl8yAuFo5ckG+8KdXKGihOnHDOEPzNdNXl2hkiurCMNFkFLIMih5QZleHHl40lql2jkGt4qw==}
/mintlify@4.0.133:
resolution: {integrity: sha512-c4axsQP0/pJLV5uDdHO0ISs17ImZmnDH/y3LINPcvhuGAg6yDbZ/PiYm8ljYT7jfhtYFqnH+8p3SG6uDwYYC2g==}
engines: {node: '>=18.0.0'}
hasBin: true
dependencies:
'@mintlify/cli': 4.0.128
'@mintlify/cli': 4.0.133
transitivePeerDependencies:
- bufferutil
- debug
@@ -27416,6 +27434,7 @@ packages:
/uvu@0.5.6:
resolution: {integrity: sha512-+g8ENReyr8YsOc6fv/NVJs2vFdHBnBNdfE49rshrTzDWOlUx4Gq7KOS2GD8eqhy2j+Ejq29+SbKH8yjkAqXqoA==}
engines: {node: '>=8'}
hasBin: true
dependencies:
dequal: 2.0.3
diff: 5.2.0