-
Notifications
You must be signed in to change notification settings - Fork 63
/
Copy pathencrypt.ts
70 lines (60 loc) · 1.92 KB
/
encrypt.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
// Copyright Amazon.com Inc. or its affiliates. All Rights Reserved.
// SPDX-License-Identifier: Apache-2.0
import {
KeyringNode,
NodeMaterialsManager,
ClientOptions,
} from '@aws-crypto/material-management-node'
import { _encryptStream, EncryptStreamInput } from './encrypt_stream'
// @ts-ignore
import { finished } from 'readable-stream'
import { Readable, Duplex } from 'stream'
import { MessageHeader } from '@aws-crypto/serialize'
export interface EncryptInput extends EncryptStreamInput {
encoding?: BufferEncoding
}
export interface EncryptOutput {
result: Buffer
messageHeader: MessageHeader
}
export async function _encrypt(
clientOptions: ClientOptions,
cmm: KeyringNode | NodeMaterialsManager,
plaintext: Buffer | Uint8Array | Readable | string | NodeJS.ReadableStream,
op: EncryptInput = {}
): Promise<EncryptOutput> {
const { encoding } = op
if (plaintext instanceof Uint8Array) {
op.plaintextLength = plaintext.byteLength
} else if (typeof plaintext === 'string') {
plaintext = Buffer.from(plaintext, encoding)
op.plaintextLength = plaintext.byteLength
}
const stream = _encryptStream(clientOptions, cmm, op)
const result: Buffer[] = []
let messageHeader: MessageHeader | false = false
stream
.once('MessageHeader', (header) => {
messageHeader = header
})
.on('data', (chunk: Buffer) => result.push(chunk))
// This will check both Uint8Array|Buffer
if (plaintext instanceof Uint8Array) {
stream.end(plaintext)
} else if (plaintext.readable) {
plaintext.pipe(stream)
} else {
throw new Error('Unsupported plaintext')
}
await finishedAsync(stream)
if (!messageHeader) throw new Error('Unknown format')
return {
result: Buffer.concat(result),
messageHeader,
}
}
async function finishedAsync(stream: Duplex) {
return new Promise<void>((resolve, reject) => {
finished(stream, (err: Error) => (err ? reject(err) : resolve()))
})
}