We read every piece of feedback, and take your input very seriously.
To see all available qualifiers, see our documentation.
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
crypto.createDiffieHellman
Setup a node instance,
» node
and run the following javascript code.
crypto = require('crypto');crypto.createDiffieHellman('','base64',()=>{});
Then the node instance occurs an abort.
This abort can always be triggered following the steps above.
If any error occurs, an exception or other similar error-reporting stuff should be thrown. There is no reason to abort the whole node process.
» node Welcome to Node.js v16.0.0-pre. Type ".help" for more information. > crypto = require('crypto');crypto.createDiffieHellman('','base64',()=>{}); /home/zys/Toolchains/node/node[5114]: ../src/crypto/crypto_util.h:620:node::crypto::ArrayBufferOrViewContents<T>::ArrayBufferOrViewContents(v8::Local<v8::Value>) [with T = char]: Assertion `IsAnyByteSource(buf)' failed. 1: 0x5643d93bbaf4 node::Abort() [/home/zys/Toolchains/node/node] 2: 0x5643d93bbb88 [/home/zys/Toolchains/node/node] 3: 0x5643d95072ec node::crypto::ArrayBufferOrViewContents<char>::ArrayBufferOrViewContents(v8::Local<v8::Value>) [/home/zys/Toolchains/node/node] 4: 0x5643d955da5a node::crypto::DiffieHellman::New(v8::FunctionCallbackInfo<v8::Value> const&) [/home/zys/Toolchains/node/node] 5: 0x5643d963a167 v8::internal::FunctionCallbackArguments::Call(v8::internal::CallHandlerInfo) [/home/zys/Toolchains/node/node] 6: 0x5643d963abe2 [/home/zys/Toolchains/node/node] 7: 0x5643d963b4ad [/home/zys/Toolchains/node/node] 8: 0x5643d963b79a v8::internal::Builtin_HandleApiCall(int, unsigned long*, v8::internal::Isolate*) [/home/zys/Toolchains/node/node] 9: 0x5643d9fd9259 [/home/zys/Toolchains/node/node] [2] 5114 abort (core dumped) /home/zys/Toolchains/node/node
The text was updated successfully, but these errors were encountered:
Can confirm on master I'm working on this
Sorry, something went wrong.
crypto: use assert instead of directly throwing an error
23b458d
Fixes: nodejs#38302
9ded02e
crypto: add check in DH if generator is a function
33b4b12
88bc864
crypto: fix DiffieHellman generator validation
generator
7354479
PR-URL: #38311 Fixes: #38302 Reviewed-By: Antoine du Hamel <[email protected]> Reviewed-By: Luigi Pinca <[email protected]> Reviewed-By: James M Snell <[email protected]> Reviewed-By: Benjamin Gruenbaum <[email protected]> Reviewed-By: Minwoo Jung <[email protected]> Reviewed-By: Darshan Sen <[email protected]>
Successfully merging a pull request may close this issue.
What steps will reproduce the bug?
Setup a node instance,
and run the following javascript code.
Then the node instance occurs an abort.
How often does it reproduce? Is there a required condition?
This abort can always be triggered following the steps above.
What is the expected behavior?
If any error occurs, an exception or other similar error-reporting stuff should be thrown. There is no reason to abort the whole node process.
What do you see instead?
Additional information
The text was updated successfully, but these errors were encountered: