@kuflow/kuflow-temporal-worker
Version:
Worker library used by KuFlow SDKs and Temporal.
87 lines (76 loc) • 2.85 kB
text/typescript
/**
* The MIT License
* Copyright © 2021-present KuFlow S.L.
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
* THE SOFTWARE.
*/
import crypto from 'crypto'
const CIPHER = 'AES-GCM'
const IV_LENGTH_BYTES = 12
const TAG_LENGTH_BYTES = 16
interface Cipher {
readonly algorithm: string
importKey: (key: crypto.webcrypto.BufferSource) => Promise<crypto.webcrypto.CryptoKey>
encrypt: (key: crypto.webcrypto.CryptoKey, plainText: Uint8Array) => Promise<Uint8Array>
decrypt: (key: crypto.webcrypto.CryptoKey, cipherText: Uint8Array) => Promise<Uint8Array>
}
class CipherAes256GCM implements Cipher {
public readonly algorithm = 'AES-256-GCM'
public async importKey(key: crypto.webcrypto.BufferSource): Promise<crypto.webcrypto.CryptoKey> {
return await crypto.subtle.importKey(
'raw',
key,
{
name: 'AES-GCM',
},
true,
['encrypt', 'decrypt'],
)
}
public async encrypt(key: crypto.webcrypto.CryptoKey, plainText: Uint8Array): Promise<Uint8Array> {
const iv = crypto.getRandomValues(new Uint8Array(IV_LENGTH_BYTES))
const encrypted = await crypto.subtle.encrypt(
{
name: CIPHER,
iv,
tagLength: TAG_LENGTH_BYTES * 8,
},
key,
plainText,
)
return Buffer.concat([iv, new Uint8Array(encrypted)])
}
public async decrypt(key: crypto.webcrypto.CryptoKey, cipherText: Uint8Array): Promise<Uint8Array> {
const iv = cipherText.subarray(0, IV_LENGTH_BYTES)
const cipherTextData = cipherText.subarray(IV_LENGTH_BYTES)
const decrypted = await crypto.subtle.decrypt(
{
name: CIPHER,
iv,
tagLength: TAG_LENGTH_BYTES * 8,
},
key,
cipherTextData,
)
return new Uint8Array(decrypted)
}
}
export const Ciphers = {
AES_256_GCM: new CipherAes256GCM(),
}