@xata.io/client 0.16.2 → 0.18.0
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/CHANGELOG.md +46 -0
- package/README.md +25 -25
- package/Usage.md +2 -0
- package/dist/index.cjs +386 -71
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.ts +988 -120
- package/dist/index.mjs +371 -72
- package/dist/index.mjs.map +1 -1
- package/package.json +1 -1
package/CHANGELOG.md
CHANGED
@@ -1,5 +1,51 @@
|
|
1
1
|
# @xata.io/client
|
2
2
|
|
3
|
+
## 0.18.0
|
4
|
+
|
5
|
+
### Minor Changes
|
6
|
+
|
7
|
+
- [#562](https://github.com/xataio/client-ts/pull/562) [`699beb4`](https://github.com/xataio/client-ts/commit/699beb4bbf21cffa001d3f88a03246980e30250b) Thanks [@SferaDev](https://github.com/SferaDev)! - Return null on nullable columns
|
8
|
+
|
9
|
+
### Patch Changes
|
10
|
+
|
11
|
+
- [#583](https://github.com/xataio/client-ts/pull/583) [`330b076`](https://github.com/xataio/client-ts/commit/330b076a0781e3576c82afab76e3fb2a64f2e041) Thanks [@SferaDev](https://github.com/SferaDev)! - Add support for unique columns
|
12
|
+
|
13
|
+
- [#598](https://github.com/xataio/client-ts/pull/598) [`c3dfb4b`](https://github.com/xataio/client-ts/commit/c3dfb4babc990634b9e9747616ed93223178a2e7) Thanks [@SferaDev](https://github.com/SferaDev)! - API: Add patch database metadata endpoint
|
14
|
+
|
15
|
+
- [#602](https://github.com/xataio/client-ts/pull/602) [`74b17aa`](https://github.com/xataio/client-ts/commit/74b17aaedc0dbdd79bfdcb182b2e70b61f98f5a5) Thanks [@gimenete](https://github.com/gimenete)! - API: Make workspace slug optional on create
|
16
|
+
|
17
|
+
- [#615](https://github.com/xataio/client-ts/pull/615) [`83f20cd`](https://github.com/xataio/client-ts/commit/83f20cdbe53706c16016c4db3f318e679b24ec86) Thanks [@SferaDev](https://github.com/SferaDev)! - Make `getMany` return more items than max pagination size
|
18
|
+
|
19
|
+
- [#562](https://github.com/xataio/client-ts/pull/562) [`addfcc6`](https://github.com/xataio/client-ts/commit/addfcc67fca663defdd340111ea09c9188bad3ab) Thanks [@SferaDev](https://github.com/SferaDev)! - Add `orThrows` methods that instead of returning null, throw an exception.
|
20
|
+
|
21
|
+
- [#583](https://github.com/xataio/client-ts/pull/583) [`eb7ba59`](https://github.com/xataio/client-ts/commit/eb7ba594be2a1f0ab90956836bbeb912e188a46d) Thanks [@SferaDev](https://github.com/SferaDev)! - Add support for non nullable columns
|
22
|
+
|
23
|
+
- [#612](https://github.com/xataio/client-ts/pull/612) [`f1a0742`](https://github.com/xataio/client-ts/commit/f1a0742a04e1aefab14f46371a04a41069faec01) Thanks [@xata-bot](https://github.com/xata-bot)! - API: Add summarize table endpoint
|
24
|
+
|
25
|
+
## 0.17.1
|
26
|
+
|
27
|
+
### Patch Changes
|
28
|
+
|
29
|
+
- [#584](https://github.com/xataio/client-ts/pull/584) [`a305072`](https://github.com/xataio/client-ts/commit/a3050726517632b4975f2a2ed5f771dd247e51d5) Thanks [@SferaDev](https://github.com/SferaDev)! - Fix issues with multiple filters
|
30
|
+
|
31
|
+
* [#249](https://github.com/xataio/client-ts/pull/249) [`7812a41`](https://github.com/xataio/client-ts/commit/7812a414b7d99e9515c0ce48a61ad7a8b84d65d0) Thanks [@xata-bot](https://github.com/xata-bot)! - API: Add first endpoints for migration requests and schema compare
|
32
|
+
|
33
|
+
- [#585](https://github.com/xataio/client-ts/pull/585) [`d4a8ced`](https://github.com/xataio/client-ts/commit/d4a8ced9c257058ed7f660e01ee5fd1da154c391) Thanks [@SferaDev](https://github.com/SferaDev)! - Fix problem with some special characters not being URI encoded
|
34
|
+
|
35
|
+
* [#574](https://github.com/xataio/client-ts/pull/574) [`cf85b13`](https://github.com/xataio/client-ts/commit/cf85b13e1ca69e79100fd02f58d79d556012395d) Thanks [@SferaDev](https://github.com/SferaDev)! - Do not allow unknown tables on codegen output
|
36
|
+
|
37
|
+
- [#576](https://github.com/xataio/client-ts/pull/576) [`2350739`](https://github.com/xataio/client-ts/commit/2350739d3f0a176b0f1fc77b0f4f597321349726) Thanks [@SferaDev](https://github.com/SferaDev)! - Allow sending empty, undefined or conditional filters
|
38
|
+
|
39
|
+
* [#581](https://github.com/xataio/client-ts/pull/581) [`a336e61`](https://github.com/xataio/client-ts/commit/a336e6161be04a652e6f0f0a4c2edac10d50c99e) Thanks [@SferaDev](https://github.com/SferaDev)! - Update error codes in tracing
|
40
|
+
|
41
|
+
## 0.17.0
|
42
|
+
|
43
|
+
### Minor Changes
|
44
|
+
|
45
|
+
- [#563](https://github.com/xataio/client-ts/pull/563) [`26e91d1`](https://github.com/xataio/client-ts/commit/26e91d1d84df082dedd7159271fc7c27ec87fefe) Thanks [@SferaDev](https://github.com/SferaDev)! - Return nulls on operations that can fail
|
46
|
+
|
47
|
+
* [#563](https://github.com/xataio/client-ts/pull/563) [`3332d43`](https://github.com/xataio/client-ts/commit/3332d43121367f61c8d87dfb7da2af65bd1c278f) Thanks [@SferaDev](https://github.com/SferaDev)! - Return object on delete operation
|
48
|
+
|
3
49
|
## 0.16.2
|
4
50
|
|
5
51
|
### Patch Changes
|
package/README.md
CHANGED
@@ -12,11 +12,11 @@ This SDK has zero dependencies, so it can be used in many JavaScript runtimes in
|
|
12
12
|
- [Schema-generated Client](#schema-generated-client)
|
13
13
|
- [Schema-less Client](#schema-less-client)
|
14
14
|
- [API Design](#api-design)
|
15
|
-
- [Creating
|
16
|
-
- [Query a Single
|
17
|
-
- [Querying Multiple
|
18
|
-
- [Updating
|
19
|
-
- [Deleting
|
15
|
+
- [Creating Records](#creating-records)
|
16
|
+
- [Query a Single Record by its ID](#query-a-single-record-by-its-id)
|
17
|
+
- [Querying Multiple Records](#querying-multiple-records)
|
18
|
+
- [Updating Records](#updating-records)
|
19
|
+
- [Deleting Records](#deleting-records)
|
20
20
|
- [API Client](#api-client)
|
21
21
|
- [Deno support](#deno-support)
|
22
22
|
|
@@ -102,7 +102,7 @@ The Xata SDK to create/read/update/delete records follows the [repository patter
|
|
102
102
|
|
103
103
|
For example if you have a `users` table, there'll be a repository at `xata.db.users`. If you're using the schema-less client, you can also use the `xata.db.[table-name]` syntax to access the repository but without TypeScript auto-completion.
|
104
104
|
|
105
|
-
#### Creating
|
105
|
+
#### Creating Records
|
106
106
|
|
107
107
|
Invoke the `create()` method in the repository. Example:
|
108
108
|
|
@@ -123,22 +123,22 @@ const user = await xata.db.users.insert('user_admin', {
|
|
123
123
|
And if you want to create or insert a record with a specific ID, you can invoke `updateOrInsert()`.
|
124
124
|
|
125
125
|
```ts
|
126
|
-
const user = await
|
126
|
+
const user = await xata.db.users.updateOrInsert('user_admin', {
|
127
127
|
fullName: 'John Smith'
|
128
128
|
});
|
129
129
|
```
|
130
130
|
|
131
|
-
#### Query a Single
|
131
|
+
#### Query a Single Record by its ID
|
132
132
|
|
133
133
|
```ts
|
134
|
-
// `user` will be null if the
|
134
|
+
// `user` will be null if the record cannot be found
|
135
135
|
const user = await xata.db.users.read('rec_1234abcdef');
|
136
136
|
```
|
137
137
|
|
138
|
-
#### Querying Multiple
|
138
|
+
#### Querying Multiple Records
|
139
139
|
|
140
140
|
```ts
|
141
|
-
// Query
|
141
|
+
// Query records selecting all fields.
|
142
142
|
const page = await xata.db.users.select().getPaginated();
|
143
143
|
const user = await xata.db.users.select().getFirst();
|
144
144
|
|
@@ -146,7 +146,7 @@ const user = await xata.db.users.select().getFirst();
|
|
146
146
|
const page = await xata.db.users.getPaginated();
|
147
147
|
const user = await xata.db.users.getFirst();
|
148
148
|
|
149
|
-
// Query
|
149
|
+
// Query records selecting just one or more fields
|
150
150
|
const page = await xata.db.users.select('email', 'profile').getPaginated();
|
151
151
|
|
152
152
|
// Apply constraints
|
@@ -207,9 +207,9 @@ for await (const records of xata.db.users.getIterator({ batchSize: 100 })) {
|
|
207
207
|
}
|
208
208
|
```
|
209
209
|
|
210
|
-
#### Updating
|
210
|
+
#### Updating Records
|
211
211
|
|
212
|
-
Updating
|
212
|
+
Updating a record leaves the existing object unchanged, but returns a new object with the updated values.
|
213
213
|
|
214
214
|
```ts
|
215
215
|
// Using an existing object
|
@@ -217,19 +217,19 @@ const updatedUser = await user.update({
|
|
217
217
|
fullName: 'John Smith Jr.'
|
218
218
|
});
|
219
219
|
|
220
|
-
// Using
|
220
|
+
// Using a record id
|
221
221
|
const updatedUser = await xata.db.users.update('rec_1234abcdef', {
|
222
222
|
fullName: 'John Smith Jr.'
|
223
223
|
});
|
224
224
|
```
|
225
225
|
|
226
|
-
#### Deleting
|
226
|
+
#### Deleting Records
|
227
227
|
|
228
228
|
```ts
|
229
229
|
// Using an existing object
|
230
230
|
await user.delete();
|
231
231
|
|
232
|
-
// Using
|
232
|
+
// Using a record id
|
233
233
|
await xata.db.users.delete('rec_1234abcdef');
|
234
234
|
```
|
235
235
|
|
@@ -246,22 +246,22 @@ const api = new XataApiClient({ apiKey: process.env.XATA_API_KEY });
|
|
246
246
|
Once you have initialized the API client, the operations are organized following the same hiearchy as in the [official documentation](https://docs.xata.io). You have different namespaces for each entity (ie. `workspaces`, `databases`, `tables`, `branches`, `users`, `records`...).
|
247
247
|
|
248
248
|
```ts
|
249
|
-
const { id: workspace } = await
|
250
|
-
const { databaseName } = await
|
249
|
+
const { id: workspace } = await api.workspaces.createWorkspace({ name: 'example' });
|
250
|
+
const { databaseName } = await api.databases.createDatabase(workspace, 'database');
|
251
251
|
|
252
|
-
await
|
253
|
-
await
|
254
|
-
await
|
252
|
+
await api.branches.createBranch(workspace, databaseName, 'branch');
|
253
|
+
await api.tables.createTable(workspace, databaseName, 'branch', 'table');
|
254
|
+
await api.tables.setTableSchema(workspace, databaseName, 'branch', 'table', {
|
255
255
|
columns: [{ name: 'email', type: 'string' }]
|
256
256
|
});
|
257
257
|
|
258
|
-
const { id: recordId } = await
|
258
|
+
const { id: recordId } = await api.records.insertRecord(workspace, databaseName, 'branch', 'table', {
|
259
259
|
email: 'example@foo.bar'
|
260
260
|
});
|
261
261
|
|
262
|
-
const record = await
|
262
|
+
const record = await api.records.getRecord(workspace, databaseName, 'branch', 'table', recordId);
|
263
263
|
|
264
|
-
await
|
264
|
+
await api.workspaces.deleteWorkspace(workspace);
|
265
265
|
```
|
266
266
|
|
267
267
|
## Deno support
|
package/Usage.md
CHANGED
@@ -41,6 +41,8 @@ To get a collection of records, you can use the `Query` object. It provides the
|
|
41
41
|
- `getAll()`: returns all the records in the query results by making multiple requests to iterate over all the pages which exist. If the query is not filtered and the table is a large dataset, this operation can affect the performance.
|
42
42
|
- `getMany()`: returns an array with a subset of the first results in the query. The default [pagination](#page) size (20) is used and can be customised by passing a different `{ pagination: { size: number } }` in its options. To learn more about default values, see [helper variables](#helper-variables).
|
43
43
|
|
44
|
+
Both the `getAll()` and `getMany()` will produce multiple requests to the server if the query should return more than the maximum page size. We perform the minimum number of requests to get the desired number of records.
|
45
|
+
|
44
46
|
All these methods allow customising its filters, column selection, column ordering, pagination or cache TTL. For example:
|
45
47
|
|
46
48
|
```ts
|