@nhost/nhost-js 1.2.2 → 1.2.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@nhost/nhost-js",
3
- "version": "1.2.2",
3
+ "version": "1.2.3",
4
4
  "description": "Nhost JavaScript SDK",
5
5
  "license": "MIT",
6
6
  "keywords": [
@@ -21,7 +21,7 @@
21
21
  "url": "git+https://github.com/nhost/nhost.git"
22
22
  },
23
23
  "main": "dist/index.cjs.js",
24
- "module": "dist/index.esm.mjs",
24
+ "module": "dist/index.esm.js",
25
25
  "types": "dist/index.d.ts",
26
26
  "source": "src/index.ts",
27
27
  "files": [
@@ -31,25 +31,22 @@
31
31
  ],
32
32
  "exports": {
33
33
  ".": {
34
- "node": {
35
- "import": "./dist/index.esm.mjs",
36
- "require": "./dist/index.cjs.js"
37
- },
38
- "default": "./dist/index.esm.js"
34
+ "import": "./dist/index.esm.js",
35
+ "require": "./dist/index.cjs.js"
39
36
  }
40
37
  },
41
38
  "publishConfig": {
42
39
  "access": "public"
43
40
  },
44
41
  "dependencies": {
45
- "@nhost/hasura-auth-js": "1.1.12",
46
- "@nhost/hasura-storage-js": "0.3.2",
42
+ "@nhost/hasura-auth-js": "1.1.13",
43
+ "@nhost/hasura-storage-js": "0.3.3",
47
44
  "axios": "^0.27.2",
48
45
  "jwt-decode": "^3.1.2",
49
46
  "query-string": "^7.0.1"
50
47
  },
51
48
  "devDependencies": {
52
- "@nhost/docgen": "0.1.1",
49
+ "@nhost/docgen": "0.1.2",
53
50
  "graphql": "16"
54
51
  },
