Skip to content

Commit

Permalink
Merge branch 'release-3.6.0' into 1205
Browse files Browse the repository at this point in the history
Signed-off-by: wenlinli <[email protected]>
  • Loading branch information
wenlinlee authored Dec 6, 2023
2 parents 089d6c7 + a1df952 commit bf9e5cb
Show file tree
Hide file tree
Showing 3 changed files with 23 additions and 2 deletions.
5 changes: 5 additions & 0 deletions .github/workflows/workflow-self-hosted-arm.yml
Original file line number Diff line number Diff line change
Expand Up @@ -60,6 +60,11 @@ jobs:
run: ./tools/.ci/clear_build_cache.sh


- name: update vcpkg
run: |
cd ${{ env.VCPKG_ROOT }} && git fetch --all
cd -
- name: Build for linux
run: |
export PATH="/usr/lib/ccache:/usr/local/opt/ccache/libexec:$PATH"
Expand Down
12 changes: 10 additions & 2 deletions bcos-crypto/bcos-crypto/signature/secp256k1/Secp256k1Crypto.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -86,6 +86,14 @@ bool bcos::crypto::secp256k1Verify(
return false;
#endif

if ((uint8_t)_signatureData[SECP256K1_SIGNATURE_V] > 3)
{
BOOST_THROW_EXCEPTION(
InvalidSignature() << errinfo_comment(
"secp256k1 verify illegal argument: recid >= 0 && recid <= 3, recid: " +
std::to_string((int)_signatureData[SECP256K1_SIGNATURE_V])));
}

secp256k1_ecdsa_recoverable_signature sig;
secp256k1_ecdsa_recoverable_signature_parse_compact(g_SECP256K1_CTX.get(), &sig,
_signatureData.data(), (int)_signatureData[SECP256K1_SIGNATURE_V]);
Expand Down Expand Up @@ -155,11 +163,11 @@ PublicPtr bcos::crypto::secp256k1Recover(const HashType& _hash, bytesConstRef _s
}
return pubKey;
#endif
if ((int)_signatureData[SECP256K1_SIGNATURE_V] > 3)
if ((uint8_t)_signatureData[SECP256K1_SIGNATURE_V] > 3)
{
BOOST_THROW_EXCEPTION(
InvalidSignature() << errinfo_comment(
"secp256k1Sign illegal argument: recid >= 0 && recid <= 3, recid: " +
"secp256k1 recover illegal argument: recid >= 0 && recid <= 3, recid: " +
std::to_string((int)_signatureData[SECP256K1_SIGNATURE_V])));
}
auto pubKey = std::make_shared<KeyImpl>(SECP256K1_PUBLIC_LEN);
Expand Down
8 changes: 8 additions & 0 deletions bcos-crypto/test/unittests/SignatureTest.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -191,6 +191,14 @@ BOOST_AUTO_TEST_CASE(testSecp256k1SignAndVerify)
BOOST_CHECK(*signData == *encodedData);
auto publicKey = secp256k1Crypto->recover(hashData, ref(*encodedData));
BOOST_CHECK(publicKey->data() == keyPair->publicKey()->data());
for (uint8_t i = 4; i < 255; i++)
{
(*encodedData)[SECP256K1_SIGNATURE_V] = i;
BOOST_CHECK_THROW(secp256k1Crypto->recover(hashData, ref(*encodedData)), InvalidSignature);
BOOST_CHECK_THROW(
secp256k1Crypto->verify(keyPair->publicKey(), hashData, ref(*encodedData)),
InvalidSignature);
}
}

BOOST_AUTO_TEST_CASE(testSM2KeyPair)
Expand Down

0 comments on commit bf9e5cb

Please sign in to comment.