diff options
| author | 2023-04-18 03:02:17 +0800 | |
|---|---|---|
| committer | 2023-04-18 03:02:17 +0800 | |
| commit | 4919f028c884a041da7ff098abb02389b4eac598 (patch) | |
| tree | b0f482568c4b8c8a680ce6e2e70a7b7ca87dc190 /pkg/encoding.ts | |
| parent | b135aac8531c1e1488147ad8c6f98eddbdbe0c99 (diff) | |
| download | HydroRoll-4919f028c884a041da7ff098abb02389b4eac598.tar.gz HydroRoll-4919f028c884a041da7ff098abb02389b4eac598.zip | |
✨add envshare docs
Diffstat (limited to 'pkg/encoding.ts')
| -rw-r--r-- | pkg/encoding.ts | 31 |
1 files changed, 0 insertions, 31 deletions
diff --git a/pkg/encoding.ts b/pkg/encoding.ts deleted file mode 100644 index 2025133..0000000 --- a/pkg/encoding.ts +++ /dev/null @@ -1,31 +0,0 @@ -import { fromBase58, toBase58 } from "../util/base58"; -import { ID_LENGTH, ENCRYPTION_KEY_LENGTH } from "./constants"; -/** - * To share links easily, we encode the id, where the data is stored in redis, together with the secret encryption key. - */ -export function encodeCompositeKey(version: number, id: string, encryptionKey: Uint8Array): string { - if (version < 0 || version > 255) { - throw new Error("Version must fit in a byte"); - } - const compositeKey = new Uint8Array([version, ...fromBase58(id), ...encryptionKey]); - - return toBase58(compositeKey); -} - -/** - * To share links easily, we encode the id, where the data is stored in redis, together with the secret encryption key. - */ -export function decodeCompositeKey(compositeKey: string): { id: string; encryptionKey: Uint8Array; version: number } { - const decoded = fromBase58(compositeKey); - const version = decoded.at(0); - - if (version === 1 || version === 2) { - return { - id: toBase58(decoded.slice(1, 1 + ID_LENGTH)), - encryptionKey: decoded.slice(1 + ID_LENGTH, 1 + ID_LENGTH + ENCRYPTION_KEY_LENGTH), - version, - }; - } - - throw new Error(`Unsupported composite key version: ${version}`); -} |
