coinbase-sdk 0.10.0 → 0.11.0

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.
Files changed (152) hide show
  1. checksums.yaml +4 -4
  2. data/lib/coinbase/address/wallet_address.rb +28 -0
  3. data/lib/coinbase/balance.rb +1 -1
  4. data/lib/coinbase/client/api/addresses_api.rb +1 -1
  5. data/lib/coinbase/client/api/assets_api.rb +1 -1
  6. data/lib/coinbase/client/api/balance_history_api.rb +1 -1
  7. data/lib/coinbase/client/api/contract_events_api.rb +1 -1
  8. data/lib/coinbase/client/api/contract_invocations_api.rb +1 -1
  9. data/lib/coinbase/client/api/external_addresses_api.rb +1 -1
  10. data/lib/coinbase/client/api/fund_api.rb +1 -1
  11. data/lib/coinbase/client/api/{wallet_stake_api.rb → mpc_wallet_stake_api.rb} +21 -21
  12. data/lib/coinbase/client/api/networks_api.rb +1 -1
  13. data/lib/coinbase/client/api/onchain_identity_api.rb +1 -1
  14. data/lib/coinbase/client/api/reputation_api.rb +160 -0
  15. data/lib/coinbase/client/api/server_signers_api.rb +1 -1
  16. data/lib/coinbase/client/api/smart_contracts_api.rb +1 -1
  17. data/lib/coinbase/client/api/stake_api.rb +158 -1
  18. data/lib/coinbase/client/api/trades_api.rb +1 -1
  19. data/lib/coinbase/client/api/transaction_history_api.rb +1 -1
  20. data/lib/coinbase/client/api/transfers_api.rb +1 -1
  21. data/lib/coinbase/client/api/users_api.rb +1 -1
  22. data/lib/coinbase/client/api/wallets_api.rb +1 -1
  23. data/lib/coinbase/client/api/webhooks_api.rb +1 -1
  24. data/lib/coinbase/client/api_client.rb +1 -1
  25. data/lib/coinbase/client/api_error.rb +1 -1
  26. data/lib/coinbase/client/configuration.rb +1 -1
  27. data/lib/coinbase/client/models/address.rb +1 -1
  28. data/lib/coinbase/client/models/address_balance_list.rb +1 -1
  29. data/lib/coinbase/client/models/address_historical_balance_list.rb +1 -1
  30. data/lib/coinbase/client/models/address_list.rb +1 -1
  31. data/lib/coinbase/client/models/address_reputation.rb +232 -0
  32. data/lib/coinbase/client/models/address_reputation_metadata.rb +376 -0
  33. data/lib/coinbase/client/models/address_risk.rb +223 -0
  34. data/lib/coinbase/client/models/address_transaction_list.rb +1 -1
  35. data/lib/coinbase/client/models/asset.rb +1 -1
  36. data/lib/coinbase/client/models/balance.rb +1 -1
  37. data/lib/coinbase/client/models/broadcast_contract_invocation_request.rb +1 -1
  38. data/lib/coinbase/client/models/broadcast_staking_operation_request.rb +1 -1
  39. data/lib/coinbase/client/models/broadcast_trade_request.rb +1 -1
  40. data/lib/coinbase/client/models/broadcast_transfer_request.rb +1 -1
  41. data/lib/coinbase/client/models/build_staking_operation_request.rb +2 -1
  42. data/lib/coinbase/client/models/contract_event.rb +1 -1
  43. data/lib/coinbase/client/models/contract_event_list.rb +1 -1
  44. data/lib/coinbase/client/models/contract_invocation.rb +1 -1
  45. data/lib/coinbase/client/models/contract_invocation_list.rb +1 -1
  46. data/lib/coinbase/client/models/create_address_request.rb +1 -1
  47. data/lib/coinbase/client/models/create_contract_invocation_request.rb +1 -1
  48. data/lib/coinbase/client/models/create_fund_operation_request.rb +1 -1
  49. data/lib/coinbase/client/models/create_fund_quote_request.rb +1 -1
  50. data/lib/coinbase/client/models/create_payload_signature_request.rb +1 -1
  51. data/lib/coinbase/client/models/create_server_signer_request.rb +1 -1
  52. data/lib/coinbase/client/models/create_smart_contract_request.rb +1 -1
  53. data/lib/coinbase/client/models/create_staking_operation_request.rb +2 -1
  54. data/lib/coinbase/client/models/create_trade_request.rb +1 -1
  55. data/lib/coinbase/client/models/create_transfer_request.rb +1 -1
  56. data/lib/coinbase/client/models/create_wallet_request.rb +1 -1
  57. data/lib/coinbase/client/models/create_wallet_request_wallet.rb +1 -1
  58. data/lib/coinbase/client/models/create_wallet_webhook_request.rb +1 -1
  59. data/lib/coinbase/client/models/create_webhook_request.rb +1 -1
  60. data/lib/coinbase/client/models/crypto_amount.rb +1 -1
  61. data/lib/coinbase/client/models/deploy_smart_contract_request.rb +1 -1
  62. data/lib/coinbase/client/models/erc20_transfer_event.rb +1 -1
  63. data/lib/coinbase/client/models/erc721_transfer_event.rb +1 -1
  64. data/lib/coinbase/client/models/error.rb +1 -1
  65. data/lib/coinbase/client/models/ethereum_token_transfer.rb +1 -1
  66. data/lib/coinbase/client/models/ethereum_transaction.rb +1 -1
  67. data/lib/coinbase/client/models/ethereum_transaction_access.rb +1 -1
  68. data/lib/coinbase/client/models/ethereum_transaction_access_list.rb +1 -1
  69. data/lib/coinbase/client/models/ethereum_transaction_flattened_trace.rb +1 -1
  70. data/lib/coinbase/client/models/ethereum_validator_metadata.rb +1 -1
  71. data/lib/coinbase/client/models/faucet_transaction.rb +1 -1
  72. data/lib/coinbase/client/models/feature_set.rb +1 -1
  73. data/lib/coinbase/client/models/fetch_historical_staking_balances200_response.rb +1 -1
  74. data/lib/coinbase/client/models/fetch_staking_rewards200_response.rb +1 -1
  75. data/lib/coinbase/client/models/fetch_staking_rewards_request.rb +1 -1
  76. data/lib/coinbase/client/models/fiat_amount.rb +1 -1
  77. data/lib/coinbase/client/models/fund_operation.rb +1 -1
  78. data/lib/coinbase/client/models/fund_operation_fees.rb +1 -1
  79. data/lib/coinbase/client/models/fund_operation_list.rb +1 -1
  80. data/lib/coinbase/client/models/fund_quote.rb +1 -1
  81. data/lib/coinbase/client/models/get_staking_context_request.rb +2 -1
  82. data/lib/coinbase/client/models/historical_balance.rb +1 -1
  83. data/lib/coinbase/client/models/multi_token_contract_options.rb +1 -1
  84. data/lib/coinbase/client/models/network.rb +1 -1
  85. data/lib/coinbase/client/models/network_identifier.rb +1 -1
  86. data/lib/coinbase/client/models/nft_contract_options.rb +1 -1
  87. data/lib/coinbase/client/models/onchain_name.rb +1 -1
  88. data/lib/coinbase/client/models/onchain_name_list.rb +1 -1
  89. data/lib/coinbase/client/models/payload_signature.rb +1 -1
  90. data/lib/coinbase/client/models/payload_signature_list.rb +1 -1
  91. data/lib/coinbase/client/models/read_contract_request.rb +1 -1
  92. data/lib/coinbase/client/models/seed_creation_event.rb +1 -1
  93. data/lib/coinbase/client/models/seed_creation_event_result.rb +1 -1
  94. data/lib/coinbase/client/models/server_signer.rb +1 -1
  95. data/lib/coinbase/client/models/server_signer_event.rb +1 -1
  96. data/lib/coinbase/client/models/server_signer_event_event.rb +1 -1
  97. data/lib/coinbase/client/models/server_signer_event_list.rb +1 -1
  98. data/lib/coinbase/client/models/server_signer_list.rb +1 -1
  99. data/lib/coinbase/client/models/signature_creation_event.rb +1 -1
  100. data/lib/coinbase/client/models/signature_creation_event_result.rb +1 -1
  101. data/lib/coinbase/client/models/signed_voluntary_exit_message_metadata.rb +1 -1
  102. data/lib/coinbase/client/models/smart_contract.rb +1 -1
  103. data/lib/coinbase/client/models/smart_contract_list.rb +1 -1
  104. data/lib/coinbase/client/models/smart_contract_options.rb +1 -1
  105. data/lib/coinbase/client/models/smart_contract_type.rb +1 -1
  106. data/lib/coinbase/client/models/solidity_value.rb +3 -3
  107. data/lib/coinbase/client/models/sponsored_send.rb +1 -1
  108. data/lib/coinbase/client/models/staking_balance.rb +1 -1
  109. data/lib/coinbase/client/models/staking_context.rb +1 -1
  110. data/lib/coinbase/client/models/staking_context_context.rb +1 -1
  111. data/lib/coinbase/client/models/staking_operation.rb +1 -1
  112. data/lib/coinbase/client/models/staking_operation_metadata.rb +1 -1
  113. data/lib/coinbase/client/models/staking_reward.rb +1 -1
  114. data/lib/coinbase/client/models/staking_reward_format.rb +1 -1
  115. data/lib/coinbase/client/models/staking_reward_usd_value.rb +1 -1
  116. data/lib/coinbase/client/models/token_contract_options.rb +1 -1
  117. data/lib/coinbase/client/models/token_transfer_type.rb +1 -1
  118. data/lib/coinbase/client/models/trade.rb +1 -1
  119. data/lib/coinbase/client/models/trade_list.rb +1 -1
  120. data/lib/coinbase/client/models/transaction.rb +1 -1
  121. data/lib/coinbase/client/models/transaction_content.rb +1 -1
  122. data/lib/coinbase/client/models/transaction_type.rb +1 -1
  123. data/lib/coinbase/client/models/transfer.rb +1 -1
  124. data/lib/coinbase/client/models/transfer_list.rb +1 -1
  125. data/lib/coinbase/client/models/update_webhook_request.rb +1 -1
  126. data/lib/coinbase/client/models/user.rb +1 -1
  127. data/lib/coinbase/client/models/validator.rb +1 -1
  128. data/lib/coinbase/client/models/validator_details.rb +1 -1
  129. data/lib/coinbase/client/models/validator_list.rb +1 -1
  130. data/lib/coinbase/client/models/validator_status.rb +1 -1
  131. data/lib/coinbase/client/models/wallet.rb +1 -1
  132. data/lib/coinbase/client/models/wallet_list.rb +1 -1
  133. data/lib/coinbase/client/models/webhook.rb +1 -1
  134. data/lib/coinbase/client/models/webhook_event_filter.rb +1 -1
  135. data/lib/coinbase/client/models/webhook_event_type.rb +1 -1
  136. data/lib/coinbase/client/models/webhook_event_type_filter.rb +1 -1
  137. data/lib/coinbase/client/models/webhook_list.rb +1 -1
  138. data/lib/coinbase/client/models/webhook_wallet_activity_filter.rb +1 -1
  139. data/lib/coinbase/client/version.rb +1 -1
  140. data/lib/coinbase/client.rb +6 -3
  141. data/lib/coinbase/crypto_amount.rb +62 -0
  142. data/lib/coinbase/fiat_amount.rb +40 -0
  143. data/lib/coinbase/fund_operation.rb +228 -0
  144. data/lib/coinbase/fund_quote.rb +149 -0
  145. data/lib/coinbase/smart_contract.rb +2 -2
  146. data/lib/coinbase/staking_operation.rb +2 -2
  147. data/lib/coinbase/validator.rb +7 -10
  148. data/lib/coinbase/version.rb +1 -1
  149. data/lib/coinbase/wallet.rb +13 -1
  150. data/lib/coinbase.rb +4 -0
  151. metadata +11 -4
  152. data/lib/coinbase/client/api/validators_api.rb +0 -179
