Skip to content

Commit

Permalink
chore(PSDK-640): add network_id to WalletData (#223)
Browse files Browse the repository at this point in the history
  • Loading branch information
0xRAG authored Dec 19, 2024
1 parent 1ee0882 commit 99d6197
Show file tree
Hide file tree
Showing 4 changed files with 24 additions and 8 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0

## Unreleased
* Add support for fetching address reputation.
* Add `network_id` to `WalletData` so that it is saved with the seed data and surfaced via the export function

## [0.12.0] - Skipped

Expand Down
5 changes: 3 additions & 2 deletions lib/coinbase/wallet.rb
Original file line number Diff line number Diff line change
Expand Up @@ -406,7 +406,7 @@ def export

raise 'Cannot export Wallet without loaded seed' if @master.nil?

Data.new(wallet_id: id, seed: @master.seed_hex)
Data.new(wallet_id: id, seed: @master.seed_hex, network_id: network.id)
end

# Returns whether the Wallet has a seed with which to derive keys and sign transactions.
Expand Down Expand Up @@ -447,7 +447,8 @@ def save_seed!(file_path, encrypt: false)
seed: seed_to_store,
encrypted: encrypt,
auth_tag: auth_tag,
iv: iv
iv: iv,
network_id: network.id
}

File.write(file_path, JSON.pretty_generate(existing_seeds_in_store))
Expand Down
10 changes: 6 additions & 4 deletions lib/coinbase/wallet/data.rb
Original file line number Diff line number Diff line change
Expand Up @@ -4,27 +4,29 @@ module Coinbase
class Wallet
# The data required to recreate a Wallet.
class Data
attr_reader :wallet_id, :seed
attr_reader :wallet_id, :seed, :network_id

# Returns a new Data object.
# @param wallet_id [String] The ID of the Wallet
# @param seed [String] The seed of the Wallet
def initialize(wallet_id:, seed:)
# @param network_id [String, nil] The network ID of the Wallet (optional)
def initialize(wallet_id:, seed:, network_id: nil)
@wallet_id = wallet_id
@seed = seed
@network_id = network_id
end

# Converts the Data object to a Hash.
# @return [Hash] The Hash representation of the Data object
def to_hash
{ wallet_id: wallet_id, seed: seed }
{ wallet_id: wallet_id, seed: seed, network_id: network_id }
end

# Creates a Data object from the given Hash.
# @param data [Hash] The Hash to create the Data object from
# @return [Data] The new Data object
def self.from_hash(data)
Data.new(wallet_id: data['wallet_id'], seed: data['seed'])
Data.new(wallet_id: data['wallet_id'], seed: data['seed'], network_id: data['network_id'])
end
end
end
Expand Down
16 changes: 14 additions & 2 deletions spec/unit/coinbase/wallet_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -1350,7 +1350,13 @@ def match_create_address_request(req, expected_public_key, expected_address_inde

it 'saves the wallet data to the seed file' do
expect(saved_seed_data[wallet.id])
.to eq({ 'seed' => seed, 'encrypted' => false, 'iv' => '', 'auth_tag' => '' })
.to eq({
'seed' => seed,
'encrypted' => false,
'iv' => '',
'auth_tag' => '',
'network_id' => network_id.to_s
})
end
end

Expand Down Expand Up @@ -1387,7 +1393,13 @@ def match_create_address_request(req, expected_public_key, expected_address_inde

it 'saves the wallet data to the new file' do
expect(saved_seed_data[wallet.id])
.to eq({ 'seed' => seed, 'encrypted' => false, 'iv' => '', 'auth_tag' => '' })
.to eq({
'seed' => seed,
'encrypted' => false,
'iv' => '',
'auth_tag' => '',
'network_id' => network_id.to_s
})
end
end

Expand Down

0 comments on commit 99d6197

Please sign in to comment.