@mastra/pg 1.13.0-alpha.0 → 1.13.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 +111 -0
- package/dist/docs/SKILL.md +1 -1
- package/dist/docs/assets/SOURCE_MAP.json +1 -1
- package/dist/docs/references/docs-memory-working-memory.md +2 -2
- package/dist/docs/references/reference-storage-composite.md +33 -1
- package/dist/index.cjs +12 -16
- package/dist/index.cjs.map +1 -1
- package/dist/index.js +13 -17
- package/dist/index.js.map +1 -1
- package/dist/{storage → shared}/pool-config.d.ts +3 -0
- package/dist/shared/pool-config.d.ts.map +1 -0
- package/dist/storage/domains/workflows/index.d.ts.map +1 -1
- package/dist/storage/index.d.ts.map +1 -1
- package/dist/vector/index.d.ts.map +1 -1
- package/package.json +6 -6
- package/dist/storage/pool-config.d.ts.map +0 -1
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,116 @@
|
|
|
1
1
|
# @mastra/pg
|
|
2
2
|
|
|
3
|
+
## 1.13.0
|
|
4
|
+
|
|
5
|
+
### Minor Changes
|
|
6
|
+
|
|
7
|
+
- Add the v-next observability storage domain for `@mastra/pg`, an insert-only, ([#16760](https://github.com/mastra-ai/mastra/pull/16760))
|
|
8
|
+
partitioned Postgres adapter for low-volume observability (~100 calls/sec,
|
|
9
|
+
up to roughly 1,500 calls/sec sustained on a single primary).
|
|
10
|
+
|
|
11
|
+
The new `PostgresStoreVNext` composes a primary `PostgresStore` (memory,
|
|
12
|
+
workflows, scores, agents, etc.) with an `ObservabilityStoragePostgresVNext`
|
|
13
|
+
for spans, logs, metrics, scores, and feedback. All observability writes go
|
|
14
|
+
through a single multi-row `INSERT ... ON CONFLICT DO NOTHING` path. Storage
|
|
15
|
+
is partitioned per day with three modes auto-detected at `init()` time:
|
|
16
|
+
TimescaleDB hypertables, pg_partman (4.x or 5.x), or native Postgres range
|
|
17
|
+
partitions. Root-span lookups are served by partial indexes, and OLAP queries
|
|
18
|
+
(aggregates, breakdowns, time-series, percentiles) prune partitions by
|
|
19
|
+
`timestamp`. A small discovery cache table powers stale-while-revalidate
|
|
20
|
+
lookups for entity names/types/labels.
|
|
21
|
+
|
|
22
|
+
The `observability` connection is **required** — callers always make an
|
|
23
|
+
explicit decision about where observability data lives. For production,
|
|
24
|
+
point it at a dedicated Postgres instance to keep OLAP scans from
|
|
25
|
+
contending with your primary OLTP workload. Reusing the primary
|
|
26
|
+
connection works for local development and logs a runtime warning on every
|
|
27
|
+
construction.
|
|
28
|
+
|
|
29
|
+
```typescript
|
|
30
|
+
import { Mastra } from '@mastra/core';
|
|
31
|
+
import { PostgresStoreVNext } from '@mastra/pg';
|
|
32
|
+
|
|
33
|
+
export const mastra = new Mastra({
|
|
34
|
+
storage: new PostgresStoreVNext({
|
|
35
|
+
id: 'app',
|
|
36
|
+
connectionString: process.env.DATABASE_URL!,
|
|
37
|
+
observability: {
|
|
38
|
+
connectionString: process.env.OBSERVABILITY_DATABASE_URL!,
|
|
39
|
+
},
|
|
40
|
+
}),
|
|
41
|
+
});
|
|
42
|
+
```
|
|
43
|
+
|
|
44
|
+
Delta polling uses Postgres transaction IDs and a safe transaction horizon so
|
|
45
|
+
concurrent writers cannot cause late-committing rows to be skipped. The
|
|
46
|
+
`observability-delta-polling` feature flag is opt-in.
|
|
47
|
+
|
|
48
|
+
`ensureNativePartitions()` swallows the `42P07 relation already exists`
|
|
49
|
+
error around `CREATE TABLE IF NOT EXISTS … PARTITION OF`, matching the
|
|
50
|
+
existing guard used for base-table and index DDL. This makes concurrent
|
|
51
|
+
`init()` from two processes (serverless cold-start, blue/green overlap, two
|
|
52
|
+
stores sharing a schema) idempotent instead of letting the loser surface an
|
|
53
|
+
unhandled duplicate-relation error.
|
|
54
|
+
|
|
55
|
+
### Patch Changes
|
|
56
|
+
|
|
57
|
+
- dependencies updates: ([#17148](https://github.com/mastra-ai/mastra/pull/17148))
|
|
58
|
+
- Updated dependency [`pg@^8.21.0` ↗︎](https://www.npmjs.com/package/pg/v/8.21.0) (from `^8.20.0`, in `dependencies`)
|
|
59
|
+
|
|
60
|
+
- Added full Agent Builder storage support to the PostgreSQL adapter, bringing it to parity with libSQL. ([#17596](https://github.com/mastra-ai/mastra/pull/17596))
|
|
61
|
+
|
|
62
|
+
Previously, projects using PostgreSQL could not store tool provider connections or agent tool providers, and several Agent Builder tables were missing from the exported schema.
|
|
63
|
+
- Added storage for tool provider connections, so connections can be created, read, listed by author, and deleted on PostgreSQL.
|
|
64
|
+
- Agent versions now persist their tool providers on PostgreSQL across save and load.
|
|
65
|
+
- Fixed schema export so all Agent Builder tables are included.
|
|
66
|
+
|
|
67
|
+
- Fixed `PgVector` ignoring an explicit `ssl` option when the connection string also contained an `sslmode=` (or `ssl=`) query parameter. `node-postgres` re-parses the connection string and overwrote the explicit `ssl` object, causing `UNABLE_TO_GET_ISSUER_CERT_LOCALLY` / "self-signed certificate" errors against self-signed or internal CAs even when verification was meant to be skipped. ([#17650](https://github.com/mastra-ai/mastra/pull/17650))
|
|
68
|
+
|
|
69
|
+
`PgVector` now honors an explicit `ssl` option over the connection string, matching the existing `PostgresStore` behavior. Connection-string-only SSL (`?sslmode=require` with no explicit `ssl`) keeps working as before.
|
|
70
|
+
|
|
71
|
+
```ts
|
|
72
|
+
import { PgVector } from '@mastra/pg';
|
|
73
|
+
|
|
74
|
+
// This now connects instead of throwing UNABLE_TO_GET_ISSUER_CERT_LOCALLY
|
|
75
|
+
const vector = new PgVector({
|
|
76
|
+
id: 'my-vector',
|
|
77
|
+
connectionString: 'postgresql://user:pass@host:5432/db?sslmode=require',
|
|
78
|
+
ssl: { rejectUnauthorized: false },
|
|
79
|
+
});
|
|
80
|
+
```
|
|
81
|
+
|
|
82
|
+
- Make atomic db updates better ([#16796](https://github.com/mastra-ai/mastra/pull/16796))
|
|
83
|
+
|
|
84
|
+
- Updated dependencies [[`d468acb`](https://github.com/mastra-ai/mastra/commit/d468acb07aec1bb19a2cb0ada8042b05b46746b2), [`575f815`](https://github.com/mastra-ai/mastra/commit/575f815c5c3567b71c0b83cbb7fa98c8253a9d9c), [`34839c1`](https://github.com/mastra-ai/mastra/commit/34839c1910b6964bf59ed0cee58844efebbb684e), [`053735a`](https://github.com/mastra-ai/mastra/commit/053735a75c2c18e23ce34d9468007efa4a45f4c4), [`306909a`](https://github.com/mastra-ai/mastra/commit/306909a693de77d709b38706e2673c9547d24a28), [`5191af8`](https://github.com/mastra-ai/mastra/commit/5191af80c799eea25357c545fc05d91b3883531d), [`43bd3d4`](https://github.com/mastra-ai/mastra/commit/43bd3d421987463fdf35386a45199c49499ed069), [`e6fa79e`](https://github.com/mastra-ai/mastra/commit/e6fa79ec72a2ddffdd25e85270398951e9d552a4), [`904bcdf`](https://github.com/mastra-ai/mastra/commit/904bcdf7b8004aa7be823f9f70ca63580e47e470), [`7f5ee1d`](https://github.com/mastra-ai/mastra/commit/7f5ee1dca46daee8d2817f2ebe49e6335da81956), [`1e9aab5`](https://github.com/mastra-ai/mastra/commit/1e9aab50ff11e6e88fde4d7cbf512c44a9fe8d61), [`2bccba4`](https://github.com/mastra-ai/mastra/commit/2bccba4c03cadc815c2d54cbf4dd43a922140a8d), [`bf8eb6d`](https://github.com/mastra-ai/mastra/commit/bf8eb6d0ec213a403eb9265a594ad283c44ab3dc), [`e9be4e7`](https://github.com/mastra-ai/mastra/commit/e9be4e747ec3d8b65548bff92f9377db06105376), [`493a328`](https://github.com/mastra-ai/mastra/commit/493a328f4346a1deeb9f1e2e44c8f2a3a4d7591b), [`d53cfc2`](https://github.com/mastra-ai/mastra/commit/d53cfc2c7f8d78343a4aa84ec4e129ba25f3325e), [`65799d4`](https://github.com/mastra-ai/mastra/commit/65799d4d549e5ebb9c848fbe3f51ac090f64becf), [`c268c89`](https://github.com/mastra-ai/mastra/commit/c268c89f4c63a93ee474d3cffdf3ea60bf00d4f2), [`34839c1`](https://github.com/mastra-ai/mastra/commit/34839c1910b6964bf59ed0cee58844efebbb684e), [`014e00f`](https://github.com/mastra-ai/mastra/commit/014e00f2b3a597a016b72f9901c6ab27d491f822), [`029a414`](https://github.com/mastra-ai/mastra/commit/029a4141719793bd3e898a39eb5a0466a55f5f3a), [`d468acb`](https://github.com/mastra-ai/mastra/commit/d468acb07aec1bb19a2cb0ada8042b05b46746b2), [`b147b29`](https://github.com/mastra-ai/mastra/commit/b147b2907f0cd1aa812efe6d6e3f58d22e66fc88), [`d371ac1`](https://github.com/mastra-ai/mastra/commit/d371ac1d9820afaaf7cfdbc380a475946a994d8f), [`2bccba4`](https://github.com/mastra-ai/mastra/commit/2bccba4c03cadc815c2d54cbf4dd43a922140a8d), [`0c72f03`](https://github.com/mastra-ai/mastra/commit/0c72f032abb13254df5a7856d64be2f207b8006d), [`cf182b7`](https://github.com/mastra-ai/mastra/commit/cf182b7fb495767946d9840ef29f19cfa906f31f), [`3b45ea9`](https://github.com/mastra-ai/mastra/commit/3b45ea95015557a6cb9d70dc5252af54ab1b78ac), [`a049c2a`](https://github.com/mastra-ai/mastra/commit/a049c2a9dfb41d0ee2e7a28874a88cd64fd5669f), [`f084be1`](https://github.com/mastra-ai/mastra/commit/f084be1fcbe33ad7480913e44d6130c421c0976f), [`b147b29`](https://github.com/mastra-ai/mastra/commit/b147b2907f0cd1aa812efe6d6e3f58d22e66fc88), [`2a96528`](https://github.com/mastra-ai/mastra/commit/2a9652848dfa3c5a2426f952e9d93554c26fd90f), [`f2ab060`](https://github.com/mastra-ai/mastra/commit/f2ab060162bea81505fda553e2cee29c1979fd04), [`5d302c8`](https://github.com/mastra-ai/mastra/commit/5d302c8eda1a6ac74eab5e442c4f64db6cc97a06), [`34839c1`](https://github.com/mastra-ai/mastra/commit/34839c1910b6964bf59ed0cee58844efebbb684e), [`a952852`](https://github.com/mastra-ai/mastra/commit/a952852c971a21fb646cd907c75fcf4443cdc963), [`2656d9c`](https://github.com/mastra-ai/mastra/commit/2656d9c2976d4f3354253bfbbbf9b88a1b2bbf34), [`63e3fe1`](https://github.com/mastra-ai/mastra/commit/63e3fe13cc1ea96f91d7c68aea92f400faf9e4da), [`1d4ce8d`](https://github.com/mastra-ai/mastra/commit/1d4ce8daaa54511f325c1b609d31b8e54009d677), [`8c68372`](https://github.com/mastra-ai/mastra/commit/8c68372e85fe0b066ec12c58bd29ffb93e54c552)]:
|
|
85
|
+
- @mastra/core@1.42.0
|
|
86
|
+
|
|
87
|
+
## 1.13.0-alpha.1
|
|
88
|
+
|
|
89
|
+
### Patch Changes
|
|
90
|
+
|
|
91
|
+
- dependencies updates: ([#17148](https://github.com/mastra-ai/mastra/pull/17148))
|
|
92
|
+
- Updated dependency [`pg@^8.21.0` ↗︎](https://www.npmjs.com/package/pg/v/8.21.0) (from `^8.20.0`, in `dependencies`)
|
|
93
|
+
|
|
94
|
+
- Fixed `PgVector` ignoring an explicit `ssl` option when the connection string also contained an `sslmode=` (or `ssl=`) query parameter. `node-postgres` re-parses the connection string and overwrote the explicit `ssl` object, causing `UNABLE_TO_GET_ISSUER_CERT_LOCALLY` / "self-signed certificate" errors against self-signed or internal CAs even when verification was meant to be skipped. ([#17650](https://github.com/mastra-ai/mastra/pull/17650))
|
|
95
|
+
|
|
96
|
+
`PgVector` now honors an explicit `ssl` option over the connection string, matching the existing `PostgresStore` behavior. Connection-string-only SSL (`?sslmode=require` with no explicit `ssl`) keeps working as before.
|
|
97
|
+
|
|
98
|
+
```ts
|
|
99
|
+
import { PgVector } from '@mastra/pg';
|
|
100
|
+
|
|
101
|
+
// This now connects instead of throwing UNABLE_TO_GET_ISSUER_CERT_LOCALLY
|
|
102
|
+
const vector = new PgVector({
|
|
103
|
+
id: 'my-vector',
|
|
104
|
+
connectionString: 'postgresql://user:pass@host:5432/db?sslmode=require',
|
|
105
|
+
ssl: { rejectUnauthorized: false },
|
|
106
|
+
});
|
|
107
|
+
```
|
|
108
|
+
|
|
109
|
+
- Make atomic db updates better ([#16796](https://github.com/mastra-ai/mastra/pull/16796))
|
|
110
|
+
|
|
111
|
+
- Updated dependencies [[`575f815`](https://github.com/mastra-ai/mastra/commit/575f815c5c3567b71c0b83cbb7fa98c8253a9d9c), [`306909a`](https://github.com/mastra-ai/mastra/commit/306909a693de77d709b38706e2673c9547d24a28), [`5191af8`](https://github.com/mastra-ai/mastra/commit/5191af80c799eea25357c545fc05d91b3883531d), [`43bd3d4`](https://github.com/mastra-ai/mastra/commit/43bd3d421987463fdf35386a45199c49499ed069), [`e6fa79e`](https://github.com/mastra-ai/mastra/commit/e6fa79ec72a2ddffdd25e85270398951e9d552a4), [`904bcdf`](https://github.com/mastra-ai/mastra/commit/904bcdf7b8004aa7be823f9f70ca63580e47e470), [`7f5ee1d`](https://github.com/mastra-ai/mastra/commit/7f5ee1dca46daee8d2817f2ebe49e6335da81956), [`1e9aab5`](https://github.com/mastra-ai/mastra/commit/1e9aab50ff11e6e88fde4d7cbf512c44a9fe8d61), [`bf8eb6d`](https://github.com/mastra-ai/mastra/commit/bf8eb6d0ec213a403eb9265a594ad283c44ab3dc), [`493a328`](https://github.com/mastra-ai/mastra/commit/493a328f4346a1deeb9f1e2e44c8f2a3a4d7591b), [`029a414`](https://github.com/mastra-ai/mastra/commit/029a4141719793bd3e898a39eb5a0466a55f5f3a), [`b147b29`](https://github.com/mastra-ai/mastra/commit/b147b2907f0cd1aa812efe6d6e3f58d22e66fc88), [`d371ac1`](https://github.com/mastra-ai/mastra/commit/d371ac1d9820afaaf7cfdbc380a475946a994d8f), [`cf182b7`](https://github.com/mastra-ai/mastra/commit/cf182b7fb495767946d9840ef29f19cfa906f31f), [`a049c2a`](https://github.com/mastra-ai/mastra/commit/a049c2a9dfb41d0ee2e7a28874a88cd64fd5669f), [`b147b29`](https://github.com/mastra-ai/mastra/commit/b147b2907f0cd1aa812efe6d6e3f58d22e66fc88), [`2a96528`](https://github.com/mastra-ai/mastra/commit/2a9652848dfa3c5a2426f952e9d93554c26fd90f), [`2656d9c`](https://github.com/mastra-ai/mastra/commit/2656d9c2976d4f3354253bfbbbf9b88a1b2bbf34), [`63e3fe1`](https://github.com/mastra-ai/mastra/commit/63e3fe13cc1ea96f91d7c68aea92f400faf9e4da), [`1d4ce8d`](https://github.com/mastra-ai/mastra/commit/1d4ce8daaa54511f325c1b609d31b8e54009d677), [`8c68372`](https://github.com/mastra-ai/mastra/commit/8c68372e85fe0b066ec12c58bd29ffb93e54c552)]:
|
|
112
|
+
- @mastra/core@1.42.0-alpha.4
|
|
113
|
+
|
|
3
114
|
## 1.13.0-alpha.0
|
|
4
115
|
|
|
5
116
|
### Minor Changes
|
package/dist/docs/SKILL.md
CHANGED
|
@@ -413,12 +413,12 @@ const memory = new Memory({
|
|
|
413
413
|
What changes:
|
|
414
414
|
|
|
415
415
|
- **Storage is identical.** The same resource/thread `workingMemory` field is read and written.
|
|
416
|
-
- **The tool is the same shape, exposed under a new name.** Writes still flow through the same underlying tool; on this path it
|
|
416
|
+
- **The tool is the same shape, exposed under a new name.** Writes still flow through the same underlying tool; on this path it's registered as `setWorkingMemory` (instead of `updateWorkingMemory`). The rename keeps legacy strip filters from removing tool-call parts so they persist as a normal audit trail and the next model step picks the new value up automatically.
|
|
417
417
|
- **Delivery only.** Instead of folding into the system prompt, `Memory` auto-attaches a `WorkingMemoryStateProcessor` that emits the current working memory as a `state` signal with `stateId: 'working-memory'`.
|
|
418
418
|
|
|
419
419
|
You inherit the standard state-signal benefits: thread-scoped tracking metadata, `cacheKey` dedup so identical snapshots are only emitted once, and `contextWindow.hasSnapshot` re-injection when an older snapshot rolls out of the window.
|
|
420
420
|
|
|
421
|
-
The default (`useStateSignals: false`) keeps the existing system-message behavior unchanged. `useStateSignals`
|
|
421
|
+
The default (`useStateSignals: false`) keeps the existing system-message behavior unchanged. `useStateSignals` isn't supported with template working memory `version: 'vnext'`.
|
|
422
422
|
|
|
423
423
|
## Examples
|
|
424
424
|
|
|
@@ -240,6 +240,38 @@ const storage = new MastraCompositeStore({
|
|
|
240
240
|
})
|
|
241
241
|
```
|
|
242
242
|
|
|
243
|
-
> **Note:** `ObservabilityStorageClickhouseVNext` is the current observability domain implementation. The legacy `ObservabilityStorageClickhouse` class is also exported and remains supported for projects that
|
|
243
|
+
> **Note:** `ObservabilityStorageClickhouseVNext` is the current observability domain implementation. The legacy `ObservabilityStorageClickhouse` class is also exported and remains supported for projects that haven't migrated. See the [ClickHouse storage reference](https://mastra.ai/reference/storage/clickhouse) for details.
|
|
244
|
+
|
|
245
|
+
### Replicated ClickHouse for multi-replica clusters
|
|
246
|
+
|
|
247
|
+
For self-managed ClickHouse clusters with multiple replicas, set `replication` so Mastra emits `ReplicatedMergeTree` engines and applies `ON CLUSTER` to its DDL:
|
|
248
|
+
|
|
249
|
+
```typescript
|
|
250
|
+
import { MastraCompositeStore } from '@mastra/core/storage'
|
|
251
|
+
import { MemoryPG, WorkflowsPG, ScoresPG } from '@mastra/pg'
|
|
252
|
+
import { ObservabilityStorageClickhouseVNext } from '@mastra/clickhouse'
|
|
253
|
+
|
|
254
|
+
const storage = new MastraCompositeStore({
|
|
255
|
+
id: 'composite',
|
|
256
|
+
domains: {
|
|
257
|
+
memory: new MemoryPG({ connectionString: process.env.DATABASE_URL }),
|
|
258
|
+
workflows: new WorkflowsPG({ connectionString: process.env.DATABASE_URL }),
|
|
259
|
+
scores: new ScoresPG({ connectionString: process.env.DATABASE_URL }),
|
|
260
|
+
observability: new ObservabilityStorageClickhouseVNext({
|
|
261
|
+
url: process.env.CLICKHOUSE_URL,
|
|
262
|
+
username: process.env.CLICKHOUSE_USERNAME,
|
|
263
|
+
password: process.env.CLICKHOUSE_PASSWORD,
|
|
264
|
+
replication: {
|
|
265
|
+
cluster: 'production_cluster',
|
|
266
|
+
// Optional (defaults shown):
|
|
267
|
+
// zookeeperPath: '/clickhouse/tables/{shard}/{database}/{table}',
|
|
268
|
+
// replicaName: '{replica}',
|
|
269
|
+
},
|
|
270
|
+
}),
|
|
271
|
+
},
|
|
272
|
+
})
|
|
273
|
+
```
|
|
274
|
+
|
|
275
|
+
Do not set `replication` on ClickHouse Cloud. Cloud rewrites `MergeTree` to `SharedMergeTree` server-side. See the [ClickHouse storage reference](https://mastra.ai/reference/storage/clickhouse) for the full config shape and operator notes.
|
|
244
276
|
|
|
245
277
|
> **Info:** This approach is also required when using storage providers that don't support observability (like Convex, DynamoDB, or Cloudflare). See the [MastraStorageExporter documentation](https://mastra.ai/docs/observability/integrations/exporters/mastra-storage) for the full list of supported providers.
|
package/dist/index.cjs
CHANGED
|
@@ -7,6 +7,7 @@ var vector = require('@mastra/core/vector');
|
|
|
7
7
|
var asyncMutex = require('async-mutex');
|
|
8
8
|
var pg = require('pg');
|
|
9
9
|
var xxhash = require('xxhash-wasm');
|
|
10
|
+
var pgConnectionString = require('pg-connection-string');
|
|
10
11
|
var filter = require('@mastra/core/vector/filter');
|
|
11
12
|
var base = require('@mastra/core/base');
|
|
12
13
|
var crypto$1 = require('crypto');
|
|
@@ -14,7 +15,6 @@ var module$1 = require('module');
|
|
|
14
15
|
var agent = require('@mastra/core/agent');
|
|
15
16
|
var features = require('@mastra/core/features');
|
|
16
17
|
var evals = require('@mastra/core/evals');
|
|
17
|
-
var pgConnectionString = require('pg-connection-string');
|
|
18
18
|
|
|
19
19
|
var _documentCurrentScript = typeof document !== 'undefined' ? document.currentScript : null;
|
|
20
20
|
function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
|
|
@@ -91,6 +91,15 @@ var validateConfig = (name, config) => {
|
|
|
91
91
|
);
|
|
92
92
|
}
|
|
93
93
|
};
|
|
94
|
+
function buildConnectionStringPoolConfig(config, defaults) {
|
|
95
|
+
const parsed = pgConnectionString.parse(config.connectionString);
|
|
96
|
+
return {
|
|
97
|
+
...parsed,
|
|
98
|
+
...config.ssl !== void 0 ? { ssl: config.ssl } : {},
|
|
99
|
+
max: config.max ?? defaults.max,
|
|
100
|
+
idleTimeoutMillis: config.idleTimeoutMillis ?? defaults.idleTimeoutMillis
|
|
101
|
+
};
|
|
102
|
+
}
|
|
94
103
|
var PGFilterTranslator = class extends filter.BaseFilterTranslator {
|
|
95
104
|
getSupportedOperators() {
|
|
96
105
|
return {
|
|
@@ -638,10 +647,7 @@ var PgVector = class extends vector.MastraVector {
|
|
|
638
647
|
let poolConfig;
|
|
639
648
|
if (isConnectionStringConfig(config)) {
|
|
640
649
|
poolConfig = {
|
|
641
|
-
|
|
642
|
-
ssl: config.ssl,
|
|
643
|
-
max: config.max ?? 20,
|
|
644
|
-
idleTimeoutMillis: config.idleTimeoutMillis ?? 3e4,
|
|
650
|
+
...buildConnectionStringPoolConfig(config, { max: 20, idleTimeoutMillis: 3e4 }),
|
|
645
651
|
connectionTimeoutMillis: 2e3,
|
|
646
652
|
...config.pgPoolOptions
|
|
647
653
|
};
|
|
@@ -17967,8 +17973,7 @@ var WorkflowsPG = class _WorkflowsPG extends storage.WorkflowsStorage {
|
|
|
17967
17973
|
const existingSnapshot = existingSnapshotResult.snapshot;
|
|
17968
17974
|
snapshot = typeof existingSnapshot === "string" ? JSON.parse(existingSnapshot) : existingSnapshot;
|
|
17969
17975
|
}
|
|
17970
|
-
snapshot
|
|
17971
|
-
snapshot.requestContext = { ...snapshot.requestContext, ...requestContext };
|
|
17976
|
+
storage.mergeWorkflowStepResult({ snapshot, stepId, result, requestContext });
|
|
17972
17977
|
const now = /* @__PURE__ */ new Date();
|
|
17973
17978
|
const sanitizedSnapshot = sanitizeJsonForPg(JSON.stringify(snapshot));
|
|
17974
17979
|
await t.none(
|
|
@@ -18941,15 +18946,6 @@ var WorkspacesPG = class _WorkspacesPG extends storage.WorkspacesStorage {
|
|
|
18941
18946
|
};
|
|
18942
18947
|
}
|
|
18943
18948
|
};
|
|
18944
|
-
function buildConnectionStringPoolConfig(config, defaults) {
|
|
18945
|
-
const parsed = pgConnectionString.parse(config.connectionString);
|
|
18946
|
-
return {
|
|
18947
|
-
...parsed,
|
|
18948
|
-
...config.ssl !== void 0 ? { ssl: config.ssl } : {},
|
|
18949
|
-
max: config.max ?? defaults.max,
|
|
18950
|
-
idleTimeoutMillis: config.idleTimeoutMillis ?? defaults.idleTimeoutMillis
|
|
18951
|
-
};
|
|
18952
|
-
}
|
|
18953
18949
|
|
|
18954
18950
|
// src/storage/index.ts
|
|
18955
18951
|
var DEFAULT_MAX_CONNECTIONS = 20;
|