@@ -0,0 +1,228 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative 'constants'
4
+ require 'bigdecimal'
5
+ require 'eth'
6
+
7
+ module Coinbase
8
+ # A representation of a Fund Operation, which buys funds from the Coinbase platform,
9
+ # and sends then to the developer's address.
10
+ class FundOperation
11
+ # A representation of a Fund Operation status.
12
+ module Status
13
+ # The Fund Operation is being processed.
14
+ PENDING = 'pending'
15
+
16
+ # The Fund Operation is complete.
17
+ COMPLETE = 'complete'
18
+
19
+ # The Fund Operation has failed for some reason.
20
+ FAILED = 'failed'
21
+
22
+ # The states that are considered terminal on-chain.
23
+ TERMINAL_STATES = [COMPLETE, FAILED].freeze
24
+ end
25
+
26
+ class << self
27
+ # Creates a new Fund Operation object.
28
+ # This takes an optional FundQuote object that can be used to lock in the rate and fees.
29
+ # Without an explicit quote, we will use the current rate and fees.
30
+ # @param address_id [String] The Address ID of the sending Address
31
+ # @param wallet_id [String] The Wallet ID of the sending Wallet
32
+ # @param amount [BigDecimal] The amount of the Asset to send
33
+ # @param network [Coinbase::Network, Symbol] The Network or Network ID of the Asset
34
+ # @param asset_id [Symbol] The Asset ID of the Asset to send
35
+ # @param quote [Coinbase::FundQuote, String] The optional FundQuote to use for the Fund Operation
36
+ # @return [FundOperation] The new pending Fund Operation object
37
+ # @raise [Coinbase::ApiError] If the Fund Operation fails
38
+ def create(wallet_id:, address_id:, amount:, asset_id:, network:, quote: nil)
39
+ network = Coinbase::Network.from_id(network)
40
+ asset = network.get_asset(asset_id)
41
+
42
+ model = Coinbase.call_api do
43
+ fund_api.create_fund_operation(
44
+ wallet_id,
45
+ address_id,
46
+ {
47
+ amount: asset.to_atomic_amount(amount).to_i.to_s,
48
+ asset_id: asset.primary_denomination.to_s,
49
+ fund_quote_id: quote_id(quote)
50
+ }.compact
51
+ )
52
+ end
53
+
54
+ new(model)
55
+ end
56
+
57
+ # Enumerates the fund operation for a given address belonging to a wallet.
58
+ # The result is an enumerator that lazily fetches from the server, and can be iterated over,
59
+ # converted to an array, etc...
60
+ # @return [Enumerable<Coinbase::FundOperation>] Enumerator that returns fund operations
61
+ def list(wallet_id:, address_id:)
62
+ Coinbase::Pagination.enumerate(
63
+ ->(page) { fetch_page(wallet_id, address_id, page) }
64
+ ) do |fund_operation|
65
+ new(fund_operation)
66
+ end
67
+ end
68
+
69
+ private
70
+
71
+ def fund_api
72
+ Coinbase::Client::FundApi.new(Coinbase.configuration.api_client)
73
+ end
74
+
75
+ def fetch_page(wallet_id, address_id, page)
76
+ fund_api.list_fund_operations(
77
+ wallet_id,
78
+ address_id,
79
+ limit: DEFAULT_PAGE_LIMIT,
80
+ page: page
81
+ )
82
+ end
83
+
84
+ def quote_id(quote)
85
+ return nil if quote.nil?
86
+ return quote.id if quote.is_a?(FundQuote)
87
+ return quote if quote.is_a?(String)
88
+
89
+ raise ArgumentError, 'quote must be a FundQuote object or ID'
90
+ end
91
+ end
92
+
93
+ # Returns a new Fund Operation object. Do not use this method directly. Instead, use
94
+ # Wallet#fund or Address#fund.
95
+ # @param model [Coinbase::Client::FundOperation] The underlying Fund Operation object
96
+ def initialize(model)
97
+ raise ArgumentError, 'must be a FundOperation' unless model.is_a?(Coinbase::Client::FundOperation)
98
+
99
+ @model = model
100
+ end
101
+
102
+ # Returns the Fund Operation ID.
103
+ # @return [String] The Fund Operation ID
104
+ def id
105
+ @model.fund_operation_id
106
+ end
107
+
108
+ # Returns the Network of the Fund Operation.
109
+ # @return [Coinbase::Network] The Network
110
+ def network
111
+ @network ||= Coinbase::Network.from_id(@model.network_id)
112
+ end
113
+
114
+ # Returns the Wallet ID that the fund quote was created for.
115
+ # @return [String] The Wallet ID
116
+ def wallet_id
117
+ @model.wallet_id
118
+ end
119
+
120
+ # Returns the Address ID that the fund quote was created for.
121
+ # @return [String] The Address ID
122
+ def address_id
123
+ @model.address_id
124
+ end
125
+
126
+ # Returns the Asset of the Fund Operation.
127
+ # @return [Coinbase::Asset] The Asset
128
+ def asset
129
+ amount.asset
130
+ end
131
+
132
+ # Returns the amount that the wallet will receive in crypto.
133
+ # @return [Coinbase::CryptoAmount] The crypto amount
134
+ def amount
135
+ @amount ||= CryptoAmount.from_model(@model.crypto_amount)
136
+ end
137
+
138
+ # Returns the amount that the wallet's owner will pay in fiat.
139
+ # @return [Coinbase::FiatAmount] The fiat amount
140
+ def fiat_amount
141
+ @fiat_amount ||= FiatAmount.from_model(@model.fiat_amount)
142
+ end
143
+
144
+ # Returns the fee that the wallet's owner will pay in fiat.
145
+ # @return [Coinbase::FiatAmount] The fiat buy fee
146
+ def buy_fee
147
+ @buy_fee ||= FiatAmount.from_model(@model.fees.buy_fee)
148
+ end
149
+
150
+ # Returns the fee that the wallet's owner will pay in crypto.
151
+ # @return [Coinbase::CryptoAmount] The crypto transfer fee
152
+ def transfer_fee
153
+ @transfer_fee ||= CryptoAmount.from_model(@model.fees.transfer_fee)
154
+ end
155
+
156
+ # Returns the status of the Fund Operation.
157
+ # @return [Symbol] The status
158
+ def status
159
+ @model.status
160
+ end
161
+
162
+ # Reload reloads the Transfer model with the latest version from the server side.
163
+ # @return [Transfer] The most recent version of Transfer from the server.
164
+ def reload
165
+ @model = Coinbase.call_api do
166
+ fund_api.get_fund_operation(wallet_id, address_id, id)
167
+ end
168
+
169
+ self
170
+ end
171
+
172
+ # Waits until the Fund Operation is completed or failed by polling the at the given interval.
173
+ # @param interval_seconds [Integer] The interval at which to poll the Network, in seconds
174
+ # @param timeout_seconds [Integer] The maximum amount of time to wait for the Fund Operation to complete, in seconds
175
+ # @return [Coinbase::FundOperation] The completed or failed Fund Operation object
176
+ # @raise [Timeout::Error] If the Fund Operation takes longer than the given timeout
177
+ def wait!(interval_seconds = 1, timeout_seconds = 60)
178
+ start_time = Time.now
179
+
180
+ loop do
181
+ reload
182
+
183
+ return self if terminal_state?
184
+
185
+ raise Timeout::Error, 'Fund Operation timed out' if Time.now - start_time > timeout_seconds
186
+
187
+ self.sleep interval_seconds
188
+ end
189
+
190
+ self
191
+ end
192
+
193
+ # Returns a String representation of the Fund Operation.
194
+ # @return [String] a String representation of the Fund Operation
195
+ def to_s
196
+ Coinbase.pretty_print_object(
197
+ self.class,
198
+ id: id,
199
+ network_id: network.id,
200
+ wallet_id: wallet_id,
201
+ address_id: address_id,
202
+ status: status,
203
+ crypto_amount: amount,
204
+ fiat_amount: fiat_amount,
205
+ buy_fee: buy_fee,
206
+ transfer_fee: transfer_fee
207
+ )
208
+ end
209
+
210
+ # Same as to_s.
211
+ # @return [String] a String representation of the Fund Operation.
212
+ def inspect
213
+ to_s
214
+ end
215
+
216
+ private
217
+
218
+ # Returns whether the Fund Operation is in a terminal state.
219
+ # @return [Boolean] Whether the Fund Operation is in a terminal state
220
+ def terminal_state?
221
+ Status::TERMINAL_STATES.include?(status)
222
+ end
223
+
224
+ def fund_api
225
+ @fund_api ||= Coinbase::Client::FundApi.new(Coinbase.configuration.api_client)
226
+ end
227
+ end
228
+ end
@@ -0,0 +1,149 @@
1
+ # frozen_string_literal: true
2
+
3
+ require_relative 'constants'
4
+ require 'bigdecimal'
5
+ require 'eth'
6
+
7
+ module Coinbase
8
+ # A representation of a Fund Operation Quote, which is a quote for a fund operation
9
+ # that buys funds from the Coinbase platform and sends then to the developer's address.
10
+ class FundQuote
11
+ class << self
12
+ # Creates a new Fund Operation Quote object.
13
+ # @param address_id [String] The Address ID of the sending Address
14
+ # @param wallet_id [String] The Wallet ID of the sending Wallet
15
+ # @param amount [BigDecimal] The amount of the Asset to send
16
+ # @param network [Coinbase::Network, Symbol] The Network or Network ID of the Asset
17
+ # @param asset_id [Symbol] The Asset ID of the Asset to send
18
+ # @return [FundQuote] The new Fund Quote object
19
+ # @raise [Coinbase::ApiError] If the Fund Quote fails
20
+ def create(wallet_id:, address_id:, amount:, asset_id:, network:)
21
+ network = Coinbase::Network.from_id(network)
22
+ asset = network.get_asset(asset_id)
23
+
24
+ model = Coinbase.call_api do
25
+ fund_api.create_fund_quote(
26
+ wallet_id,
27
+ address_id,
28
+ {
29
+ asset_id: asset.primary_denomination.to_s,
30
+ amount: asset.to_atomic_amount(amount).to_i.to_s
31
+ }
32
+ )
33
+ end
34
+
35
+ new(model)
36
+ end
37
+
38
+ private
39
+
40
+ def fund_api
41
+ Coinbase::Client::FundApi.new(Coinbase.configuration.api_client)
42
+ end
43
+ end
44
+
45
+ # Returns a new Fund Quote object. Do not use this method directly.
46
+ # Instead, use Wallet#quote_fund or Address#quote_fund.
47
+ # @param model [Coinbase::Client::FundQuote] The underlying Fund Quote object
48
+ def initialize(model)
49
+ raise ArgumentError, 'must be a FundQuote' unless model.is_a?(Coinbase::Client::FundQuote)
50
+
51
+ @model = model
52
+ end
53
+
54
+ # Returns the ID of the Fund Quote.
55
+ # @return [String] The Fund Quote ID
56
+ def id
57
+ @model.fund_quote_id
58
+ end
59
+
60
+ # Executes a fund operation using the quote.
61
+ # @return [Coinbase::FundOperation] The FundOperation object
62
+ # @raise [Coinbase::ApiError] If the FundOperation fails
63
+ def execute!
64
+ FundOperation.create(
65
+ wallet_id: wallet_id,
66
+ address_id: address_id,
67
+ amount: amount.amount,
68
+ asset_id: asset.asset_id,
69
+ network: network.id,
70
+ quote: self
71
+ )
72
+ end
73
+
74
+ # Returns the Network the fund quote was created on.
75
+ # @return [Coinbase::Network] The Network
76
+ def network
77
+ @network ||= Coinbase::Network.from_id(@model.network_id)
78
+ end
79
+
80
+ # Returns the Wallet ID that the fund quote was created for.
81
+ # @return [String] The Wallet ID
82
+ def wallet_id
83
+ @model.wallet_id
84
+ end
85
+
86
+ # Returns the Address ID that the fund quote was created for.
87
+ # @return [String] The Address ID
88
+ def address_id
89
+ @model.address_id
90
+ end
91
+
92
+ # Returns the Asset of the FundOperation.
93
+ # @return [Coinbase::Asset] The Asset
94
+ def asset
95
+ amount.asset
96
+ end
97
+
98
+ # Returns the amount that the wallet will receive in crypto.
99
+ # @return [Coinbase::CryptoAmount] The crypto amount
100
+ def amount
101
+ @amount ||= CryptoAmount.from_model(@model.crypto_amount)
102
+ end
103
+
104
+ # Returns the amount that the wallet's owner will pay in fiat.
105
+ # @return [Coinbase::FiatAmount] The fiat amount
106
+ def fiat_amount
107
+ @fiat_amount ||= FiatAmount.from_model(@model.fiat_amount)
108
+ end
109
+
110
+ # Returns the fee that the wallet's owner will pay in fiat.
111
+ # @return [Coinbase::FiatAmount] The fiat buy fee
112
+ def buy_fee
113
+ @buy_fee ||= FiatAmount.from_model(@model.fees.buy_fee)
114
+ end
115
+
116
+ # Returns the fee that the wallet's owner will pay in crypto.
117
+ # @return [Coinbase::CryptoAmount] The crypto transfer fee
118
+ def transfer_fee
119
+ @transfer_fee ||= CryptoAmount.from_model(@model.fees.transfer_fee)
120
+ end
121
+
122
+ # Returns a String representation of the Fund Operation.
123
+ # @return [String] a String representation of the Fund Operation
124
+ def to_s
125
+ Coinbase.pretty_print_object(
126
+ self.class,
127
+ network_id: network.id,
128
+ wallet_id: wallet_id,
129
+ address_id: address_id,
130
+ crypto_amount: amount,
131
+ fiat_amount: fiat_amount,
132
+ buy_fee: buy_fee,
133
+ transfer_fee: transfer_fee
134
+ )
135
+ end
136
+
137
+ # Same as to_s.
138
+ # @return [String] a String representation of the Transfer
139
+ def inspect
140
+ to_s
141
+ end
142
+
143
+ private
144
+
145
+ def fund_api
146
+ @fund_api ||= Coinbase::Client::FundApi.new(Coinbase.configuration.api_client)
147
+ end
148
+ end
149
+ end
@@ -143,9 +143,9 @@ module Coinbase
143
143
  # @return [Object] The result of the contract call, converted to an appropriate Ruby type
