| 
									
										
										
										
											2024-03-06 16:53:50 -07:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * Copyright (c) 2024, Andrew Kaster <akaster@serenityos.org> | 
					
						
							| 
									
										
										
										
											2024-10-26 20:12:09 +02:00
										 |  |  |  * Copyright (c) 2024, stelar7 <dudedbz@gmail.com> | 
					
						
							| 
									
										
										
										
											2024-11-13 15:23:50 +01:00
										 |  |  |  * Copyright (c) 2024, Jelle Raaijmakers <jelle@ladybird.org> | 
					
						
							| 
									
										
										
										
											2024-03-06 16:53:50 -07:00
										 |  |  |  * | 
					
						
							|  |  |  |  * SPDX-License-Identifier: BSD-2-Clause | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <AK/EnumBits.h>
 | 
					
						
							|  |  |  | #include <AK/String.h>
 | 
					
						
							| 
									
										
										
										
											2024-03-08 16:30:17 -07:00
										 |  |  | #include <LibCrypto/BigInt/UnsignedBigInteger.h>
 | 
					
						
							| 
									
										
										
										
											2024-11-15 04:01:23 +13:00
										 |  |  | #include <LibGC/Ptr.h>
 | 
					
						
							| 
									
										
										
										
											2024-03-06 16:53:50 -07:00
										 |  |  | #include <LibJS/Forward.h>
 | 
					
						
							|  |  |  | #include <LibWeb/Bindings/SubtleCryptoPrototype.h>
 | 
					
						
							|  |  |  | #include <LibWeb/Crypto/CryptoBindings.h>
 | 
					
						
							|  |  |  | #include <LibWeb/Crypto/CryptoKey.h>
 | 
					
						
							|  |  |  | #include <LibWeb/WebIDL/Buffers.h>
 | 
					
						
							|  |  |  | #include <LibWeb/WebIDL/ExceptionOr.h>
 | 
					
						
							| 
									
										
										
										
											2024-11-13 15:23:50 +01:00
										 |  |  | #include <LibWeb/WebIDL/Types.h>
 | 
					
						
							| 
									
										
										
										
											2024-03-06 16:53:50 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace Web::Crypto { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-15 04:01:23 +13:00
										 |  |  | using AlgorithmIdentifier = Variant<GC::Root<JS::Object>, String>; | 
					
						
							| 
									
										
										
										
											2024-03-27 01:27:42 +01:00
										 |  |  | using NamedCurve = String; | 
					
						
							| 
									
										
										
										
											2024-11-15 04:01:23 +13:00
										 |  |  | using KeyDataType = Variant<GC::Root<WebIDL::BufferSource>, Bindings::JsonWebKey>; | 
					
						
							| 
									
										
										
										
											2024-03-06 16:53:50 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-09 09:27:53 +02:00
										 |  |  | struct HashAlgorithmIdentifier : public AlgorithmIdentifier { | 
					
						
							|  |  |  |     using AlgorithmIdentifier::AlgorithmIdentifier; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     JS::ThrowCompletionOr<String> name(JS::VM& vm) const | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         auto value = visit( | 
					
						
							|  |  |  |             [](String const& name) -> JS::ThrowCompletionOr<String> { return name; }, | 
					
						
							| 
									
										
										
										
											2024-11-15 04:01:23 +13:00
										 |  |  |             [&](GC::Root<JS::Object> const& obj) -> JS::ThrowCompletionOr<String> { | 
					
						
							| 
									
										
										
										
											2024-04-09 09:27:53 +02:00
										 |  |  |                 auto name_property = TRY(obj->get("name")); | 
					
						
							|  |  |  |                 return name_property.to_string(vm); | 
					
						
							|  |  |  |             }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return value; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-06 16:53:50 -07:00
										 |  |  | // https://w3c.github.io/webcrypto/#algorithm-overview
 | 
					
						
							|  |  |  | struct AlgorithmParams { | 
					
						
							| 
									
										
										
										
											2024-03-13 21:26:00 -06:00
										 |  |  |     virtual ~AlgorithmParams(); | 
					
						
							|  |  |  |     explicit AlgorithmParams(String name) | 
					
						
							|  |  |  |         : name(move(name)) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-06 16:53:50 -07:00
										 |  |  |     String name; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     static JS::ThrowCompletionOr<NonnullOwnPtr<AlgorithmParams>> from_value(JS::VM&, JS::Value); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-25 05:58:30 +02:00
										 |  |  | // https://w3c.github.io/webcrypto/#aes-cbc
 | 
					
						
							|  |  |  | struct AesCbcParams : public AlgorithmParams { | 
					
						
							|  |  |  |     virtual ~AesCbcParams() override; | 
					
						
							|  |  |  |     AesCbcParams(String name, ByteBuffer iv) | 
					
						
							|  |  |  |         : AlgorithmParams(move(name)) | 
					
						
							|  |  |  |         , iv(move(iv)) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ByteBuffer iv; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     static JS::ThrowCompletionOr<NonnullOwnPtr<AlgorithmParams>> from_value(JS::VM&, JS::Value); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-30 23:53:48 +01:00
										 |  |  | // https://w3c.github.io/webcrypto/#dfn-AesCtrParams
 | 
					
						
							|  |  |  | struct AesCtrParams : public AlgorithmParams { | 
					
						
							|  |  |  |     virtual ~AesCtrParams() override; | 
					
						
							|  |  |  |     AesCtrParams(String name, ByteBuffer counter, u8 length) | 
					
						
							|  |  |  |         : AlgorithmParams(move(name)) | 
					
						
							|  |  |  |         , counter(move(counter)) | 
					
						
							|  |  |  |         , length(length) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ByteBuffer counter; | 
					
						
							|  |  |  |     u8 length; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     static JS::ThrowCompletionOr<NonnullOwnPtr<AlgorithmParams>> from_value(JS::VM&, JS::Value); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-31 16:29:39 +01:00
										 |  |  | // https://w3c.github.io/webcrypto/#dfn-AesGcmParams
 | 
					
						
							|  |  |  | struct AesGcmParams : public AlgorithmParams { | 
					
						
							|  |  |  |     virtual ~AesGcmParams() override; | 
					
						
							|  |  |  |     AesGcmParams(String name, ByteBuffer iv, Optional<ByteBuffer> additional_data, Optional<u8> tag_length) | 
					
						
							|  |  |  |         : AlgorithmParams(move(name)) | 
					
						
							|  |  |  |         , iv(move(iv)) | 
					
						
							|  |  |  |         , additional_data(move(additional_data)) | 
					
						
							|  |  |  |         , tag_length(tag_length) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ByteBuffer iv; | 
					
						
							|  |  |  |     Optional<ByteBuffer> additional_data; | 
					
						
							|  |  |  |     Optional<u8> tag_length; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     static JS::ThrowCompletionOr<NonnullOwnPtr<AlgorithmParams>> from_value(JS::VM&, JS::Value); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-20 06:10:36 +02:00
										 |  |  | // https://w3c.github.io/webcrypto/#hkdf-params
 | 
					
						
							|  |  |  | struct HKDFParams : public AlgorithmParams { | 
					
						
							|  |  |  |     virtual ~HKDFParams() override; | 
					
						
							|  |  |  |     HKDFParams(String name, HashAlgorithmIdentifier hash, ByteBuffer salt, ByteBuffer info) | 
					
						
							|  |  |  |         : AlgorithmParams(move(name)) | 
					
						
							|  |  |  |         , hash(move(hash)) | 
					
						
							|  |  |  |         , salt(move(salt)) | 
					
						
							|  |  |  |         , info(move(info)) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     HashAlgorithmIdentifier hash; | 
					
						
							|  |  |  |     ByteBuffer salt; | 
					
						
							|  |  |  |     ByteBuffer info; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     static JS::ThrowCompletionOr<NonnullOwnPtr<AlgorithmParams>> from_value(JS::VM&, JS::Value); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-06 16:53:50 -07:00
										 |  |  | // https://w3c.github.io/webcrypto/#pbkdf2-params
 | 
					
						
							|  |  |  | struct PBKDF2Params : public AlgorithmParams { | 
					
						
							| 
									
										
										
										
											2024-03-13 21:26:00 -06:00
										 |  |  |     virtual ~PBKDF2Params() override; | 
					
						
							| 
									
										
										
										
											2024-03-14 22:11:56 -06:00
										 |  |  |     PBKDF2Params(String name, ByteBuffer salt, u32 iterations, HashAlgorithmIdentifier hash) | 
					
						
							| 
									
										
										
										
											2024-03-13 21:26:00 -06:00
										 |  |  |         : AlgorithmParams(move(name)) | 
					
						
							|  |  |  |         , salt(move(salt)) | 
					
						
							|  |  |  |         , iterations(iterations) | 
					
						
							|  |  |  |         , hash(move(hash)) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-14 22:11:56 -06:00
										 |  |  |     ByteBuffer salt; | 
					
						
							| 
									
										
										
										
											2024-03-06 16:53:50 -07:00
										 |  |  |     u32 iterations; | 
					
						
							|  |  |  |     HashAlgorithmIdentifier hash; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     static JS::ThrowCompletionOr<NonnullOwnPtr<AlgorithmParams>> from_value(JS::VM&, JS::Value); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-08 16:30:17 -07:00
										 |  |  | // https://w3c.github.io/webcrypto/#dfn-RsaKeyGenParams
 | 
					
						
							|  |  |  | struct RsaKeyGenParams : public AlgorithmParams { | 
					
						
							| 
									
										
										
										
											2024-03-13 21:26:00 -06:00
										 |  |  |     virtual ~RsaKeyGenParams() override; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     RsaKeyGenParams(String name, u32 modulus_length, ::Crypto::UnsignedBigInteger public_exponent) | 
					
						
							|  |  |  |         : AlgorithmParams(move(name)) | 
					
						
							|  |  |  |         , modulus_length(modulus_length) | 
					
						
							|  |  |  |         , public_exponent(move(public_exponent)) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-08 16:30:17 -07:00
										 |  |  |     u32 modulus_length; | 
					
						
							|  |  |  |     // NOTE that the raw data is going to be in Big Endian u8[] format
 | 
					
						
							|  |  |  |     ::Crypto::UnsignedBigInteger public_exponent; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     static JS::ThrowCompletionOr<NonnullOwnPtr<AlgorithmParams>> from_value(JS::VM&, JS::Value); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // https://w3c.github.io/webcrypto/#dfn-RsaHashedKeyGenParams
 | 
					
						
							|  |  |  | struct RsaHashedKeyGenParams : public RsaKeyGenParams { | 
					
						
							| 
									
										
										
										
											2024-03-13 21:26:00 -06:00
										 |  |  |     virtual ~RsaHashedKeyGenParams() override; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     RsaHashedKeyGenParams(String name, u32 modulus_length, ::Crypto::UnsignedBigInteger public_exponent, HashAlgorithmIdentifier hash) | 
					
						
							|  |  |  |         : RsaKeyGenParams(move(name), modulus_length, move(public_exponent)) | 
					
						
							|  |  |  |         , hash(move(hash)) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-08 16:30:17 -07:00
										 |  |  |     HashAlgorithmIdentifier hash; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     static JS::ThrowCompletionOr<NonnullOwnPtr<AlgorithmParams>> from_value(JS::VM&, JS::Value); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-14 21:57:32 -06:00
										 |  |  | // https://w3c.github.io/webcrypto/#dfn-RsaHashedImportParams
 | 
					
						
							|  |  |  | struct RsaHashedImportParams : public AlgorithmParams { | 
					
						
							|  |  |  |     virtual ~RsaHashedImportParams() override; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     RsaHashedImportParams(String name, HashAlgorithmIdentifier hash) | 
					
						
							|  |  |  |         : AlgorithmParams(move(name)) | 
					
						
							|  |  |  |         , hash(move(hash)) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     HashAlgorithmIdentifier hash; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     static JS::ThrowCompletionOr<NonnullOwnPtr<AlgorithmParams>> from_value(JS::VM&, JS::Value); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-14 23:07:13 -06:00
										 |  |  | // https://w3c.github.io/webcrypto/#dfn-RsaOaepParams
 | 
					
						
							|  |  |  | struct RsaOaepParams : public AlgorithmParams { | 
					
						
							|  |  |  |     virtual ~RsaOaepParams() override; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     RsaOaepParams(String name, ByteBuffer label) | 
					
						
							|  |  |  |         : AlgorithmParams(move(name)) | 
					
						
							|  |  |  |         , label(move(label)) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     ByteBuffer label; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     static JS::ThrowCompletionOr<NonnullOwnPtr<AlgorithmParams>> from_value(JS::VM&, JS::Value); | 
					
						
							|  |  |  | }; | 
					
						
							| 
									
										
										
										
											2024-03-27 01:34:04 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | // https://w3c.github.io/webcrypto/#dfn-EcdsaParams
 | 
					
						
							|  |  |  | struct EcdsaParams : public AlgorithmParams { | 
					
						
							|  |  |  |     virtual ~EcdsaParams() override; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     EcdsaParams(String name, HashAlgorithmIdentifier hash) | 
					
						
							|  |  |  |         : AlgorithmParams(move(name)) | 
					
						
							|  |  |  |         , hash(move(hash)) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     HashAlgorithmIdentifier hash; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     static JS::ThrowCompletionOr<NonnullOwnPtr<AlgorithmParams>> from_value(JS::VM&, JS::Value); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-27 01:27:42 +01:00
										 |  |  | // https://w3c.github.io/webcrypto/#dfn-EcKeyGenParams
 | 
					
						
							|  |  |  | struct EcKeyGenParams : public AlgorithmParams { | 
					
						
							|  |  |  |     virtual ~EcKeyGenParams() override; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     EcKeyGenParams(String name, NamedCurve named_curve) | 
					
						
							|  |  |  |         : AlgorithmParams(move(name)) | 
					
						
							|  |  |  |         , named_curve(move(named_curve)) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     NamedCurve named_curve; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     static JS::ThrowCompletionOr<NonnullOwnPtr<AlgorithmParams>> from_value(JS::VM&, JS::Value); | 
					
						
							|  |  |  | }; | 
					
						
							| 
									
										
										
										
											2024-03-14 23:07:13 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-25 10:38:33 +02:00
										 |  |  | // https://w3c.github.io/webcrypto/#dfn-AesKeyGenParams
 | 
					
						
							|  |  |  | struct AesKeyGenParams : public AlgorithmParams { | 
					
						
							|  |  |  |     virtual ~AesKeyGenParams() override; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     AesKeyGenParams(String name, u16 length) | 
					
						
							|  |  |  |         : AlgorithmParams(move(name)) | 
					
						
							|  |  |  |         , length(length) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     u16 length; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     static JS::ThrowCompletionOr<NonnullOwnPtr<AlgorithmParams>> from_value(JS::VM&, JS::Value); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // https://w3c.github.io/webcrypto/#dfn-AesDerivedKeyParams
 | 
					
						
							|  |  |  | struct AesDerivedKeyParams : public AlgorithmParams { | 
					
						
							|  |  |  |     virtual ~AesDerivedKeyParams() override; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     AesDerivedKeyParams(String name, u16 length) | 
					
						
							|  |  |  |         : AlgorithmParams(move(name)) | 
					
						
							|  |  |  |         , length(length) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     u16 length; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     static JS::ThrowCompletionOr<NonnullOwnPtr<AlgorithmParams>> from_value(JS::VM&, JS::Value); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-13 15:23:50 +01:00
										 |  |  | // https://w3c.github.io/webcrypto/#hmac-importparams
 | 
					
						
							|  |  |  | struct HmacImportParams : public AlgorithmParams { | 
					
						
							|  |  |  |     virtual ~HmacImportParams() override; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     HmacImportParams(String name, HashAlgorithmIdentifier hash, Optional<WebIDL::UnsignedLong> length) | 
					
						
							|  |  |  |         : AlgorithmParams(move(name)) | 
					
						
							|  |  |  |         , hash(move(hash)) | 
					
						
							|  |  |  |         , length(length) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     HashAlgorithmIdentifier hash; | 
					
						
							|  |  |  |     Optional<WebIDL::UnsignedLong> length; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     static JS::ThrowCompletionOr<NonnullOwnPtr<AlgorithmParams>> from_value(JS::VM&, JS::Value); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // https://w3c.github.io/webcrypto/#hmac-keygen-params
 | 
					
						
							|  |  |  | struct HmacKeyGenParams : public AlgorithmParams { | 
					
						
							|  |  |  |     virtual ~HmacKeyGenParams() override; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     HmacKeyGenParams(String name, HashAlgorithmIdentifier hash, Optional<WebIDL::UnsignedLong> length) | 
					
						
							|  |  |  |         : AlgorithmParams(move(name)) | 
					
						
							|  |  |  |         , hash(move(hash)) | 
					
						
							|  |  |  |         , length(length) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     HashAlgorithmIdentifier hash; | 
					
						
							|  |  |  |     Optional<WebIDL::UnsignedLong> length; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     static JS::ThrowCompletionOr<NonnullOwnPtr<AlgorithmParams>> from_value(JS::VM&, JS::Value); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-06 16:53:50 -07:00
										 |  |  | class AlgorithmMethods { | 
					
						
							|  |  |  | public: | 
					
						
							|  |  |  |     virtual ~AlgorithmMethods(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-15 04:01:23 +13:00
										 |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<JS::ArrayBuffer>> encrypt(AlgorithmParams const&, GC::Ref<CryptoKey>, ByteBuffer const&) | 
					
						
							| 
									
										
										
										
											2024-03-14 22:39:48 -06:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2024-10-12 20:56:21 +02:00
										 |  |  |         return WebIDL::NotSupportedError::create(m_realm, "encrypt is not supported"_string); | 
					
						
							| 
									
										
										
										
											2024-03-14 22:39:48 -06:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-15 04:01:23 +13:00
										 |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<JS::ArrayBuffer>> decrypt(AlgorithmParams const&, GC::Ref<CryptoKey>, ByteBuffer const&) | 
					
						
							| 
									
										
										
										
											2024-03-14 22:47:06 -06:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2024-10-12 20:56:21 +02:00
										 |  |  |         return WebIDL::NotSupportedError::create(m_realm, "decrypt is not supported"_string); | 
					
						
							| 
									
										
										
										
											2024-03-14 22:47:06 -06:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-15 04:01:23 +13:00
										 |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<JS::ArrayBuffer>> sign(AlgorithmParams const&, GC::Ref<CryptoKey>, ByteBuffer const&) | 
					
						
							| 
									
										
										
										
											2024-03-26 23:53:35 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2024-10-12 20:56:21 +02:00
										 |  |  |         return WebIDL::NotSupportedError::create(m_realm, "sign is not supported"_string); | 
					
						
							| 
									
										
										
										
											2024-03-26 23:53:35 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-15 04:01:23 +13:00
										 |  |  |     virtual WebIDL::ExceptionOr<JS::Value> verify(AlgorithmParams const&, GC::Ref<CryptoKey>, ByteBuffer const&, ByteBuffer const&) | 
					
						
							| 
									
										
										
										
											2024-03-27 01:50:25 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2024-10-12 20:56:21 +02:00
										 |  |  |         return WebIDL::NotSupportedError::create(m_realm, "verify is not supported"_string); | 
					
						
							| 
									
										
										
										
											2024-03-27 01:50:25 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-15 04:01:23 +13:00
										 |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<JS::ArrayBuffer>> digest(AlgorithmParams const&, ByteBuffer const&) | 
					
						
							| 
									
										
										
										
											2024-03-06 16:53:50 -07:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2024-10-12 20:56:21 +02:00
										 |  |  |         return WebIDL::NotSupportedError::create(m_realm, "digest is not supported"_string); | 
					
						
							| 
									
										
										
										
											2024-03-06 16:53:50 -07:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-15 04:01:23 +13:00
										 |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<JS::ArrayBuffer>> derive_bits(AlgorithmParams const&, GC::Ref<CryptoKey>, Optional<u32>) | 
					
						
							| 
									
										
										
										
											2024-03-27 19:15:49 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2024-10-12 20:56:21 +02:00
										 |  |  |         return WebIDL::NotSupportedError::create(m_realm, "deriveBits is not supported"_string); | 
					
						
							| 
									
										
										
										
											2024-03-27 19:15:49 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-15 04:01:23 +13:00
										 |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<CryptoKey>> import_key(AlgorithmParams const&, Bindings::KeyFormat, CryptoKey::InternalKeyData, bool, Vector<Bindings::KeyUsage> const&) | 
					
						
							| 
									
										
										
										
											2024-03-06 16:53:50 -07:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2024-10-12 20:56:21 +02:00
										 |  |  |         return WebIDL::NotSupportedError::create(m_realm, "importKey is not supported"_string); | 
					
						
							| 
									
										
										
										
											2024-03-06 16:53:50 -07:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-15 04:01:23 +13:00
										 |  |  |     virtual WebIDL::ExceptionOr<Variant<GC::Ref<CryptoKey>, GC::Ref<CryptoKeyPair>>> generate_key(AlgorithmParams const&, bool, Vector<Bindings::KeyUsage> const&) | 
					
						
							| 
									
										
										
										
											2024-03-06 19:15:03 -07:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2024-10-12 20:56:21 +02:00
										 |  |  |         return WebIDL::NotSupportedError::create(m_realm, "generateKey is not supported"_string); | 
					
						
							| 
									
										
										
										
											2024-03-06 19:15:03 -07:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-15 04:01:23 +13:00
										 |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<JS::Object>> export_key(Bindings::KeyFormat, GC::Ref<CryptoKey>) | 
					
						
							| 
									
										
										
										
											2024-03-13 21:19:57 -06:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2024-10-12 20:56:21 +02:00
										 |  |  |         return WebIDL::NotSupportedError::create(m_realm, "exportKey is not supported"_string); | 
					
						
							| 
									
										
										
										
											2024-03-13 21:19:57 -06:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-27 20:30:11 +01:00
										 |  |  |     virtual WebIDL::ExceptionOr<JS::Value> get_key_length(AlgorithmParams const&) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2024-10-12 20:56:21 +02:00
										 |  |  |         return WebIDL::NotSupportedError::create(m_realm, "getKeyLength is not supported"_string); | 
					
						
							| 
									
										
										
										
											2024-03-27 20:30:11 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-06 16:53:50 -07:00
										 |  |  |     static NonnullOwnPtr<AlgorithmMethods> create(JS::Realm& realm) { return adopt_own(*new AlgorithmMethods(realm)); } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | protected: | 
					
						
							|  |  |  |     explicit AlgorithmMethods(JS::Realm& realm) | 
					
						
							|  |  |  |         : m_realm(realm) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-15 04:01:23 +13:00
										 |  |  |     GC::Ref<JS::Realm> m_realm; | 
					
						
							| 
									
										
										
										
											2024-03-06 16:53:50 -07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-08 16:30:17 -07:00
										 |  |  | class RSAOAEP : public AlgorithmMethods { | 
					
						
							|  |  |  | public: | 
					
						
							| 
									
										
										
										
											2024-11-15 04:01:23 +13:00
										 |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<JS::ArrayBuffer>> encrypt(AlgorithmParams const&, GC::Ref<CryptoKey>, ByteBuffer const&) override; | 
					
						
							|  |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<JS::ArrayBuffer>> decrypt(AlgorithmParams const&, GC::Ref<CryptoKey>, ByteBuffer const&) override; | 
					
						
							| 
									
										
										
										
											2024-03-14 23:07:13 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-15 04:01:23 +13:00
										 |  |  |     virtual WebIDL::ExceptionOr<Variant<GC::Ref<CryptoKey>, GC::Ref<CryptoKeyPair>>> generate_key(AlgorithmParams const&, bool, Vector<Bindings::KeyUsage> const&) override; | 
					
						
							| 
									
										
										
										
											2024-03-14 21:57:32 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-15 04:01:23 +13:00
										 |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<CryptoKey>> import_key(AlgorithmParams const&, Bindings::KeyFormat, CryptoKey::InternalKeyData, bool, Vector<Bindings::KeyUsage> const&) override; | 
					
						
							|  |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<JS::Object>> export_key(Bindings::KeyFormat, GC::Ref<CryptoKey>) override; | 
					
						
							| 
									
										
										
										
											2024-03-08 16:30:17 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     static NonnullOwnPtr<AlgorithmMethods> create(JS::Realm& realm) { return adopt_own(*new RSAOAEP(realm)); } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							|  |  |  |     explicit RSAOAEP(JS::Realm& realm) | 
					
						
							|  |  |  |         : AlgorithmMethods(realm) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-25 05:58:30 +02:00
										 |  |  | class AesCbc : public AlgorithmMethods { | 
					
						
							|  |  |  | public: | 
					
						
							| 
									
										
										
										
											2024-11-15 04:01:23 +13:00
										 |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<JS::ArrayBuffer>> encrypt(AlgorithmParams const&, GC::Ref<CryptoKey>, ByteBuffer const&) override; | 
					
						
							|  |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<JS::ArrayBuffer>> decrypt(AlgorithmParams const&, GC::Ref<CryptoKey>, ByteBuffer const&) override; | 
					
						
							|  |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<CryptoKey>> import_key(AlgorithmParams const&, Bindings::KeyFormat, CryptoKey::InternalKeyData, bool, Vector<Bindings::KeyUsage> const&) override; | 
					
						
							|  |  |  |     virtual WebIDL::ExceptionOr<Variant<GC::Ref<CryptoKey>, GC::Ref<CryptoKeyPair>>> generate_key(AlgorithmParams const&, bool, Vector<Bindings::KeyUsage> const&) override; | 
					
						
							|  |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<JS::Object>> export_key(Bindings::KeyFormat, GC::Ref<CryptoKey>) override; | 
					
						
							| 
									
										
										
										
											2024-10-25 05:58:30 +02:00
										 |  |  |     virtual WebIDL::ExceptionOr<JS::Value> get_key_length(AlgorithmParams const&) override; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     static NonnullOwnPtr<AlgorithmMethods> create(JS::Realm& realm) { return adopt_own(*new AesCbc(realm)); } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							|  |  |  |     explicit AesCbc(JS::Realm& realm) | 
					
						
							|  |  |  |         : AlgorithmMethods(realm) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-30 22:44:20 +01:00
										 |  |  | class AesCtr : public AlgorithmMethods { | 
					
						
							|  |  |  | public: | 
					
						
							| 
									
										
										
										
											2024-11-15 04:01:23 +13:00
										 |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<CryptoKey>> import_key(AlgorithmParams const&, Bindings::KeyFormat, CryptoKey::InternalKeyData, bool, Vector<Bindings::KeyUsage> const&) override; | 
					
						
							|  |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<JS::Object>> export_key(Bindings::KeyFormat, GC::Ref<CryptoKey>) override; | 
					
						
							| 
									
										
										
										
											2024-10-30 22:53:47 +01:00
										 |  |  |     virtual WebIDL::ExceptionOr<JS::Value> get_key_length(AlgorithmParams const&) override; | 
					
						
							| 
									
										
										
										
											2024-11-15 04:01:23 +13:00
										 |  |  |     virtual WebIDL::ExceptionOr<Variant<GC::Ref<CryptoKey>, GC::Ref<CryptoKeyPair>>> generate_key(AlgorithmParams const&, bool, Vector<Bindings::KeyUsage> const&) override; | 
					
						
							|  |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<JS::ArrayBuffer>> encrypt(AlgorithmParams const&, GC::Ref<CryptoKey>, ByteBuffer const&) override; | 
					
						
							|  |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<JS::ArrayBuffer>> decrypt(AlgorithmParams const&, GC::Ref<CryptoKey>, ByteBuffer const&) override; | 
					
						
							| 
									
										
										
										
											2024-10-30 22:44:20 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     static NonnullOwnPtr<AlgorithmMethods> create(JS::Realm& realm) { return adopt_own(*new AesCtr(realm)); } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							|  |  |  |     explicit AesCtr(JS::Realm& realm) | 
					
						
							|  |  |  |         : AlgorithmMethods(realm) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-31 15:57:19 +01:00
										 |  |  | class AesGcm : public AlgorithmMethods { | 
					
						
							|  |  |  | public: | 
					
						
							|  |  |  |     virtual WebIDL::ExceptionOr<JS::Value> get_key_length(AlgorithmParams const&) override; | 
					
						
							| 
									
										
										
										
											2024-11-15 04:01:23 +13:00
										 |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<CryptoKey>> import_key(AlgorithmParams const&, Bindings::KeyFormat, CryptoKey::InternalKeyData, bool, Vector<Bindings::KeyUsage> const&) override; | 
					
						
							|  |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<JS::Object>> export_key(Bindings::KeyFormat, GC::Ref<CryptoKey>) override; | 
					
						
							|  |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<JS::ArrayBuffer>> encrypt(AlgorithmParams const&, GC::Ref<CryptoKey>, ByteBuffer const&) override; | 
					
						
							|  |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<JS::ArrayBuffer>> decrypt(AlgorithmParams const&, GC::Ref<CryptoKey>, ByteBuffer const&) override; | 
					
						
							|  |  |  |     virtual WebIDL::ExceptionOr<Variant<GC::Ref<CryptoKey>, GC::Ref<CryptoKeyPair>>> generate_key(AlgorithmParams const&, bool, Vector<Bindings::KeyUsage> const&) override; | 
					
						
							| 
									
										
										
										
											2024-10-31 15:57:19 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     static NonnullOwnPtr<AlgorithmMethods> create(JS::Realm& realm) { return adopt_own(*new AesGcm(realm)); } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							|  |  |  |     explicit AesGcm(JS::Realm& realm) | 
					
						
							|  |  |  |         : AlgorithmMethods(realm) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-20 06:10:36 +02:00
										 |  |  | class HKDF : public AlgorithmMethods { | 
					
						
							|  |  |  | public: | 
					
						
							| 
									
										
										
										
											2024-11-15 04:01:23 +13:00
										 |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<CryptoKey>> import_key(AlgorithmParams const&, Bindings::KeyFormat, CryptoKey::InternalKeyData, bool, Vector<Bindings::KeyUsage> const&) override; | 
					
						
							|  |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<JS::ArrayBuffer>> derive_bits(AlgorithmParams const&, GC::Ref<CryptoKey>, Optional<u32>) override; | 
					
						
							| 
									
										
										
										
											2024-10-20 06:10:36 +02:00
										 |  |  |     virtual WebIDL::ExceptionOr<JS::Value> get_key_length(AlgorithmParams const&) override; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     static NonnullOwnPtr<AlgorithmMethods> create(JS::Realm& realm) { return adopt_own(*new HKDF(realm)); } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							|  |  |  |     explicit HKDF(JS::Realm& realm) | 
					
						
							|  |  |  |         : AlgorithmMethods(realm) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-06 16:53:50 -07:00
										 |  |  | class PBKDF2 : public AlgorithmMethods { | 
					
						
							|  |  |  | public: | 
					
						
							| 
									
										
										
										
											2024-11-15 04:01:23 +13:00
										 |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<CryptoKey>> import_key(AlgorithmParams const&, Bindings::KeyFormat, CryptoKey::InternalKeyData, bool, Vector<Bindings::KeyUsage> const&) override; | 
					
						
							|  |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<JS::ArrayBuffer>> derive_bits(AlgorithmParams const&, GC::Ref<CryptoKey>, Optional<u32>) override; | 
					
						
							| 
									
										
										
										
											2024-03-27 20:30:11 +01:00
										 |  |  |     virtual WebIDL::ExceptionOr<JS::Value> get_key_length(AlgorithmParams const&) override; | 
					
						
							| 
									
										
										
										
											2024-03-06 16:53:50 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     static NonnullOwnPtr<AlgorithmMethods> create(JS::Realm& realm) { return adopt_own(*new PBKDF2(realm)); } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							|  |  |  |     explicit PBKDF2(JS::Realm& realm) | 
					
						
							|  |  |  |         : AlgorithmMethods(realm) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class SHA : public AlgorithmMethods { | 
					
						
							|  |  |  | public: | 
					
						
							| 
									
										
										
										
											2024-11-15 04:01:23 +13:00
										 |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<JS::ArrayBuffer>> digest(AlgorithmParams const&, ByteBuffer const&) override; | 
					
						
							| 
									
										
										
										
											2024-03-06 16:53:50 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     static NonnullOwnPtr<AlgorithmMethods> create(JS::Realm& realm) { return adopt_own(*new SHA(realm)); } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							|  |  |  |     explicit SHA(JS::Realm& realm) | 
					
						
							|  |  |  |         : AlgorithmMethods(realm) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-27 01:27:42 +01:00
										 |  |  | class ECDSA : public AlgorithmMethods { | 
					
						
							|  |  |  | public: | 
					
						
							| 
									
										
										
										
											2024-11-15 04:01:23 +13:00
										 |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<JS::ArrayBuffer>> sign(AlgorithmParams const&, GC::Ref<CryptoKey>, ByteBuffer const&) override; | 
					
						
							|  |  |  |     virtual WebIDL::ExceptionOr<JS::Value> verify(AlgorithmParams const&, GC::Ref<CryptoKey>, ByteBuffer const&, ByteBuffer const&) override; | 
					
						
							| 
									
										
										
										
											2024-03-27 01:34:04 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-15 04:01:23 +13:00
										 |  |  |     virtual WebIDL::ExceptionOr<Variant<GC::Ref<CryptoKey>, GC::Ref<CryptoKeyPair>>> generate_key(AlgorithmParams const&, bool, Vector<Bindings::KeyUsage> const&) override; | 
					
						
							| 
									
										
										
										
											2024-03-27 01:27:42 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     static NonnullOwnPtr<AlgorithmMethods> create(JS::Realm& realm) { return adopt_own(*new ECDSA(realm)); } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							|  |  |  |     explicit ECDSA(JS::Realm& realm) | 
					
						
							|  |  |  |         : AlgorithmMethods(realm) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-17 18:14:13 +01:00
										 |  |  | class ECDH : public AlgorithmMethods { | 
					
						
							|  |  |  | public: | 
					
						
							|  |  |  |     virtual WebIDL::ExceptionOr<Variant<GC::Ref<CryptoKey>, GC::Ref<CryptoKeyPair>>> generate_key(AlgorithmParams const&, bool, Vector<Bindings::KeyUsage> const&) override; | 
					
						
							|  |  |  |     // TODO: virtual WebIDL::ExceptionOr<GC::Ref<JS::Object>> export_key(Bindings::KeyFormat, GC::Ref<CryptoKey>) override;
 | 
					
						
							| 
									
										
										
										
											2024-11-26 19:46:04 +01:00
										 |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<CryptoKey>> import_key(AlgorithmParams const&, Bindings::KeyFormat, CryptoKey::InternalKeyData, bool, Vector<Bindings::KeyUsage> const&) override; | 
					
						
							| 
									
										
										
										
											2024-11-26 19:22:05 +01:00
										 |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<JS::ArrayBuffer>> derive_bits(AlgorithmParams const&, GC::Ref<CryptoKey>, Optional<u32>) override; | 
					
						
							| 
									
										
										
										
											2024-11-17 18:14:13 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     static NonnullOwnPtr<AlgorithmMethods> create(JS::Realm& realm) { return adopt_own(*new ECDH(realm)); } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							|  |  |  |     explicit ECDH(JS::Realm& realm) | 
					
						
							|  |  |  |         : AlgorithmMethods(realm) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-31 23:04:12 +02:00
										 |  |  | class ED25519 : public AlgorithmMethods { | 
					
						
							|  |  |  | public: | 
					
						
							| 
									
										
										
										
											2024-11-15 04:01:23 +13:00
										 |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<JS::ArrayBuffer>> sign(AlgorithmParams const&, GC::Ref<CryptoKey>, ByteBuffer const&) override; | 
					
						
							|  |  |  |     virtual WebIDL::ExceptionOr<JS::Value> verify(AlgorithmParams const&, GC::Ref<CryptoKey>, ByteBuffer const&, ByteBuffer const&) override; | 
					
						
							| 
									
										
										
										
											2024-03-31 23:05:05 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-15 04:01:23 +13:00
										 |  |  |     virtual WebIDL::ExceptionOr<Variant<GC::Ref<CryptoKey>, GC::Ref<CryptoKeyPair>>> generate_key(AlgorithmParams const&, bool, Vector<Bindings::KeyUsage> const&) override; | 
					
						
							| 
									
										
										
										
											2024-11-24 20:21:51 +01:00
										 |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<CryptoKey>> import_key(AlgorithmParams const&, Bindings::KeyFormat, CryptoKey::InternalKeyData, bool, Vector<Bindings::KeyUsage> const&) override; | 
					
						
							| 
									
										
										
										
											2024-11-24 20:48:46 +01:00
										 |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<JS::Object>> export_key(Bindings::KeyFormat, GC::Ref<CryptoKey>) override; | 
					
						
							| 
									
										
										
										
											2024-03-31 23:04:12 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     static NonnullOwnPtr<AlgorithmMethods> create(JS::Realm& realm) { return adopt_own(*new ED25519(realm)); } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							|  |  |  |     explicit ED25519(JS::Realm& realm) | 
					
						
							|  |  |  |         : AlgorithmMethods(realm) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-26 19:57:59 +02:00
										 |  |  | class X25519 : public AlgorithmMethods { | 
					
						
							|  |  |  | public: | 
					
						
							| 
									
										
										
										
											2024-11-15 04:01:23 +13:00
										 |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<JS::ArrayBuffer>> derive_bits(AlgorithmParams const&, GC::Ref<CryptoKey>, Optional<u32>) override; | 
					
						
							|  |  |  |     virtual WebIDL::ExceptionOr<Variant<GC::Ref<CryptoKey>, GC::Ref<CryptoKeyPair>>> generate_key(AlgorithmParams const&, bool, Vector<Bindings::KeyUsage> const&) override; | 
					
						
							|  |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<CryptoKey>> import_key(AlgorithmParams const&, Bindings::KeyFormat, CryptoKey::InternalKeyData, bool, Vector<Bindings::KeyUsage> const&) override; | 
					
						
							|  |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<JS::Object>> export_key(Bindings::KeyFormat, GC::Ref<CryptoKey>) override; | 
					
						
							| 
									
										
										
										
											2024-10-26 19:57:59 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     static NonnullOwnPtr<AlgorithmMethods> create(JS::Realm& realm) { return adopt_own(*new X25519(realm)); } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							|  |  |  |     explicit X25519(JS::Realm& realm) | 
					
						
							|  |  |  |         : AlgorithmMethods(realm) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-25 11:18:05 +01:00
										 |  |  | class X448 : public AlgorithmMethods { | 
					
						
							|  |  |  | public: | 
					
						
							| 
									
										
										
										
											2024-11-25 15:56:40 +01:00
										 |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<JS::ArrayBuffer>> derive_bits(AlgorithmParams const&, GC::Ref<CryptoKey>, Optional<u32>) override; | 
					
						
							| 
									
										
										
										
											2024-11-25 11:18:05 +01:00
										 |  |  |     virtual WebIDL::ExceptionOr<Variant<GC::Ref<CryptoKey>, GC::Ref<CryptoKeyPair>>> generate_key(AlgorithmParams const&, bool, Vector<Bindings::KeyUsage> const&) override; | 
					
						
							| 
									
										
										
										
											2024-11-25 15:46:21 +01:00
										 |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<CryptoKey>> import_key(AlgorithmParams const&, Bindings::KeyFormat, CryptoKey::InternalKeyData, bool, Vector<Bindings::KeyUsage> const&) override; | 
					
						
							| 
									
										
										
										
											2024-11-25 11:35:09 +01:00
										 |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<JS::Object>> export_key(Bindings::KeyFormat, GC::Ref<CryptoKey>) override; | 
					
						
							| 
									
										
										
										
											2024-11-25 11:18:05 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     static NonnullOwnPtr<AlgorithmMethods> create(JS::Realm& realm) { return adopt_own(*new X448(realm)); } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							|  |  |  |     explicit X448(JS::Realm& realm) | 
					
						
							|  |  |  |         : AlgorithmMethods(realm) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-13 15:23:50 +01:00
										 |  |  | class HMAC : public AlgorithmMethods { | 
					
						
							|  |  |  | public: | 
					
						
							| 
									
										
										
										
											2024-11-15 04:01:23 +13:00
										 |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<JS::ArrayBuffer>> sign(AlgorithmParams const&, GC::Ref<CryptoKey>, ByteBuffer const&) override; | 
					
						
							|  |  |  |     virtual WebIDL::ExceptionOr<JS::Value> verify(AlgorithmParams const&, GC::Ref<CryptoKey>, ByteBuffer const&, ByteBuffer const&) override; | 
					
						
							|  |  |  |     virtual WebIDL::ExceptionOr<Variant<GC::Ref<CryptoKey>, GC::Ref<CryptoKeyPair>>> generate_key(AlgorithmParams const&, bool, Vector<Bindings::KeyUsage> const&) override; | 
					
						
							|  |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<CryptoKey>> import_key(AlgorithmParams const&, Bindings::KeyFormat, CryptoKey::InternalKeyData, bool, Vector<Bindings::KeyUsage> const&) override; | 
					
						
							|  |  |  |     virtual WebIDL::ExceptionOr<GC::Ref<JS::Object>> export_key(Bindings::KeyFormat, GC::Ref<CryptoKey>) override; | 
					
						
							| 
									
										
										
										
											2024-11-13 15:23:50 +01:00
										 |  |  |     virtual WebIDL::ExceptionOr<JS::Value> get_key_length(AlgorithmParams const&) override; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     static NonnullOwnPtr<AlgorithmMethods> create(JS::Realm& realm) { return adopt_own(*new HMAC(realm)); } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							|  |  |  |     explicit HMAC(JS::Realm& realm) | 
					
						
							|  |  |  |         : AlgorithmMethods(realm) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-10-26 19:57:59 +02:00
										 |  |  | struct EcdhKeyDerivePrams : public AlgorithmParams { | 
					
						
							|  |  |  |     virtual ~EcdhKeyDerivePrams() override; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     EcdhKeyDerivePrams(String name, CryptoKey& public_key) | 
					
						
							|  |  |  |         : AlgorithmParams(move(name)) | 
					
						
							|  |  |  |         , public_key(public_key) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-15 04:01:23 +13:00
										 |  |  |     GC::Ref<CryptoKey> public_key; | 
					
						
							| 
									
										
										
										
											2024-10-26 19:57:59 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     static JS::ThrowCompletionOr<NonnullOwnPtr<AlgorithmParams>> from_value(JS::VM&, JS::Value); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-11-26 17:53:33 +01:00
										 |  |  | struct EcKeyImportParams : public AlgorithmParams { | 
					
						
							|  |  |  |     virtual ~EcKeyImportParams() override; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     EcKeyImportParams(String name, String named_curve) | 
					
						
							|  |  |  |         : AlgorithmParams(move(name)) | 
					
						
							|  |  |  |         , named_curve(move(named_curve)) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     String named_curve; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     static JS::ThrowCompletionOr<NonnullOwnPtr<AlgorithmParams>> from_value(JS::VM&, JS::Value); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-13 21:19:57 -06:00
										 |  |  | ErrorOr<String> base64_url_uint_encode(::Crypto::UnsignedBigInteger); | 
					
						
							| 
									
										
										
										
											2024-10-25 05:58:30 +02:00
										 |  |  | WebIDL::ExceptionOr<ByteBuffer> base64_url_bytes_decode(JS::Realm&, String const& base64_url_string); | 
					
						
							| 
									
										
										
										
											2024-03-14 21:57:32 -06:00
										 |  |  | WebIDL::ExceptionOr<::Crypto::UnsignedBigInteger> base64_url_uint_decode(JS::Realm&, String const& base64_url_string); | 
					
						
							| 
									
										
										
										
											2024-03-13 21:19:57 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-06 16:53:50 -07:00
										 |  |  | } |