| 12345678910111213141516171819202122232425262728 | // Electronic Code Bookimport { ModeOfOperation } from "./mode.js";export class ECB extends ModeOfOperation {    constructor(key) {        super("ECB", key, ECB);    }    encrypt(plaintext) {        if (plaintext.length % 16) {            throw new TypeError("invalid plaintext size (must be multiple of 16 bytes)");        }        const crypttext = new Uint8Array(plaintext.length);        for (let i = 0; i < plaintext.length; i += 16) {            crypttext.set(this.aes.encrypt(plaintext.subarray(i, i + 16)), i);        }        return crypttext;    }    decrypt(crypttext) {        if (crypttext.length % 16) {            throw new TypeError("invalid ciphertext size (must be multiple of 16 bytes)");        }        const plaintext = new Uint8Array(crypttext.length);        for (let i = 0; i < crypttext.length; i += 16) {            plaintext.set(this.aes.decrypt(crypttext.subarray(i, i + 16)), i);        }        return plaintext;    }}//# sourceMappingURL=mode-ecb.js.map
 |