1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-26 00:47:50 -05:00
denoland-deno/ext/node/polyfills/internal/crypto
Luca Casonato 4fa8869f24
feat(ext/node): rewrite crypto keys (#24463)
This completely rewrites how we handle key material in ext/node. Changes
in this
PR:

- **Signing**
  - RSA
  - RSA-PSS 🆕
  - DSA 🆕
  - EC
  - ED25519 🆕
- **Verifying**
  - RSA
  - RSA-PSS 🆕
  - DSA 🆕
  - EC 🆕
  - ED25519 🆕
- **Private key import**
  - Passphrase encrypted private keys 🆕
  - RSA
    - PEM
    - DER (PKCS#1) 🆕
    - DER (PKCS#8) 🆕
  - RSA-PSS
    - PEM
    - DER (PKCS#1) 🆕
    - DER (PKCS#8) 🆕
  - DSA 🆕
  - EC
    - PEM
    - DER (SEC1) 🆕
    - DER (PKCS#8) 🆕
  - X25519 🆕
  - ED25519 🆕
  - DH
- **Public key import**
  - RSA
    - PEM
    - DER (PKCS#1) 🆕
    - DER (PKCS#8) 🆕
  - RSA-PSS 🆕
  - DSA 🆕
  - EC 🆕
  - X25519 🆕
  - ED25519 🆕
  - DH 🆕
- **Private key export**
  - RSA 🆕
  - DSA 🆕
  - EC 🆕
  - X25519 🆕
  - ED25519 🆕
  - DH 🆕
- **Public key export**
  - RSA
  - DSA 🆕
  - EC 🆕
  - X25519 🆕
  - ED25519 🆕
  - DH 🆕
- **Key pair generation**
  - Overhauled, but supported APIs unchanged

This PR adds a lot of new individual functionality. But most importantly
because
of the new key material representation, it is now trivial to add new
algorithms
(as shown by this PR).

Now, when adding a new algorithm, it is also widely supported - for
example
previously we supported ED25519 key pair generation, but we could not
import,
export, sign or verify with ED25519. We can now do all of those things.
2024-08-07 08:43:58 +02:00
..
_keys.ts feat(ext/node): rewrite crypto keys (#24463) 2024-08-07 08:43:58 +02:00
_randomBytes.ts chore: update copyright to 2024 (#21753) 2024-01-01 19:58:21 +00:00
_randomFill.mjs feat(ext/node): rewrite crypto keys (#24463) 2024-08-07 08:43:58 +02:00
_randomInt.ts refactor: migrate 'ext/node' extension to virtual ops module (#22157) 2024-01-29 14:58:08 +01:00
certificate.ts chore: update copyright to 2024 (#21753) 2024-01-01 19:58:21 +00:00
cipher.ts feat(ext/node): rewrite crypto keys (#24463) 2024-08-07 08:43:58 +02:00
constants.ts chore: update copyright to 2024 (#21753) 2024-01-01 19:58:21 +00:00
diffiehellman.ts feat(ext/node): rewrite crypto keys (#24463) 2024-08-07 08:43:58 +02:00
hash.ts feat(ext/node): rewrite crypto keys (#24463) 2024-08-07 08:43:58 +02:00
hkdf.ts feat(ext/node): rewrite crypto keys (#24463) 2024-08-07 08:43:58 +02:00
keygen.ts feat(ext/node): rewrite crypto keys (#24463) 2024-08-07 08:43:58 +02:00
keys.ts feat(ext/node): rewrite crypto keys (#24463) 2024-08-07 08:43:58 +02:00
pbkdf2.ts fix(ext/node): rewrite digest handling (#24392) 2024-07-05 10:10:22 +02:00
random.ts refactor: Use virtul ops module (#22175) 2024-01-29 22:02:26 +01:00
scrypt.ts refactor: migrate 'ext/node' extension to virtual ops module (#22157) 2024-01-29 14:58:08 +01:00
sig.ts feat(ext/node): rewrite crypto keys (#24463) 2024-08-07 08:43:58 +02:00
types.ts feat(ext/node): rewrite crypto keys (#24463) 2024-08-07 08:43:58 +02:00
util.ts fix(ext/node): support public key point encoding in ECDH.generateKeys() (#22976) 2024-03-18 13:20:10 +05:30
x509.ts refactor: migrate 'ext/node' extension to virtual ops module (#22157) 2024-01-29 14:58:08 +01:00