@juit/pgproxy-client-whatwg 1.3.6 → 1.4.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/dist/index.cjs +8 -5
- package/dist/index.cjs.map +1 -1
- package/dist/index.mjs +4 -1
- package/dist/index.mjs.map +1 -1
- package/package.json +2 -2
- package/src/index.ts +6 -1
package/dist/index.cjs
CHANGED
|
@@ -25,6 +25,9 @@ __export(index_exports, {
|
|
|
25
25
|
});
|
|
26
26
|
module.exports = __toCommonJS(index_exports);
|
|
27
27
|
var import_pgproxy_client = require("@juit/pgproxy-client");
|
|
28
|
+
function assert(what, message) {
|
|
29
|
+
if (!what) throw new Error(message);
|
|
30
|
+
}
|
|
28
31
|
async function createToken(secret, crypto = globalThis.crypto) {
|
|
29
32
|
const encoder = new TextEncoder();
|
|
30
33
|
const buffer = new ArrayBuffer(48);
|
|
@@ -64,9 +67,9 @@ var WHATWGProvider = class _WHATWGProvider extends import_pgproxy_client.WebSock
|
|
|
64
67
|
fetch = _WHATWGProvider.fetch
|
|
65
68
|
} = options;
|
|
66
69
|
url = new URL(url);
|
|
67
|
-
|
|
70
|
+
assert(/^https?:$/.test(url.protocol), `Unsupported protocol "${url.protocol}"`);
|
|
68
71
|
const secret = decodeURIComponent(url.password || url.username);
|
|
69
|
-
|
|
72
|
+
assert(secret, "No connection secret specified in URL");
|
|
70
73
|
url.password = "";
|
|
71
74
|
url.username = "";
|
|
72
75
|
const baseHttpUrl = new URL(url);
|
|
@@ -98,8 +101,8 @@ var WHATWGProvider = class _WHATWGProvider extends import_pgproxy_client.WebSock
|
|
|
98
101
|
} catch {
|
|
99
102
|
throw new Error(`Unable to parse JSON payload (status=${response.status})`);
|
|
100
103
|
}
|
|
101
|
-
|
|
102
|
-
|
|
104
|
+
assert(payload && typeof payload === "object", "JSON payload is not an object");
|
|
105
|
+
assert(payload.id === id, 'Invalid/uncorrelated ID in response"');
|
|
103
106
|
if (payload.statusCode === 200) return payload;
|
|
104
107
|
throw new Error(`${payload.error || /* coverage ignore next */
|
|
105
108
|
"Unknown error"} (${payload.statusCode})`);
|
|
@@ -124,7 +127,7 @@ var WHATWGProvider = class _WHATWGProvider extends import_pgproxy_client.WebSock
|
|
|
124
127
|
var WHATWGClient = class extends import_pgproxy_client.PGClient {
|
|
125
128
|
constructor(url) {
|
|
126
129
|
url = url || globalThis.process?.env?.PGURL;
|
|
127
|
-
|
|
130
|
+
assert(url, "No URL to connect to (PGURL environment variable missing?)");
|
|
128
131
|
super(new WHATWGProvider(typeof url === "string" ? new URL(url) : url));
|
|
129
132
|
}
|
|
130
133
|
};
|
package/dist/index.cjs.map
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../src/index.ts"],
|
|
4
|
-
"mappings": ";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,
|
|
4
|
+
"mappings": "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",
|
|
5
5
|
"names": []
|
|
6
6
|
}
|
package/dist/index.mjs
CHANGED
|
@@ -1,5 +1,8 @@
|
|
|
1
1
|
// index.ts
|
|
2
|
-
import { PGClient, WebSocketProvider,
|
|
2
|
+
import { PGClient, WebSocketProvider, registerProvider } from "@juit/pgproxy-client";
|
|
3
|
+
function assert(what, message) {
|
|
4
|
+
if (!what) throw new Error(message);
|
|
5
|
+
}
|
|
3
6
|
async function createToken(secret, crypto = globalThis.crypto) {
|
|
4
7
|
const encoder = new TextEncoder();
|
|
5
8
|
const buffer = new ArrayBuffer(48);
|
package/dist/index.mjs.map
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../src/index.ts"],
|
|
4
|
-
"mappings": ";AAAA,SAAS,UAAU,mBAAmB,
|
|
4
|
+
"mappings": "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",
|
|
5
5
|
"names": []
|
|
6
6
|
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@juit/pgproxy-client-whatwg",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.4.0",
|
|
4
4
|
"main": "./dist/index.cjs",
|
|
5
5
|
"module": "./dist/index.mjs",
|
|
6
6
|
"types": "./dist/index.d.ts",
|
|
@@ -35,7 +35,7 @@
|
|
|
35
35
|
},
|
|
36
36
|
"homepage": "https://github.com/juitnow/juit-pgproxy#readme",
|
|
37
37
|
"dependencies": {
|
|
38
|
-
"@juit/pgproxy-client": "1.
|
|
38
|
+
"@juit/pgproxy-client": "1.4.0"
|
|
39
39
|
},
|
|
40
40
|
"directories": {
|
|
41
41
|
"test": "test"
|
package/src/index.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { PGClient, WebSocketProvider,
|
|
1
|
+
import { PGClient, WebSocketProvider, registerProvider } from '@juit/pgproxy-client'
|
|
2
2
|
|
|
3
3
|
import type { PGProviderResult, PGWebSocket } from '@juit/pgproxy-client'
|
|
4
4
|
import type { Request, Response } from '@juit/pgproxy-server'
|
|
@@ -20,6 +20,11 @@ type MimimalWebSocket = {
|
|
|
20
20
|
* INTERNALS *
|
|
21
21
|
* ========================================================================== */
|
|
22
22
|
|
|
23
|
+
/** The easiest assertion function in the world */
|
|
24
|
+
function assert(what: unknown, message: string): asserts what {
|
|
25
|
+
if (! what) throw new Error(message)
|
|
26
|
+
}
|
|
27
|
+
|
|
23
28
|
async function createToken(
|
|
24
29
|
secret: string,
|
|
25
30
|
crypto: MimimalCrypto = globalThis.crypto,
|