PRCYCoin  2.0.0.7rc1
P2P Digital Currency
eccryptoverify.cpp
Go to the documentation of this file.
1 // Copyright (c) 2009-2010 Satoshi Nakamoto
2 // Copyright (c) 2009-2014 The Bitcoin developers
3 // Distributed under the MIT software license, see the accompanying
4 // file COPYING or http://www.opensource.org/licenses/mit-license.php.
5 
6 #include "eccryptoverify.h"
7 
8 namespace
9 {
10 int CompareBigEndian(const unsigned char* c1, size_t c1len, const unsigned char* c2, size_t c2len)
11 {
12  while (c1len > c2len) {
13  if (*c1)
14  return 1;
15  c1++;
16  c1len--;
17  }
18  while (c2len > c1len) {
19  if (*c2)
20  return -1;
21  c2++;
22  c2len--;
23  }
24  while (c1len > 0) {
25  if (*c1 > *c2)
26  return 1;
27  if (*c2 > *c1)
28  return -1;
29  c1++;
30  c2++;
31  c1len--;
32  }
33  return 0;
34 }
35 
37 const unsigned char vchMaxModOrder[32] = {
38  0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF,
39  0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFE,
40  0xBA, 0xAE, 0xDC, 0xE6, 0xAF, 0x48, 0xA0, 0x3B,
41  0xBF, 0xD2, 0x5E, 0x8C, 0xD0, 0x36, 0x41, 0x40};
42 
44 const unsigned char vchMaxModHalfOrder[32] = {
45  0x7F, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF,
46  0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF,
47  0x5D, 0x57, 0x6E, 0x73, 0x57, 0xA4, 0x50, 0x1D,
48  0xDF, 0xE9, 0x2F, 0x46, 0x68, 0x1B, 0x20, 0xA0};
49 
50 const unsigned char vchZero[1] = {0};
51 } // anon namespace
52 
53 namespace eccrypto
54 {
55 bool Check(const unsigned char* vch)
56 {
57  return vch &&
58  CompareBigEndian(vch, 32, vchZero, 0) > 0 &&
59  CompareBigEndian(vch, 32, vchMaxModOrder, 32) <= 0;
60 }
61 
62 bool CheckSignatureElement(const unsigned char* vch, int len, bool half)
63 {
64  return vch &&
65  CompareBigEndian(vch, len, vchZero, 0) > 0 &&
66  CompareBigEndian(vch, len, half ? vchMaxModHalfOrder : vchMaxModOrder, 32) <= 0;
67 }
68 
69 } // namespace eccrypto
eccrypto::CheckSignatureElement
bool CheckSignatureElement(const unsigned char *vch, int len, bool half)
Definition: eccryptoverify.cpp:62
eccrypto::Check
bool Check(const unsigned char *vch)
Definition: eccryptoverify.cpp:55
eccryptoverify.h
eccrypto
Definition: eccryptoverify.cpp:53