144
144
  # @raise [Coinbase::ApiError] If there's an error in the API call
145
145
  def self.read(
146
- network:,
147
146
  contract_address:,
148
147
  method:,
148
+ network: Coinbase.default_network,
149
149
  abi: nil,
150
150
  args: {}
151
151
  )
@@ -159,7 +159,7 @@ module Coinbase
159
159
  method: method,
160
160
  args: (args || {}).to_json,
161
161
  abi: abi&.to_json
162
- }
162
+ }.compact
163
163
  )
164
164
  end
165
165
 
@@ -107,7 +107,7 @@ module Coinbase
107
107
  private_class_method :stake_api
108
108
 
109
109
  def self.wallet_stake_api
110
- Coinbase::Client::WalletStakeApi.new(Coinbase.configuration.api_client)
110
+ Coinbase::Client::MPCWalletStakeApi.new(Coinbase.configuration.api_client)
111
111
  end
112
112
 
113
113
  private_class_method :wallet_stake_api
@@ -324,7 +324,7 @@ module Coinbase
324
324
  end
325
325
 
326
326
  def wallet_stake_api
327
- @wallet_stake_api ||= Coinbase::Client::WalletStakeApi.new(Coinbase.configuration.api_client)
327
+ @wallet_stake_api ||= Coinbase::Client::MPCWalletStakeApi.new(Coinbase.configuration.api_client)
328
328
  end