55
52
  "peerDependencies": {
@@ -1,203 +0,0 @@
1
- var __defProp = Object.defineProperty;
2
- var __defProps = Object.defineProperties;
3
- var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
4
- var __getOwnPropSymbols = Object.getOwnPropertySymbols;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __propIsEnum = Object.prototype.propertyIsEnumerable;
7
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
8
- var __spreadValues = (a, b) => {
9
- for (var prop in b || (b = {}))
10
- if (__hasOwnProp.call(b, prop))
11
- __defNormalProp(a, prop, b[prop]);
12
- if (__getOwnPropSymbols)
13
- for (var prop of __getOwnPropSymbols(b)) {
14
- if (__propIsEnum.call(b, prop))
15
- __defNormalProp(a, prop, b[prop]);
16
- }
17
- return a;
18
- };
19
- var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
20
- import { HasuraAuthClient } from "@nhost/hasura-auth-js";
21
- import { HasuraStorageClient } from "@nhost/hasura-storage-js";
22
- import axios from "axios";
23
- import { print } from "graphql";
24
- class NhostFunctionsClient {
25
- constructor(params) {
26
- const { url, adminSecret } = params;
27
- this.accessToken = null;
28
- this.adminSecret = adminSecret;
29
- this.instance = axios.create({
30
- baseURL: url
31
- });
32
- }
33
- async call(url, data, config) {
34
- const headers = __spreadValues(__spreadValues({}, this.generateAccessTokenHeaders()), config == null ? void 0 : config.headers);
35
- let res;
36
- try {
37
- res = await this.instance.post(url, data, __spreadProps(__spreadValues({}, config), { headers }));
38
- } catch (error) {
39
- if (error instanceof Error) {
40
- return { res: null, error };
41
- }
42
- }
43
- if (!res) {
44
- return {
45
- res: null,
46
- error: new Error("Unable to make post request to funtion")
47
- };
48
- }
49
- return { res, error: null };
50
- }
51
- setAccessToken(accessToken) {
52
- if (!accessToken) {
53
- this.accessToken = null;
54
- return;
55
- }
56
- this.accessToken = accessToken;
57
- }
58
- generateAccessTokenHeaders() {
59
- if (this.adminSecret) {
60
- return {
61
- "x-hasura-admin-secret": this.adminSecret
62
- };
63
- }
64
- if (this.accessToken) {
65
- return {
66
- Authorization: `Bearer ${this.accessToken}`
67
- };
68
- }
69
- return {};
70
- }
71
- }
72
- class NhostGraphqlClient {
73
- constructor(params) {
74
- const { url, adminSecret } = params;
75
- this.url = url;
76
- this.accessToken = null;
77
- this.adminSecret = adminSecret;
78
- this.instance = axios.create({
79
- baseURL: url
80
- });
81
- }
82
- async request(document, variables, config) {
83
- const headers = __spreadValues(__spreadValues({}, this.generateAccessTokenHeaders()), config == null ? void 0 : config.headers);
84
- try {
85
- const operationName = "";
86
- const res = await this.instance.post("", {
87
- operationName: operationName || void 0,
88
- query: typeof document === "string" ? document : print(document),
89
- variables
90
- }, __spreadProps(__spreadValues({}, config), { headers }));
91
- const responseData = res.data;
92
- const { data } = responseData;
93
- if (responseData.errors) {
94
- return {
95
- data: null,
96
- error: responseData.errors
97
- };
98
- }
99
- if (typeof data !== "object" || Array.isArray(data) || data === null) {
100
- return {
101
- data: null,
102
- error: new Error("incorrect response data from GraphQL server")
103
- };
104
- }
105
- return { data, error: null };
106
- } catch (error) {
107
- if (error instanceof Error) {
108
- return { data: null, error };
109
- }
110
- console.error(error);
111
- return {
112
- data: null,
113
- error: new Error("Unable to get do GraphQL request")
114
- };
115
- }
116
- }
117
- getUrl() {
118
- return this.url;
119
- }
120
- setAccessToken(accessToken) {
121
- if (!accessToken) {
122
- this.accessToken = null;
123
- return;
124
- }
125
- this.accessToken = accessToken;
126
- }
127
- generateAccessTokenHeaders() {
128
- if (this.adminSecret) {
129
- return {
130
- "x-hasura-admin-secret": this.adminSecret
131
- };
132
- }
133
- if (this.accessToken) {
134
- return {
135
- Authorization: `Bearer ${this.accessToken}`
136
- };
137
- }
138
- return {};
139
- }
140
- }
141
- class NhostClient {
142
- constructor({
143
- backendUrl,
144
- refreshIntervalTime,
145
- clientStorageGetter,
146
- clientStorageSetter,
147
- clientStorage,
148
- clientStorageType,
149
- autoRefreshToken,
150
- autoSignIn,
151
- adminSecret,
152
- devTools,
153
- start = true
154
- }) {
155
- var _a;
156
- if (!backendUrl)
157
- throw new Error("Please specify a `backendUrl`. Docs: [todo]!");
158
- this.auth = new HasuraAuthClient({
159
- url: `${backendUrl}/v1/auth`,
160
- refreshIntervalTime,
161
- clientStorageGetter,
162
- clientStorageSetter,
163
- clientStorage,
164
- clientStorageType,
165
- autoRefreshToken,
166
- autoSignIn,
167
- start
168
- });
169
- this.storage = new HasuraStorageClient({
170
- url: `${backendUrl}/v1/storage`,
171
- adminSecret
172
- });
173
- this.functions = new NhostFunctionsClient({
174
- url: `${backendUrl}/v1/functions`,
175
- adminSecret
176
- });
177
- this.graphql = new NhostGraphqlClient({
178
- url: `${backendUrl}/v1/graphql`,
179
- adminSecret
180
- });
181
- this.storage.setAccessToken(this.auth.getAccessToken());
182
- this.functions.setAccessToken(this.auth.getAccessToken());
183
- this.graphql.setAccessToken(this.auth.getAccessToken());
184
- (_a = this.auth.client) == null ? void 0 : _a.onStart(() => {
185
- this.auth.onAuthStateChanged((_event, session) => {
186
- if (_event === "SIGNED_OUT") {
187
- this.storage.setAccessToken(void 0);
188
- this.functions.setAccessToken(void 0);
189
- this.graphql.setAccessToken(void 0);
190
- }
191
- });
192
- this.auth.onTokenChanged((session) => {
193
- this.storage.setAccessToken(session == null ? void 0 : session.accessToken);
194
- this.functions.setAccessToken(session == null ? void 0 : session.accessToken);
195
- this.graphql.setAccessToken(session == null ? void 0 : session.accessToken);
196
- });
197
- });
198
- this.devTools = devTools;
199
- }
200
- }
201
- const createClient = (config) => new NhostClient(config);
202
- export { NhostClient, NhostFunctionsClient, NhostGraphqlClient, createClient };
203
- //# sourceMappingURL=index.esm.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.esm.js","sources":["../src/clients/functions.ts","../src/clients/graphql.ts","../src/core/nhost-client.ts","../src/index.ts"],"sourcesContent":["import axios, { AxiosInstance, AxiosRequestConfig, AxiosRequestHeaders, AxiosResponse } from 'axios'\n\nimport { FunctionCallResponse } from '../types'\nexport interface NhostFunctionsConstructorParams {\n /**\n * Serverless Functions endpoint.\n */\n url: string\n /**\n * Admin secret. When set, it is sent as an `x-hasura-admin-secret` header for all requests.\n */\n adminSecret?: string\n}\n\n/**\n * @alias Functions\n */\nexport class NhostFunctionsClient {\n private instance: AxiosInstance\n private accessToken: string | null\n private adminSecret?: string\n\n constructor(params: NhostFunctionsConstructorParams) {\n const { url, adminSecret } = params\n\n this.accessToken = null\n this.adminSecret = adminSecret\n this.instance = axios.create({\n baseURL: url\n })\n }\n\n /**\n * Use `nhost.functions.call` to call (sending a POST request to) a serverless function.\n *\n * @example\n * ```ts\n * await nhost.functions.call('send-welcome-email', { email: 'joe@example.com', name: 'Joe Doe' })\n * ```\n *\n * @docs https://docs.nhost.io/reference/javascript/nhost-js/functions/call\n */\n async call<T = unknown, D = any>(\n url: string,\n data: D,\n config?: AxiosRequestConfig\n ): Promise<FunctionCallResponse<T>> {\n const headers = {\n ...this.generateAccessTokenHeaders(),\n ...config?.headers\n }\n\n let res\n try {\n res = await this.instance.post<T, AxiosResponse<T>, D>(url, data, { ...config, headers })\n } catch (error) {\n if (error instanceof Error) {\n return { res: null, error }\n }\n }\n\n if (!res) {\n return {\n res: null,\n error: new Error('Unable to make post request to funtion')\n }\n }\n\n return { res, error: null }\n }\n\n /**\n * Use `nhost.functions.setAccessToken` to a set an access token to be used in subsequent functions requests. Note that if you're signin in users with `nhost.auth.signIn()` the access token will be set automatically.\n *\n * @example\n * ```ts\n * nhost.functions.setAccessToken('some-access-token')\n * ```\n *\n * @docs https://docs.nhost.io/reference/javascript/nhost-js/functions/set-access-token\n */\n setAccessToken(accessToken: string | undefined) {\n if (!accessToken) {\n this.accessToken = null\n return\n }\n\n this.accessToken = accessToken\n }\n\n private generateAccessTokenHeaders(): AxiosRequestHeaders {\n if (this.adminSecret) {\n return {\n 'x-hasura-admin-secret': this.adminSecret\n }\n }\n if (this.accessToken) {\n return {\n Authorization: `Bearer ${this.accessToken}`\n }\n }\n return {}\n }\n}\n","import axios, { AxiosInstance, AxiosRequestConfig, AxiosRequestHeaders } from 'axios'\nimport { DocumentNode, print } from 'graphql'\n\nimport { GraphqlRequestResponse, GraphqlResponse } from '../types'\n\nexport interface NhostGraphqlConstructorParams {\n /**\n * GraphQL endpoint.\n */\n url: string\n /**\n * Admin secret. When set, it is sent as an `x-hasura-admin-secret` header for all requests.\n */\n adminSecret?: string\n}\n\n/**\n * @alias GraphQL\n */\nexport class NhostGraphqlClient {\n private url: string\n private instance: AxiosInstance\n private accessToken: string | null\n private adminSecret?: string\n\n constructor(params: NhostGraphqlConstructorParams) {\n const { url, adminSecret } = params\n\n this.url = url\n this.accessToken = null\n this.adminSecret = adminSecret\n this.instance = axios.create({\n baseURL: url\n })\n }\n\n /**\n * Use `nhost.graphql.request` to send a GraphQL request. For more serious GraphQL usage in your app we recommend using a GraphQL client such as Apollo Client (https://www.apollographql.com/docs/react).\n *\n * @example\n * ```ts\n * const CUSTOMERS = gql`\n * query {\n * customers {\n * id\n * name\n * }\n * }\n * `\n * const { data, error } = await nhost.graphql.request(CUSTOMERS)\n * ```\n *\n * @docs https://docs.nhost.io/reference/javascript/nhost-js/graphql/request\n */\n async request<T = any, V = any>(\n document: string | DocumentNode,\n variables?: V,\n config?: AxiosRequestConfig\n ): Promise<GraphqlRequestResponse<T>> {\n // add auth headers if any\n const headers = {\n ...this.generateAccessTokenHeaders(),\n ...config?.headers\n }\n\n try {\n const operationName = ''\n const res = await this.instance.post<GraphqlResponse<T>>(\n '',\n {\n operationName: operationName || undefined,\n query: typeof document === 'string' ? document : print(document),\n variables\n },\n { ...config, headers }\n )\n\n const responseData = res.data\n const { data } = responseData\n\n if (responseData.errors) {\n return {\n data: null,\n error: responseData.errors\n }\n }\n\n if (typeof data !== 'object' || Array.isArray(data) || data === null) {\n return {\n data: null,\n error: new Error('incorrect response data from GraphQL server')\n }\n }\n\n return { data, error: null }\n } catch (error) {\n if (error instanceof Error) {\n return { data: null, error }\n }\n console.error(error)\n return {\n data: null,\n error: new Error('Unable to get do GraphQL request')\n }\n }\n }\n\n /**\n * Use `nhost.graphql.getUrl` to get the GraphQL URL.\n *\n * @example\n * ```ts\n * const url = nhost.graphql.getUrl();\n * ```\n *\n * @docs https://docs.nhost.io/reference/javascript/nhost-js/graphql/get-url\n */\n getUrl(): string {\n return this.url\n }\n\n /**\n * Use `nhost.graphql.setAccessToken` to a set an access token to be used in subsequent graphql requests. Note that if you're signin in users with `nhost.auth.signIn()` the access token will be set automatically.\n *\n * @example\n * ```ts\n * nhost.graphql.setAccessToken('some-access-token')\n * ```\n *\n * @docs https://docs.nhost.io/reference/javascript/nhost-js/graphql/set-access-token\n */\n setAccessToken(accessToken: string | undefined) {\n if (!accessToken) {\n this.accessToken = null\n return\n }\n\n this.accessToken = accessToken\n }\n\n private generateAccessTokenHeaders(): AxiosRequestHeaders {\n if (this.adminSecret) {\n return {\n 'x-hasura-admin-secret': this.adminSecret\n }\n }\n if (this.accessToken) {\n return {\n Authorization: `Bearer ${this.accessToken}`\n }\n }\n return {}\n }\n}\n","import { HasuraAuthClient, NhostAuthConstructorParams } from '@nhost/hasura-auth-js'\nimport { HasuraStorageClient } from '@nhost/hasura-storage-js'\n\nimport { NhostFunctionsClient } from '../clients/functions'\nimport { NhostGraphqlClient } from '../clients/graphql'\n\nexport interface NhostClientConstructorParams extends Omit<NhostAuthConstructorParams, 'url'> {\n /**\n * Nhost backend URL.\n */\n backendUrl: string\n /**\n * Admin secret. When set, it is sent as an `x-hasura-admin-secret` header for all\n * GraphQL, Storage, and Serverless Functions requests.\n */\n adminSecret?: string\n}\n\nexport class NhostClient {\n auth: HasuraAuthClient\n storage: HasuraStorageClient\n functions: NhostFunctionsClient\n graphql: NhostGraphqlClient\n readonly devTools?: boolean\n\n /**\n * Nhost Client\n *\n * @example\n * const nhost = new NhostClient({ url });\n *\n * @docs https://docs.nhost.io/reference/javascript\n */\n constructor({\n backendUrl,\n refreshIntervalTime,\n clientStorageGetter,\n clientStorageSetter,\n clientStorage,\n clientStorageType,\n autoRefreshToken,\n autoSignIn,\n adminSecret,\n devTools,\n start = true\n }: NhostClientConstructorParams) {\n if (!backendUrl) throw new Error('Please specify a `backendUrl`. Docs: [todo]!')\n this.auth = new HasuraAuthClient({\n url: `${backendUrl}/v1/auth`,\n refreshIntervalTime,\n clientStorageGetter,\n clientStorageSetter,\n clientStorage,\n clientStorageType,\n autoRefreshToken,\n autoSignIn,\n start\n })\n\n this.storage = new HasuraStorageClient({\n url: `${backendUrl}/v1/storage`,\n adminSecret\n })\n\n this.functions = new NhostFunctionsClient({\n url: `${backendUrl}/v1/functions`,\n adminSecret\n })\n\n this.graphql = new NhostGraphqlClient({\n url: `${backendUrl}/v1/graphql`,\n adminSecret\n })\n\n // * Set current token if token is already accessable\n this.storage.setAccessToken(this.auth.getAccessToken())\n this.functions.setAccessToken(this.auth.getAccessToken())\n this.graphql.setAccessToken(this.auth.getAccessToken())\n\n this.auth.client?.onStart(() => {\n // * Set access token when signing out\n this.auth.onAuthStateChanged((_event, session) => {\n if (_event === 'SIGNED_OUT') {\n this.storage.setAccessToken(undefined)\n this.functions.setAccessToken(undefined)\n this.graphql.setAccessToken(undefined)\n }\n })\n\n // * Update access token for clients, including when signin in\n this.auth.onTokenChanged((session) => {\n this.storage.setAccessToken(session?.accessToken)\n this.functions.setAccessToken(session?.accessToken)\n this.graphql.setAccessToken(session?.accessToken)\n })\n })\n this.devTools = devTools\n }\n}\n","import { NhostClient, NhostClientConstructorParams } from './core'\n\nconst createClient = (config: NhostClientConstructorParams) => new NhostClient(config)\n\nexport * from './clients'\nexport * from './core'\nexport { createClient }\n"],"names":[],"mappings":"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"}