wallet_validator 0.3.3 → 0.4.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: f3ac603fed93cd9dce85b3ffe8ea60e10489721c4f55d16296f6ae0c35b6c13b
4
- data.tar.gz: 8852e861273715a6d05362427c2258e23ae5dddb34b849d3afa58cb3b94b0e23
3
+ metadata.gz: 29724f86c1f4be8d63ee893baaac6514dbc1308ef1af99d9942fe450bf8d59a0
4
+ data.tar.gz: 87719c18db6cdf807dd2d59eb850cf83d4393f928af6b670202e8ca98437362d
5
5
  SHA512:
6
- metadata.gz: 5f63d1547da43cf4c0593e4eca8ac87d5ce38445f3b3cea1c2574d3c816e8440d55c32a7b4cacbaacadb6183f2dcb2e6cefc56da208834207600bf132aed23c6
7
- data.tar.gz: a8e8eade81642220cda1d0a76a8df52cf48d812e3cbcacb470362a420b87b2c90f0ff003372b5b4a71646effc617253167fda255a9d5a2885fe1ae31e63160ea
6
+ metadata.gz: 3c48d03542cd0b8fed79bfa492903341d0c587f140bd8cfa8e277ab8d93b72eb52169ebefb5b2791d40cb2d685486dbb84c5568b862127b69c86d429566f8b51
7
+ data.tar.gz: 1928196c30b53e84d65fc092b539245fcaf618bfb5f0101d85595fed2ec6d3032eaa1e8400b56362fe3d43f898fe11106710d6edc577e48cd9703e7e636927c6
data/Gemfile CHANGED
@@ -5,4 +5,6 @@ gemspec
5
5
 
6
6
  gem "rake", "~> 12.0"
7
7
  gem "rspec", "~> 3.0"
8
- gem "digest-sha3"
8
+ gem "digest-sha3"
9
+ gem "base58"
10
+ gem "cbor"
data/Gemfile.lock CHANGED
@@ -1,11 +1,13 @@
1
1
  PATH
2
2
  remote: .
3
3
  specs:
4
- wallet_validator (0.3.2)
4
+ wallet_validator (0.4.3)
5
5
 
6
6
  GEM
7
7
  remote: https://rubygems.org/
8
8
  specs:
9
+ base58 (0.2.3)
10
+ cbor (0.5.9.6)
9
11
  diff-lcs (1.4.4)
10
12
  digest-sha3 (1.1.0)
11
13
  rake (12.3.3)
@@ -27,6 +29,8 @@ PLATFORMS
27
29
  ruby
28
30
 
29
31
  DEPENDENCIES
32
+ base58
33
+ cbor
30
34
  digest-sha3
31
35
  rake (~> 12.0)
32
36
  rspec (~> 3.0)
@@ -1,3 +1,5 @@
1
+ require "cbor"
2
+ require 'zlib'
1
3
 
2
4
  module WalletValidator
3
5
  class Ada < Btc
@@ -17,11 +19,31 @@ module WalletValidator
17
19
  }.freeze
18
20
 
19
21
  def valid?
20
- Crypto::Bech32.valid?(address, attribute["bech32"]["hrp"], attribute["bech32"]["separator"], attribute["bech32"]["length_check"])
22
+ valid_address_v1? || valid_address_shelley?
21
23
  end
22
24
 
23
25
  private
24
26
 
27
+ def valid_address_v1?
28
+ begin
29
+ decoded_baase58 = Crypto::Base58.base58_to_binary(address, "ADA")
30
+
31
+ tagged, valid_crc = CBOR.decode(decoded_baase58)
32
+
33
+ return false if !valid_crc.is_a?(Numeric)
34
+
35
+ crc = Zlib::crc32(tagged.value)
36
+
37
+ return crc == valid_crc
38
+ rescue
39
+ return false
40
+ end
41
+ end
42
+
43
+ def valid_address_shelley?
44
+ Crypto::Bech32.valid?(address, attribute["bech32"]["hrp"], attribute["bech32"]["separator"])
45
+ end
46
+
25
47
  def attribute
26
48
  is_testnet && CURRENCY_ATTR["testnet"] ? CURRENCY_ATTR["testnet"] : CURRENCY_ATTR["main"]
27
49
  end
