begin ECDSA

This commit is contained in:
Pieter Wuille 2013-03-10 05:34:04 +01:00
parent 949bea9262
commit 83e640f0ba
4 changed files with 91 additions and 3 deletions

55
ecdsa.h Normal file
View file

@ -0,0 +1,55 @@
#ifndef _SECP256K1_ECDSA_
#define _SECP256K1_ECDSA_
namespace secp256k1 {
bool ParsePubkey(GroupElemJac &elem, const unsigned char *pub, int size) {
if (size == 33 && (pub[0] == 0x02 || pub[0] == 0x03)) {
FieldElem x;
x.SetBytes(pub+1);
elem.SetCompressed(x, pub[0] == 0x03);
} else if (size == 65 && (pub[0] == 0x04 || pub[0] == 0x06 || pub[0] == 0x07)) {
FieldElem x,y;
x.SetBytes(pub+1);
y.SetBytes(pub+33);
elem = GroupElem(x,y);
if ((pub[0] == 0x06 || pub[0] == 0x07) && y.IsOdd() != (pub[0] == 0x07))
return false;
} else {
return false;
}
return elem.IsValid();
}
class Signature {
private:
Number r,s;
public:
bool Verify(Context &ctx, const GroupElemJac &pubkey, const Number &message) {
const GroupConstants &c = GetGroupConst();
if (r.IsNeg() || s.IsNeg())
return false;
if (r.IsZero() || s.IsZero())
return false;
if (r.Compare(c.order) >= 0 || s.Compare(c.order) >= 0)
return false;
Context ct(ctx);
Number sn(ct); sn.SetModInverse(ct, s, c.order);
Number u1(ct); u1.SetModMul(ct, sn, message, c.order);
Number u2(ct); u2.SetModMul(ct, sn, r, c.order);
GroupElemJac pr; ECMult(ct, pr, pubkey, u2, u1);
if (pr.IsInfinity())
return false;
FieldElem xr; pr.GetX(xr);
unsigned char xrb[32]; xr.GetBytes(xrb);
Number xrn(ct); xrn.SetBytes(xrb,32); xrn.SetMod(ct,xrn,c.order);
return xrn.Compare(r) == 0;
}
};
}
#endif

26
group.h
View file

@ -39,6 +39,14 @@ public:
y.SetNeg(y, 1); y.SetNeg(y, 1);
} }
void GetX(FieldElem &xout) const {
xout = x;
}
void GetY(FieldElem &yout) const {
yout = y;
}
std::string ToString() const { std::string ToString() const {
if (fInfinity) if (fInfinity)
return "(inf)"; return "(inf)";
@ -101,6 +109,24 @@ public:
aff.y = y; aff.y = y;
} }
void GetX(FieldElem &xout) {
FieldElem zi;
zi.SetInverse(z);
zi.SetSquare(zi);
xout.SetMult(x, zi);
}
bool IsInfinity() const {
return fInfinity;
}
void GetY(FieldElem &yout) {
FieldElem zi;
zi.SetInverse(z);
FieldElem zi3; zi3.SetSquare(zi); zi3.SetMult(zi, zi3);
yout.SetMult(y, zi3);
}
void SetNeg(const GroupElemJac &p) { void SetNeg(const GroupElemJac &p) {
*this = p; *this = p;
y.Normalize(); y.Normalize();

12
num.h
View file

@ -71,8 +71,8 @@ public:
void SetModInverse(Context &ctx, const Number &x, const Number &m) { void SetModInverse(Context &ctx, const Number &x, const Number &m) {
BN_mod_inverse(bn, x.bn, m.bn, ctx); BN_mod_inverse(bn, x.bn, m.bn, ctx);
} }
void SetModMul(Context &ctx, const Number &f, const Number &m) { void SetModMul(Context &ctx, const Number &a, const Number &b, const Number &m) {
BN_mod_mul(bn, bn, f.bn, m.bn, ctx); BN_mod_mul(bn, a.bn, b.bn, m.bn, ctx);
} }
void SetAdd(Context &ctx, const Number &a1, const Number &a2) { void SetAdd(Context &ctx, const Number &a1, const Number &a2) {
BN_add(bn, a1.bn, a2.bn); BN_add(bn, a1.bn, a2.bn);
@ -86,6 +86,12 @@ public:
void SetDiv(Context &ctx, const Number &a1, const Number &a2) { void SetDiv(Context &ctx, const Number &a1, const Number &a2) {
BN_div(bn, NULL, a1.bn, a2.bn, ctx); BN_div(bn, NULL, a1.bn, a2.bn, ctx);
} }
void SetMod(Context &ctx, const Number &a, const Number &m) {
BN_nnmod(bn, m.bn, a.bn, ctx);
}
int Compare(const Number &a) {
return BN_cmp(bn, a.bn);
}
int GetBits() const { int GetBits() const {
return BN_num_bits(bn); return BN_num_bits(bn);
} }
@ -99,7 +105,7 @@ public:
BN_rshift(bn, bn, bits); BN_rshift(bn, bn, bits);
return ret; return ret;
} }
// check whether number is 0 // check whether number is 0,
bool IsZero() { bool IsZero() {
return BN_is_zero(bn); return BN_is_zero(bn);
} }

View file

@ -4,6 +4,7 @@
#include "field.h" #include "field.h"
#include "group.h" #include "group.h"
#include "ecmult.h" #include "ecmult.h"
#include "ecdsa.h"
using namespace secp256k1; using namespace secp256k1;