GithubHelp home page GithubHelp logo

Comments (12)

dot-asm avatar dot-asm commented on May 28, 2024

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.

Nashatyrev avatar Nashatyrev commented on May 28, 2024

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.

dot-asm avatar dot-asm commented on May 28, 2024

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.

dot-asm avatar dot-asm commented on May 28, 2024

Oh! It's for Linux... Definitely won't work on other platforms...

from blst.

dot-asm avatar dot-asm commented on May 28, 2024

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.

Nashatyrev avatar Nashatyrev commented on May 28, 2024

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.

Nashatyrev avatar Nashatyrev commented on May 28, 2024

Oh, just realized that pairing_finalverify returns bool. So verification also fails here

from blst.

Nashatyrev avatar Nashatyrev commented on May 28, 2024

Will close this for now. Thanks for support 👍

from blst.

Nashatyrev avatar Nashatyrev commented on May 28, 2024

Hurray! I was just incorrectly rebuilding the library. Everything works now 👍

from blst.

dot-asm avatar dot-asm commented on May 28, 2024

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.

Nashatyrev avatar Nashatyrev commented on May 28, 2024

Yep thanks! Will probably try C++ bindings a bit later 👍

from blst.

dot-asm avatar dot-asm commented on May 28, 2024

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)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo 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.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.