@depup/postgres 3.4.8-depup.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/README.md +25 -0
- package/cf/polyfills.js +233 -0
- package/cf/src/bytes.js +79 -0
- package/cf/src/connection.js +1064 -0
- package/cf/src/errors.js +53 -0
- package/cf/src/index.js +568 -0
- package/cf/src/large.js +70 -0
- package/cf/src/query.js +173 -0
- package/cf/src/queue.js +31 -0
- package/cf/src/result.js +16 -0
- package/cf/src/subscribe.js +278 -0
- package/cf/src/types.js +368 -0
- package/changes.json +5 -0
- package/cjs/package.json +1 -0
- package/cjs/src/bytes.js +78 -0
- package/cjs/src/connection.js +1062 -0
- package/cjs/src/errors.js +53 -0
- package/cjs/src/index.js +567 -0
- package/cjs/src/large.js +70 -0
- package/cjs/src/query.js +173 -0
- package/cjs/src/queue.js +31 -0
- package/cjs/src/result.js +16 -0
- package/cjs/src/subscribe.js +277 -0
- package/cjs/src/types.js +367 -0
- package/package.json +74 -0
- package/src/bytes.js +78 -0
- package/src/connection.js +1062 -0
- package/src/errors.js +53 -0
- package/src/index.js +567 -0
- package/src/large.js +70 -0
- package/src/query.js +173 -0
- package/src/queue.js +31 -0
- package/src/result.js +16 -0
- package/src/subscribe.js +277 -0
- package/src/types.js +367 -0
- package/types/index.d.ts +743 -0
- package/types/package.json +5 -0
- package/types/tsconfig.json +14 -0
package/README.md
ADDED
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
# @depup/postgres
|
|
2
|
+
|
|
3
|
+
> Dependency-bumped version of [postgres](https://www.npmjs.com/package/postgres)
|
|
4
|
+
|
|
5
|
+
Generated by [DepUp](https://github.com/depup/npm) -- all production
|
|
6
|
+
dependencies bumped to latest versions.
|
|
7
|
+
|
|
8
|
+
## Installation
|
|
9
|
+
|
|
10
|
+
```bash
|
|
11
|
+
npm install @depup/postgres
|
|
12
|
+
```
|
|
13
|
+
|
|
14
|
+
| Field | Value |
|
|
15
|
+
|-------|-------|
|
|
16
|
+
| Original | [postgres](https://www.npmjs.com/package/postgres) @ 3.4.8 |
|
|
17
|
+
| Processed | 2026-03-17 |
|
|
18
|
+
| Smoke test | passed |
|
|
19
|
+
| Deps updated | 0 |
|
|
20
|
+
|
|
21
|
+
---
|
|
22
|
+
|
|
23
|
+
Source: https://github.com/depup/npm | Original: https://www.npmjs.com/package/postgres
|
|
24
|
+
|
|
25
|
+
License inherited from the original package.
|
package/cf/polyfills.js
ADDED
|
@@ -0,0 +1,233 @@
|
|
|
1
|
+
import { EventEmitter } from 'node:events'
|
|
2
|
+
import { Buffer } from 'node:buffer'
|
|
3
|
+
|
|
4
|
+
const Crypto = globalThis.crypto
|
|
5
|
+
|
|
6
|
+
let ids = 1
|
|
7
|
+
const tasks = new Set()
|
|
8
|
+
|
|
9
|
+
const v4Seg = '(?:[0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])'
|
|
10
|
+
const v4Str = `(${v4Seg}[.]){3}${v4Seg}`
|
|
11
|
+
const IPv4Reg = new RegExp(`^${v4Str}$`)
|
|
12
|
+
|
|
13
|
+
const v6Seg = '(?:[0-9a-fA-F]{1,4})'
|
|
14
|
+
const IPv6Reg = new RegExp(
|
|
15
|
+
'^(' +
|
|
16
|
+
`(?:${v6Seg}:){7}(?:${v6Seg}|:)|` +
|
|
17
|
+
`(?:${v6Seg}:){6}(?:${v4Str}|:${v6Seg}|:)|` +
|
|
18
|
+
`(?:${v6Seg}:){5}(?::${v4Str}|(:${v6Seg}){1,2}|:)|` +
|
|
19
|
+
`(?:${v6Seg}:){4}(?:(:${v6Seg}){0,1}:${v4Str}|(:${v6Seg}){1,3}|:)|` +
|
|
20
|
+
`(?:${v6Seg}:){3}(?:(:${v6Seg}){0,2}:${v4Str}|(:${v6Seg}){1,4}|:)|` +
|
|
21
|
+
`(?:${v6Seg}:){2}(?:(:${v6Seg}){0,3}:${v4Str}|(:${v6Seg}){1,5}|:)|` +
|
|
22
|
+
`(?:${v6Seg}:){1}(?:(:${v6Seg}){0,4}:${v4Str}|(:${v6Seg}){1,6}|:)|` +
|
|
23
|
+
`(?::((?::${v6Seg}){0,5}:${v4Str}|(?::${v6Seg}){1,7}|:))` +
|
|
24
|
+
')(%[0-9a-zA-Z-.:]{1,})?$'
|
|
25
|
+
)
|
|
26
|
+
|
|
27
|
+
const textEncoder = new TextEncoder()
|
|
28
|
+
export const crypto = {
|
|
29
|
+
randomBytes: l => Crypto.getRandomValues(Buffer.alloc(l)),
|
|
30
|
+
pbkdf2Sync: async(password, salt, iterations, keylen) =>
|
|
31
|
+
Crypto.subtle.deriveBits(
|
|
32
|
+
{
|
|
33
|
+
name: 'PBKDF2',
|
|
34
|
+
hash: 'SHA-256',
|
|
35
|
+
salt,
|
|
36
|
+
iterations
|
|
37
|
+
},
|
|
38
|
+
await Crypto.subtle.importKey(
|
|
39
|
+
'raw',
|
|
40
|
+
textEncoder.encode(password),
|
|
41
|
+
'PBKDF2',
|
|
42
|
+
false,
|
|
43
|
+
['deriveBits']
|
|
44
|
+
),
|
|
45
|
+
keylen * 8,
|
|
46
|
+
['deriveBits']
|
|
47
|
+
),
|
|
48
|
+
createHash: type => ({
|
|
49
|
+
update: x => ({
|
|
50
|
+
digest: encoding => {
|
|
51
|
+
if (!(x instanceof Uint8Array)) {
|
|
52
|
+
x = textEncoder.encode(x)
|
|
53
|
+
}
|
|
54
|
+
let prom
|
|
55
|
+
if (type === 'sha256') {
|
|
56
|
+
prom = Crypto.subtle.digest('SHA-256', x)
|
|
57
|
+
} else if (type === 'md5') {
|
|
58
|
+
prom = Crypto.subtle.digest('md5', x)
|
|
59
|
+
} else {
|
|
60
|
+
throw Error('createHash only supports sha256 or md5 in this environment, not ${type}.')
|
|
61
|
+
}
|
|
62
|
+
if (encoding === 'hex') {
|
|
63
|
+
return prom.then((arrayBuf) => Buffer.from(arrayBuf).toString('hex'))
|
|
64
|
+
} else if (encoding) {
|
|
65
|
+
throw Error(`createHash only supports hex encoding or unencoded in this environment, not ${encoding}`)
|
|
66
|
+
} else {
|
|
67
|
+
return prom
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
})
|
|
71
|
+
}),
|
|
72
|
+
createHmac: (type, key) => ({
|
|
73
|
+
update: x => ({
|
|
74
|
+
digest: async() =>
|
|
75
|
+
Buffer.from(
|
|
76
|
+
await Crypto.subtle.sign(
|
|
77
|
+
'HMAC',
|
|
78
|
+
await Crypto.subtle.importKey('raw', key, { name: 'HMAC', hash: 'SHA-256' }, false, ['sign']),
|
|
79
|
+
textEncoder.encode(x)
|
|
80
|
+
)
|
|
81
|
+
)
|
|
82
|
+
})
|
|
83
|
+
})
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
export const performance = globalThis.performance
|
|
87
|
+
|
|
88
|
+
export const process = {
|
|
89
|
+
env: {}
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
export const os = {
|
|
93
|
+
userInfo() {
|
|
94
|
+
return { username: 'postgres' }
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
export const fs = {
|
|
99
|
+
readFile() {
|
|
100
|
+
throw new Error('Reading files not supported on CloudFlare')
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
export const net = {
|
|
105
|
+
isIP: (x) => IPv4Reg.test(x) ? 4 : IPv6Reg.test(x) ? 6 : 0,
|
|
106
|
+
Socket
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
export { setImmediate, clearImmediate }
|
|
110
|
+
|
|
111
|
+
export const tls = {
|
|
112
|
+
connect({ socket: tcp, servername }) {
|
|
113
|
+
tcp.writer.releaseLock()
|
|
114
|
+
tcp.reader.releaseLock()
|
|
115
|
+
tcp.readyState = 'upgrading'
|
|
116
|
+
tcp.raw = tcp.raw.startTls({ servername })
|
|
117
|
+
tcp.raw.closed.then(
|
|
118
|
+
() => tcp.emit('close'),
|
|
119
|
+
(e) => tcp.emit('error', e)
|
|
120
|
+
)
|
|
121
|
+
tcp.writer = tcp.raw.writable.getWriter()
|
|
122
|
+
tcp.reader = tcp.raw.readable.getReader()
|
|
123
|
+
|
|
124
|
+
tcp.writer.ready.then(() => {
|
|
125
|
+
tcp.read()
|
|
126
|
+
tcp.readyState = 'upgrade'
|
|
127
|
+
})
|
|
128
|
+
return tcp
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
function Socket() {
|
|
133
|
+
const tcp = Object.assign(new EventEmitter(), {
|
|
134
|
+
readyState: 'open',
|
|
135
|
+
raw: null,
|
|
136
|
+
writer: null,
|
|
137
|
+
reader: null,
|
|
138
|
+
connect,
|
|
139
|
+
write,
|
|
140
|
+
end,
|
|
141
|
+
destroy,
|
|
142
|
+
read
|
|
143
|
+
})
|
|
144
|
+
|
|
145
|
+
return tcp
|
|
146
|
+
|
|
147
|
+
async function connect(port, host) {
|
|
148
|
+
try {
|
|
149
|
+
tcp.readyState = 'opening'
|
|
150
|
+
const { connect } = await import('cloudflare:sockets')
|
|
151
|
+
tcp.raw = connect(host + ':' + port, tcp.ssl ? { secureTransport: 'starttls' } : {})
|
|
152
|
+
tcp.raw.closed.then(
|
|
153
|
+
() => {
|
|
154
|
+
tcp.readyState !== 'upgrade'
|
|
155
|
+
? close()
|
|
156
|
+
: ((tcp.readyState = 'open'), tcp.emit('secureConnect'))
|
|
157
|
+
},
|
|
158
|
+
(e) => tcp.emit('error', e)
|
|
159
|
+
)
|
|
160
|
+
tcp.writer = tcp.raw.writable.getWriter()
|
|
161
|
+
tcp.reader = tcp.raw.readable.getReader()
|
|
162
|
+
|
|
163
|
+
tcp.ssl ? readFirst() : read()
|
|
164
|
+
tcp.writer.ready.then(() => {
|
|
165
|
+
tcp.readyState = 'open'
|
|
166
|
+
tcp.emit('connect')
|
|
167
|
+
})
|
|
168
|
+
} catch (err) {
|
|
169
|
+
error(err)
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
|
|
173
|
+
function close() {
|
|
174
|
+
if (tcp.readyState === 'closed')
|
|
175
|
+
return
|
|
176
|
+
|
|
177
|
+
tcp.readyState = 'closed'
|
|
178
|
+
tcp.emit('close')
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
function write(data, cb) {
|
|
182
|
+
tcp.writer.write(data).then(cb, error)
|
|
183
|
+
return true
|
|
184
|
+
}
|
|
185
|
+
|
|
186
|
+
function end(data) {
|
|
187
|
+
return data
|
|
188
|
+
? tcp.write(data, () => tcp.raw.close())
|
|
189
|
+
: tcp.raw.close()
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
function destroy() {
|
|
193
|
+
tcp.destroyed = true
|
|
194
|
+
tcp.end()
|
|
195
|
+
}
|
|
196
|
+
|
|
197
|
+
async function read() {
|
|
198
|
+
try {
|
|
199
|
+
let done
|
|
200
|
+
, value
|
|
201
|
+
while (({ done, value } = await tcp.reader.read(), !done))
|
|
202
|
+
tcp.emit('data', Buffer.from(value))
|
|
203
|
+
} catch (err) {
|
|
204
|
+
error(err)
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
|
|
208
|
+
async function readFirst() {
|
|
209
|
+
const { value } = await tcp.reader.read()
|
|
210
|
+
tcp.emit('data', Buffer.from(value))
|
|
211
|
+
}
|
|
212
|
+
|
|
213
|
+
function error(err) {
|
|
214
|
+
tcp.emit('error', err)
|
|
215
|
+
tcp.emit('close')
|
|
216
|
+
}
|
|
217
|
+
}
|
|
218
|
+
|
|
219
|
+
function setImmediate(fn) {
|
|
220
|
+
const id = ids++
|
|
221
|
+
tasks.add(id)
|
|
222
|
+
queueMicrotask(() => {
|
|
223
|
+
if (tasks.has(id)) {
|
|
224
|
+
fn()
|
|
225
|
+
tasks.delete(id)
|
|
226
|
+
}
|
|
227
|
+
})
|
|
228
|
+
return id
|
|
229
|
+
}
|
|
230
|
+
|
|
231
|
+
function clearImmediate(id) {
|
|
232
|
+
tasks.delete(id)
|
|
233
|
+
}
|
package/cf/src/bytes.js
ADDED
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import { Buffer } from 'node:buffer'
|
|
2
|
+
const size = 256
|
|
3
|
+
let buffer = Buffer.allocUnsafe(size)
|
|
4
|
+
|
|
5
|
+
const messages = 'BCcDdEFfHPpQSX'.split('').reduce((acc, x) => {
|
|
6
|
+
const v = x.charCodeAt(0)
|
|
7
|
+
acc[x] = () => {
|
|
8
|
+
buffer[0] = v
|
|
9
|
+
b.i = 5
|
|
10
|
+
return b
|
|
11
|
+
}
|
|
12
|
+
return acc
|
|
13
|
+
}, {})
|
|
14
|
+
|
|
15
|
+
const b = Object.assign(reset, messages, {
|
|
16
|
+
N: String.fromCharCode(0),
|
|
17
|
+
i: 0,
|
|
18
|
+
inc(x) {
|
|
19
|
+
b.i += x
|
|
20
|
+
return b
|
|
21
|
+
},
|
|
22
|
+
str(x) {
|
|
23
|
+
const length = Buffer.byteLength(x)
|
|
24
|
+
fit(length)
|
|
25
|
+
b.i += buffer.write(x, b.i, length, 'utf8')
|
|
26
|
+
return b
|
|
27
|
+
},
|
|
28
|
+
i16(x) {
|
|
29
|
+
fit(2)
|
|
30
|
+
buffer.writeUInt16BE(x, b.i)
|
|
31
|
+
b.i += 2
|
|
32
|
+
return b
|
|
33
|
+
},
|
|
34
|
+
i32(x, i) {
|
|
35
|
+
if (i || i === 0) {
|
|
36
|
+
buffer.writeUInt32BE(x, i)
|
|
37
|
+
return b
|
|
38
|
+
}
|
|
39
|
+
fit(4)
|
|
40
|
+
buffer.writeUInt32BE(x, b.i)
|
|
41
|
+
b.i += 4
|
|
42
|
+
return b
|
|
43
|
+
},
|
|
44
|
+
z(x) {
|
|
45
|
+
fit(x)
|
|
46
|
+
buffer.fill(0, b.i, b.i + x)
|
|
47
|
+
b.i += x
|
|
48
|
+
return b
|
|
49
|
+
},
|
|
50
|
+
raw(x) {
|
|
51
|
+
buffer = Buffer.concat([buffer.subarray(0, b.i), x])
|
|
52
|
+
b.i = buffer.length
|
|
53
|
+
return b
|
|
54
|
+
},
|
|
55
|
+
end(at = 1) {
|
|
56
|
+
buffer.writeUInt32BE(b.i - at, at)
|
|
57
|
+
const out = buffer.subarray(0, b.i)
|
|
58
|
+
b.i = 0
|
|
59
|
+
buffer = Buffer.allocUnsafe(size)
|
|
60
|
+
return out
|
|
61
|
+
}
|
|
62
|
+
})
|
|
63
|
+
|
|
64
|
+
export default b
|
|
65
|
+
|
|
66
|
+
function fit(x) {
|
|
67
|
+
if (buffer.length - b.i < x) {
|
|
68
|
+
const prev = buffer
|
|
69
|
+
, length = prev.length
|
|
70
|
+
|
|
71
|
+
buffer = Buffer.allocUnsafe(length + (length >> 1) + x)
|
|
72
|
+
prev.copy(buffer)
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
function reset() {
|
|
77
|
+
b.i = 0
|
|
78
|
+
return b
|
|
79
|
+
}
|