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();
|
2024-11-27 21:17:07 +01:00
|
|
|
explicit AlgorithmParams()
|
2024-03-13 21:26:00 -06:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2024-11-27 21:17:07 +01:00
|
|
|
// NOTE: this is initialized when normalizing the algorithm name as the spec requests.
|
|
|
|
// It must not be set in `from_value`.
|
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;
|
2024-11-27 21:17:07 +01:00
|
|
|
AesCbcParams(ByteBuffer iv)
|
|
|
|
: iv(move(iv))
|
2024-10-25 05:58:30 +02:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
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;
|
2024-11-27 21:17:07 +01:00
|
|
|
AesCtrParams(ByteBuffer counter, u8 length)
|
|
|
|
: counter(move(counter))
|
2024-10-30 23:53:48 +01:00
|
|
|
, 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;
|
2024-11-27 21:17:07 +01:00
|
|
|
AesGcmParams(ByteBuffer iv, Optional<ByteBuffer> additional_data, Optional<u8> tag_length)
|
|
|
|
: iv(move(iv))
|
2024-10-31 16:29:39 +01:00
|
|
|
, 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;
|
2024-11-27 21:17:07 +01:00
|
|
|
HKDFParams(HashAlgorithmIdentifier hash, ByteBuffer salt, ByteBuffer info)
|
|
|
|
: hash(move(hash))
|
2024-10-20 06:10:36 +02:00
|
|
|
, 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-11-27 21:17:07 +01:00
|
|
|
PBKDF2Params(ByteBuffer salt, u32 iterations, HashAlgorithmIdentifier hash)
|
|
|
|
: salt(move(salt))
|
2024-03-13 21:26:00 -06:00
|
|
|
, 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;
|
|
|
|
|
2024-11-27 21:17:07 +01:00
|
|
|
RsaKeyGenParams(u32 modulus_length, ::Crypto::UnsignedBigInteger public_exponent)
|
|
|
|
: modulus_length(modulus_length)
|
2024-03-13 21:26:00 -06:00
|
|
|
, 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;
|
|
|
|
|
2024-11-27 21:17:07 +01:00
|
|
|
RsaHashedKeyGenParams(u32 modulus_length, ::Crypto::UnsignedBigInteger public_exponent, HashAlgorithmIdentifier hash)
|
|
|
|
: RsaKeyGenParams(modulus_length, move(public_exponent))
|
2024-03-13 21:26:00 -06:00
|
|
|
, 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;
|
|
|
|
|
2024-11-27 21:17:07 +01:00
|
|
|
RsaHashedImportParams(HashAlgorithmIdentifier hash)
|
|
|
|
: hash(move(hash))
|
2024-03-14 21:57:32 -06:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
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;
|
|
|
|
|
2024-11-27 21:17:07 +01:00
|
|
|
RsaOaepParams(ByteBuffer label)
|
|
|
|
: label(move(label))
|
2024-03-14 23:07:13 -06:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
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;
|
|
|
|
|
2024-11-27 21:17:07 +01:00
|
|
|
EcdsaParams(HashAlgorithmIdentifier hash)
|
|
|
|
: hash(move(hash))
|
2024-03-27 01:34:04 +01:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
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;
|
|
|
|
|
2024-11-27 21:17:07 +01:00
|
|
|
EcKeyGenParams(NamedCurve named_curve)
|
|
|
|
: named_curve(move(named_curve))
|
2024-03-27 01:27:42 +01:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
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;
|
|
|
|
|
2024-11-27 21:17:07 +01:00
|
|
|
AesKeyGenParams(u16 length)
|
|
|
|
: length(length)
|
2024-10-25 10:38:33 +02:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
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;
|
|
|
|
|
2024-11-27 21:17:07 +01:00
|
|
|
AesDerivedKeyParams(u16 length)
|
|
|
|
: length(length)
|
2024-10-25 10:38:33 +02:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
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;
|
|
|
|
|
2024-11-27 21:17:07 +01:00
|
|
|
HmacImportParams(HashAlgorithmIdentifier hash, Optional<WebIDL::UnsignedLong> length)
|
|
|
|
: hash(move(hash))
|
2024-11-13 15:23:50 +01:00
|
|
|
, 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;
|
|
|
|
|
2024-11-27 21:17:07 +01:00
|
|
|
HmacKeyGenParams(HashAlgorithmIdentifier hash, Optional<WebIDL::UnsignedLong> length)
|
|
|
|
: hash(move(hash))
|
2024-11-13 15:23:50 +01:00
|
|
|
, 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-12-14 12:23:52 +01:00
|
|
|
virtual WebIDL::ExceptionOr<GC::Ref<JS::ArrayBuffer>> wrap_key(AlgorithmParams const&, GC::Ref<CryptoKey>, ByteBuffer const&)
|
|
|
|
{
|
|
|
|
return WebIDL::NotSupportedError::create(m_realm, "wrapKey is not supported"_string);
|
|
|
|
}
|
|
|
|
|
|
|
|
virtual WebIDL::ExceptionOr<GC::Ref<JS::ArrayBuffer>> unwrap_key(AlgorithmParams const&, GC::Ref<CryptoKey>, ByteBuffer const&)
|
|
|
|
{
|
|
|
|
return WebIDL::NotSupportedError::create(m_realm, "unwwrapKey is not supported"_string);
|
|
|
|
}
|
|
|
|
|
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-12-16 19:38:10 +01:00
|
|
|
class AesKw : public AlgorithmMethods {
|
|
|
|
public:
|
|
|
|
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<JS::Value> get_key_length(AlgorithmParams 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::ArrayBuffer>> wrap_key(AlgorithmParams const&, GC::Ref<CryptoKey>, ByteBuffer const&) override;
|
|
|
|
virtual WebIDL::ExceptionOr<GC::Ref<JS::ArrayBuffer>> unwrap_key(AlgorithmParams const&, GC::Ref<CryptoKey>, ByteBuffer const&) override;
|
|
|
|
|
|
|
|
static NonnullOwnPtr<AlgorithmMethods> create(JS::Realm& realm) { return adopt_own(*new AesKw(realm)); }
|
|
|
|
|
|
|
|
private:
|
|
|
|
explicit AesKw(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-12-02 17:36:21 +01: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-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;
|
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 20:26:48 +01:00
|
|
|
virtual WebIDL::ExceptionOr<GC::Ref<JS::Object>> export_key(Bindings::KeyFormat, GC::Ref<CryptoKey>) 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-12-21 14:45:29 +01:00
|
|
|
class ED448 : public AlgorithmMethods {
|
|
|
|
public:
|
|
|
|
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;
|
|
|
|
|
|
|
|
static NonnullOwnPtr<AlgorithmMethods> create(JS::Realm& realm) { return adopt_own(*new ED448(realm)); }
|
|
|
|
|
|
|
|
private:
|
|
|
|
explicit ED448(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-11-27 20:31:37 +01:00
|
|
|
struct EcdhKeyDeriveParams : public AlgorithmParams {
|
|
|
|
virtual ~EcdhKeyDeriveParams() override;
|
2024-10-26 19:57:59 +02:00
|
|
|
|
2024-11-27 21:17:07 +01:00
|
|
|
EcdhKeyDeriveParams(CryptoKey& public_key)
|
|
|
|
: public_key(public_key)
|
2024-10-26 19:57:59 +02:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
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;
|
|
|
|
|
2024-11-27 21:17:07 +01:00
|
|
|
EcKeyImportParams(String named_curve)
|
|
|
|
: named_curve(move(named_curve))
|
2024-11-26 17:53:33 +01:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
String named_curve;
|
|
|
|
|
|
|
|
static JS::ThrowCompletionOr<NonnullOwnPtr<AlgorithmParams>> from_value(JS::VM&, JS::Value);
|
|
|
|
};
|
|
|
|
|
2024-12-21 14:45:29 +01:00
|
|
|
// https://wicg.github.io/webcrypto-secure-curves/#dfn-Ed448Params
|
|
|
|
struct Ed448Params : public AlgorithmParams {
|
|
|
|
virtual ~Ed448Params() override;
|
|
|
|
|
|
|
|
Ed448Params(Optional<ByteBuffer>& context)
|
|
|
|
: context(context)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
Optional<ByteBuffer> context;
|
|
|
|
|
|
|
|
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
|
|
|
}
|