2021-12-13 22:09:55 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								/*
  
						 
					
						
							
								
									
										
										
										
											2022-08-22 18:31:08 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 *  Copyright  ( c )  2021 - 2022 ,  Linus  Groh  < linusg @ serenityos . org > 
							 
						 
					
						
							
								
									
										
										
										
											2023-12-15 21:05:09 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 *  Copyright  ( c )  2023 ,  stelar7  < dudedbz @ gmail . com > 
							 
						 
					
						
							
								
									
										
										
										
											2021-12-13 22:09:55 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								 * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  SPDX - License - Identifier :  BSD - 2 - Clause 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 */ 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-06 19:11:08 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <AK/QuickSort.h> 
  
						 
					
						
							
								
									
										
										
										
											2021-12-13 22:09:55 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								# include  <LibCrypto/Hash/HashManager.h> 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# include  <LibJS/Runtime/ArrayBuffer.h> 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# include  <LibJS/Runtime/Promise.h> 
  
						 
					
						
							
								
									
										
										
										
											2024-01-23 11:52:15 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/Bindings/ExceptionOrUtils.h> 
  
						 
					
						
							
								
									
										
										
											
												LibWeb: Remove unecessary dependence on Window from assorted classes
These classes only needed Window to get at its realm. Pass a realm
directly to construct Crypto, Encoding, HRT, IntersectionObserver,
NavigationTiming, Page, RequestIdleCallback, Selection, Streams, URL,
and XML classes.
											 
										 
										
											2022-09-25 18:11:21 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/Bindings/Intrinsics.h> 
  
						 
					
						
							
								
									
										
										
										
											2024-04-27 12:09:58 +12:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/Bindings/SubtleCryptoPrototype.h> 
  
						 
					
						
							
								
									
										
										
										
											2024-03-13 21:19:57 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/Crypto/KeyAlgorithms.h> 
  
						 
					
						
							
								
									
										
										
										
											2021-12-13 22:09:55 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								# include  <LibWeb/Crypto/SubtleCrypto.h> 
  
						 
					
						
							
								
									
										
										
										
											2024-01-23 11:52:15 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/HTML/Scripting/TemporaryExecutionContext.h> 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# include  <LibWeb/Platform/EventLoopPlugin.h> 
  
						 
					
						
							
								
									
										
										
										
											2022-09-24 16:14:37 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/WebIDL/AbstractOperations.h> 
  
						 
					
						
							
								
									
										
										
										
											2023-11-23 20:07:25 +13:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/WebIDL/Buffers.h> 
  
						 
					
						
							
								
									
										
										
										
											2023-02-12 21:25:57 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/WebIDL/ExceptionOr.h> 
  
						 
					
						
							
								
									
										
										
										
											2024-01-23 11:52:15 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								# include  <LibWeb/WebIDL/Promise.h> 
  
						 
					
						
							
								
									
										
										
										
											2021-12-13 22:09:55 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								namespace  Web : : Crypto  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-06 19:11:08 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								static  void  normalize_key_usages ( Vector < Bindings : : KeyUsage > &  key_usages )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    quick_sort ( key_usages ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
									
										
										
										
											2024-03-14 21:52:17 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								struct  RegisteredAlgorithm  {  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    NonnullOwnPtr < AlgorithmMethods >  ( * create_methods ) ( JS : : Realm & )  =  nullptr ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    JS : : ThrowCompletionOr < NonnullOwnPtr < AlgorithmParams > >  ( * parameter_from_value ) ( JS : : VM & ,  JS : : Value )  =  nullptr ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								} ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								using  SupportedAlgorithmsMap  =  HashMap < String ,  HashMap < String ,  RegisteredAlgorithm ,  AK : : ASCIICaseInsensitiveStringTraits > > ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  SupportedAlgorithmsMap &  supported_algorithms_internal ( ) ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  SupportedAlgorithmsMap  supported_algorithms ( ) ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								template < typename  Methods ,  typename  Param  =  AlgorithmParams >  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								static  void  define_an_algorithm ( String  op ,  String  algorithm ) ;  
						 
					
						
							
								
									
										
										
										
											2024-03-06 19:11:08 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-11-19 19:47:52 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								JS_DEFINE_ALLOCATOR ( SubtleCrypto ) ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-08-13 13:05:26 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								JS : : NonnullGCPtr < SubtleCrypto >  SubtleCrypto : : create ( JS : : Realm &  realm )  
						 
					
						
							
								
									
										
										
										
											2022-09-03 19:59:53 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
									
										
										
										
											2023-08-13 13:05:26 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    return  realm . heap ( ) . allocate < SubtleCrypto > ( realm ,  realm ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-09-03 19:59:53 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
											
												LibWeb: Remove unecessary dependence on Window from assorted classes
These classes only needed Window to get at its realm. Pass a realm
directly to construct Crypto, Encoding, HRT, IntersectionObserver,
NavigationTiming, Page, RequestIdleCallback, Selection, Streams, URL,
and XML classes.
											 
										 
										
											2022-09-25 18:11:21 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								SubtleCrypto : : SubtleCrypto ( JS : : Realm &  realm )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    :  PlatformObject ( realm ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-09-03 19:59:53 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								SubtleCrypto : : ~ SubtleCrypto ( )  =  default ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-08-07 08:41:28 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								void  SubtleCrypto : : initialize ( JS : : Realm &  realm )  
						 
					
						
							
								
									
										
										
										
											2023-01-10 06:28:20 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
									
										
										
										
											2023-08-07 08:41:28 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    Base : : initialize ( realm ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-16 13:13:08 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    WEB_SET_PROTOTYPE_FOR_INTERFACE ( SubtleCrypto ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-01-10 06:28:20 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-12-14 00:38:14 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								// https://w3c.github.io/webcrypto/#dfn-normalize-an-algorithm
  
						 
					
						
							
								
									
										
										
										
											2024-03-14 21:52:17 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								WebIDL : : ExceptionOr < NormalizedAlgorithmAndParameter >  normalize_an_algorithm ( JS : : Realm &  realm ,  AlgorithmIdentifier  const &  algorithm ,  String  operation )  
						 
					
						
							
								
									
										
										
										
											2023-12-14 00:38:14 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
									
										
										
										
											2024-03-14 21:52:17 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    auto &  vm  =  realm . vm ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-12-14 00:38:14 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // If alg is an instance of a DOMString:
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  ( algorithm . has < String > ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // Return the result of running the normalize an algorithm algorithm,
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // with the alg set to a new Algorithm dictionary whose name attribute is alg, and with the op set to op.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  dictionary  =  JS : : make_handle ( JS : : Object : : create ( realm ,  realm . intrinsics ( ) . object_prototype ( ) ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-06 16:53:50 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        TRY ( dictionary - > create_data_property ( " name " ,  JS : : PrimitiveString : : create ( vm ,  algorithm . get < String > ( ) ) ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-12-14 00:38:14 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-14 21:52:17 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        return  normalize_an_algorithm ( realm ,  dictionary ,  operation ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-12-14 00:38:14 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // If alg is an object:
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 1. Let registeredAlgorithms be the associative container stored at the op key of supportedAlgorithms.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // NOTE: There should always be a container at the op key.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  internal_object  =  supported_algorithms ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  maybe_registered_algorithms  =  internal_object . get ( operation ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  registered_algorithms  =  maybe_registered_algorithms . value ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 2. Let initialAlg be the result of converting the ECMAScript object represented by alg to
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // the IDL dictionary type Algorithm, as defined by [WebIDL].
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 3. If an error occurred, return the error and terminate this algorithm.
 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-06 16:53:50 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    // Note: We're not going to bother creating an Algorithm object, all we want is the name attribute so that we can
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    //       fetch the actual algorithm factory from the registeredAlgorithms map.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  initial_algorithm  =  TRY ( algorithm . get < JS : : Handle < JS : : Object > > ( ) - > get ( " name " ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-12-14 00:38:14 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 4. Let algName be the value of the name attribute of initialAlg.
 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-06 16:53:50 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    auto  algorithm_name  =  TRY ( initial_algorithm . to_string ( vm ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-12-14 00:38:14 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-06 16:53:50 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    RegisteredAlgorithm  desired_type ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-12-14 00:38:14 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 5. If registeredAlgorithms contains a key that is a case-insensitive string match for algName:
 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-06 16:53:50 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    if  ( auto  it  =  registered_algorithms . find ( algorithm_name ) ;  it  ! =  registered_algorithms . end ( ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2023-12-14 00:38:14 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        // 1. Set algName to the value of the matching key.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 2. Let desiredType be the IDL dictionary type stored at algName in registeredAlgorithms.
 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-06 16:53:50 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        desired_type  =  it - > value ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-12-14 00:38:14 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    }  else  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // Otherwise:
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // Return a new NotSupportedError and terminate this algorithm.
 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-27 19:24:33 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        return  WebIDL : : NotSupportedError : : create ( realm ,  MUST ( String : : formatted ( " Algorithm '{}' is not supported for operation '{}' " ,  algorithm_name ,  operation ) ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-12-14 00:38:14 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 8. Let normalizedAlgorithm be the result of converting the ECMAScript object represented by alg
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // to the IDL dictionary type desiredType, as defined by [WebIDL].
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 9. Set the name attribute of normalizedAlgorithm to algName.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 10. If an error occurred, return the error and terminate this algorithm.
 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-06 16:53:50 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    // 11. Let dictionaries be a list consisting of the IDL dictionary type desiredType
 
							 
						 
					
						
							
								
									
										
										
										
											2023-12-14 00:38:14 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    // and all of desiredType's inherited dictionaries, in order from least to most derived.
 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-06 16:53:50 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    // 12. For each dictionary dictionary in dictionaries:
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    //    Note: All of these steps are handled by the create_methods and parameter_from_value methods.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  methods  =  desired_type . create_methods ( realm ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  parameter  =  TRY ( desired_type . parameter_from_value ( vm ,  algorithm . get < JS : : Handle < JS : : Object > > ( ) ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  normalized_algorithm  =  NormalizedAlgorithmAndParameter  {  move ( methods ) ,  move ( parameter )  } ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-12-14 00:38:14 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 13. Return normalizedAlgorithm.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return  normalized_algorithm ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-14 22:39:48 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								// https://w3c.github.io/webcrypto/#dfn-SubtleCrypto-method-encrypt
  
						 
					
						
							
								
									
										
										
										
											2024-10-25 12:38:19 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								JS : : NonnullGCPtr < WebIDL : : Promise >  SubtleCrypto : : encrypt ( AlgorithmIdentifier  const &  algorithm ,  JS : : NonnullGCPtr < CryptoKey >  key ,  JS : : Handle < WebIDL : : BufferSource >  const &  data_parameter )  
						 
					
						
							
								
									
										
										
										
											2024-03-14 22:39:48 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto &  realm  =  this - > realm ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto &  vm  =  this - > vm ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 1. Let algorithm and key be the algorithm and key parameters passed to the encrypt() method, respectively.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 2. Let data be the result of getting a copy of the bytes held by the data parameter passed to the encrypt() method.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  data_or_error  =  WebIDL : : get_buffer_source_copy ( * data_parameter - > raw_object ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  ( data_or_error . is_error ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        VERIFY ( data_or_error . error ( ) . code ( )  = =  ENOMEM ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  WebIDL : : create_rejected_promise_from_exception ( realm ,  vm . throw_completion < JS : : InternalError > ( vm . error_message ( JS : : VM : : ErrorMessage : : OutOfMemory ) ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  data  =  data_or_error . release_value ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 3. Let normalizedAlgorithm be the result of normalizing an algorithm, with alg set to algorithm and op set to "encrypt".
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  normalized_algorithm  =  normalize_an_algorithm ( realm ,  algorithm ,  " encrypt " _string ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 4. If an error occurred, return a Promise rejected with normalizedAlgorithm.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  ( normalized_algorithm . is_error ( ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  WebIDL : : create_rejected_promise_from_exception ( realm ,  normalized_algorithm . release_error ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 5. Let promise be a new Promise.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  promise  =  WebIDL : : create_promise ( realm ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 6. Return promise and perform the remaining steps in parallel.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-10-31 02:39:29 +13:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    Platform : : EventLoopPlugin : : the ( ) . deferred_invoke ( JS : : create_heap_function ( realm . heap ( ) ,  [ & realm ,  normalized_algorithm  =  normalized_algorithm . release_value ( ) ,  promise ,  key ,  data  =  move ( data ) ] ( )  - >  void  { 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-14 22:39:48 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        HTML : : TemporaryExecutionContext  context ( Bindings : : host_defined_environment_settings_object ( realm ) ,  HTML : : TemporaryExecutionContext : : CallbacksEnabled : : Yes ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 7. If the following steps or referenced procedures say to throw an error, reject promise with the returned error and then terminate the algorithm.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 8. If the name member of normalizedAlgorithm is not equal to the name attribute of the [[algorithm]] internal slot of key then throw an InvalidAccessError.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( normalized_algorithm . parameter - > name  ! =  key - > algorithm_name ( ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-12 20:56:21 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            WebIDL : : reject_promise ( realm ,  promise ,  WebIDL : : InvalidAccessError : : create ( realm ,  " Algorithm mismatch " _string ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-14 22:39:48 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            return ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 9. If the [[usages]] internal slot of key does not contain an entry that is "encrypt", then throw an InvalidAccessError.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( ! key - > internal_usages ( ) . contains_slow ( Bindings : : KeyUsage : : Encrypt ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-12 20:56:21 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            WebIDL : : reject_promise ( realm ,  promise ,  WebIDL : : InvalidAccessError : : create ( realm ,  " Key does not support encryption " _string ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-14 22:39:48 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            return ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 10. Let ciphertext be the result of performing the encrypt operation specified by normalizedAlgorithm using algorithm and key and with data as plaintext.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  cipher_text  =  normalized_algorithm . methods - > encrypt ( * normalized_algorithm . parameter ,  key ,  data ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( cipher_text . is_error ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            WebIDL : : reject_promise ( realm ,  promise ,  Bindings : : dom_exception_to_throw_completion ( realm . vm ( ) ,  cipher_text . release_error ( ) ) . release_value ( ) . value ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            return ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 9. Resolve promise with ciphertext.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        WebIDL : : resolve_promise ( realm ,  promise ,  cipher_text . release_value ( ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-31 02:39:29 +13:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    } ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-14 22:39:48 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-10-25 12:38:19 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    return  promise ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-14 22:39:48 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-14 22:47:06 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								// https://w3c.github.io/webcrypto/#dfn-SubtleCrypto-method-decrypt
  
						 
					
						
							
								
									
										
										
										
											2024-10-25 12:38:19 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								JS : : NonnullGCPtr < WebIDL : : Promise >  SubtleCrypto : : decrypt ( AlgorithmIdentifier  const &  algorithm ,  JS : : NonnullGCPtr < CryptoKey >  key ,  JS : : Handle < WebIDL : : BufferSource >  const &  data_parameter )  
						 
					
						
							
								
									
										
										
										
											2024-03-14 22:47:06 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto &  realm  =  this - > realm ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto &  vm  =  this - > vm ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 1. Let algorithm and key be the algorithm and key parameters passed to the decrypt() method, respectively.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 2. Let data be the result of getting a copy of the bytes held by the data parameter passed to the decrypt() method.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  data_or_error  =  WebIDL : : get_buffer_source_copy ( * data_parameter - > raw_object ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  ( data_or_error . is_error ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        VERIFY ( data_or_error . error ( ) . code ( )  = =  ENOMEM ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  WebIDL : : create_rejected_promise_from_exception ( realm ,  vm . throw_completion < JS : : InternalError > ( vm . error_message ( JS : : VM : : ErrorMessage : : OutOfMemory ) ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  data  =  data_or_error . release_value ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 3. Let normalizedAlgorithm be the result of normalizing an algorithm, with alg set to algorithm and op set to "decrypt".
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  normalized_algorithm  =  normalize_an_algorithm ( realm ,  algorithm ,  " decrypt " _string ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 4. If an error occurred, return a Promise rejected with normalizedAlgorithm.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  ( normalized_algorithm . is_error ( ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  WebIDL : : create_rejected_promise_from_exception ( realm ,  normalized_algorithm . release_error ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 5. Let promise be a new Promise.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  promise  =  WebIDL : : create_promise ( realm ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 6. Return promise and perform the remaining steps in parallel.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-10-31 02:39:29 +13:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    Platform : : EventLoopPlugin : : the ( ) . deferred_invoke ( JS : : create_heap_function ( realm . heap ( ) ,  [ & realm ,  normalized_algorithm  =  normalized_algorithm . release_value ( ) ,  promise ,  key ,  data  =  move ( data ) ] ( )  - >  void  { 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-14 22:47:06 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        HTML : : TemporaryExecutionContext  context ( Bindings : : host_defined_environment_settings_object ( realm ) ,  HTML : : TemporaryExecutionContext : : CallbacksEnabled : : Yes ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 7. If the following steps or referenced procedures say to throw an error, reject promise with the returned error and then terminate the algorithm.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 8. If the name member of normalizedAlgorithm is not equal to the name attribute of the [[algorithm]] internal slot of key then throw an InvalidAccessError.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( normalized_algorithm . parameter - > name  ! =  key - > algorithm_name ( ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-12 20:56:21 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            WebIDL : : reject_promise ( realm ,  promise ,  WebIDL : : InvalidAccessError : : create ( realm ,  " Algorithm mismatch " _string ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-14 22:47:06 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            return ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 9. If the [[usages]] internal slot of key does not contain an entry that is "decrypt", then throw an InvalidAccessError.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( ! key - > internal_usages ( ) . contains_slow ( Bindings : : KeyUsage : : Decrypt ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-12 20:56:21 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            WebIDL : : reject_promise ( realm ,  promise ,  WebIDL : : InvalidAccessError : : create ( realm ,  " Key does not support encryption " _string ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-14 22:47:06 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            return ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 10. Let plaintext be the result of performing the decrypt operation specified by normalizedAlgorithm using algorithm and key and with data as ciphertext.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  plain_text  =  normalized_algorithm . methods - > decrypt ( * normalized_algorithm . parameter ,  key ,  data ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( plain_text . is_error ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            WebIDL : : reject_promise ( realm ,  promise ,  Bindings : : dom_exception_to_throw_completion ( realm . vm ( ) ,  plain_text . release_error ( ) ) . release_value ( ) . value ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            return ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 9. Resolve promise with plaintext.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        WebIDL : : resolve_promise ( realm ,  promise ,  plain_text . release_value ( ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-31 02:39:29 +13:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    } ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-14 22:47:06 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-10-25 12:38:19 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    return  promise ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-14 22:47:06 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
											
												LibWeb: Remove unecessary dependence on Window from assorted classes
These classes only needed Window to get at its realm. Pass a realm
directly to construct Crypto, Encoding, HRT, IntersectionObserver,
NavigationTiming, Page, RequestIdleCallback, Selection, Streams, URL,
and XML classes.
											 
										 
										
											2022-09-25 18:11:21 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								// https://w3c.github.io/webcrypto/#dfn-SubtleCrypto-method-digest
  
						 
					
						
							
								
									
										
										
										
											2024-10-25 12:38:19 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								JS : : NonnullGCPtr < WebIDL : : Promise >  SubtleCrypto : : digest ( AlgorithmIdentifier  const &  algorithm ,  JS : : Handle < WebIDL : : BufferSource >  const &  data )  
						 
					
						
							
								
									
										
										
										
											2021-12-13 22:09:55 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
									
										
										
											
												LibWeb: Remove unecessary dependence on Window from assorted classes
These classes only needed Window to get at its realm. Pass a realm
directly to construct Crypto, Encoding, HRT, IntersectionObserver,
NavigationTiming, Page, RequestIdleCallback, Selection, Streams, URL,
and XML classes.
											 
										 
										
											2022-09-25 18:11:21 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    auto &  realm  =  this - > realm ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-14 22:38:09 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    auto &  vm  =  this - > vm ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-12-13 22:09:55 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 1. Let algorithm be the algorithm parameter passed to the digest() method.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 2. Let data be the result of getting a copy of the bytes held by the data parameter passed to the digest() method.
 
							 
						 
					
						
							
								
									
										
										
										
											2023-11-23 20:07:25 +13:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    auto  data_buffer_or_error  =  WebIDL : : get_buffer_source_copy ( * data - > raw_object ( ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-14 22:38:09 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    if  ( data_buffer_or_error . is_error ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        VERIFY ( data_buffer_or_error . error ( ) . code ( )  = =  ENOMEM ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  WebIDL : : create_rejected_promise_from_exception ( realm ,  vm . throw_completion < JS : : InternalError > ( vm . error_message ( JS : : VM : : ErrorMessage : : OutOfMemory ) ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    } 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-23 11:52:15 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    auto  data_buffer  =  data_buffer_or_error . release_value ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-12-13 22:09:55 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 3. Let normalizedAlgorithm be the result of normalizing an algorithm, with alg set to algorithm and op set to "digest".
 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-14 21:52:17 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    auto  normalized_algorithm  =  normalize_an_algorithm ( realm ,  algorithm ,  " digest " _string ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-12-14 20:56:30 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-12-13 22:09:55 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    // 4. If an error occurred, return a Promise rejected with normalizedAlgorithm.
 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-23 11:52:15 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    // FIXME: Spec bug: link to https://webidl.spec.whatwg.org/#a-promise-rejected-with
 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-08 15:37:28 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    if  ( normalized_algorithm . is_error ( ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  WebIDL : : create_rejected_promise_from_exception ( realm ,  normalized_algorithm . release_error ( ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-12-13 22:09:55 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 5. Let promise be a new Promise.
 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-23 11:52:15 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    auto  promise  =  WebIDL : : create_promise ( realm ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-12-13 22:09:55 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 6. Return promise and perform the remaining steps in parallel.
 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-31 02:39:29 +13:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    Platform : : EventLoopPlugin : : the ( ) . deferred_invoke ( JS : : create_heap_function ( realm . heap ( ) ,  [ & realm ,  algorithm_object  =  normalized_algorithm . release_value ( ) ,  promise ,  data_buffer  =  move ( data_buffer ) ] ( )  - >  void  { 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-23 11:52:15 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        HTML : : TemporaryExecutionContext  context ( Bindings : : host_defined_environment_settings_object ( realm ) ,  HTML : : TemporaryExecutionContext : : CallbacksEnabled : : Yes ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 7. If the following steps or referenced procedures say to throw an error, reject promise with the returned error and then terminate the algorithm.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // FIXME: Need spec reference to https://webidl.spec.whatwg.org/#reject
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 8. Let result be the result of performing the digest operation specified by normalizedAlgorithm using algorithm, with data as message.
 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-06 16:53:50 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        auto  result  =  algorithm_object . methods - > digest ( * algorithm_object . parameter ,  data_buffer ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-23 11:52:15 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-06 16:53:50 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        if  ( result . is_exception ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            WebIDL : : reject_promise ( realm ,  promise ,  Bindings : : dom_exception_to_throw_completion ( realm . vm ( ) ,  result . release_error ( ) ) . release_value ( ) . value ( ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-23 11:52:15 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            return ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 9. Resolve promise with result.
 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-06 16:53:50 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        WebIDL : : resolve_promise ( realm ,  promise ,  result . release_value ( ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-31 02:39:29 +13:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    } ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-01-23 11:52:15 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-10-25 12:38:19 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    return  promise ; 
							 
						 
					
						
							
								
									
										
										
										
											2021-12-13 22:09:55 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-06 19:15:03 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								// https://w3c.github.io/webcrypto/#dfn-SubtleCrypto-method-generateKey
  
						 
					
						
							
								
									
										
										
										
											2024-10-25 12:38:19 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								JS : : ThrowCompletionOr < JS : : NonnullGCPtr < WebIDL : : Promise > >  SubtleCrypto : : generate_key ( AlgorithmIdentifier  algorithm ,  bool  extractable ,  Vector < Bindings : : KeyUsage >  key_usages )  
						 
					
						
							
								
									
										
										
										
											2024-03-06 19:15:03 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto &  realm  =  this - > realm ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 1. Let algorithm, extractable and usages be the algorithm, extractable and keyUsages
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    //    parameters passed to the generateKey() method, respectively.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 2. Let normalizedAlgorithm be the result of normalizing an algorithm,
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    //    with alg set to algorithm and op set to "generateKey".
 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-14 21:52:17 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    auto  normalized_algorithm  =  normalize_an_algorithm ( realm ,  algorithm ,  " generateKey " _string ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-06 19:15:03 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 3. If an error occurred, return a Promise rejected with normalizedAlgorithm.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  ( normalized_algorithm . is_error ( ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  WebIDL : : create_rejected_promise_from_exception ( realm ,  normalized_algorithm . release_error ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 4. Let promise be a new Promise.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  promise  =  WebIDL : : create_promise ( realm ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 5. Return promise and perform the remaining steps in parallel.
 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-31 02:39:29 +13:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    Platform : : EventLoopPlugin : : the ( ) . deferred_invoke ( JS : : create_heap_function ( realm . heap ( ) ,  [ & realm ,  normalized_algorithm  =  normalized_algorithm . release_value ( ) ,  promise ,  extractable ,  key_usages  =  move ( key_usages ) ] ( )  - >  void  { 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-06 19:15:03 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        HTML : : TemporaryExecutionContext  context ( Bindings : : host_defined_environment_settings_object ( realm ) ,  HTML : : TemporaryExecutionContext : : CallbacksEnabled : : Yes ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 6. If the following steps or referenced procedures say to throw an error, reject promise with
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        //    the returned error and then terminate the algorithm.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 7. Let result be the result of performing the generate key operation specified by normalizedAlgorithm
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        //    using algorithm, extractable and usages.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  result_or_error  =  normalized_algorithm . methods - > generate_key ( * normalized_algorithm . parameter ,  extractable ,  key_usages ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( result_or_error . is_error ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            WebIDL : : reject_promise ( realm ,  promise ,  Bindings : : dom_exception_to_throw_completion ( realm . vm ( ) ,  result_or_error . release_error ( ) ) . release_value ( ) . value ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            return ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  result  =  result_or_error . release_value ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 8. If result is a CryptoKey object:
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        //      If the [[type]] internal slot of result is "secret" or "private" and usages is empty, then throw a SyntaxError.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        //    If result is a CryptoKeyPair object:
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        //      If the [[usages]] internal slot of the privateKey attribute of result is the empty sequence, then throw a SyntaxError.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 9. Resolve promise with result.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        result . visit ( 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            [ & ] ( JS : : NonnullGCPtr < CryptoKey > &  key )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  ( ( key - > type ( )  = =  Bindings : : KeyType : : Secret  | |  key - > type ( )  = =  Bindings : : KeyType : : Private )  & &  key_usages . is_empty ( ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-12 20:56:21 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    WebIDL : : reject_promise ( realm ,  promise ,  WebIDL : : SyntaxError : : create ( realm ,  " usages must not be empty " _string ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-06 19:15:03 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    return ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                WebIDL : : resolve_promise ( realm ,  promise ,  key ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            } , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            [ & ] ( JS : : NonnullGCPtr < CryptoKeyPair > &  key_pair )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  ( key_pair - > private_key ( ) - > internal_usages ( ) . is_empty ( ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-12 20:56:21 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    WebIDL : : reject_promise ( realm ,  promise ,  WebIDL : : SyntaxError : : create ( realm ,  " usages must not be empty " _string ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-06 19:15:03 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    return ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                WebIDL : : resolve_promise ( realm ,  promise ,  key_pair ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            } ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-31 02:39:29 +13:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    } ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-06 19:15:03 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-10-25 12:38:19 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    return  promise ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-06 19:15:03 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-12-15 22:03:04 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								// https://w3c.github.io/webcrypto/#SubtleCrypto-method-importKey
  
						 
					
						
							
								
									
										
										
										
											2024-10-25 12:38:19 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								JS : : ThrowCompletionOr < JS : : NonnullGCPtr < WebIDL : : Promise > >  SubtleCrypto : : import_key ( Bindings : : KeyFormat  format ,  KeyDataType  key_data ,  AlgorithmIdentifier  algorithm ,  bool  extractable ,  Vector < Bindings : : KeyUsage >  key_usages )  
						 
					
						
							
								
									
										
										
										
											2023-12-15 22:03:04 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto &  realm  =  this - > realm ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 1. Let format, algorithm, extractable and usages, be the format, algorithm, extractable
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // and key_usages parameters passed to the importKey() method, respectively.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    Variant < ByteBuffer ,  Bindings : : JsonWebKey ,  Empty >  real_key_data ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 2. If format is equal to the string "raw", "pkcs8", or "spki":
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  ( format  = =  Bindings : : KeyFormat : : Raw  | |  format  = =  Bindings : : KeyFormat : : Pkcs8  | |  format  = =  Bindings : : KeyFormat : : Spki )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 1. If the keyData parameter passed to the importKey() method is a JsonWebKey dictionary, throw a TypeError.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( key_data . has < Bindings : : JsonWebKey > ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            return  realm . vm ( ) . throw_completion < JS : : TypeError > ( JS : : ErrorType : : NotAnObjectOfType ,  " BufferSource " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 2. Let keyData be the result of getting a copy of the bytes held by the keyData parameter passed to the importKey() method.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        real_key_data  =  MUST ( WebIDL : : get_buffer_source_copy ( * key_data . get < JS : : Handle < WebIDL : : BufferSource > > ( ) - > raw_object ( ) ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  ( format  = =  Bindings : : KeyFormat : : Jwk )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 1. If the keyData parameter passed to the importKey() method is not a JsonWebKey dictionary, throw a TypeError.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( ! key_data . has < Bindings : : JsonWebKey > ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            return  realm . vm ( ) . throw_completion < JS : : TypeError > ( JS : : ErrorType : : NotAnObjectOfType ,  " JsonWebKey " ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 2. Let keyData be the keyData parameter passed to the importKey() method.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        real_key_data  =  key_data . get < Bindings : : JsonWebKey > ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // NOTE: The spec jumps to 5 here for some reason?
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 5. Let normalizedAlgorithm be the result of normalizing an algorithm, with alg set to algorithm and op set to "importKey".
 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-14 21:52:17 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    auto  normalized_algorithm  =  normalize_an_algorithm ( realm ,  algorithm ,  " importKey " _string ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-12-15 22:03:04 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 6. If an error occurred, return a Promise rejected with normalizedAlgorithm.
 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-08 15:37:28 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    if  ( normalized_algorithm . is_error ( ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  WebIDL : : create_rejected_promise_from_exception ( realm ,  normalized_algorithm . release_error ( ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-12-15 22:03:04 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 7. Let promise be a new Promise.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  promise  =  WebIDL : : create_promise ( realm ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 8. Return promise and perform the remaining steps in parallel.
 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-31 02:39:29 +13:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    Platform : : EventLoopPlugin : : the ( ) . deferred_invoke ( JS : : create_heap_function ( heap ( ) ,  [ & realm ,  real_key_data  =  move ( real_key_data ) ,  normalized_algorithm  =  normalized_algorithm . release_value ( ) ,  promise ,  format ,  extractable ,  key_usages  =  move ( key_usages ) ,  algorithm  =  move ( algorithm ) ] ( )  mutable  - >  void  { 
							 
						 
					
						
							
								
									
										
										
										
											2023-12-15 22:03:04 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        HTML : : TemporaryExecutionContext  context ( Bindings : : host_defined_environment_settings_object ( realm ) ,  HTML : : TemporaryExecutionContext : : CallbacksEnabled : : Yes ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 9. If the following steps or referenced procedures say to throw an error, reject promise with the returned error and then terminate the algorithm.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 10. Let result be the CryptoKey object that results from performing the import key operation
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // specified by normalizedAlgorithm using keyData, algorithm, format, extractable and usages.
 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-06 16:53:50 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        auto  maybe_result  =  normalized_algorithm . methods - > import_key ( * normalized_algorithm . parameter ,  format ,  real_key_data . downcast < CryptoKey : : InternalKeyData > ( ) ,  extractable ,  key_usages ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-12-15 22:03:04 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        if  ( maybe_result . is_error ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            WebIDL : : reject_promise ( realm ,  promise ,  Bindings : : dom_exception_to_throw_completion ( realm . vm ( ) ,  maybe_result . release_error ( ) ) . release_value ( ) . value ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            return ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  result  =  maybe_result . release_value ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 11. If the [[type]] internal slot of result is "secret" or "private" and usages is empty, then throw a SyntaxError.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( ( result - > type ( )  = =  Bindings : : KeyType : : Secret  | |  result - > type ( )  = =  Bindings : : KeyType : : Private )  & &  key_usages . is_empty ( ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-12 20:56:21 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            WebIDL : : reject_promise ( realm ,  promise ,  WebIDL : : SyntaxError : : create ( realm ,  " usages must not be empty " _string ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-12-15 22:03:04 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            return ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 12. Set the [[extractable]] internal slot of result to extractable.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        result - > set_extractable ( extractable ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 13. Set the [[usages]] internal slot of result to the normalized value of usages.
 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-06 19:11:08 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        normalize_key_usages ( key_usages ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        result - > set_usages ( key_usages ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-12-15 22:03:04 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 14. Resolve promise with result.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        WebIDL : : resolve_promise ( realm ,  promise ,  result ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-31 02:39:29 +13:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    } ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-12-15 22:03:04 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-10-25 12:38:19 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    return  promise ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-12-15 22:03:04 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-13 21:19:57 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								// https://w3c.github.io/webcrypto/#dfn-SubtleCrypto-method-exportKey
  
						 
					
						
							
								
									
										
										
										
											2024-10-25 12:38:19 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								JS : : ThrowCompletionOr < JS : : NonnullGCPtr < WebIDL : : Promise > >  SubtleCrypto : : export_key ( Bindings : : KeyFormat  format ,  JS : : NonnullGCPtr < CryptoKey >  key )  
						 
					
						
							
								
									
										
										
										
											2024-03-13 21:19:57 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto &  realm  =  this - > realm ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 1. Let format and key be the format and key parameters passed to the exportKey() method, respectively.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 2. Let promise be a new Promise.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  promise  =  WebIDL : : create_promise ( realm ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 3. Return promise and perform the remaining steps in parallel.
 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-31 02:39:29 +13:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    Platform : : EventLoopPlugin : : the ( ) . deferred_invoke ( JS : : create_heap_function ( heap ( ) ,  [ & realm ,  key ,  promise ,  format ] ( )  - >  void  { 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-13 21:19:57 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        HTML : : TemporaryExecutionContext  context ( Bindings : : host_defined_environment_settings_object ( realm ) ,  HTML : : TemporaryExecutionContext : : CallbacksEnabled : : Yes ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 4.  If the following steps or referenced procedures say to throw an error, reject promise with the returned error and then terminate the algorithm.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 5. If the name member of the [[algorithm]] internal slot of key does not identify a registered algorithm that supports the export key operation,
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        //    then throw a NotSupportedError.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // Note: Handled by the base AlgorithmMethods implementation
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto &  algorithm  =  verify_cast < KeyAlgorithm > ( * key - > algorithm ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // FIXME: Stash the AlgorithmMethods on the KeyAlgorithm
 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-14 21:52:17 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        auto  normalized_algorithm_or_error  =  normalize_an_algorithm ( realm ,  algorithm . name ( ) ,  " exportKey " _string ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-13 21:19:57 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        if  ( normalized_algorithm_or_error . is_error ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            WebIDL : : reject_promise ( realm ,  promise ,  Bindings : : dom_exception_to_throw_completion ( realm . vm ( ) ,  normalized_algorithm_or_error . release_error ( ) ) . release_value ( ) . value ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            return ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  normalized_algorithm  =  normalized_algorithm_or_error . release_value ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 6. If the [[extractable]] internal slot of key is false, then throw an InvalidAccessError.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( ! key - > extractable ( ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-12 20:56:21 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            WebIDL : : reject_promise ( realm ,  promise ,  WebIDL : : InvalidAccessError : : create ( realm ,  " Key is not extractable " _string ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-13 21:19:57 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            return ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 7. Let result be the result of performing the export key operation specified by the [[algorithm]] internal slot of key using key and format.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  result_or_error  =  normalized_algorithm . methods - > export_key ( format ,  key ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( result_or_error . is_error ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            WebIDL : : reject_promise ( realm ,  promise ,  Bindings : : dom_exception_to_throw_completion ( realm . vm ( ) ,  result_or_error . release_error ( ) ) . release_value ( ) . value ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            return ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 8. Resolve promise with result.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        WebIDL : : resolve_promise ( realm ,  promise ,  result_or_error . release_value ( ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-31 02:39:29 +13:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    } ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-13 21:19:57 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-10-25 12:38:19 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    return  promise ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-26 23:53:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// https://w3c.github.io/webcrypto/#dfn-SubtleCrypto-method-sign
  
						 
					
						
							
								
									
										
										
										
											2024-10-25 12:38:19 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								JS : : ThrowCompletionOr < JS : : NonnullGCPtr < WebIDL : : Promise > >  SubtleCrypto : : sign ( AlgorithmIdentifier  const &  algorithm ,  JS : : NonnullGCPtr < CryptoKey >  key ,  JS : : Handle < WebIDL : : BufferSource >  const &  data_parameter )  
						 
					
						
							
								
									
										
										
										
											2024-03-26 23:53:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto &  realm  =  this - > realm ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto &  vm  =  this - > vm ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 1. Let algorithm and key be the algorithm and key parameters passed to the sign() method, respectively.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 2. Let data be the result of getting a copy of the bytes held by the data parameter passed to the sign() method.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  data_or_error  =  WebIDL : : get_buffer_source_copy ( * data_parameter - > raw_object ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  ( data_or_error . is_error ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        VERIFY ( data_or_error . error ( ) . code ( )  = =  ENOMEM ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  WebIDL : : create_rejected_promise_from_exception ( realm ,  vm . throw_completion < JS : : InternalError > ( vm . error_message ( JS : : VM : : ErrorMessage : : OutOfMemory ) ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  data  =  data_or_error . release_value ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 3. Let normalizedAlgorithm be the result of normalizing an algorithm, with alg set to algorithm and op set to "sign".
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  normalized_algorithm  =  normalize_an_algorithm ( realm ,  algorithm ,  " sign " _string ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 4. If an error occurred, return a Promise rejected with normalizedAlgorithm.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  ( normalized_algorithm . is_error ( ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  WebIDL : : create_rejected_promise_from_exception ( realm ,  normalized_algorithm . release_error ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 5. Let promise be a new Promise.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  promise  =  WebIDL : : create_promise ( realm ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 6. Return promise and perform the remaining steps in parallel.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-10-31 02:39:29 +13:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    Platform : : EventLoopPlugin : : the ( ) . deferred_invoke ( JS : : create_heap_function ( realm . heap ( ) ,  [ & realm ,  normalized_algorithm  =  normalized_algorithm . release_value ( ) ,  promise ,  key ,  data  =  move ( data ) ] ( )  - >  void  { 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-26 23:53:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        HTML : : TemporaryExecutionContext  context ( Bindings : : host_defined_environment_settings_object ( realm ) ,  HTML : : TemporaryExecutionContext : : CallbacksEnabled : : Yes ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 7. If the following steps or referenced procedures say to throw an error, reject promise with the returned error and then terminate the algorithm.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 8. If the name member of normalizedAlgorithm is not equal to the name attribute of the [[algorithm]] internal slot of key then throw an InvalidAccessError.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( normalized_algorithm . parameter - > name  ! =  key - > algorithm_name ( ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-12 20:56:21 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            WebIDL : : reject_promise ( realm ,  promise ,  WebIDL : : InvalidAccessError : : create ( realm ,  " Algorithm mismatch " _string ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-26 23:53:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            return ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 9. If the [[usages]] internal slot of key does not contain an entry that is "sign", then throw an InvalidAccessError.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( ! key - > internal_usages ( ) . contains_slow ( Bindings : : KeyUsage : : Sign ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-12 20:56:21 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            WebIDL : : reject_promise ( realm ,  promise ,  WebIDL : : InvalidAccessError : : create ( realm ,  " Key does not support signing " _string ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-26 23:53:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            return ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 10. Let result be the result of performing the sign operation specified by normalizedAlgorithm using key and algorithm and with data as message.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  result  =  normalized_algorithm . methods - > sign ( * normalized_algorithm . parameter ,  key ,  data ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( result . is_error ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            WebIDL : : reject_promise ( realm ,  promise ,  Bindings : : dom_exception_to_throw_completion ( realm . vm ( ) ,  result . release_error ( ) ) . release_value ( ) . value ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            return ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 9. Resolve promise with result.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        WebIDL : : resolve_promise ( realm ,  promise ,  result . release_value ( ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-31 02:39:29 +13:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    } ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-26 23:53:35 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-10-25 12:38:19 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    return  promise ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-13 21:19:57 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-27 01:50:25 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								// https://w3c.github.io/webcrypto/#dfn-SubtleCrypto-method-verify
  
						 
					
						
							
								
									
										
										
										
											2024-10-25 12:38:19 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								JS : : ThrowCompletionOr < JS : : NonnullGCPtr < WebIDL : : Promise > >  SubtleCrypto : : verify ( AlgorithmIdentifier  const &  algorithm ,  JS : : NonnullGCPtr < CryptoKey >  key ,  JS : : Handle < WebIDL : : BufferSource >  const &  signature_data ,  JS : : Handle < WebIDL : : BufferSource >  const &  data_parameter )  
						 
					
						
							
								
									
										
										
										
											2024-03-27 01:50:25 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto &  realm  =  this - > realm ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto &  vm  =  this - > vm ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 1. Let algorithm and key be the algorithm and key parameters passed to the verify() method, respectively.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 2. Let signature be the result of getting a copy of the bytes held by the signature parameter passed to the verify() method.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  signature_or_error  =  WebIDL : : get_buffer_source_copy ( * signature_data - > raw_object ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  ( signature_or_error . is_error ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        VERIFY ( signature_or_error . error ( ) . code ( )  = =  ENOMEM ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  WebIDL : : create_rejected_promise_from_exception ( realm ,  vm . throw_completion < JS : : InternalError > ( vm . error_message ( JS : : VM : : ErrorMessage : : OutOfMemory ) ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  signature  =  signature_or_error . release_value ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 3. Let data be the result of getting a copy of the bytes held by the data parameter passed to the verify() method.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  data_or_error  =  WebIDL : : get_buffer_source_copy ( * data_parameter - > raw_object ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  ( data_or_error . is_error ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        VERIFY ( data_or_error . error ( ) . code ( )  = =  ENOMEM ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  WebIDL : : create_rejected_promise_from_exception ( realm ,  vm . throw_completion < JS : : InternalError > ( vm . error_message ( JS : : VM : : ErrorMessage : : OutOfMemory ) ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  data  =  data_or_error . release_value ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 3. Let normalizedAlgorithm be the result of normalizing an algorithm, with alg set to algorithm and op set to "verify".
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  normalized_algorithm  =  normalize_an_algorithm ( realm ,  algorithm ,  " verify " _string ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 5. If an error occurred, return a Promise rejected with normalizedAlgorithm.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  ( normalized_algorithm . is_error ( ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  WebIDL : : create_rejected_promise_from_exception ( realm ,  normalized_algorithm . release_error ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 6. Let promise be a new Promise.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  promise  =  WebIDL : : create_promise ( realm ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 7. Return promise and perform the remaining steps in parallel.
 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-31 02:39:29 +13:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    Platform : : EventLoopPlugin : : the ( ) . deferred_invoke ( JS : : create_heap_function ( realm . heap ( ) ,  [ & realm ,  normalized_algorithm  =  normalized_algorithm . release_value ( ) ,  promise ,  key ,  signature  =  move ( signature ) ,  data  =  move ( data ) ] ( )  - >  void  { 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-27 01:50:25 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        HTML : : TemporaryExecutionContext  context ( Bindings : : host_defined_environment_settings_object ( realm ) ,  HTML : : TemporaryExecutionContext : : CallbacksEnabled : : Yes ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 8. If the following steps or referenced procedures say to throw an error, reject promise with the returned error and then terminate the algorithm.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 9. If the name member of normalizedAlgorithm is not equal to the name attribute of the [[algorithm]] internal slot of key then throw an InvalidAccessError.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( normalized_algorithm . parameter - > name  ! =  key - > algorithm_name ( ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-12 20:56:21 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            WebIDL : : reject_promise ( realm ,  promise ,  WebIDL : : InvalidAccessError : : create ( realm ,  " Algorithm mismatch " _string ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-27 01:50:25 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            return ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 10. If the [[usages]] internal slot of key does not contain an entry that is "verify", then throw an InvalidAccessError.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( ! key - > internal_usages ( ) . contains_slow ( Bindings : : KeyUsage : : Verify ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-12 20:56:21 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            WebIDL : : reject_promise ( realm ,  promise ,  WebIDL : : InvalidAccessError : : create ( realm ,  " Key does not support verification " _string ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-27 01:50:25 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            return ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 11. Let result be the result of performing the verify operation specified by normalizedAlgorithm using key, algorithm and signature and with data as message.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  result  =  normalized_algorithm . methods - > verify ( * normalized_algorithm . parameter ,  key ,  signature ,  data ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( result . is_error ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            WebIDL : : reject_promise ( realm ,  promise ,  Bindings : : dom_exception_to_throw_completion ( realm . vm ( ) ,  result . release_error ( ) ) . release_value ( ) . value ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            return ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 12. Resolve promise with result.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        WebIDL : : resolve_promise ( realm ,  promise ,  result . release_value ( ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-31 02:39:29 +13:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    } ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-27 01:50:25 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-10-25 12:38:19 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    return  promise ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-27 01:50:25 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-27 19:15:49 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								// https://w3c.github.io/webcrypto/#SubtleCrypto-method-deriveBits
  
						 
					
						
							
								
									
										
										
										
											2024-10-25 12:38:19 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								JS : : ThrowCompletionOr < JS : : NonnullGCPtr < WebIDL : : Promise > >  SubtleCrypto : : derive_bits ( AlgorithmIdentifier  algorithm ,  JS : : NonnullGCPtr < CryptoKey >  base_key ,  u32  length )  
						 
					
						
							
								
									
										
										
										
											2024-03-27 19:15:49 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto &  realm  =  this - > realm ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 1. Let algorithm, baseKey and length, be the algorithm, baseKey and length parameters passed to the deriveBits() method, respectively.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 2. Let normalizedAlgorithm be the result of normalizing an algorithm, with alg set to algorithm and op set to "deriveBits".
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  normalized_algorithm  =  normalize_an_algorithm ( realm ,  algorithm ,  " deriveBits " _string ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 3. If an error occurred, return a Promise rejected with normalizedAlgorithm.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  ( normalized_algorithm . is_error ( ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  WebIDL : : create_rejected_promise_from_exception ( realm ,  normalized_algorithm . release_error ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 4. Let promise be a new Promise object.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  promise  =  WebIDL : : create_promise ( realm ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 5. Return promise and perform the remaining steps in parallel.
 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-31 02:39:29 +13:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    Platform : : EventLoopPlugin : : the ( ) . deferred_invoke ( JS : : create_heap_function ( realm . heap ( ) ,  [ & realm ,  normalized_algorithm  =  normalized_algorithm . release_value ( ) ,  promise ,  base_key ,  length ] ( )  - >  void  { 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-27 19:15:49 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        HTML : : TemporaryExecutionContext  context ( Bindings : : host_defined_environment_settings_object ( realm ) ,  HTML : : TemporaryExecutionContext : : CallbacksEnabled : : Yes ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 6. If the following steps or referenced procedures say to throw an error, reject promise with the returned error and then terminate the algorithm.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 7. If the name member of normalizedAlgorithm is not equal to the name attribute of the [[algorithm]] internal slot of baseKey then throw an InvalidAccessError.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( normalized_algorithm . parameter - > name  ! =  base_key - > algorithm_name ( ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-12 20:56:21 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            WebIDL : : reject_promise ( realm ,  promise ,  WebIDL : : InvalidAccessError : : create ( realm ,  " Algorithm mismatch " _string ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-27 19:15:49 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            return ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 8. If the [[usages]] internal slot of baseKey does not contain an entry that is "deriveBits", then throw an InvalidAccessError.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( ! base_key - > internal_usages ( ) . contains_slow ( Bindings : : KeyUsage : : Derivebits ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-12 20:56:21 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            WebIDL : : reject_promise ( realm ,  promise ,  WebIDL : : InvalidAccessError : : create ( realm ,  " Key does not support deriving bits " _string ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-27 19:15:49 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            return ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 9. Let result be the result of creating an ArrayBuffer containing the result of performing the derive bits operation specified by normalizedAlgorithm using baseKey, algorithm and length.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  result  =  normalized_algorithm . methods - > derive_bits ( * normalized_algorithm . parameter ,  base_key ,  length ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( result . is_error ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            WebIDL : : reject_promise ( realm ,  promise ,  Bindings : : dom_exception_to_throw_completion ( realm . vm ( ) ,  result . release_error ( ) ) . release_value ( ) . value ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            return ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 10. Resolve promise with result.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        WebIDL : : resolve_promise ( realm ,  promise ,  result . release_value ( ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-31 02:39:29 +13:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    } ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-27 19:15:49 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-10-25 12:38:19 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    return  promise ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-27 19:15:49 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-10-25 12:38:19 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								JS : : ThrowCompletionOr < JS : : NonnullGCPtr < WebIDL : : Promise > >  SubtleCrypto : : derive_key ( AlgorithmIdentifier  algorithm ,  JS : : NonnullGCPtr < CryptoKey >  base_key ,  AlgorithmIdentifier  derived_key_type ,  bool  extractable ,  Vector < Bindings : : KeyUsage >  key_usages )  
						 
					
						
							
								
									
										
										
										
											2024-03-27 20:51:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto &  realm  =  this - > realm ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto &  vm  =  this - > vm ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 1. Let algorithm, baseKey, derivedKeyType, extractable and usages be the algorithm, baseKey, derivedKeyType, extractable and keyUsages parameters passed to the deriveKey() method, respectively.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 2. Let normalizedAlgorithm be the result of normalizing an algorithm, with alg set to algorithm and op set to "deriveBits".
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  normalized_algorithm  =  normalize_an_algorithm ( realm ,  algorithm ,  " deriveBits " _string ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 3. If an error occurred, return a Promise rejected with normalizedAlgorithm.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  ( normalized_algorithm . is_error ( ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  WebIDL : : create_rejected_promise_from_exception ( realm ,  normalized_algorithm . release_error ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 4. Let normalizedDerivedKeyAlgorithmImport be the result of normalizing an algorithm, with alg set to derivedKeyType and op set to "importKey".
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  normalized_derived_key_algorithm_import  =  normalize_an_algorithm ( realm ,  derived_key_type ,  " importKey " _string ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 5. If an error occurred, return a Promise rejected with normalizedDerivedKeyAlgorithmImport.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  ( normalized_derived_key_algorithm_import . is_error ( ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  WebIDL : : create_rejected_promise_from_exception ( realm ,  normalized_derived_key_algorithm_import . release_error ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 6. Let normalizedDerivedKeyAlgorithmLength be the result of normalizing an algorithm, with alg set to derivedKeyType and op set to "get key length".
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  normalized_derived_key_algorithm_length  =  normalize_an_algorithm ( realm ,  derived_key_type ,  " get key length " _string ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 7. If an error occurred, return a Promise rejected with normalizedDerivedKeyAlgorithmLength.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  ( normalized_derived_key_algorithm_length . is_error ( ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  WebIDL : : create_rejected_promise_from_exception ( realm ,  normalized_derived_key_algorithm_length . release_error ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 8. Let promise be a new Promise.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  promise  =  WebIDL : : create_promise ( realm ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 9. Return promise and perform the remaining steps in parallel.
 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-31 02:39:29 +13:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    Platform : : EventLoopPlugin : : the ( ) . deferred_invoke ( JS : : create_heap_function ( realm . heap ( ) ,  [ & realm ,  & vm ,  normalized_algorithm  =  normalized_algorithm . release_value ( ) ,  promise ,  normalized_derived_key_algorithm_import  =  normalized_derived_key_algorithm_import . release_value ( ) ,  normalized_derived_key_algorithm_length  =  normalized_derived_key_algorithm_length . release_value ( ) ,  base_key  =  move ( base_key ) ,  extractable ,  key_usages  =  move ( key_usages ) ] ( )  - >  void  { 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-27 20:51:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        HTML : : TemporaryExecutionContext  context ( Bindings : : host_defined_environment_settings_object ( realm ) ,  HTML : : TemporaryExecutionContext : : CallbacksEnabled : : Yes ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 10. If the following steps or referenced procedures say to throw an error, reject promise with the returned error and then terminate the algorithm.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 11. If the name member of normalizedAlgorithm is not equal to the name attribute of the [[algorithm]] internal slot of baseKey then throw an InvalidAccessError.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( normalized_algorithm . parameter - > name  ! =  base_key - > algorithm_name ( ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-12 20:56:21 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            WebIDL : : reject_promise ( realm ,  promise ,  WebIDL : : InvalidAccessError : : create ( realm ,  " Algorithm mismatch " _string ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-27 20:51:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            return ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 12. If the [[usages]] internal slot of baseKey does not contain an entry that is "deriveKey", then throw an InvalidAccessError.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( ! base_key - > internal_usages ( ) . contains_slow ( Bindings : : KeyUsage : : Derivekey ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-12 20:56:21 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            WebIDL : : reject_promise ( realm ,  promise ,  WebIDL : : InvalidAccessError : : create ( realm ,  " Key does not support deriving keys " _string ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-27 20:51:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            return ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 13. Let length be the result of performing the get key length algorithm specified by normalizedDerivedKeyAlgorithmLength using derivedKeyType.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  length_result  =  normalized_derived_key_algorithm_length . methods - > get_key_length ( * normalized_derived_key_algorithm_length . parameter ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( length_result . is_error ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            WebIDL : : reject_promise ( realm ,  promise ,  Bindings : : dom_exception_to_throw_completion ( realm . vm ( ) ,  length_result . release_error ( ) ) . release_value ( ) . value ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            return ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  length_raw_value  =  length_result . release_value ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        Optional < u32 >  length  =  { } ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( length_raw_value . is_number ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            auto  maybe_length  =  length_raw_value . to_u32 ( vm ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            if  ( ! maybe_length . has_value ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                WebIDL : : reject_promise ( realm ,  promise ,  maybe_length . release_error ( ) . release_value ( ) . value ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                return ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            length  =  maybe_length . value ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 14. Let secret be the result of performing the derive bits operation specified by normalizedAlgorithm using key, algorithm and length.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  secret  =  normalized_algorithm . methods - > derive_bits ( * normalized_algorithm . parameter ,  base_key ,  length ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( secret . is_error ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            WebIDL : : reject_promise ( realm ,  promise ,  Bindings : : dom_exception_to_throw_completion ( realm . vm ( ) ,  secret . release_error ( ) ) . release_value ( ) . value ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            return ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 15. Let result be the result of performing the import key operation specified by normalizedDerivedKeyAlgorithmImport using "raw" as format, secret as keyData, derivedKeyType as algorithm and using extractable and usages.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        auto  result  =  normalized_derived_key_algorithm_import . methods - > import_key ( * normalized_derived_key_algorithm_import . parameter ,  Bindings : : KeyFormat : : Raw ,  secret . release_value ( ) - > buffer ( ) ,  extractable ,  key_usages ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( result . is_error ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            WebIDL : : reject_promise ( realm ,  promise ,  Bindings : : dom_exception_to_throw_completion ( realm . vm ( ) ,  result . release_error ( ) ) . release_value ( ) . value ( ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            return ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 16. If the [[type]] internal slot of result is "secret" or "private" and usages is empty, then throw a SyntaxError.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  ( ( result . release_value ( ) - > type ( )  = =  Bindings : : KeyType : : Secret  | |  result . release_value ( ) - > type ( )  = =  Bindings : : KeyType : : Private )  & &  key_usages . is_empty ( ) )  { 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-12 20:56:21 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            WebIDL : : reject_promise ( realm ,  promise ,  WebIDL : : SyntaxError : : create ( realm ,  " usages must not be empty " _string ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-27 20:51:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            return ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // 17. Resolve promise with result.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        WebIDL : : resolve_promise ( realm ,  promise ,  result . release_value ( ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-31 02:39:29 +13:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    } ) ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-27 20:51:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-10-25 12:38:19 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    return  promise ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-27 20:51:18 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-14 21:52:17 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								SupportedAlgorithmsMap &  supported_algorithms_internal ( )  
						 
					
						
							
								
									
										
										
										
											2023-12-14 00:38:14 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
									
										
										
										
											2024-03-14 21:52:17 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    static  SupportedAlgorithmsMap  s_supported_algorithms ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-12-14 00:38:14 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    return  s_supported_algorithms ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-12-15 23:40:52 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								// https://w3c.github.io/webcrypto/#algorithm-normalization-internalS
  
						 
					
						
							
								
									
										
										
										
											2024-03-14 21:52:17 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								SupportedAlgorithmsMap  supported_algorithms ( )  
						 
					
						
							
								
									
										
										
										
											2023-12-14 00:38:14 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto &  internal_object  =  supported_algorithms_internal ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  ( ! internal_object . is_empty ( ) )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  internal_object ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 1. For each value, v in the List of supported operations,
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // set the v key of the internal object supportedAlgorithms to a new associative container.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  supported_operations  =  Vector  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        " encrypt " _string , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        " decrypt " _string , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        " sign " _string , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        " verify " _string , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        " digest " _string , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        " deriveBits " _string , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        " wrapKey " _string , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        " unwrapKey " _string , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        " generateKey " _string , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        " importKey " _string , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        " exportKey " _string , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        " get key length " _string , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    } ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    for  ( auto &  operation  :  supported_operations )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        internal_object . set ( operation ,  { } ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // https://w3c.github.io/webcrypto/#algorithm-conventions
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // https://w3c.github.io/webcrypto/#sha
 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-06 16:53:50 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    define_an_algorithm < SHA > ( " digest " _string ,  " SHA-1 " _string ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    define_an_algorithm < SHA > ( " digest " _string ,  " SHA-256 " _string ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    define_an_algorithm < SHA > ( " digest " _string ,  " SHA-384 " _string ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    define_an_algorithm < SHA > ( " digest " _string ,  " SHA-512 " _string ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-12-14 00:38:14 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-10-25 05:58:30 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    // https://w3c.github.io/webcrypto/#aes-cbc-registration
 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-26 02:29:16 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    define_an_algorithm < AesCbc ,  AesCbcParams > ( " encrypt " _string ,  " AES-CBC " _string ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-26 03:07:05 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    define_an_algorithm < AesCbc ,  AesCbcParams > ( " decrypt " _string ,  " AES-CBC " _string ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-25 10:38:33 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    define_an_algorithm < AesCbc ,  AesKeyGenParams > ( " generateKey " _string ,  " AES-CBC " _string ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-25 05:58:30 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    define_an_algorithm < AesCbc > ( " importKey " _string ,  " AES-CBC " _string ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-25 09:40:55 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    define_an_algorithm < AesCbc > ( " exportKey " _string ,  " AES-CBC " _string ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-25 10:38:33 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    define_an_algorithm < AesCbc ,  AesDerivedKeyParams > ( " get key length " _string ,  " AES-CBC " _string ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-10-25 05:58:30 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-10-20 06:10:36 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    // https://w3c.github.io/webcrypto/#hkdf
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    define_an_algorithm < HKDF > ( " importKey " _string ,  " HKDF " _string ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    define_an_algorithm < HKDF ,  HKDFParams > ( " deriveBits " _string ,  " HKDF " _string ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    define_an_algorithm < HKDF > ( " get key length " _string ,  " HKDF " _string ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-12-15 22:03:04 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    // https://w3c.github.io/webcrypto/#pbkdf2
 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-06 16:53:50 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    define_an_algorithm < PBKDF2 > ( " importKey " _string ,  " PBKDF2 " _string ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-27 19:53:08 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    define_an_algorithm < PBKDF2 ,  PBKDF2Params > ( " deriveBits " _string ,  " PBKDF2 " _string ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-27 20:30:11 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    define_an_algorithm < PBKDF2 > ( " get key length " _string ,  " PBKDF2 " _string ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-12-15 22:03:04 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-08 16:30:17 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    // https://w3c.github.io/webcrypto/#rsa-oaep
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    define_an_algorithm < RSAOAEP ,  RsaHashedKeyGenParams > ( " generateKey " _string ,  " RSA-OAEP " _string ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-13 21:19:57 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    define_an_algorithm < RSAOAEP > ( " exportKey " _string ,  " RSA-OAEP " _string ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-14 21:57:32 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    define_an_algorithm < RSAOAEP ,  RsaHashedImportParams > ( " importKey " _string ,  " RSA-OAEP " _string ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-14 23:07:13 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    define_an_algorithm < RSAOAEP ,  RsaOaepParams > ( " encrypt " _string ,  " RSA-OAEP " _string ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-14 23:12:13 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    define_an_algorithm < RSAOAEP ,  RsaOaepParams > ( " decrypt " _string ,  " RSA-OAEP " _string ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-08 16:30:17 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-27 01:27:42 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    // https://w3c.github.io/webcrypto/#ecdsa
 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-27 01:34:04 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    define_an_algorithm < ECDSA ,  EcdsaParams > ( " sign " _string ,  " ECDSA " _string ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-27 02:35:17 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    define_an_algorithm < ECDSA ,  EcdsaParams > ( " verify " _string ,  " ECDSA " _string ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-27 01:27:42 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    define_an_algorithm < ECDSA ,  EcKeyGenParams > ( " generateKey " _string ,  " ECDSA " _string ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2024-03-31 23:04:12 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    // https://wicg.github.io/webcrypto-secure-curves/#ed25519
 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-31 23:04:58 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    define_an_algorithm < ED25519 > ( " sign " _string ,  " Ed25519 " _string ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-31 23:05:05 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    define_an_algorithm < ED25519 > ( " verify " _string ,  " Ed25519 " _string ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-31 23:04:12 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    define_an_algorithm < ED25519 > ( " generateKey " _string ,  " Ed25519 " _string ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-12-14 00:38:14 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    return  internal_object ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// https://w3c.github.io/webcrypto/#concept-define-an-algorithm
  
						 
					
						
							
								
									
										
										
										
											2024-03-06 16:53:50 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								template < typename  Methods ,  typename  Param >  
						 
					
						
							
								
									
										
										
										
											2024-03-14 21:52:17 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								void  define_an_algorithm ( AK : : String  op ,  AK : : String  algorithm )  
						 
					
						
							
								
									
										
										
										
											2023-12-14 00:38:14 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto &  internal_object  =  supported_algorithms_internal ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 1. Let registeredAlgorithms be the associative container stored at the op key of supportedAlgorithms.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // NOTE: There should always be a container at the op key.
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  maybe_registered_algorithms  =  internal_object . get ( op ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    auto  registered_algorithms  =  maybe_registered_algorithms . value ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // 2. Set the alg key of registeredAlgorithms to the IDL dictionary type type.
 
							 
						 
					
						
							
								
									
										
										
										
											2024-03-06 16:53:50 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    registered_algorithms . set ( algorithm ,  RegisteredAlgorithm  {  & Methods : : create ,  & Param : : from_value  } ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-12-14 00:38:14 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    internal_object . set ( op ,  registered_algorithms ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-12-13 22:09:55 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}