schnorr_sig 0.0.0.3 → 0.1.0.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/VERSION +1 -1
- data/lib/schnorr_sig.rb +3 -2
- metadata +1 -1
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 151da6ed14b8d23233e92c09c4354d00454d9c10a4abbbb6f8429f17bba10cfb
|
4
|
+
data.tar.gz: 9391ae74a60a5275bf2704b8fef73b6d69591313c924f3bb9cddb24ee08e7372
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: dc77694c5a19118374eab690d7fe6a2bf04e24a009e7c62108397a4dcb4fdf4e002d5e980018a9d83875c6fff93d4c132a9b6b8f1ffd1394304d584447706ab1
|
7
|
+
data.tar.gz: 76aceaed2e98afacc253c20549d3b16a48f3d7159aed457f51d2a7f37ea4a9b7a3bfee239b92b04b9b40f8de9f855e5330aef96ec446e01ddec260505d6f0254
|
data/VERSION
CHANGED
@@ -1 +1 @@
|
|
1
|
-
0.
|
1
|
+
0.1.0.1
|
data/lib/schnorr_sig.rb
CHANGED
@@ -9,6 +9,7 @@ module SchnorrSig
|
|
9
9
|
class BoundsError < Error; end
|
10
10
|
class SanityCheck < Error; end
|
11
11
|
class VerifyFail < Error; end
|
12
|
+
class InfinityPoint < Error; end
|
12
13
|
|
13
14
|
GROUP = ECDSA::Group::Secp256k1
|
14
15
|
P = GROUP.field.prime # smaller than 256**32
|
@@ -40,7 +41,7 @@ module SchnorrSig
|
|
40
41
|
big2bin(val)
|
41
42
|
when ECDSA::Point
|
42
43
|
# BIP340: The function bytes(P), where P is a point, returns bytes(x(P)).
|
43
|
-
val.infinity? ? (
|
44
|
+
val.infinity? ? raise(InfinityPoint, va.inspect) : big2bin(val.x)
|
44
45
|
else
|
45
46
|
raise(SanityCheck, val.inspect)
|
46
47
|
end
|
@@ -150,7 +151,7 @@ module SchnorrSig
|
|
150
151
|
end
|
151
152
|
|
152
153
|
# BIP340: The function lift_x(x), where x is a 256-bit unsigned integer,
|
153
|
-
# returns the point P for which x(P) = x
|
154
|
+
# returns the point P for which x(P) = x and has_even_y(P),
|
154
155
|
# or fails if x is greater than p-1 or no such point exists.
|
155
156
|
# Input
|
156
157
|
# A large integer, x
|