Skip to content

Add Jubjub Schnorr signature verification moduleΒ #548

@0xisk

Description

@0xisk

🧐 Motivation
Midnight needs native, in-circuit signature verification. Schnorr over the embedded Jubjub curve (BLS12-381's embedded curve) is the cheap, SNARK-friendly option β€” unlike foreign-field ECDSA (#475), which is expensive and blocked on foreign-field arithmetic. It's the substrate for multisig / FROST and any in-circuit signature check.

πŸ“ Details
Pure stateless module: derivePublicKey, generateKeyPair, sign(sk, msg, nonce), verifySignature(pk, msg, sig), hashToScalar (Poseidon via transientHash), isValidPublicKey. Uses ecMulGenerator / ecMul / ecAdd over the embedded Jubjub curve.
Known blocker: EmbeddedFr decode failures for some Field values in ecMul / ecMulGenerator (SDK/runtime). PoC in #521.
Roadmap: Libraries β†’ Jubjub Schnorr Signature Verification (Priority MNF: medium).

Metadata

Metadata

Assignees

No one assigned

    Labels

    enhancementNew feature or request

    Type

    No type
    No fields configured for issues without a type.

    Projects

    Status
    Backlog

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions