Comments (12)
git pull, rebuild and re-test.
Just in case, Go and Rust bindings didn't suffer from this, because they parallelize even core verify, and didn't exercise the problematic code path. Which is how typo slipped through. I'm putting together a python script to keep swig in the loop...
from blst.
Yeah, thanks for the prompt fix, but this case still fails for me (pulled, rebuilt and checked). I will double check tomorrow, may be something wrong on my side.
So the described case now passes on your side right? If so, may be you can share your test code?
from blst.
It's in-the-middle-of-it, but you can git clone https://github.com/dot-asm/blst.git -b python.demo
and run blst/bindings/python/demo.py. At the end of the script you'll see your inputs.
from blst.
Oh! It's for Linux... Definitely won't work on other platforms...
from blst.
Just in case, script doesn't actually call core_verify, but you can replace everything past "# vet the public key" with result = blst.core_verify_pk_in_g1(pk, sig, True, msg, DST)
. Note that it returns BLST_ERROR, and 0 stands for success. So in application code you'd write if blst.core_verify_pk_in_g1(pk, sig, True, msg, DST) != blst.BLST_SUCCESS panic
.
from blst.
Thanks! Your python code works for me both as is and with core_verify_pk_in_g1
Doing verification the same way as in your python demo (with pairing
) in Java SWIG binding always results for me in 0
return from pairing_finalverify
on both valid and invalid data :/
There must be something goes wrong on a Java wrapper side
from blst.
Oh, just realized that pairing_finalverify
returns bool
. So verification also fails here
from blst.
Will close this for now. Thanks for support 👍
from blst.
Hurray! I was just incorrectly rebuilding the library. Everything works now 👍
from blst.
python.demo branch switched to c++ class interface. I wonder how would it, class interface, look for you in Java. Keep in mind that this is work in progress...
from blst.
Yep thanks! Will probably try C++ bindings a bit later 👍
from blst.
The python.demo branch was updated to return Java byte[] from serialization methods. Check it out... [Not that I fully tested it, but it does compile...]
from blst.
Related Issues (20)
- multi-exponentiation with single point is wrong HOT 2
- Portable builds fail in shared library build HOT 2
- Support `-fvisibility=hidden`, use explicit visibility attributes for both private and public symbols HOT 7
- Using the C library: exp_mont_384 is hard to use HOT 1
- Rust bindings: `std` feature used but not declared in Cargo.toml HOT 25
- Unoptimized sha256 funcs always do runtime detection HOT 4
- Update optimization level recommendation HOT 2
- LVI countermeasures in assembly HOT 1
- Rust bindings reference non-existent "std" feature HOT 3
- Error building blst Wasm in Rust HOT 2
- Windows: bool is 4-bytes by default HOT 3
- `blst` fails to build in Windows on ARM device HOT 4
- `blst` fails to build macos 13.x HOT 2
- Rust bindings: `PublicKey::key_validate` not linking for `x86_64-fortanix-unknown-sgx` (current master branch) HOT 11
- [Rust-binding] Proposal to implement `std::hash::Hash` for publicly exposed structures HOT 6
- Rust Bindings: Replacing slices of references to iterators of references for aggregation HOT 3
- BLST throws illegal instruction error on AMD K10 CPUs (Windows) HOT 27
- How Derive keys by path? HOT 2
- The same private key but different public key results HOT 2
- Segmentation fault in some machines and not in others using OpenBSD adJ74 HOT 14
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from blst.