329
329
 
330
330
  def update_transactions(transactions)
@@ -33,12 +33,9 @@ module Coinbase
33
33
  network = Coinbase::Network.from_id(network)
34
34
 
35
35
  validator = Coinbase.call_api do
36
- validators_api.get_validator(
37
- network.normalized_id,
38
- asset_id,
39
- validator_id
40
- )
36
+ stake_api.get_validator(network.normalized_id, asset_id, validator_id)
41
37
  end
38
+
42
39
  new(validator)
43
40
  end
44
41
 
@@ -57,7 +54,7 @@ module Coinbase
57
54
  # Returns a string representation of the Validator.
58
55
  # @return [String] a string representation of the Validator
59
56
  def to_s
60
- "Coinbase::Validator{id: '#{validator_id}' status: '#{status}'}"
57
+ Coinbase.pretty_print_object(self, validator_id: validator_id, status: status)
61
58
  end
62
59
 
63
60
  # Same as to_s.
@@ -68,7 +65,7 @@ module Coinbase
68
65
 
69
66
  def self.list_page(network, asset_id, status, page)
70
67
  Coinbase.call_api do
71
- validators_api.list_validators(
68
+ stake_api.list_validators(
72
69
  network.normalized_id,
73
70
  asset_id,
74
71
  {
@@ -81,10 +78,10 @@ module Coinbase
81
78
 
82
79
  private_class_method :list_page
83
80
 
84
- def self.validators_api
85
- Coinbase::Client::ValidatorsApi.new(Coinbase.configuration.api_client)
81
+ def self.stake_api
82
+ Coinbase::Client::StakeApi.new(Coinbase.configuration.api_client)
86
83
  end
87
84
 
88
- private_class_method :validators_api
85
+ private_class_method :stake_api
89
86
  end
90
87
  end
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module Coinbase
4
- VERSION = '0.10.0'
4
+ VERSION = '0.11.0'
5
5
  end
@@ -258,9 +258,21 @@ module Coinbase
258
258
  # @return [Coinbase::SmartContract] The deployed multi-token contract.
259
259
  # @raise [AddressCannotSignError] if the Address does not have a private key backing it.
260
260
 
261
+ # @!method quote_fund
262
+ # Gets a quote for a fund operation to fund the address from your Coinbase platform,
263
+ # account for the amount of the specified Asset.
264
+ # @param asset_id [Symbol] The ID of the Asset to trade from. For Ether, :eth, :gwei, and :wei are supported.
265
+ # @return [Coinbase::FundQuote] The FundQuote object.
266
+
267
+ # @!method fund
268
+ # Funds the address from your account on the Coinbase Platform for the given amount of the given Asset.
269
+ # @param amount [Integer, Float, BigDecimal] The amount of the Asset to fund the wallet with.
270
+ # @param asset_id [Symbol] The ID of the Asset to trade from. For Ether, :eth, :gwei, and :wei are supported.
271
+ # @return [Coinbase::FundOperation] The FundOperation object.
272
+
261
273
  def_delegators :default_address, :transfer, :trade, :faucet, :stake, :unstake, :claim_stake, :staking_balances,
262
274
  :stakeable_balance, :unstakeable_balance, :claimable_balance, :sign_payload, :invoke_contract,
263
- :deploy_token, :deploy_nft, :deploy_multi_token
275
+ :deploy_token, :deploy_nft, :deploy_multi_token, :quote_fund, :fund
264
276
 
265
277
  # Returns the addresses belonging to the Wallet.
266
278
  # @return [Array<Coinbase::WalletAddress>] The addresses belonging to the Wallet
data/lib/coinbase.rb CHANGED
@@ -13,11 +13,15 @@ require_relative 'coinbase/client'
13
13
  require_relative 'coinbase/constants'
14
14
  require_relative 'coinbase/contract_event'
15
15
  require_relative 'coinbase/contract_invocation'
16
+ require_relative 'coinbase/crypto_amount'
16
17
  require_relative 'coinbase/destination'
17
18
  require_relative 'coinbase/errors'
18
19
  require_relative 'coinbase/faucet_transaction'
20
+ require_relative 'coinbase/fiat_amount'
19
21
  require_relative 'coinbase/middleware'
20
22
  require_relative 'coinbase/network'
23
+ require_relative 'coinbase/fund_operation'
24
+ require_relative 'coinbase/fund_quote'
21
25
  require_relative 'coinbase/pagination'
22
26
  require_relative 'coinbase/payload_signature'
23
27
  require_relative 'coinbase/trade'
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: coinbase-sdk
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.10.0
4
+ version: 0.11.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Yuga Cohler
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2024-10-31 00:00:00.000000000 Z
11
+ date: 2024-11-27 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: bigdecimal
@@ -284,8 +284,10 @@ files:
284
284
  - lib/coinbase/client/api/contract_invocations_api.rb
285
285
  - lib/coinbase/client/api/external_addresses_api.rb
286
286
  - lib/coinbase/client/api/fund_api.rb
287
+ - lib/coinbase/client/api/mpc_wallet_stake_api.rb
287
288
  - lib/coinbase/client/api/networks_api.rb
288
289
  - lib/coinbase/client/api/onchain_identity_api.rb
290
+ - lib/coinbase/client/api/reputation_api.rb
289
291
  - lib/coinbase/client/api/server_signers_api.rb
290
292
  - lib/coinbase/client/api/smart_contracts_api.rb
291
293
  - lib/coinbase/client/api/stake_api.rb
@@ -293,8 +295,6 @@ files:
293
295
  - lib/coinbase/client/api/transaction_history_api.rb
294
296
  - lib/coinbase/client/api/transfers_api.rb
295
297
  - lib/coinbase/client/api/users_api.rb
296
- - lib/coinbase/client/api/validators_api.rb
297
- - lib/coinbase/client/api/wallet_stake_api.rb
298
298
  - lib/coinbase/client/api/wallets_api.rb
299
299
  - lib/coinbase/client/api/webhooks_api.rb
300
300
  - lib/coinbase/client/api_client.rb
@@ -304,6 +304,9 @@ files:
304
304
  - lib/coinbase/client/models/address_balance_list.rb
305
305
  - lib/coinbase/client/models/address_historical_balance_list.rb
306
306
  - lib/coinbase/client/models/address_list.rb
307
+ - lib/coinbase/client/models/address_reputation.rb
308
+ - lib/coinbase/client/models/address_reputation_metadata.rb
309
+ - lib/coinbase/client/models/address_risk.rb
307
310
  - lib/coinbase/client/models/address_transaction_list.rb
308
311
  - lib/coinbase/client/models/asset.rb
309
312
  - lib/coinbase/client/models/balance.rb
@@ -414,9 +417,13 @@ files:
414
417
  - lib/coinbase/contract_event.rb
415
418
  - lib/coinbase/contract_invocation.rb
416
419
  - lib/coinbase/correlation.rb
420
+ - lib/coinbase/crypto_amount.rb
417
421
  - lib/coinbase/destination.rb
418
422
  - lib/coinbase/errors.rb
419
423
  - lib/coinbase/faucet_transaction.rb
424
+ - lib/coinbase/fiat_amount.rb
425
+ - lib/coinbase/fund_operation.rb
426
+ - lib/coinbase/fund_quote.rb
420
427
  - lib/coinbase/historical_balance.rb
421
428
  - lib/coinbase/middleware.rb
422
429
  - lib/coinbase/network.rb