From 5c5d17179105ab65fce46c40835261447145d196 Mon Sep 17 00:00:00 2001 From: Kohei Watanabe Date: Mon, 9 Sep 2024 18:32:50 +0900 Subject: [PATCH] organize hash algorithm names --- src/index.ts | 28 ++++++++++------------------ 1 file changed, 10 insertions(+), 18 deletions(-) diff --git a/src/index.ts b/src/index.ts index 7a39133..94ca241 100644 --- a/src/index.ts +++ b/src/index.ts @@ -1,17 +1,12 @@ /** Content Security Policy Level 2, section 4.2 */ export type HashAlgorithm = "sha256" | "sha384" | "sha512"; -export const supportedHashAlgorithm: ReadonlyArray = [ - "sha512", - "sha384", - "sha256", -]; - -export const supportedHashAlgorithmName = { +/** Supported Hash Algorithms */ +export const supportedHashAlgorithms = { sha256: "SHA-256", sha384: "SHA-384", sha512: "SHA-512", -} satisfies Record; +} as const satisfies Record; export type PrioritizedHashAlgorithm = "" | HashAlgorithm; @@ -20,8 +15,8 @@ export function getPrioritizedHashAlgorithm( b: HashAlgorithm, ): PrioritizedHashAlgorithm { if (a === b) return ""; - if (!supportedHashAlgorithm.includes(a)) return ""; - if (!supportedHashAlgorithm.includes(b)) return ""; + if (!(a in supportedHashAlgorithms)) return ""; + if (!(b in supportedHashAlgorithms)) return ""; return a < b ? b : a; } @@ -69,7 +64,7 @@ export class IntegrityMetadata { }): string { if (!integrity.alg) return ""; if (!integrity.val) return ""; - if (!supportedHashAlgorithm.includes(integrity.alg)) return ""; + if (!(integrity.alg in supportedHashAlgorithms)) return ""; return `${integrity.alg}-${[integrity.val, ...integrity.opt].join("?")}`; } } @@ -81,13 +76,10 @@ export async function createIntegrityMetadata( ): Promise { const alg = hashAlgorithm.toLowerCase() as HashAlgorithm; - if (!supportedHashAlgorithm.includes(alg)) return ""; - - const arrayBuffer = await crypto.subtle.digest( - supportedHashAlgorithmName[alg], - data, - ); + if (!(alg in supportedHashAlgorithms)) return ""; + const hashAlgorithmIdentifier = supportedHashAlgorithms[alg]; + const arrayBuffer = await crypto.subtle.digest(hashAlgorithmIdentifier, data); const val = btoa(String.fromCharCode(...new Uint8Array(arrayBuffer))); return IntegrityMetadata.stringify({ @@ -124,7 +116,7 @@ export class IntegrityMetadataSet extends Map< } get strongest(): IntegrityMetadata { - const [hashAlgorithm = supportedHashAlgorithm[0]]: HashAlgorithm[] = [ + const [hashAlgorithm = "sha512"]: ReadonlyArray = [ ...this.keys(), ].sort((a, b) => { switch (this.getPrioritizedHashAlgorithm(a, b)) {