@@ -8,20 +8,18 @@ module WalletValidator
8
8
  "bech32" => {
9
9
  "hrp" => "bnb", # hrp
10
10
  "separator" => "1", # separator
11
- "length_check" => [38] # length check
12
11
  },
13
12
  },
14
13
  "testnet" => {
15
14
  "bech32" => {
16
15
  "hrp" => "tbnb", # hrp
17
16
  "separator" => "1", # separator
18
- "length_check" => [38] # length check
19
17
  }
20
18
  }
21
19
  }.freeze
22
20
 
23
21
  def valid?
24
- Crypto::Bech32.valid?(address, attribute["bech32"]["hrp"], attribute["bech32"]["separator"], attribute["bech32"]["length_check"])
22
+ Crypto::Bech32.valid?(address, attribute["bech32"]["hrp"], attribute["bech32"]["separator"])
25
23
  end
26
24
 
27
25
  private
@@ -37,7 +37,7 @@ module WalletValidator
37
37
 
38
38
  if filter_def
39
39
  # false時繼續往下
40
- return true if Crypto::Bech32.valid?(address, filter_def["hrp"], filter_def["separator"], filter_def["length_check"])
40
+ return true if Crypto::Bech32.valid?(address, filter_def["hrp"], filter_def["separator"])
41
41
  end
42
42
 
43
43
  filter = attribute["filter"]
@@ -3,10 +3,16 @@ module Crypto
3
3
  ALPHABET = {
4
4
  :flickr => "123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ", # This is the default
5
5
  :ripple => "rpshnaf39wBUDNEGHJKLM4PQRST7VWXYZ2bcdeCg65jkm8oFqi1tuvAxyz",
6
+ :cardano => "123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"
6
7
  }.freeze
7
8
 
8
9
  def self.base58_to_binary(base58_val, currency)
9
- alphabet = currency.downcase == "xrp" ? ALPHABET[:ripple] : ALPHABET[:flickr]
10
+ alphabet = case currency.downcase
11
+ when "xrp"
12
+ ALPHABET[:ripple]
13
+ else
14
+ ALPHABET[:flickr]
15
+ end
10
16
 
11
17
  nzeroes = nil
12
18
  base58_val.chars.each_with_index do |c, index|
@@ -26,7 +32,14 @@ module Crypto
26
32
  end
27
33
 
28
34
  def self.base58_to_int(base58_val, currency)
29
- alphabet = currency.downcase == "xrp" ? ALPHABET[:ripple] : ALPHABET[:flickr]
35
+ alphabet = case currency.downcase
36
+ when "xrp"
37
+ ALPHABET[:ripple]
38
+ when "ada"
39
+ ALPHABET[:cardano]
40
+ else
41
+ ALPHABET[:flickr]
42
+ end
30
43
 
31
44
  int_val = 0
32
45
  base58_val.reverse.split(//).each_with_index do |char, index|
@@ -1,16 +1,13 @@
1
1
  module Crypto
2
2
  module Bech32
3
- LENGTH_CHECK_SET = [39, 59, 98].freeze
4
3
  CHARSET = "qpzry9x8gf2tvdw0s3jn54khce6mua7l".split(//)
5
4
  GENERATOR = [0x3b6a57b2, 0x26508e6d, 0x1ea119fa, 0x3d4233dd, 0x2a1462b3].freeze
6
5
 
7
- def self.valid?(address, hrp, separator, length_set = LENGTH_CHECK_SET)
8
- length_set ||= LENGTH_CHECK_SET # 歸正
6
+ def self.valid?(address, hrp, separator)
9
7
  address = address.downcase.strip
10
8
 
11
9
  match = address.match(/^#{hrp}#{separator}([\da-z]+)$/)
12
10
  return false if !match
13
- return false if !length_set.include?(match[1].length)
14
11
 
15
12
  pos = address.rindex(separator)
16
13
  return false if pos.nil? || pos < 1 || pos + 7 > address.length || address.length > 108
@@ -1,3 +1,3 @@
1
1
  module WalletValidator
2
- VERSION = "0.3.3"
2
+ VERSION = "0.4.3"
3
3
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: wallet_validator
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.3.3
4
+ version: 0.4.3
5
5
  platform: ruby
6
6
  authors:
7
7
  - Nic
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2021-10-18 00:00:00.000000000 Z
11
+ date: 2021-10-25 00:00:00.000000000 Z
12
12
  dependencies: []
13
13
  description: Write a longer description or delete this line.
14
14
  email: