peatio-ndc 0.2.1 → 0.2.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.travis.yml +1 -3
- data/CHANGELOG.md +0 -0
- data/CODE_OF_CONDUCT.md +74 -0
- data/Gemfile +4 -3
- data/Gemfile.lock +94 -10
- data/LICENSE.txt +1 -1
- data/README.md +13 -36
- data/lib/peatio/ndc.rb +5 -0
- data/lib/peatio/ndc/blockchain.rb +23 -22
- data/lib/peatio/ndc/client.rb +25 -21
- data/lib/peatio/ndc/hooks.rb +7 -4
- data/lib/peatio/ndc/railtie.rb +3 -0
- data/lib/peatio/ndc/version.rb +1 -1
- data/lib/peatio/ndc/wallet.rb +15 -14
- data/peatio-ndc.gemspec +19 -15
- metadata +83 -30
- data/config/blockchains.yml +0 -10
- data/config/currencies.yml +0 -18
- data/config/wallets.yml +0 -44
- data/docs/integration.md +0 -29
- data/docs/json-rpc.md +0 -29
- data/peatio-ndc-0.1.0.gem +0 -0
- data/peatio-ndc-0.1.1.gem +0 -0
- data/peatio-ndc-0.1.2.gem +0 -0
- data/peatio-ndc-0.1.3.gem +0 -0
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: ca92d7872c52df3e6caab7a8dc0f10f970b753d4aab007f0676275d731c38603
|
4
|
+
data.tar.gz: 98dc57297a2285be0dce49550a9e0410393c34ceaf6f48aaa908144ac429b692
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 46cf47e863f7cc790f2d4dcd2c464daf02ff1f32bceee479fe1416086d0132284600618419f1c1b90a6126b33310c2b5083c1c542525435103ace2de836c2b3b
|
7
|
+
data.tar.gz: 38cab011b4fca422f717ea3d8d4a7839489dedefdf6ad111f8c085f9c5f7fd01b8af2e0ea51b001f5d6ef2ed07924a90e735a9cf025aaaf1929f43b36d80c1e8
|
data/.travis.yml
CHANGED
data/CHANGELOG.md
ADDED
File without changes
|
data/CODE_OF_CONDUCT.md
ADDED
@@ -0,0 +1,74 @@
|
|
1
|
+
# Contributor Covenant Code of Conduct
|
2
|
+
|
3
|
+
## Our Pledge
|
4
|
+
|
5
|
+
In the interest of fostering an open and welcoming environment, we as
|
6
|
+
contributors and maintainers pledge to making participation in our project and
|
7
|
+
our community a harassment-free experience for everyone, regardless of age, body
|
8
|
+
size, disability, ethnicity, gender identity and expression, level of experience,
|
9
|
+
nationality, personal appearance, race, religion, or sexual identity and
|
10
|
+
orientation.
|
11
|
+
|
12
|
+
## Our Standards
|
13
|
+
|
14
|
+
Examples of behavior that contributes to creating a positive environment
|
15
|
+
include:
|
16
|
+
|
17
|
+
* Using welcoming and inclusive language
|
18
|
+
* Being respectful of differing viewpoints and experiences
|
19
|
+
* Gracefully accepting constructive criticism
|
20
|
+
* Focusing on what is best for the community
|
21
|
+
* Showing empathy towards other community members
|
22
|
+
|
23
|
+
Examples of unacceptable behavior by participants include:
|
24
|
+
|
25
|
+
* The use of sexualized language or imagery and unwelcome sexual attention or
|
26
|
+
advances
|
27
|
+
* Trolling, insulting/derogatory comments, and personal or political attacks
|
28
|
+
* Public or private harassment
|
29
|
+
* Publishing others' private information, such as a physical or electronic
|
30
|
+
address, without explicit permission
|
31
|
+
* Other conduct which could reasonably be considered inappropriate in a
|
32
|
+
professional setting
|
33
|
+
|
34
|
+
## Our Responsibilities
|
35
|
+
|
36
|
+
Project maintainers are responsible for clarifying the standards of acceptable
|
37
|
+
behavior and are expected to take appropriate and fair corrective action in
|
38
|
+
response to any instances of unacceptable behavior.
|
39
|
+
|
40
|
+
Project maintainers have the right and responsibility to remove, edit, or
|
41
|
+
reject comments, commits, code, wiki edits, issues, and other contributions
|
42
|
+
that are not aligned to this Code of Conduct, or to ban temporarily or
|
43
|
+
permanently any contributor for other behaviors that they deem inappropriate,
|
44
|
+
threatening, offensive, or harmful.
|
45
|
+
|
46
|
+
## Scope
|
47
|
+
|
48
|
+
This Code of Conduct applies both within project spaces and in public spaces
|
49
|
+
when an individual is representing the project or its community. Examples of
|
50
|
+
representing a project or community include using an official project e-mail
|
51
|
+
address, posting via an official social media account, or acting as an appointed
|
52
|
+
representative at an online or offline event. Representation of a project may be
|
53
|
+
further defined and clarified by project maintainers.
|
54
|
+
|
55
|
+
## Enforcement
|
56
|
+
|
57
|
+
Instances of abusive, harassing, or otherwise unacceptable behavior may be
|
58
|
+
reported by contacting the project team at tanvirtex@gmail.com. All
|
59
|
+
complaints will be reviewed and investigated and will result in a response that
|
60
|
+
is deemed necessary and appropriate to the circumstances. The project team is
|
61
|
+
obligated to maintain confidentiality with regard to the reporter of an incident.
|
62
|
+
Further details of specific enforcement policies may be posted separately.
|
63
|
+
|
64
|
+
Project maintainers who do not follow or enforce the Code of Conduct in good
|
65
|
+
faith may face temporary or permanent repercussions as determined by other
|
66
|
+
members of the project's leadership.
|
67
|
+
|
68
|
+
## Attribution
|
69
|
+
|
70
|
+
This Code of Conduct is adapted from the [Contributor Covenant][homepage], version 1.4,
|
71
|
+
available at [https://contributor-covenant.org/version/1/4][version]
|
72
|
+
|
73
|
+
[homepage]: https://contributor-covenant.org
|
74
|
+
[version]: https://contributor-covenant.org/version/1/4/
|
data/Gemfile
CHANGED
@@ -1,6 +1,7 @@
|
|
1
1
|
source "https://rubygems.org"
|
2
2
|
|
3
|
-
|
4
|
-
|
5
|
-
# Specify your gem's dependencies in peatio-umbru.gemspec
|
3
|
+
# Specify your gem's dependencies in peatio-ndc.gemspec
|
6
4
|
gemspec
|
5
|
+
|
6
|
+
gem "rake", "~> 12.0"
|
7
|
+
gem "rspec", "~> 3.0"
|
data/Gemfile.lock
CHANGED
@@ -1,12 +1,13 @@
|
|
1
1
|
PATH
|
2
2
|
remote: .
|
3
3
|
specs:
|
4
|
-
peatio-ndc (0.2.
|
4
|
+
peatio-ndc (0.2.2)
|
5
5
|
activesupport (~> 5.2.3)
|
6
6
|
better-faraday (~> 1.0.5)
|
7
|
-
faraday (~> 0.
|
7
|
+
faraday (~> 0.17)
|
8
8
|
memoist (~> 0.16.0)
|
9
|
-
|
9
|
+
net-http-persistent (~> 3.0.1)
|
10
|
+
peatio (>= 0.6.3)
|
10
11
|
|
11
12
|
GEM
|
12
13
|
remote: https://rubygems.org/
|
@@ -24,6 +25,7 @@ GEM
|
|
24
25
|
amqp (1.8.0)
|
25
26
|
amq-protocol (>= 2.2.0)
|
26
27
|
eventmachine
|
28
|
+
ast (2.4.0)
|
27
29
|
better-faraday (1.0.8)
|
28
30
|
activesupport (>= 4.0, < 6.0)
|
29
31
|
faraday (~> 0.12)
|
@@ -33,35 +35,78 @@ GEM
|
|
33
35
|
clamp (1.3.1)
|
34
36
|
coderay (1.1.2)
|
35
37
|
concurrent-ruby (1.1.6)
|
38
|
+
connection_pool (2.2.2)
|
39
|
+
cookiejar (0.3.3)
|
36
40
|
crack (0.4.3)
|
37
41
|
safe_yaml (~> 1.0.0)
|
42
|
+
daemons (1.3.1)
|
38
43
|
diff-lcs (1.3)
|
44
|
+
docile (1.3.2)
|
45
|
+
em-http-request (1.1.5)
|
46
|
+
addressable (>= 2.3.4)
|
47
|
+
cookiejar (!= 0.3.1)
|
48
|
+
em-socksify (>= 0.3)
|
49
|
+
eventmachine (>= 1.0.3)
|
50
|
+
http_parser.rb (>= 0.6.0)
|
51
|
+
em-socksify (0.3.2)
|
52
|
+
eventmachine (>= 1.0.0.beta.4)
|
53
|
+
em-synchrony (1.0.6)
|
54
|
+
eventmachine (>= 1.0.0.beta.1)
|
39
55
|
em-websocket (0.5.1)
|
40
56
|
eventmachine (>= 0.12.9)
|
41
57
|
http_parser.rb (~> 0.6.0)
|
42
58
|
eventmachine (1.2.7)
|
43
|
-
faraday (0.
|
59
|
+
faraday (0.17.3)
|
44
60
|
multipart-post (>= 1.2, < 3)
|
61
|
+
faraday_middleware (0.13.1)
|
62
|
+
faraday (>= 0.7.4, < 1.0)
|
63
|
+
faye (1.2.5)
|
64
|
+
cookiejar (>= 0.3.0)
|
65
|
+
em-http-request (>= 0.3.0)
|
66
|
+
eventmachine (>= 0.12.0)
|
67
|
+
faye-websocket (>= 0.9.1)
|
68
|
+
multi_json (>= 1.0.0)
|
69
|
+
rack (>= 1.0.0)
|
70
|
+
websocket-driver (>= 0.5.1)
|
71
|
+
faye-websocket (0.10.9)
|
72
|
+
eventmachine (>= 0.12.0)
|
73
|
+
websocket-driver (>= 0.5.1)
|
45
74
|
hashdiff (1.0.1)
|
46
75
|
http_parser.rb (0.6.0)
|
47
76
|
i18n (1.8.2)
|
48
77
|
concurrent-ruby (~> 1.0)
|
78
|
+
io-console (0.5.6)
|
79
|
+
irb (1.2.4)
|
80
|
+
reline (>= 0.0.1)
|
81
|
+
jaro_winkler (1.5.4)
|
49
82
|
jwt (2.2.1)
|
50
83
|
memoist (0.16.2)
|
51
84
|
method_source (1.0.0)
|
52
85
|
minitest (5.14.1)
|
53
86
|
mocha (1.11.2)
|
87
|
+
multi_json (1.14.1)
|
54
88
|
multipart-post (2.1.1)
|
55
89
|
mysql2 (0.5.3)
|
56
|
-
|
90
|
+
net-http-persistent (3.0.1)
|
91
|
+
connection_pool (~> 2.2)
|
92
|
+
parallel (1.19.1)
|
93
|
+
parser (2.7.1.3)
|
94
|
+
ast (~> 2.4.0)
|
95
|
+
peatio (2.4.4)
|
57
96
|
activemodel (> 5.2, <= 6.0.0)
|
58
97
|
amqp
|
59
98
|
bunny
|
60
99
|
clamp
|
100
|
+
em-synchrony (~> 1.0)
|
61
101
|
em-websocket
|
62
102
|
eventmachine
|
103
|
+
faraday_middleware (~> 0.13.1)
|
104
|
+
faye (~> 1.2)
|
63
105
|
jwt
|
64
106
|
mysql2
|
107
|
+
prometheus-client
|
108
|
+
thin
|
109
|
+
prometheus-client (2.0.0)
|
65
110
|
pry (0.13.1)
|
66
111
|
coderay (~> 1.1)
|
67
112
|
method_source (~> 1.0)
|
@@ -69,7 +114,12 @@ GEM
|
|
69
114
|
byebug (~> 11.0)
|
70
115
|
pry (~> 0.13.0)
|
71
116
|
public_suffix (4.0.5)
|
72
|
-
|
117
|
+
rack (2.2.2)
|
118
|
+
rainbow (3.0.0)
|
119
|
+
rake (12.3.3)
|
120
|
+
reline (0.1.4)
|
121
|
+
io-console (~> 0.5)
|
122
|
+
rexml (3.2.4)
|
73
123
|
rspec (3.9.0)
|
74
124
|
rspec-core (~> 3.9.0)
|
75
125
|
rspec-expectations (~> 3.9.0)
|
@@ -83,26 +133,60 @@ GEM
|
|
83
133
|
diff-lcs (>= 1.2.0, < 2.0)
|
84
134
|
rspec-support (~> 3.9.0)
|
85
135
|
rspec-support (3.9.3)
|
136
|
+
rubocop (0.82.0)
|
137
|
+
jaro_winkler (~> 1.5.1)
|
138
|
+
parallel (~> 1.10)
|
139
|
+
parser (>= 2.7.0.1)
|
140
|
+
rainbow (>= 2.2.2, < 4.0)
|
141
|
+
rexml
|
142
|
+
ruby-progressbar (~> 1.7)
|
143
|
+
unicode-display_width (>= 1.4.0, < 2.0)
|
144
|
+
rubocop-github (0.16.0)
|
145
|
+
rubocop (<= 0.82.0)
|
146
|
+
rubocop-performance (~> 1.0)
|
147
|
+
rubocop-rails (~> 2.0)
|
148
|
+
rubocop-performance (1.6.0)
|
149
|
+
rubocop (>= 0.71.0)
|
150
|
+
rubocop-rails (2.5.2)
|
151
|
+
activesupport
|
152
|
+
rack (>= 1.1)
|
153
|
+
rubocop (>= 0.72.0)
|
154
|
+
ruby-progressbar (1.10.1)
|
86
155
|
safe_yaml (1.0.5)
|
156
|
+
simplecov (0.18.5)
|
157
|
+
docile (~> 1.1)
|
158
|
+
simplecov-html (~> 0.11)
|
159
|
+
simplecov-html (0.12.2)
|
160
|
+
thin (1.7.2)
|
161
|
+
daemons (~> 1.0, >= 1.0.9)
|
162
|
+
eventmachine (~> 1.0, >= 1.0.4)
|
163
|
+
rack (>= 1, < 3)
|
87
164
|
thread_safe (0.3.6)
|
88
165
|
tzinfo (1.2.7)
|
89
166
|
thread_safe (~> 0.1)
|
167
|
+
unicode-display_width (1.7.0)
|
90
168
|
webmock (3.8.3)
|
91
169
|
addressable (>= 2.3.6)
|
92
170
|
crack (>= 0.3.2)
|
93
171
|
hashdiff (>= 0.4.0, < 2.0.0)
|
172
|
+
websocket-driver (0.7.2)
|
173
|
+
websocket-extensions (>= 0.1.0)
|
174
|
+
websocket-extensions (0.1.4)
|
94
175
|
|
95
176
|
PLATFORMS
|
96
177
|
ruby
|
97
178
|
|
98
179
|
DEPENDENCIES
|
99
|
-
bundler (~>
|
180
|
+
bundler (~> 1.17)
|
181
|
+
irb
|
100
182
|
mocha (~> 1.8)
|
101
183
|
peatio-ndc!
|
102
|
-
pry-byebug
|
103
|
-
rake (~>
|
184
|
+
pry-byebug
|
185
|
+
rake (~> 12.0)
|
104
186
|
rspec (~> 3.0)
|
187
|
+
rubocop-github
|
188
|
+
simplecov
|
105
189
|
webmock (~> 3.5)
|
106
190
|
|
107
191
|
BUNDLED WITH
|
108
|
-
|
192
|
+
1.17.3
|
data/LICENSE.txt
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
The MIT License (MIT)
|
2
2
|
|
3
|
-
Copyright (c) 2020 Md Tanvir Rahaman
|
3
|
+
Copyright (c) 2020 Md Tanvir Rahaman
|
4
4
|
|
5
5
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
6
6
|
of this software and associated documentation files (the "Software"), to deal
|
data/README.md
CHANGED
@@ -1,6 +1,8 @@
|
|
1
|
-
# Peatio::
|
1
|
+
# Peatio::Ndc
|
2
2
|
|
3
|
-
|
3
|
+
Welcome to your new gem! In this directory, you'll find the files you need to be able to package up your Ruby library into a gem. Put your Ruby code in the file `lib/peatio/ndc`. To experiment with that code, run `bin/console` for an interactive prompt.
|
4
|
+
|
5
|
+
TODO: Delete this and the text above, and describe your gem
|
4
6
|
|
5
7
|
## Installation
|
6
8
|
|
@@ -12,7 +14,7 @@ gem 'peatio-ndc'
|
|
12
14
|
|
13
15
|
And then execute:
|
14
16
|
|
15
|
-
$ bundle
|
17
|
+
$ bundle install
|
16
18
|
|
17
19
|
Or install it yourself as:
|
18
20
|
|
@@ -20,48 +22,23 @@ Or install it yourself as:
|
|
20
22
|
|
21
23
|
## Usage
|
22
24
|
|
23
|
-
|
24
|
-
|
25
|
-
### Image Build.
|
26
|
-
|
27
|
-
1. Add peatio-ndc gem into your Gemfile.plugin
|
28
|
-
```ruby
|
29
|
-
gem 'peatio-ndc', '~> 0.1.3'
|
30
|
-
```
|
31
|
-
|
32
|
-
2. Run `bundle install` for updating Gemfile.lock
|
33
|
-
|
34
|
-
3. Build custom Peatio [docker image with NDC plugin](https://github.com/nexbitio/peatio/blob/master/docs/plugins.md#build)
|
35
|
-
|
36
|
-
4. Push your image using `docker push`
|
37
|
-
|
38
|
-
5. Update your deployment to use image with peatio-ndc gem
|
39
|
-
|
40
|
-
### Peatio Configuration.
|
41
|
-
|
42
|
-
1. Create NDC Blockchain [config example](../config/blockchains.yml).
|
43
|
-
* No additional steps are needed
|
44
|
-
|
45
|
-
2. Create NDC Currency [config example](../config/currencies.yml).
|
46
|
-
* No additional steps are needed
|
47
|
-
|
48
|
-
3. Create NDC Wallets [config example](../config/wallets.yml)(deposit and hot wallets are required).
|
49
|
-
* No additional steps are needed
|
50
|
-
|
25
|
+
TODO: Write usage instructions here
|
51
26
|
|
52
27
|
## Development
|
53
28
|
|
54
|
-
|
29
|
+
After checking out the repo, run `bin/setup` to install dependencies. Then, run `rake spec` to run the tests. You can also run `bin/console` for an interactive prompt that will allow you to experiment.
|
30
|
+
|
31
|
+
To install this gem onto your local machine, run `bundle exec rake install`. To release a new version, update the version number in `version.rb`, and then run `bundle exec rake release`, which will create a git tag for the version, push git commits and tags, and push the `.gem` file to [rubygems.org](https://rubygems.org).
|
55
32
|
|
56
33
|
## Contributing
|
57
34
|
|
58
|
-
Bug reports and pull requests are welcome on GitHub at https://github.com/
|
35
|
+
Bug reports and pull requests are welcome on GitHub at https://github.com/[USERNAME]/peatio-ndc. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the [code of conduct](https://github.com/[USERNAME]/peatio-ndc/blob/master/CODE_OF_CONDUCT.md).
|
36
|
+
|
59
37
|
|
60
38
|
## License
|
61
39
|
|
62
40
|
The gem is available as open source under the terms of the [MIT License](https://opensource.org/licenses/MIT).
|
63
41
|
|
64
|
-
##
|
42
|
+
## Code of Conduct
|
65
43
|
|
66
|
-
|
67
|
-
[NEXBIT.IO](https://www.nexbit.io)
|
44
|
+
Everyone interacting in the Peatio::Ndc project's codebases, issue trackers, chat rooms and mailing lists is expected to follow the [code of conduct](https://github.com/[USERNAME]/peatio-ndc/blob/master/CODE_OF_CONDUCT.md).
|
data/lib/peatio/ndc.rb
CHANGED
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
require "active_support/core_ext/object/blank"
|
2
4
|
require "active_support/core_ext/enumerable"
|
3
5
|
require "peatio"
|
@@ -6,10 +8,13 @@ module Peatio
|
|
6
8
|
module Ndc
|
7
9
|
require "bigdecimal"
|
8
10
|
require "bigdecimal/util"
|
11
|
+
|
9
12
|
require "peatio/ndc/blockchain"
|
10
13
|
require "peatio/ndc/client"
|
11
14
|
require "peatio/ndc/wallet"
|
15
|
+
|
12
16
|
require "peatio/ndc/hooks"
|
17
|
+
|
13
18
|
require "peatio/ndc/version"
|
14
19
|
end
|
15
20
|
end
|
@@ -1,17 +1,17 @@
|
|
1
|
+
# frozen_string_literal: true
|
1
2
|
|
2
3
|
module Peatio
|
3
4
|
module Ndc
|
4
5
|
# TODO: Processing of unconfirmed transactions from mempool isn't supported now.
|
5
6
|
class Blockchain < Peatio::Blockchain::Abstract
|
6
|
-
|
7
7
|
DEFAULT_FEATURES = {case_sensitive: true, cash_addr_format: false}.freeze
|
8
8
|
|
9
|
-
def initialize(custom_features
|
9
|
+
def initialize(custom_features={})
|
10
10
|
@features = DEFAULT_FEATURES.merge(custom_features).slice(*SUPPORTED_FEATURES)
|
11
11
|
@settings = {}
|
12
12
|
end
|
13
13
|
|
14
|
-
def configure(settings
|
14
|
+
def configure(settings={})
|
15
15
|
# Clean client state during configure.
|
16
16
|
@client = nil
|
17
17
|
@settings.merge!(settings.slice(*SUPPORTED_SETTINGS))
|
@@ -20,13 +20,15 @@ module Peatio
|
|
20
20
|
def fetch_block!(block_number)
|
21
21
|
block_hash = client.json_rpc(:getblockhash, [block_number])
|
22
22
|
|
23
|
-
client.json_rpc(:getblock, [block_hash, 2])
|
24
|
-
|
23
|
+
block_txs = client.json_rpc(:getblock, [block_hash, 2])
|
24
|
+
.fetch("tx").each_with_object([]) do |tx, txs_array|
|
25
25
|
txs = build_transaction(tx).map do |ntx|
|
26
26
|
Peatio::Transaction.new(ntx.merge(block_number: block_number))
|
27
27
|
end
|
28
28
|
txs_array.append(*txs)
|
29
|
-
end
|
29
|
+
end
|
30
|
+
|
31
|
+
Peatio::Block.new(block_number, block_txs)
|
30
32
|
rescue Client::Error => e
|
31
33
|
raise Peatio::Blockchain::ClientError, e
|
32
34
|
end
|
@@ -39,12 +41,10 @@ module Peatio
|
|
39
41
|
|
40
42
|
def load_balance_of_address!(address, _currency_id)
|
41
43
|
address_with_balance = client.json_rpc(:listaddressgroupings)
|
42
|
-
|
43
|
-
|
44
|
+
.flatten(1)
|
45
|
+
.find {|addr| addr[0] == address }
|
44
46
|
|
45
|
-
if address_with_balance.blank?
|
46
|
-
raise Peatio::Blockchain::UnavailableAddressBalanceError, address
|
47
|
-
end
|
47
|
+
raise Peatio::Blockchain::UnavailableAddressBalanceError, address if address_with_balance.blank?
|
48
48
|
|
49
49
|
address_with_balance[1].to_d
|
50
50
|
rescue Client::Error => e
|
@@ -53,18 +53,18 @@ module Peatio
|
|
53
53
|
|
54
54
|
private
|
55
55
|
|
56
|
-
def
|
57
|
-
tx_hash.fetch(
|
58
|
-
.
|
59
|
-
entry.fetch('value').to_d > 0 &&
|
60
|
-
entry['scriptPubKey'].has_key?('addresses')
|
56
|
+
def filter_vout(tx_hash)
|
57
|
+
tx_hash.fetch("vout").select do |entry|
|
58
|
+
entry.fetch("value").to_d.positive? && entry["scriptPubKey"].has_key?("addresses")
|
61
59
|
end
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
60
|
+
end
|
61
|
+
|
62
|
+
def build_transaction(tx_hash)
|
63
|
+
filter_vout(tx_hash).each_with_object([]) do |entry, formatted_txs|
|
64
|
+
no_currency_tx = {hash: tx_hash["txid"], txout: entry["n"],
|
65
|
+
to_address: entry["scriptPubKey"]["addresses"][0],
|
66
|
+
amount: entry.fetch("value").to_d,
|
67
|
+
status: "success"}
|
68
68
|
|
69
69
|
# Build transaction for each currency belonging to blockchain.
|
70
70
|
settings_fetch(:currencies).pluck(:id).each do |currency_id|
|
@@ -83,3 +83,4 @@ module Peatio
|
|
83
83
|
end
|
84
84
|
end
|
85
85
|
end
|
86
|
+
|
data/lib/peatio/ndc/client.rb
CHANGED
@@ -1,12 +1,14 @@
|
|
1
|
-
|
2
|
-
|
3
|
-
require
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require "memoist"
|
4
|
+
require "faraday"
|
5
|
+
require "better-faraday"
|
4
6
|
|
5
7
|
module Peatio
|
6
8
|
module Ndc
|
7
9
|
class Client
|
8
10
|
Error = Class.new(StandardError)
|
9
|
-
|
11
|
+
ConnectionError = Class.new(Error)
|
10
12
|
|
11
13
|
class ResponseError < Error
|
12
14
|
def initialize(code, msg)
|
@@ -25,37 +27,39 @@ module Peatio
|
|
25
27
|
@json_rpc_endpoint = URI.parse(endpoint)
|
26
28
|
end
|
27
29
|
|
28
|
-
def json_rpc(method, params
|
29
|
-
response =
|
30
|
-
|
31
|
-
{ jsonrpc: '1.0', method: method, params: params }.to_json,
|
32
|
-
{ 'Accept' => 'application/json',
|
33
|
-
'Content-Type' => 'application/json' }
|
30
|
+
def json_rpc(method, params=[])
|
31
|
+
response = post(method, params)
|
32
|
+
|
34
33
|
response.assert_2xx!
|
35
34
|
response = JSON.parse(response.body)
|
36
|
-
|
37
|
-
response.
|
38
|
-
|
39
|
-
if e.is_a?(Error)
|
40
|
-
raise e
|
41
|
-
elsif e.is_a?(Faraday::Error)
|
42
|
-
raise ConnectionError, e
|
43
|
-
else
|
44
|
-
raise Error, e
|
35
|
+
|
36
|
+
response["error"].tap do |e|
|
37
|
+
raise ResponseError.new(e["code"], e["message"]) if e
|
45
38
|
end
|
39
|
+
|
40
|
+
response.fetch("result")
|
41
|
+
rescue Faraday::Error => e
|
42
|
+
raise ConnectionError, e
|
46
43
|
end
|
47
44
|
|
48
45
|
private
|
49
46
|
|
47
|
+
def post(method, params)
|
48
|
+
connection.post("/", {jsonrpc: "1.0", method: method, params: params}.to_json,
|
49
|
+
"Accept" => "application/json", "Content-Type" => "application/json")
|
50
|
+
end
|
51
|
+
|
50
52
|
def connection
|
51
|
-
Faraday.new(@json_rpc_endpoint)
|
53
|
+
@connection ||= Faraday.new(@json_rpc_endpoint) do |f|
|
54
|
+
f.adapter :net_http_persistent, pool_size: 5
|
55
|
+
end.tap do |connection|
|
52
56
|
unless @json_rpc_endpoint.user.blank?
|
53
57
|
connection.basic_auth(@json_rpc_endpoint.user,
|
54
58
|
@json_rpc_endpoint.password)
|
55
59
|
end
|
56
60
|
end
|
57
61
|
end
|
58
|
-
memoize :connection
|
59
62
|
end
|
60
63
|
end
|
61
64
|
end
|
65
|
+
|
data/lib/peatio/ndc/hooks.rb
CHANGED
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
module Peatio
|
2
4
|
module Ndc
|
3
5
|
module Hooks
|
@@ -12,7 +14,7 @@ module Peatio
|
|
12
14
|
"Ndc blockchain version requiremnt was not suttisfied by Peatio::Blockchain.",
|
13
15
|
"Ndc blockchain requires #{BLOCKCHAIN_VERSION_REQUIREMENT}.",
|
14
16
|
"Peatio::Blockchain version is #{Peatio::Blockchain::VERSION}"
|
15
|
-
].join('\n').tap {
|
17
|
+
].join('\n').tap {|s| Kernel.abort s }
|
16
18
|
end
|
17
19
|
|
18
20
|
unless Gem::Requirement.new(WALLET_VERSION_REQUIREMENT)
|
@@ -21,13 +23,13 @@ module Peatio
|
|
21
23
|
"Ndc wallet version requiremnt was not suttisfied by Peatio::Wallet.",
|
22
24
|
"Ndc wallet requires #{WALLET_VERSION_REQUIREMENT}.",
|
23
25
|
"Peatio::Wallet version is #{Peatio::Wallet::VERSION}"
|
24
|
-
].join('\n').tap {
|
26
|
+
].join('\n').tap {|s| Kernel.abort s }
|
25
27
|
end
|
26
28
|
end
|
27
29
|
|
28
30
|
def register
|
29
|
-
Peatio::Blockchain.registry[:ndc] = Ndc::Blockchain
|
30
|
-
Peatio::Wallet.registry[:ndcd] = Ndc::Wallet
|
31
|
+
Peatio::Blockchain.registry[:ndc] = Ndc::Blockchain
|
32
|
+
Peatio::Wallet.registry[:ndcd] = Ndc::Wallet
|
31
33
|
end
|
32
34
|
end
|
33
35
|
|
@@ -40,3 +42,4 @@ module Peatio
|
|
40
42
|
end
|
41
43
|
end
|
42
44
|
end
|
45
|
+
|
data/lib/peatio/ndc/railtie.rb
CHANGED
data/lib/peatio/ndc/version.rb
CHANGED
data/lib/peatio/ndc/wallet.rb
CHANGED
@@ -1,40 +1,41 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
module Peatio
|
2
4
|
module Ndc
|
3
5
|
class Wallet < Peatio::Wallet::Abstract
|
4
|
-
|
5
|
-
def initialize(settings = {})
|
6
|
+
def initialize(settings={})
|
6
7
|
@settings = settings
|
7
8
|
end
|
8
9
|
|
9
|
-
def configure(settings
|
10
|
+
def configure(settings={})
|
10
11
|
# Clean client state during configure.
|
11
12
|
@client = nil
|
12
13
|
|
13
14
|
@settings.merge!(settings.slice(*SUPPORTED_SETTINGS))
|
14
15
|
|
15
|
-
@wallet = @settings.fetch(:wallet)
|
16
|
+
@wallet = @settings.fetch(:wallet) {
|
16
17
|
raise Peatio::Wallet::MissingSettingError, :wallet
|
17
|
-
|
18
|
+
}.slice(:uri, :address)
|
18
19
|
|
19
|
-
@currency = @settings.fetch(:currency)
|
20
|
+
@currency = @settings.fetch(:currency) {
|
20
21
|
raise Peatio::Wallet::MissingSettingError, :currency
|
21
|
-
|
22
|
+
}.slice(:id, :base_factor, :options)
|
22
23
|
end
|
23
24
|
|
24
|
-
def create_address!(_options
|
25
|
-
{
|
25
|
+
def create_address!(_options={})
|
26
|
+
{address: client.json_rpc(:getnewaddress)}
|
26
27
|
rescue Ndc::Client::Error => e
|
27
28
|
raise Peatio::Wallet::ClientError, e
|
28
29
|
end
|
29
30
|
|
30
|
-
def create_transaction!(transaction, options
|
31
|
+
def create_transaction!(transaction, options={})
|
31
32
|
txid = client.json_rpc(:sendtoaddress,
|
32
33
|
[
|
33
34
|
transaction.to_address,
|
34
35
|
transaction.amount,
|
35
|
-
|
36
|
-
|
37
|
-
options[:subtract_fee].to_s ==
|
36
|
+
"",
|
37
|
+
"",
|
38
|
+
options[:subtract_fee].to_s == "true" # subtract fee from transaction amount.
|
38
39
|
])
|
39
40
|
transaction.hash = txid
|
40
41
|
transaction
|
@@ -44,7 +45,6 @@ module Peatio
|
|
44
45
|
|
45
46
|
def load_balance!
|
46
47
|
client.json_rpc(:getbalance).to_d
|
47
|
-
|
48
48
|
rescue Ndc::Client::Error => e
|
49
49
|
raise Peatio::Wallet::ClientError, e
|
50
50
|
end
|
@@ -58,3 +58,4 @@ module Peatio
|
|
58
58
|
end
|
59
59
|
end
|
60
60
|
end
|
61
|
+
|
data/peatio-ndc.gemspec
CHANGED
@@ -1,18 +1,19 @@
|
|
1
|
-
|
2
|
-
lib = File.expand_path("../lib", __FILE__)
|
3
|
-
$LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
|
4
|
-
require "peatio/ndc/version"
|
1
|
+
require_relative 'lib/peatio/ndc/version'
|
5
2
|
|
6
3
|
Gem::Specification.new do |spec|
|
7
4
|
spec.name = "peatio-ndc"
|
8
5
|
spec.version = Peatio::Ndc::VERSION
|
9
|
-
spec.authors = ["
|
10
|
-
spec.email = ["
|
6
|
+
spec.authors = ["Md Tanvir Rahaman"]
|
7
|
+
spec.email = ["tanvirtex@gmail.com"]
|
11
8
|
|
12
|
-
spec.summary = %q{
|
13
|
-
spec.description = %q{
|
14
|
-
spec.homepage = "https://ndcwallet.pro
|
9
|
+
spec.summary = %q{Peatio Blockchain Gem for NDC Wallet.}
|
10
|
+
spec.description = %q{Peatio Blockchain Plugin for easy integration of NDC Wallet Blockchain platform.}
|
11
|
+
spec.homepage = "https://ndcwallet.pro."
|
15
12
|
spec.license = "MIT"
|
13
|
+
spec.required_ruby_version = Gem::Requirement.new(">= 2.3.0")
|
14
|
+
spec.metadata["homepage_uri"] = spec.homepage
|
15
|
+
spec.metadata["source_code_uri"] = "https://github.com/ndcwallet/peatio-ndc"
|
16
|
+
spec.metadata["changelog_uri"] = "https://github.com/ndcwallet/peatio-ndc/blob/master/CHANGELOG.md"
|
16
17
|
|
17
18
|
# Specify which files should be added to the gem when it is released.
|
18
19
|
# The `git ls-files -z` loads the files in the RubyGem that have been added into git.
|
@@ -25,15 +26,18 @@ Gem::Specification.new do |spec|
|
|
25
26
|
|
26
27
|
spec.add_dependency "activesupport", "~> 5.2.3"
|
27
28
|
spec.add_dependency "better-faraday", "~> 1.0.5"
|
28
|
-
spec.add_dependency "faraday", "~> 0.
|
29
|
+
spec.add_dependency "faraday", "~> 0.17"
|
29
30
|
spec.add_dependency "memoist", "~> 0.16.0"
|
30
|
-
spec.add_dependency "peatio", "
|
31
|
-
|
31
|
+
spec.add_dependency "peatio", ">= 0.6.3"
|
32
|
+
spec.add_dependency 'net-http-persistent', '~> 3.0.1'
|
32
33
|
|
33
|
-
spec.add_development_dependency "bundler", "~>
|
34
|
+
spec.add_development_dependency "bundler", "~> 1.17"
|
35
|
+
spec.add_development_dependency "irb"
|
34
36
|
spec.add_development_dependency "mocha", "~> 1.8"
|
35
|
-
spec.add_development_dependency "pry-byebug"
|
36
|
-
spec.add_development_dependency "rake", "~>
|
37
|
+
spec.add_development_dependency "pry-byebug"
|
38
|
+
spec.add_development_dependency "rake", "~> 13.0"
|
37
39
|
spec.add_development_dependency "rspec", "~> 3.0"
|
40
|
+
spec.add_development_dependency "rubocop-github"
|
41
|
+
spec.add_development_dependency "simplecov"
|
38
42
|
spec.add_development_dependency "webmock", "~> 3.5"
|
39
43
|
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: peatio-ndc
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.2.
|
4
|
+
version: 0.2.2
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
|
-
-
|
7
|
+
- Md Tanvir Rahaman
|
8
8
|
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date: 2020-05-
|
11
|
+
date: 2020-05-28 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: activesupport
|
@@ -44,14 +44,14 @@ dependencies:
|
|
44
44
|
requirements:
|
45
45
|
- - "~>"
|
46
46
|
- !ruby/object:Gem::Version
|
47
|
-
version: 0.
|
47
|
+
version: '0.17'
|
48
48
|
type: :runtime
|
49
49
|
prerelease: false
|
50
50
|
version_requirements: !ruby/object:Gem::Requirement
|
51
51
|
requirements:
|
52
52
|
- - "~>"
|
53
53
|
- !ruby/object:Gem::Version
|
54
|
-
version: 0.
|
54
|
+
version: '0.17'
|
55
55
|
- !ruby/object:Gem::Dependency
|
56
56
|
name: memoist
|
57
57
|
requirement: !ruby/object:Gem::Requirement
|
@@ -70,30 +70,58 @@ dependencies:
|
|
70
70
|
name: peatio
|
71
71
|
requirement: !ruby/object:Gem::Requirement
|
72
72
|
requirements:
|
73
|
-
- -
|
73
|
+
- - ">="
|
74
74
|
- !ruby/object:Gem::Version
|
75
75
|
version: 0.6.3
|
76
76
|
type: :runtime
|
77
77
|
prerelease: false
|
78
78
|
version_requirements: !ruby/object:Gem::Requirement
|
79
79
|
requirements:
|
80
|
-
- -
|
80
|
+
- - ">="
|
81
81
|
- !ruby/object:Gem::Version
|
82
82
|
version: 0.6.3
|
83
|
+
- !ruby/object:Gem::Dependency
|
84
|
+
name: net-http-persistent
|
85
|
+
requirement: !ruby/object:Gem::Requirement
|
86
|
+
requirements:
|
87
|
+
- - "~>"
|
88
|
+
- !ruby/object:Gem::Version
|
89
|
+
version: 3.0.1
|
90
|
+
type: :runtime
|
91
|
+
prerelease: false
|
92
|
+
version_requirements: !ruby/object:Gem::Requirement
|
93
|
+
requirements:
|
94
|
+
- - "~>"
|
95
|
+
- !ruby/object:Gem::Version
|
96
|
+
version: 3.0.1
|
83
97
|
- !ruby/object:Gem::Dependency
|
84
98
|
name: bundler
|
85
99
|
requirement: !ruby/object:Gem::Requirement
|
86
100
|
requirements:
|
87
101
|
- - "~>"
|
88
102
|
- !ruby/object:Gem::Version
|
89
|
-
version:
|
103
|
+
version: '1.17'
|
90
104
|
type: :development
|
91
105
|
prerelease: false
|
92
106
|
version_requirements: !ruby/object:Gem::Requirement
|
93
107
|
requirements:
|
94
108
|
- - "~>"
|
95
109
|
- !ruby/object:Gem::Version
|
96
|
-
version:
|
110
|
+
version: '1.17'
|
111
|
+
- !ruby/object:Gem::Dependency
|
112
|
+
name: irb
|
113
|
+
requirement: !ruby/object:Gem::Requirement
|
114
|
+
requirements:
|
115
|
+
- - ">="
|
116
|
+
- !ruby/object:Gem::Version
|
117
|
+
version: '0'
|
118
|
+
type: :development
|
119
|
+
prerelease: false
|
120
|
+
version_requirements: !ruby/object:Gem::Requirement
|
121
|
+
requirements:
|
122
|
+
- - ">="
|
123
|
+
- !ruby/object:Gem::Version
|
124
|
+
version: '0'
|
97
125
|
- !ruby/object:Gem::Dependency
|
98
126
|
name: mocha
|
99
127
|
requirement: !ruby/object:Gem::Requirement
|
@@ -112,30 +140,30 @@ dependencies:
|
|
112
140
|
name: pry-byebug
|
113
141
|
requirement: !ruby/object:Gem::Requirement
|
114
142
|
requirements:
|
115
|
-
- - "
|
143
|
+
- - ">="
|
116
144
|
- !ruby/object:Gem::Version
|
117
|
-
version: '
|
145
|
+
version: '0'
|
118
146
|
type: :development
|
119
147
|
prerelease: false
|
120
148
|
version_requirements: !ruby/object:Gem::Requirement
|
121
149
|
requirements:
|
122
|
-
- - "
|
150
|
+
- - ">="
|
123
151
|
- !ruby/object:Gem::Version
|
124
|
-
version: '
|
152
|
+
version: '0'
|
125
153
|
- !ruby/object:Gem::Dependency
|
126
154
|
name: rake
|
127
155
|
requirement: !ruby/object:Gem::Requirement
|
128
156
|
requirements:
|
129
157
|
- - "~>"
|
130
158
|
- !ruby/object:Gem::Version
|
131
|
-
version: '
|
159
|
+
version: '13.0'
|
132
160
|
type: :development
|
133
161
|
prerelease: false
|
134
162
|
version_requirements: !ruby/object:Gem::Requirement
|
135
163
|
requirements:
|
136
164
|
- - "~>"
|
137
165
|
- !ruby/object:Gem::Version
|
138
|
-
version: '
|
166
|
+
version: '13.0'
|
139
167
|
- !ruby/object:Gem::Dependency
|
140
168
|
name: rspec
|
141
169
|
requirement: !ruby/object:Gem::Requirement
|
@@ -150,6 +178,34 @@ dependencies:
|
|
150
178
|
- - "~>"
|
151
179
|
- !ruby/object:Gem::Version
|
152
180
|
version: '3.0'
|
181
|
+
- !ruby/object:Gem::Dependency
|
182
|
+
name: rubocop-github
|
183
|
+
requirement: !ruby/object:Gem::Requirement
|
184
|
+
requirements:
|
185
|
+
- - ">="
|
186
|
+
- !ruby/object:Gem::Version
|
187
|
+
version: '0'
|
188
|
+
type: :development
|
189
|
+
prerelease: false
|
190
|
+
version_requirements: !ruby/object:Gem::Requirement
|
191
|
+
requirements:
|
192
|
+
- - ">="
|
193
|
+
- !ruby/object:Gem::Version
|
194
|
+
version: '0'
|
195
|
+
- !ruby/object:Gem::Dependency
|
196
|
+
name: simplecov
|
197
|
+
requirement: !ruby/object:Gem::Requirement
|
198
|
+
requirements:
|
199
|
+
- - ">="
|
200
|
+
- !ruby/object:Gem::Version
|
201
|
+
version: '0'
|
202
|
+
type: :development
|
203
|
+
prerelease: false
|
204
|
+
version_requirements: !ruby/object:Gem::Requirement
|
205
|
+
requirements:
|
206
|
+
- - ">="
|
207
|
+
- !ruby/object:Gem::Version
|
208
|
+
version: '0'
|
153
209
|
- !ruby/object:Gem::Dependency
|
154
210
|
name: webmock
|
155
211
|
requirement: !ruby/object:Gem::Requirement
|
@@ -164,9 +220,10 @@ dependencies:
|
|
164
220
|
- - "~>"
|
165
221
|
- !ruby/object:Gem::Version
|
166
222
|
version: '3.5'
|
167
|
-
description:
|
223
|
+
description: Peatio Blockchain Plugin for easy integration of NDC Wallet Blockchain
|
224
|
+
platform.
|
168
225
|
email:
|
169
|
-
-
|
226
|
+
- tanvirtex@gmail.com
|
170
227
|
executables: []
|
171
228
|
extensions: []
|
172
229
|
extra_rdoc_files: []
|
@@ -174,6 +231,8 @@ files:
|
|
174
231
|
- ".gitignore"
|
175
232
|
- ".rspec"
|
176
233
|
- ".travis.yml"
|
234
|
+
- CHANGELOG.md
|
235
|
+
- CODE_OF_CONDUCT.md
|
177
236
|
- Gemfile
|
178
237
|
- Gemfile.lock
|
179
238
|
- LICENSE.txt
|
@@ -181,11 +240,6 @@ files:
|
|
181
240
|
- Rakefile
|
182
241
|
- bin/console
|
183
242
|
- bin/setup
|
184
|
-
- config/blockchains.yml
|
185
|
-
- config/currencies.yml
|
186
|
-
- config/wallets.yml
|
187
|
-
- docs/integration.md
|
188
|
-
- docs/json-rpc.md
|
189
243
|
- lib/peatio/ndc.rb
|
190
244
|
- lib/peatio/ndc/blockchain.rb
|
191
245
|
- lib/peatio/ndc/client.rb
|
@@ -193,15 +247,14 @@ files:
|
|
193
247
|
- lib/peatio/ndc/railtie.rb
|
194
248
|
- lib/peatio/ndc/version.rb
|
195
249
|
- lib/peatio/ndc/wallet.rb
|
196
|
-
- peatio-ndc-0.1.0.gem
|
197
|
-
- peatio-ndc-0.1.1.gem
|
198
|
-
- peatio-ndc-0.1.2.gem
|
199
|
-
- peatio-ndc-0.1.3.gem
|
200
250
|
- peatio-ndc.gemspec
|
201
|
-
homepage: https://ndcwallet.pro
|
251
|
+
homepage: https://ndcwallet.pro.
|
202
252
|
licenses:
|
203
253
|
- MIT
|
204
|
-
metadata:
|
254
|
+
metadata:
|
255
|
+
homepage_uri: https://ndcwallet.pro.
|
256
|
+
source_code_uri: https://github.com/ndcwallet/peatio-ndc
|
257
|
+
changelog_uri: https://github.com/ndcwallet/peatio-ndc/blob/master/CHANGELOG.md
|
205
258
|
post_install_message:
|
206
259
|
rdoc_options: []
|
207
260
|
require_paths:
|
@@ -210,7 +263,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
|
|
210
263
|
requirements:
|
211
264
|
- - ">="
|
212
265
|
- !ruby/object:Gem::Version
|
213
|
-
version:
|
266
|
+
version: 2.3.0
|
214
267
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
215
268
|
requirements:
|
216
269
|
- - ">="
|
@@ -220,5 +273,5 @@ requirements: []
|
|
220
273
|
rubygems_version: 3.0.6
|
221
274
|
signing_key:
|
222
275
|
specification_version: 4
|
223
|
-
summary:
|
276
|
+
summary: Peatio Blockchain Gem for NDC Wallet.
|
224
277
|
test_files: []
|
data/config/blockchains.yml
DELETED
@@ -1,10 +0,0 @@
|
|
1
|
-
- key: ndc-mainet
|
2
|
-
name: NDC Mainet
|
3
|
-
client: ndc # API client name.
|
4
|
-
server: http://user:password@127.0.0.1:17798 # Public ndc node endpoint.
|
5
|
-
height: 5000 # Initial block number from which sync will be started.
|
6
|
-
min_confirmations: 6 # Minimal confirmations needed for withdraw and deposit confirmation.
|
7
|
-
explorer:
|
8
|
-
address: https://explorer.ndcwallet.pro/address/#{address}
|
9
|
-
transaction: https://explorer.ndcwallet.pro/tx/#{txid}
|
10
|
-
status: active
|
data/config/currencies.yml
DELETED
@@ -1,18 +0,0 @@
|
|
1
|
-
- id: ndc
|
2
|
-
name: NDC
|
3
|
-
blockchain_key: ndc-mainet
|
4
|
-
symbol: 'C'
|
5
|
-
type: coin
|
6
|
-
precision: 8
|
7
|
-
base_factor: 100_000_000
|
8
|
-
enabled: true
|
9
|
-
# Deposits with less amount are skipped during blockchain synchronization.
|
10
|
-
# We advise to set value 10 times bigger than the network fee to prevent losses.
|
11
|
-
min_deposit_amount: 0.0004488
|
12
|
-
min_collection_amount: 0.0004488
|
13
|
-
withdraw_limit_24h: 0.5
|
14
|
-
withdraw_limit_72h: 1.2
|
15
|
-
deposit_fee: 0
|
16
|
-
withdraw_fee: 0
|
17
|
-
position: 5
|
18
|
-
options: {}
|
data/config/wallets.yml
DELETED
@@ -1,44 +0,0 @@
|
|
1
|
-
- name: NDC Deposit Wallet
|
2
|
-
blockchain_key: ndc-mainet
|
3
|
-
currency_id: ndc
|
4
|
-
# Address where deposits will be collected to.
|
5
|
-
address: 'NrR24vjA6AwoLw9w34hCpJKytUiAJnpSTP' # IMPORTANT: Always wrap this value in quotes!
|
6
|
-
kind: deposit # Wallet kind (deposit, hot, warm, cold or fee).
|
7
|
-
nsig: 1 # Number of signatures required for performing withdraw.
|
8
|
-
max_balance: 0.0
|
9
|
-
status: active
|
10
|
-
gateway: ndcd # Gateway client name.
|
11
|
-
settings:
|
12
|
-
#
|
13
|
-
# NDCd gateway client settings.
|
14
|
-
uri: http://user:password@127.0.0.1:17798
|
15
|
-
|
16
|
-
- name: NDC Hot Wallet
|
17
|
-
blockchain_key: ndc-mainet
|
18
|
-
currency_id: ndc
|
19
|
-
# Address where deposits will be collected to.
|
20
|
-
address: 'NrR24vjA6AwoLw9w34hCpJKytUiAJnpSTP' # IMPORTANT: Always wrap this value in quotes!
|
21
|
-
kind: hot # Wallet kind (deposit, hot, warm, cold or fee).
|
22
|
-
nsig: 1 # Number of signatures required for performing withdraw.
|
23
|
-
max_balance: 5.0
|
24
|
-
status: active
|
25
|
-
gateway: ndcd # Gateway client name.
|
26
|
-
settings:
|
27
|
-
#
|
28
|
-
# NDC gateway client settings.
|
29
|
-
uri: http://user:password@127.0.0.1:17798
|
30
|
-
|
31
|
-
- name: NDC Warm Wallet
|
32
|
-
blockchain_key: ndc-mainet
|
33
|
-
currency_id: ndc
|
34
|
-
# Address where deposits will be collected to.
|
35
|
-
address: 'NrR24vjA6AwoLw9w34hCpJKytUiAJnpSTP' # IMPORTANT: Always wrap this value in quotes!
|
36
|
-
kind: warm # Wallet kind (deposit, hot, warm, cold or fee).
|
37
|
-
nsig: 1 # Number of signatures required for performing withdraw.
|
38
|
-
max_balance: 50.0
|
39
|
-
status: active
|
40
|
-
gateway: ndcd # Gateway client name.
|
41
|
-
settings:
|
42
|
-
#
|
43
|
-
# NDCd gateway client settings.
|
44
|
-
uri: http://user:password@127.0.0.1:17798
|
data/docs/integration.md
DELETED
@@ -1,29 +0,0 @@
|
|
1
|
-
# Integration.
|
2
|
-
|
3
|
-
For Peatio NDC plugin integration you need to do the following steps:
|
4
|
-
|
5
|
-
## Image Build.
|
6
|
-
|
7
|
-
1. Add peatio-ndc gem into your Gemfile.plugin
|
8
|
-
```ruby
|
9
|
-
gem 'peatio-ndc', '~> 0.1.3'
|
10
|
-
```
|
11
|
-
|
12
|
-
2. Run `bundle install` for updating Gemfile.lock
|
13
|
-
|
14
|
-
3. Build custom Peatio [docker image with NDC plugin](https://github.com/nexbitio/peatio/blob/master/docs/plugins.md#build)
|
15
|
-
|
16
|
-
4. Push your image using `docker push`
|
17
|
-
|
18
|
-
5. Update your deployment to use image with peatio-ndc gem
|
19
|
-
|
20
|
-
## Peatio Configuration.
|
21
|
-
|
22
|
-
1. Create NDC Blockchain [config example](../config/blockchains.yml).
|
23
|
-
* No additional steps are needed
|
24
|
-
|
25
|
-
2. Create NDC Currency [config example](../config/currencies.yml).
|
26
|
-
* No additional steps are needed
|
27
|
-
|
28
|
-
3. Create NDC Wallets [config example](../config/wallets.yml)(deposit and hot wallets are required).
|
29
|
-
* No additional steps are needed
|
data/docs/json-rpc.md
DELETED
@@ -1,29 +0,0 @@
|
|
1
|
-
# JSON RPC
|
2
|
-
|
3
|
-
The next list of JSON RPC calls where used for plugin development.
|
4
|
-
For response examples see spec/resources:
|
5
|
-
|
6
|
-
* getbalance
|
7
|
-
|
8
|
-
`curl --data-binary '{"jsonrpc": "1.0", "id":"curltest", "method": "getbalance", "params": [] }' -H 'content-type: text/plain;' http://user:password@127.0.0.1:17798`
|
9
|
-
* getblock
|
10
|
-
|
11
|
-
`curl --data-binary '{"jsonrpc": "1.0", "id":"curltest", "method": "getblock", "params": ["51c209db5f7eaad7aee6983579a463eb49f03b9970d8cd852dc687a7380d3abb", 2] }' -H 'content-type: text/plain;' http://user:password@127.0.0.1:17798`
|
12
|
-
* getblockcount
|
13
|
-
|
14
|
-
`curl --data-binary '{"jsonrpc": "1.0", "id":"curltest", "method": "getblockcount", "params": [] }' -H 'content-type: text/plain;' http://user:password@127.0.0.1:17798`
|
15
|
-
* getblockhash
|
16
|
-
|
17
|
-
`curl --data-binary '{"jsonrpc": "1.0", "id":"curltest", "method": "getblockhash", "params": [40500] }' -H 'content-type: text/plain;' http://user:password@127.0.0.1:17798 `
|
18
|
-
* getnewaddress
|
19
|
-
|
20
|
-
`curl --data-binary '{"jsonrpc": "1.0", "id":"curltest", "method": "getnewaddress", "params": [] }' -H 'content-type: text/plain;' http://user:password@127.0.0.1:17798 `
|
21
|
-
* listaddressgroupings
|
22
|
-
|
23
|
-
`curl --data-binary '{"jsonrpc": "1.0", "id":"curltest", "method": "listaddressgroupings", "params": [] }' -H 'content-type: text/plain;' http://user:password@127.0.0.1:17798`
|
24
|
-
* sendtoaddress
|
25
|
-
|
26
|
-
`curl --data-binary '{"jsonrpc": "1.0", "id":"curltest", "method": "sendtoaddress", "params": ["NrR24vjA6AwoLw9w34hCpJKytUiAJnpSTP", 0.11] }' -H 'content-type: text/plain;' http://user:password@127.0.0.1:17798`
|
27
|
-
* methodnotfound
|
28
|
-
|
29
|
-
`curl --data-binary '{"jsonrpc": "1.0", "id":"curltest", "method": "methodnotfound", "params": [] }' -H 'content-type: text/plain;' http://user:password@127.0.0.1:17798`
|
data/peatio-ndc-0.1.0.gem
DELETED
Binary file
|
data/peatio-ndc-0.1.1.gem
DELETED
Binary file
|
data/peatio-ndc-0.1.2.gem
DELETED
Binary file
|
data/peatio-ndc-0.1.3.gem
DELETED
Binary file
|