diff options
author | Divy Srivastava <dj.srivastava23@gmail.com> | 2022-10-09 03:08:38 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-10-09 15:38:38 +0530 |
commit | a622c5df27e908bff152ce7374c47dabfdba0bba (patch) | |
tree | 0c836839a6d359db2afa8baf640860a31decf714 /ext/crypto/lib.rs | |
parent | cc3e2b9b1a7ccd6c671bc0b3813cf7e2b0d88b5c (diff) |
perf(ext/crypto): optimize `getRandomValues` (#16212)
Diffstat (limited to 'ext/crypto/lib.rs')
-rw-r--r-- | ext/crypto/lib.rs | 12 |
1 files changed, 6 insertions, 6 deletions
diff --git a/ext/crypto/lib.rs b/ext/crypto/lib.rs index d949135e7..f09982920 100644 --- a/ext/crypto/lib.rs +++ b/ext/crypto/lib.rs @@ -132,24 +132,24 @@ pub fn op_crypto_base64url_encode(data: ZeroCopyBuf) -> String { data } -#[op] +#[op(fast)] pub fn op_crypto_get_random_values( state: &mut OpState, - mut zero_copy: ZeroCopyBuf, + out: &mut [u8], ) -> Result<(), AnyError> { - if zero_copy.len() > 65536 { + if out.len() > 65536 { return Err( - deno_web::DomExceptionQuotaExceededError::new(&format!("The ArrayBufferView's byte length ({}) exceeds the number of bytes of entropy available via this API (65536)", zero_copy.len())) + deno_web::DomExceptionQuotaExceededError::new(&format!("The ArrayBufferView's byte length ({}) exceeds the number of bytes of entropy available via this API (65536)", out.len())) .into(), ); } let maybe_seeded_rng = state.try_borrow_mut::<StdRng>(); if let Some(seeded_rng) = maybe_seeded_rng { - seeded_rng.fill(&mut *zero_copy); + seeded_rng.fill(out); } else { let mut rng = thread_rng(); - rng.fill(&mut *zero_copy); + rng.fill(out); } Ok(()) |