Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Replace GoF with confirmation state #2313

Merged
merged 335 commits into from
Jul 7, 2022
Merged
Show file tree
Hide file tree
Changes from 250 commits
Commits
Show all changes
335 commits
Select commit Hold shift + click to select a range
b6b7985
Feat: proper getters and setters for storables
karimodm Jun 8, 2022
947d77f
Add TODOs
karimodm Jun 8, 2022
08588d9
Merge branch 'feat/epoch-commitment' into feat/update-ec-structure
daria305 Jun 8, 2022
b25558f
Merge remote-tracking branch 'origin/develop' into feat/epoch-commitment
karimodm Jun 8, 2022
87f9a51
Fix: using new models after merge
karimodm Jun 8, 2022
da505cd
Fix: no compile errors
karimodm Jun 8, 2022
bb51d3e
Fix: storage nil pointer dereference
karimodm Jun 8, 2022
fc8307d
Add commitments progressing when delayed
daria305 Jun 9, 2022
42ffd22
Merge branch 'feat/epoch-commitment' into feat/update-ec-structure
daria305 Jun 9, 2022
6b0cf8a
Add comments to exported methods
jkrvivian Jun 9, 2022
cd1e8b5
Only have one MinMana threshold
karimodm Jun 9, 2022
079a005
Merge branch 'feat/epoch-commitment' of github.com:iotaledger/goshimm…
karimodm Jun 9, 2022
4380699
Change load snapshot logic for mana
georgysavva Jun 9, 2022
c51273d
Make epoch indeces persistent
karimodm Jun 9, 2022
39df69f
Add mana state root
daria305 Jun 9, 2022
3990932
Remove ecc
daria305 Jun 9, 2022
a5e12de
Use CachedECRecord
karimodm Jun 9, 2022
928d349
Merge branch 'feat/epoch-commitment' into feat/add-mana-root
daria305 Jun 9, 2022
f43fb1b
Merge branch 'feat/epoch-commitment' into snapshot-mana-epochs
georgysavva Jun 9, 2022
37ce2a5
Fix merge conflicts
georgysavva Jun 9, 2022
a3bb2f3
Fic EpochDiff definition
georgysavva Jun 9, 2022
3e73aff
Remove mana leaf if balance is 0
daria305 Jun 9, 2022
8ebc0b3
Remove EpochCommitment struct & code duplication
karimodm Jun 9, 2022
a6ae03c
Store latest ECRecord from snapshot
karimodm Jun 9, 2022
07321b7
Merge branch 'feat/epoch-commitment' into snapshot-mana-epochs-genera…
karimodm Jun 9, 2022
22da58f
Update packages/ledger/models.go
georgysavva Jun 9, 2022
7688260
EpochDiff now in ledger package to avoid cycles
karimodm Jun 9, 2022
df6971e
Merge branch 'snapshot-mana-epochs' of github.com:iotaledger/goshimme…
karimodm Jun 9, 2022
3825f8e
Genesis Snapshot Generation
karimodm Jun 9, 2022
840e65f
Merge branch 'feat/epoch-commitment' into feat/add-mana-root
daria305 Jun 9, 2022
d232ebd
AccessMana is now Mana1
karimodm Jun 9, 2022
42d174a
Remove references to --mana.snapshotResetTime=true
karimodm Jun 9, 2022
d546f29
Merge branch 'snapshot-mana-epochs' into feat/accessmana-mana1
karimodm Jun 9, 2022
03e9614
Remove references to --mana.snapshotResetTime=true
karimodm Jun 9, 2022
cda189a
Merge branch 'feat/accessmana-mana1' into feat/snapshot-mana-epochs-g…
karimodm Jun 9, 2022
090d5db
Fix some issues
karimodm Jun 9, 2022
fe263fb
Merge branch 'feat/epoch-commitment' into test-commitment
karimodm Jun 9, 2022
c12ebd6
Review fixes
georgysavva Jun 10, 2022
25beea7
Merge branch 'feat/epoch-commitment' into snapshot-mana-epochs
georgysavva Jun 10, 2022
0f65c0f
Genesis Snapshot Generation (#2266)
karimodm Jun 10, 2022
efdad0f
Remove OracleEpochShift
karimodm Jun 10, 2022
8247123
Fix: always initialize trees on new epoch
karimodm Jun 10, 2022
771763f
Working committments in messages
karimodm Jun 10, 2022
5ebe2e3
AccessMana is now Mana1 (#2267)
karimodm Jun 10, 2022
3a4a766
Add EC related variables to test framework
jkrvivian Jun 10, 2022
f4db46e
Add event mock structure for notarization manager
jkrvivian Jun 10, 2022
5dacd0e
Implement Tangle smt Tree test
jkrvivian Jun 10, 2022
0297231
EpochCommittment in dashboard
karimodm Jun 10, 2022
212cc2e
ECs finally in Messages
karimodm Jun 10, 2022
b56895c
Fixed dashboard LatestConfirmedEpoch glitch
karimodm Jun 10, 2022
938c22f
Fix: correctly compute PrevEC
karimodm Jun 10, 2022
96cc07c
Feat: include computed EC in dashboard
karimodm Jun 10, 2022
862dfae
Remove debugging prints
karimodm Jun 10, 2022
55bd58f
Merge branch 'feat/epoch-commitment' into test/notarization-manager
jkrvivian Jun 10, 2022
0ecbc6c
Update initialize with data method
georgysavva Jun 10, 2022
fe8023d
Snapshot
georgysavva Jun 10, 2022
87bf63a
Merge branch 'feat/epoch-commitment' into snapshot-mana-epochs
georgysavva Jun 10, 2022
832396f
Fix after merge
georgysavva Jun 10, 2022
bc7903c
Revert "Remove debugging prints"
karimodm Jun 10, 2022
dd0769c
Bump hive.go
karimodm Jun 11, 2022
25ddcf6
Several fixes
karimodm Jun 11, 2022
62d910c
Create snapshot in createGenesisOutputs
jkrvivian Jun 13, 2022
0ad47b9
Load snapshot and fix test
jkrvivian Jun 13, 2022
7e95967
Set up Tangle and issue messages
jkrvivian Jun 13, 2022
90b99f1
Fixes
jkrvivian Jun 13, 2022
b53e5b7
Fix a bunch of things
karimodm Jun 13, 2022
0c0111f
Merge pull request #2265 from iotaledger/snapshot-mana-epochs
karimodm Jun 13, 2022
120f372
Temporary Fix: epochdiff loading
karimodm Jun 13, 2022
0d702ab
Bypass finality gadget
jkrvivian Jun 14, 2022
2ff623e
Merge branch 'feat/epoch-commitment' into feat/add-mana-root
daria305 Jun 14, 2022
4c789b9
Fixes after merge
daria305 Jun 14, 2022
ad1dba2
Split EpochDiff storage & several fixes
karimodm Jun 14, 2022
946dfeb
Move store and load diff functions back to commitment factory
karimodm Jun 14, 2022
3fa3930
Update mana trees
daria305 Jun 15, 2022
6d1c636
Solve Update diff storage on inclusion todo
daria305 Jun 15, 2022
fff3aa5
Update diff on the message orphaned event if contain tx
daria305 Jun 15, 2022
2b999ac
Fix epochdiff storage
karimodm Jun 15, 2022
4f87ff4
Remove OnTransactionConfirmed in favor of OnTransactionInclusionUpdated
karimodm Jun 15, 2022
e6a8c0c
Merge remote-tracking branch 'origin/feat/add-mana-root' into feat/sp…
karimodm Jun 15, 2022
1c8f4d1
Rewrite test with TestScenario
jkrvivian Jun 15, 2022
c48bd04
Check CommitmentFunc error and committed epoch EI
jkrvivian Jun 16, 2022
d75d3c2
Working epoch committments with ManaRoot
karimodm Jun 16, 2022
a503124
Move proof stuff to its own file
karimodm Jun 16, 2022
196c418
Add state mutation and PCC tests
jkrvivian Jun 17, 2022
de0401b
Change mutation state test to non-conflicting txs scenario
jkrvivian Jun 17, 2022
2e6b32c
Add debug prints
jkrvivian Jun 17, 2022
db0f244
Remove some TODOs
karimodm Jun 17, 2022
fed2388
Addressed review
karimodm Jun 17, 2022
22c6260
Merge pull request #2291 from iotaledger/feat/split-epochdiff-storage
karimodm Jun 17, 2022
bb2b617
Fix: typos
karimodm Jun 17, 2022
a7e8b71
SnapshotDepth as notarization parameter
karimodm Jun 17, 2022
310fec2
Wire events from within notarization Manager
karimodm Jun 17, 2022
b13f3a0
Fix: do not shutdown Tangle twice
karimodm Jun 17, 2022
e4d4a88
Fix: removed unused mana snapshot
karimodm Jun 17, 2022
092951c
Dockerfile support go.work
karimodm Jun 17, 2022
2c1257e
Fix snapshot mana allocation for integration tests
karimodm Jun 17, 2022
d363d9e
Fix: mana test
karimodm Jun 17, 2022
180afbd
Merge branch 'feat/epoch-commitment' into test/notarization-manager
jkrvivian Jun 17, 2022
f86be7e
Fix Tangle tree test
jkrvivian Jun 20, 2022
e879c9f
Initialize ECRecord in new options
jkrvivian Jun 20, 2022
643fe73
Update State Mutation test to the latest changes
jkrvivian Jun 20, 2022
cd9ab89
Remove OnTransactionConfirmed
jkrvivian Jun 20, 2022
a3eb794
Fix some race conditions
karimodm Jun 20, 2022
d4f847f
Small improvement
karimodm Jun 20, 2022
ef266e8
Fix conflict Transaction Inclusion
karimodm Jun 20, 2022
9230360
Fix storage shutdown
karimodm Jun 20, 2022
953be01
Merge remote-tracking branch 'origin/develop' into fix/integration-tests
karimodm Jun 20, 2022
638c5ce
Fix common tests
karimodm Jun 20, 2022
a298075
Fix missing mana leaf startup error
karimodm Jun 20, 2022
72b4b13
Removed debugging prints
karimodm Jun 20, 2022
37cfcdf
Exported functions first
karimodm Jun 20, 2022
567182b
Fix: attachment might not be booked yet on BranchCreated
karimodm Jun 20, 2022
63d5a01
Use Tangle Time for old enough check
daria305 Jun 21, 2022
7d14eaf
Move Epoch Manager to epoch package
daria305 Jun 21, 2022
c7fe27c
Check if commitment tree exists before generating a proof
jkrvivian Jun 21, 2022
08595b9
Rename newEpochManager
daria305 Jun 21, 2022
641a08e
Fix snapshot creation in TestFramework
karimodm Jun 21, 2022
523d209
Epoch Commitments: fix bugs & integration tests #2297 from iotaledger…
karimodm Jun 21, 2022
58c6832
Merge remote-tracking branch 'origin/feat/epoch-commitment' into feat…
karimodm Jun 21, 2022
7fb2a8b
Merge remote-tracking branch 'origin/develop' into feat/merge-base-de…
karimodm Jun 21, 2022
7e68d36
Merge remote-tracking branch 'origin/test/notarization-manager' into …
karimodm Jun 21, 2022
27e904d
Fixes after merge
karimodm Jun 21, 2022
65f0dac
Merge remote-tracking branch 'origin/feat/epoch-commitment' into test…
karimodm Jun 21, 2022
056c62e
Fixes after merge
karimodm Jun 21, 2022
e83929f
Verify root and msgID/txID
jkrvivian Jun 21, 2022
ec1c29f
pkged.go
karimodm Jun 21, 2022
71d3d29
Disable notarization plugin on entrynode
karimodm Jun 21, 2022
a4e8fb1
Add next epoch started event
daria305 Jun 22, 2022
9b18abf
Merge branch 'feat/epoch-commitment' into feat/add-epoch-committable-…
daria305 Jun 22, 2022
fb409ee
Fix typo
daria305 Jun 22, 2022
b66987f
Remove unnecessary indexes from storage and add new
daria305 Jun 22, 2022
bdd9b9b
Fix and add conflicting test
jkrvivian Jun 22, 2022
1ed2211
Only treat Notarization events when node is bootstrapped
karimodm Jun 23, 2022
785e16c
Initialize aMana from snapshot without epoch delay
karimodm Jun 23, 2022
ce9eac1
Remove EpochManager as it is completely stateless
karimodm Jun 23, 2022
c0e9e86
Properly return or panic when error conditions are detected
karimodm Jun 23, 2022
f8bb143
Drop committmentTrees upon committing an epoch
karimodm Jun 23, 2022
01caec4
Book consensus mana in whole epochs
daria305 Jun 24, 2022
14d1b5a
Refactor testing framework set-up
jkrvivian Jun 24, 2022
2500836
Refactor assert functions
jkrvivian Jun 24, 2022
47d4b0a
Remove proofs code
karimodm Jun 24, 2022
fac32ec
Merge pull request #2310 from iotaledger/feat/epoch-commitment-fixes
karimodm Jun 24, 2022
35d873a
Merge remote-tracking branch 'origin/feat/epoch-commitment' into feat…
karimodm Jun 24, 2022
40c041e
Merge pull request #2309 from iotaledger/feat/move-epochmanager-to-epoch
karimodm Jun 24, 2022
33ebc9e
Ditch TestScenario in testing
jkrvivian Jun 24, 2022
b774ba3
Merge branch 'feat/merge-develop-into-epochs' into feat/epoch-commitment
karimodm Jun 24, 2022
3292b58
Merge remote-tracking branch 'origin/develop' into feat/epoch-commitment
karimodm Jun 24, 2022
e95dcdb
Merge pull request #2304 from iotaledger/feat/epoch-commitment-only-w…
karimodm Jun 24, 2022
f72181e
Merge branch 'feat/epoch-commitment' into feat/add-epoch-committable-…
daria305 Jun 24, 2022
8c85325
Clean up after merge
daria305 Jun 24, 2022
6b03bb7
Only trigger EpochCommitted if newly committed
karimodm Jun 24, 2022
a34277d
WIP: TestManager_DiffUTXOs
karimodm Jun 24, 2022
16d6cd8
Add TransactionInclusionUpdate test
jkrvivian Jun 24, 2022
64e3f04
Add assert diff store function
jkrvivian Jun 25, 2022
bd65e4e
Fix OutputWithMetadata model FromObjectStorage
karimodm Jun 26, 2022
16bd789
Merge branch 'test/notarization-manager' of github.com:iotaledger/gos…
karimodm Jun 26, 2022
73370ef
Fix: properly compact spent/created diff
karimodm Jun 26, 2022
5527fe7
Fix: async diffStorage shutdown in goroutine
karimodm Jun 26, 2022
ea76c9d
DiffUTXO test with reattachment
karimodm Jun 26, 2022
b094f02
Fix: isNew ecRecord
karimodm Jun 26, 2022
e32d180
DiffUTXO test with event expectation
karimodm Jun 26, 2022
da8bc45
Fix all notarization manager tests
karimodm Jun 26, 2022
31dee3f
OutputWithMetadata FromBytes with correct IDs
karimodm Jun 27, 2022
8f5d647
Merge remote-tracking branch 'origin/feat/epoch-commitment' into test…
karimodm Jun 27, 2022
0b21d7a
Some fixes after merge
karimodm Jun 27, 2022
6d30ad2
Compiles again
karimodm Jun 27, 2022
82ece8d
notarization tests passing
karimodm Jun 27, 2022
4b84f2b
Fix all the things!
karimodm Jun 27, 2022
86a8f41
Add bookEpoch test
daria305 Jun 27, 2022
05eeaf3
Fixes in tests
daria305 Jun 27, 2022
e12f721
Merge branch 'feat/epoch-commitment' into feat/add-epoch-committable-…
daria305 Jun 27, 2022
373e7ba
Fix Genesis snapshot loading with epoch 0
karimodm Jun 27, 2022
e6a1011
Use ATT time
daria305 Jun 27, 2022
ed908e8
Fix mManaVectorToUpdate event initialization
daria305 Jun 27, 2022
7b409cc
Remove --mana.snapshotResetTime=true from docker network compose
karimodm Jun 27, 2022
b5bffa0
Update packages/epoch/types.go
karimodm Jun 27, 2022
9e9180c
Address review
karimodm Jun 27, 2022
36b11ab
Merge branch 'test/notarization-manager' of github.com:iotaledger/gos…
karimodm Jun 27, 2022
233e79c
Update packages/notarization/manager.go
daria305 Jun 27, 2022
2fda38c
Apply review suggestions
daria305 Jun 28, 2022
04ba0c3
Merge remote-tracking branch 'origin/feat/add-epoch-committable-even'…
daria305 Jun 28, 2022
9e26820
Make diffs private
daria305 Jun 28, 2022
2287d1e
Fix: always check inclusionTime before triggering TransactionConfirme…
karimodm Jun 28, 2022
154172f
Remove unnecessary code
daria305 Jun 28, 2022
db3c51d
More fixes to bugs and tests
karimodm Jun 28, 2022
a482804
Merge branch 'test/notarization-manager' into feat/add-epoch-committa…
daria305 Jun 28, 2022
796e69e
Fix all tests
karimodm Jun 28, 2022
754b332
Remove prints
karimodm Jun 28, 2022
2ad8f30
Merge branch 'test/notarization-manager' into feat/add-epoch-committa…
daria305 Jun 28, 2022
16f0d20
Revert "Fix: always check inclusionTime before triggering Transaction…
karimodm Jun 28, 2022
b2562e1
Update commitments on new epoch event
daria305 Jun 28, 2022
34f35ee
txMeta.InclusionTime().IsZero() guard in OnTransactionConfirmed
karimodm Jun 28, 2022
3f387f9
Fix the indexes
daria305 Jun 28, 2022
1cce33e
Fix other unit tests
karimodm Jun 28, 2022
f9df532
Merge branch 'test/notarization-manager' into feat/add-epoch-committa…
daria305 Jun 29, 2022
04eae67
Fix TransactionConfirmed w/ InclusionTime
karimodm Jun 29, 2022
dd4e08d
Fix isCommittable condition, and race with ATT
daria305 Jun 29, 2022
4bee1c0
Fix most unit tests
daria305 Jun 29, 2022
ccc6ee9
Fix diff unittest
daria305 Jun 29, 2022
b73be48
Merge branch 'test/notarization-manager' into feat/add-epoch-committa…
daria305 Jun 29, 2022
dcafb04
Fix UpdateStateMutationTreeWithConflict unittest
daria305 Jun 29, 2022
23f559f
Trigger next epoch on AcceptanceTime updated
daria305 Jun 30, 2022
ba5e574
Advance epochs on ATT update: extend event to include ATT
karimodm Jun 30, 2022
d231efe
More unit test fixes
karimodm Jun 30, 2022
62c6c87
Remove check on Zero InclusionTime for Transactions
karimodm Jun 30, 2022
740ec58
Code quality
karimodm Jun 30, 2022
d09e326
Hook to ManaVectorUpdate from within mana plugin
karimodm Jun 30, 2022
10c517e
Fix BookEpoch test
daria305 Jun 30, 2022
0c2e82e
Code quality
karimodm Jun 30, 2022
c86e423
Fix TestPowFilter_Filter test
daria305 Jun 30, 2022
c16c509
Merge remote-tracking branch 'origin/feat/add-epoch-committable-even'…
daria305 Jun 30, 2022
14bd64d
Fix TestTangle_InvalidParentsAgeMessage
karimodm Jun 30, 2022
a56e061
Fix TestRateSetter_ErrorHandling test
daria305 Jun 30, 2022
e17ca9a
Merge remote-tracking branch 'origin/feat/add-epoch-committable-even'…
daria305 Jun 30, 2022
38cdc4e
Fix TestScheduler_SkipConfirmed test
daria305 Jun 30, 2022
f36e6b0
Fix TestScheduler_SkipConfirmed test
daria305 Jun 30, 2022
a21f832
Fix integration tests
karimodm Jun 30, 2022
1dd5ee0
Lock EpochCommittmentFactory upon OnAcceptanceTimeUpdated
karimodm Jun 30, 2022
a961773
ReadLock on GetLatestEC
karimodm Jun 30, 2022
264a437
Remove slow prints
karimodm Jun 30, 2022
63afe2c
Fresh GenesisTime
karimodm Jun 30, 2022
0a4a2d9
CMana calculation is now anchored to epochs
karimodm Jun 30, 2022
6ad7364
Fix: Set output pledgeID in booker
daria305 Jul 1, 2022
ff23c90
Merge remote-tracking branch 'origin/feat/add-epoch-committable-even'…
daria305 Jul 1, 2022
667f982
Fix: Set output pledgeID in booker
daria305 Jul 1, 2022
0edcfed
WIP mana tests
daria305 Jul 4, 2022
9dea252
Merge remote-tracking branch 'origin/feat/add-epoch-committable-even'…
daria305 Jul 4, 2022
5ef6ddb
Fix: Set output pledgeID in booker
daria305 Jul 1, 2022
f73b82d
Fix access mana pledge
daria305 Jul 4, 2022
e76f877
Fix invalid cast from MockedTransaction when storing outputs
karimodm Jul 4, 2022
8cc356d
Code quality
karimodm Jul 4, 2022
26655e3
Remove slow prints
karimodm Jul 4, 2022
95e6fef
Replace GoF with confirmation state
jonastheis Jul 5, 2022
f08320c
Merge remote-tracking branch 'origin/develop' into feat/confirmation-…
jonastheis Jul 5, 2022
9779835
Rename finality gadget to acceptance gadget
jonastheis Jul 5, 2022
3c7cbb4
Add Undefined confirmation state and add functionality for output con…
jonastheis Jul 5, 2022
c8bc6a7
Fix compile errors in integration tests
jonastheis Jul 5, 2022
2a048e0
Fix output confirmation state and consensus integration tests
jonastheis Jul 5, 2022
9a99019
Adjust dashboard and improve conflicts page
jonastheis Jul 6, 2022
056bad7
Remove GoF appearance throughout code base
jonastheis Jul 6, 2022
67d3411
Adjust dags visualizer
jonastheis Jul 6, 2022
6f5dfc0
Address review comments
jonastheis Jul 6, 2022
5061d6a
pkger
jonastheis Jul 6, 2022
5672e14
Fix integration mana_test
karimodm Jul 6, 2022
07964a8
Fix: epochs, mana booking and other fixes
karimodm Jul 6, 2022
3cdf2b7
Fix: all times above genesisTime are epoch 1
karimodm Jul 6, 2022
e0565b9
OutputWithMetadata now embeds used fields directly
karimodm Jul 6, 2022
577f8c7
Remove unused stuff
karimodm Jul 7, 2022
dcaac11
Fix output metadata snapshot load
karimodm Jul 7, 2022
82a118e
Fix: logging error
karimodm Jul 7, 2022
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
26 changes: 13 additions & 13 deletions client/evilwallet/connector.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,10 +5,10 @@ import (
"time"

"github.com/iotaledger/hive.go/identity"
"github.com/iotaledger/hive.go/types/confirmation"

"github.com/iotaledger/goshimmer/client"
"github.com/iotaledger/goshimmer/client/wallet"
"github.com/iotaledger/goshimmer/packages/consensus/gof"
"github.com/iotaledger/goshimmer/packages/jsonmodels"
"github.com/iotaledger/goshimmer/packages/ledger/utxo"
"github.com/iotaledger/goshimmer/packages/ledger/vm/devnetvm"
Expand Down Expand Up @@ -179,12 +179,12 @@ type Client interface {
GetUnspentOutputForAddress(addr devnetvm.Address) *jsonmodels.WalletOutput
// GetAddressUnspentOutputs gets the unspent outputs of an address.
GetAddressUnspentOutputs(address string) (outputIDs []utxo.OutputID, err error)
// GetTransactionGoF returns the GoF of a given transaction ID.
GetTransactionGoF(txID string) gof.GradeOfFinality
// GetTransactionConfirmationState returns the ConfirmationState of a given transaction ID.
GetTransactionConfirmationState(txID string) confirmation.State
// GetOutput gets the output of a given outputID.
GetOutput(outputID utxo.OutputID) devnetvm.Output
// GetOutputGoF gets the first unspent outputs of a given address.
GetOutputGoF(outputID utxo.OutputID) gof.GradeOfFinality
// GetOutputConfirmationState gets the first unspent outputs of a given address.
GetOutputConfirmationState(outputID utxo.OutputID) confirmation.State
// BroadcastFaucetRequest requests funds from the faucet and returns the faucet request message ID.
BroadcastFaucetRequest(address string) error
// GetTransactionOutputs returns the outputs the transaction created.
Expand Down Expand Up @@ -288,14 +288,14 @@ func (c *WebClient) GetUnspentOutputForAddress(addr devnetvm.Address) *jsonmodel
return nil
}

// GetOutputGoF gets the first unspent outputs of a given address.
func (c *WebClient) GetOutputGoF(outputID utxo.OutputID) gof.GradeOfFinality {
// GetOutputConfirmationState gets the first unspent outputs of a given address.
func (c *WebClient) GetOutputConfirmationState(outputID utxo.OutputID) confirmation.State {
res, err := c.api.GetOutputMetadata(outputID.Base58())
if err != nil {
return gof.None
return confirmation.Pending
}

return res.GradeOfFinality
return res.ConfirmationState
}

// GetOutput gets the output of a given outputID.
Expand All @@ -308,13 +308,13 @@ func (c *WebClient) GetOutput(outputID utxo.OutputID) devnetvm.Output {
return output
}

// GetTransactionGoF returns the GoF of a given transaction ID.
func (c *WebClient) GetTransactionGoF(txID string) gof.GradeOfFinality {
// GetTransactionConfirmationState returns the ConfirmationState of a given transaction ID.
func (c *WebClient) GetTransactionConfirmationState(txID string) confirmation.State {
resp, err := c.api.GetTransactionMetadata(txID)
if err != nil {
return gof.None
return confirmation.Pending
}
return resp.GradeOfFinality
return resp.ConfirmationState
}

// GetTransactionOutputs returns the outputs the transaction created.
Expand Down
2 changes: 0 additions & 2 deletions client/evilwallet/evilwallet.go
Original file line number Diff line number Diff line change
Expand Up @@ -15,8 +15,6 @@ import (
)

const (
// GoFConfirmed defines the grade of finality that is considered confirmed.
GoFConfirmed = 3
// FaucetRequestSplitNumber defines the number of outputs to split from a faucet request.
FaucetRequestSplitNumber = 100
faucetTokensPerRequest = 1000000
Expand Down
32 changes: 16 additions & 16 deletions client/evilwallet/output_manager.go
Original file line number Diff line number Diff line change
Expand Up @@ -119,7 +119,7 @@ func (o *OutputManager) Track(outputIDs []utxo.OutputID) (allConfirmed bool) {
wg.Add(1)
go func(id utxo.OutputID, allConfirmed bool) {
defer wg.Done()
ok := o.AwaitOutputToBeConfirmed(id, awaitOutputToBeConfirmed)
ok := o.AwaitOutputToBeAccepted(id, awaitOutputToBeConfirmed)
if !ok {
allConfirmed = false
return
Expand Down Expand Up @@ -234,21 +234,21 @@ func (o *OutputManager) AwaitWalletOutputsToBeConfirmed(wallet *Wallet) {
wg.Wait()
}

// AwaitOutputToBeConfirmed awaits for output from a provided outputID is confirmed. Timeout is waitFor.
// AwaitOutputToBeAccepted awaits for output from a provided outputID is accepted. Timeout is waitFor.
// Useful when we have only an address and no transactionID, e.g. faucet funds request.
func (o *OutputManager) AwaitOutputToBeConfirmed(outputID utxo.OutputID, waitFor time.Duration) (confirmed bool) {
func (o *OutputManager) AwaitOutputToBeAccepted(outputID utxo.OutputID, waitFor time.Duration) (accepted bool) {
s := time.Now()
clt := o.connector.GetClient()
confirmed = false
accepted = false
for ; time.Since(s) < waitFor; time.Sleep(awaitConfirmationSleep) {
gof := clt.GetOutputGoF(outputID)
if gof == GoFConfirmed {
confirmed = true
confirmationState := clt.GetOutputConfirmationState(outputID)
if confirmationState.IsAccepted() {
accepted = true
break
}
}

return confirmed
return accepted
}

// AwaitTransactionsConfirmation awaits for transaction confirmation and updates wallet with outputIDs.
Expand All @@ -264,7 +264,7 @@ func (o *OutputManager) AwaitTransactionsConfirmation(txIDs []string, maxGorouti
defer func() {
<-semaphore
}()
err := o.AwaitTransactionToBeConfirmed(txID, waitForConfirmation)
err := o.AwaitTransactionToBeAccepted(txID, waitForConfirmation)
if err != nil {
return
}
Expand All @@ -273,19 +273,19 @@ func (o *OutputManager) AwaitTransactionsConfirmation(txIDs []string, maxGorouti
wg.Wait()
}

// AwaitTransactionToBeConfirmed awaits for confirmation of a single transaction.
func (o *OutputManager) AwaitTransactionToBeConfirmed(txID string, waitFor time.Duration) error {
// AwaitTransactionToBeAccepted awaits for acceptance of a single transaction.
func (o *OutputManager) AwaitTransactionToBeAccepted(txID string, waitFor time.Duration) error {
s := time.Now()
clt := o.connector.GetClient()
var confirmed bool
var accepted bool
for ; time.Since(s) < waitFor; time.Sleep(awaitConfirmationSleep) {
if gof := clt.GetTransactionGoF(txID); gof == GoFConfirmed {
confirmed = true
if confirmationState := clt.GetTransactionConfirmationState(txID); confirmationState.IsAccepted() {
accepted = true
break
}
}
if !confirmed {
return fmt.Errorf("transaction %s not confirmed in time", txID)
if !accepted {
return fmt.Errorf("transaction %s not accepted in time", txID)
}
return nil
}
Expand Down
5 changes: 3 additions & 2 deletions client/wallet/connector.go
Original file line number Diff line number Diff line change
@@ -1,8 +1,9 @@
package wallet

import (
"github.com/iotaledger/hive.go/types/confirmation"

"github.com/iotaledger/goshimmer/client/wallet/packages/address"
"github.com/iotaledger/goshimmer/packages/consensus/gof"
"github.com/iotaledger/goshimmer/packages/ledger/utxo"
"github.com/iotaledger/goshimmer/packages/ledger/vm/devnetvm"
"github.com/iotaledger/goshimmer/packages/mana"
Expand All @@ -15,6 +16,6 @@ type Connector interface {
SendTransaction(transaction *devnetvm.Transaction) (err error)
RequestFaucetFunds(address address.Address, powTarget int) (err error)
GetAllowedPledgeIDs() (pledgeIDMap map[mana.Type][]string, err error)
GetTransactionGoF(txID utxo.TransactionID) (gradeOfFinality gof.GradeOfFinality, err error)
GetTransactionConfirmationState(txID utxo.TransactionID) (confirmationState confirmation.State, err error)
GetUnspentAliasOutput(address *devnetvm.AliasAddress) (output *devnetvm.AliasOutput, err error)
}
8 changes: 4 additions & 4 deletions client/wallet/output.go
Original file line number Diff line number Diff line change
Expand Up @@ -10,10 +10,10 @@ import (

// Output is a wallet specific representation of an output in the IOTA network.
type Output struct {
Address address.Address
Object devnetvm.Output
Metadata OutputMetadata
GradeOfFinalityReached bool
Address address.Address
Object devnetvm.Output
Metadata OutputMetadata
ConfirmationStateReached bool
// Spent is a local wallet-only property that gets set once an output is spent from within the same wallet.
Spent bool
}
Expand Down
2 changes: 1 addition & 1 deletion client/wallet/output_manager.go
Original file line number Diff line number Diff line change
Expand Up @@ -100,7 +100,7 @@ func (o *OutputManager) getOutputs(includePending bool, addresses ...address.Add
continue
}
// discard non-confirmed if includePending is false
if !includePending && !output.GradeOfFinalityReached {
if !includePending && !output.ConfirmationStateReached {
continue
}

Expand Down
43 changes: 21 additions & 22 deletions client/wallet/wallet.go
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,6 @@ import (
"github.com/iotaledger/goshimmer/client/wallet/packages/sweepnftownedoptions"
"github.com/iotaledger/goshimmer/client/wallet/packages/transfernftoptions"
"github.com/iotaledger/goshimmer/client/wallet/packages/withdrawfromnftoptions"
"github.com/iotaledger/goshimmer/packages/consensus/gof"
"github.com/iotaledger/goshimmer/packages/ledger/utxo"
"github.com/iotaledger/goshimmer/packages/ledger/vm/devnetvm"
"github.com/iotaledger/goshimmer/packages/mana"
Expand Down Expand Up @@ -170,7 +169,7 @@ func (wallet *Wallet) SendFunds(options ...sendoptions.SendFundsOption) (tx *dev
return nil, err
}
if sendOptions.WaitForConfirmation {
err = wallet.WaitForTxConfirmation(tx.ID())
err = wallet.WaitForTxAcceptance(tx.ID())
}

return tx, err
Expand Down Expand Up @@ -255,7 +254,7 @@ func (wallet *Wallet) ConsolidateFunds(options ...consolidateoptions.Consolidate
}
txs = append(txs, tx)
if consolidateOptions.WaitForConfirmation {
err = wallet.WaitForTxConfirmation(tx.ID())
err = wallet.WaitForTxAcceptance(tx.ID())
if err != nil {
return txs, err
}
Expand Down Expand Up @@ -337,7 +336,7 @@ func (wallet *Wallet) ClaimConditionalFunds(options ...claimconditionaloptions.C
return nil, err
}
if claimOptions.WaitForConfirmation {
err = wallet.WaitForTxConfirmation(tx.ID())
err = wallet.WaitForTxAcceptance(tx.ID())
}
return
}
Expand Down Expand Up @@ -508,7 +507,7 @@ func (wallet *Wallet) CreateNFT(options ...createnftoptions.CreateNFTOption) (tx
return nil, nil, err
}
if createNFTOptions.WaitForConfirmation {
err = wallet.WaitForTxConfirmation(tx.ID())
err = wallet.WaitForTxAcceptance(tx.ID())
}

return tx, nftID, err
Expand Down Expand Up @@ -628,7 +627,7 @@ func (wallet *Wallet) TransferNFT(options ...transfernftoptions.TransferNFTOptio
}

if transferOptions.WaitForConfirmation {
err = wallet.WaitForTxConfirmation(tx.ID())
err = wallet.WaitForTxAcceptance(tx.ID())
}

return tx, err
Expand Down Expand Up @@ -728,7 +727,7 @@ func (wallet *Wallet) DestroyNFT(options ...destroynftoptions.DestroyNFTOption)
}

if destroyOptions.WaitForConfirmation {
err = wallet.WaitForTxConfirmation(tx.ID())
err = wallet.WaitForTxAcceptance(tx.ID())
}

return tx, err
Expand Down Expand Up @@ -844,7 +843,7 @@ func (wallet *Wallet) WithdrawFundsFromNFT(options ...withdrawfromnftoptions.Wit
}

if withdrawOptions.WaitForConfirmation {
err = wallet.WaitForTxConfirmation(tx.ID())
err = wallet.WaitForTxAcceptance(tx.ID())
}

return tx, err
Expand Down Expand Up @@ -960,7 +959,7 @@ func (wallet *Wallet) DepositFundsToNFT(options ...deposittonftoptions.DepositFu
}

if depositOptions.WaitForConfirmation {
err = wallet.WaitForTxConfirmation(tx.ID())
err = wallet.WaitForTxAcceptance(tx.ID())
}

return tx, err
Expand Down Expand Up @@ -1106,7 +1105,7 @@ func (wallet Wallet) SweepNFTOwnedFunds(options ...sweepnftownedoptions.SweepNFT
}

if sweepOptions.WaitForConfirmation {
err = wallet.WaitForTxConfirmation(tx.ID())
err = wallet.WaitForTxAcceptance(tx.ID())
}

return tx, err
Expand Down Expand Up @@ -1262,7 +1261,7 @@ func (wallet *Wallet) SweepNFTOwnedNFTs(options ...sweepnftownednftsoptions.Swee
}

if sweepOptions.WaitForConfirmation {
err = wallet.WaitForTxConfirmation(tx.ID())
err = wallet.WaitForTxAcceptance(tx.ID())
}
return tx, sweptNFTs, err
}
Expand Down Expand Up @@ -1412,7 +1411,7 @@ func (wallet *Wallet) Balance(refresh ...bool) (confirmedBalance, pendingBalance
for _, output := range outputsOnAddress {
// determine target map
var targetMap map[devnetvm.Color]uint64
if output.GradeOfFinalityReached {
if output.ConfirmationStateReached {
targetMap = confirmedBalance
} else {
targetMap = pendingBalance
Expand Down Expand Up @@ -1503,7 +1502,7 @@ func (wallet *Wallet) AvailableBalance(refresh ...bool) (confirmedBalance, pendi
for _, output := range outputsOnAddress {
// determine target map
var targetMap map[devnetvm.Color]uint64
if output.GradeOfFinalityReached {
if output.ConfirmationStateReached {
targetMap = confirmedBalance
} else {
targetMap = pendingBalance
Expand Down Expand Up @@ -1571,7 +1570,7 @@ func (wallet *Wallet) TimelockedBalances(refresh ...bool) (confirmed, pending Ti
Balance: casted.Balances().Map(),
Time: casted.TimeLock(),
}
if output.GradeOfFinalityReached {
if output.ConfirmationStateReached {
confirmed = append(confirmed, tBal)
} else {
pending = append(pending, tBal)
Expand Down Expand Up @@ -1618,7 +1617,7 @@ func (wallet *Wallet) ConditionalBalances(refresh ...bool) (confirmed, pending T
Balance: casted.Balances().Map(),
Time: fallbackDeadline,
}
if output.GradeOfFinalityReached {
if output.ConfirmationStateReached {
confirmed = append(confirmed, cBal)
} else {
pending = append(pending, cBal)
Expand Down Expand Up @@ -1666,7 +1665,7 @@ func (wallet *Wallet) AliasBalance(refresh ...bool) (
}
// target maps
var governedAliases, stateControlledAliases map[devnetvm.AliasAddress]*devnetvm.AliasOutput
if output.GradeOfFinalityReached {
if output.ConfirmationStateReached {
governedAliases = confirmedGovernedAliases
stateControlledAliases = confirmedStateControlledAliases
} else {
Expand Down Expand Up @@ -1764,7 +1763,7 @@ func (wallet *Wallet) DelegatedAliasBalance(refresh ...bool) (
}
// target maps
var delegatedAliases map[devnetvm.AliasAddress]*devnetvm.AliasOutput
if output.GradeOfFinalityReached {
if output.ConfirmationStateReached {
delegatedAliases = confirmedDelegatedAliases
} else {
delegatedAliases = pendingDelegatedAliases
Expand Down Expand Up @@ -1813,19 +1812,19 @@ func (wallet *Wallet) ExportState() []byte {

// endregion ///////////////////////////////////////////////////////////////////////////////////////////////////////////

// region WaitForTxConfirmation ////////////////////////////////////////////////////////////////////////////////////////
// region WaitForTxAcceptance //////////////////////////////////////////////////////////////////////////////////////////

// WaitForTxConfirmation waits for the given tx to reach a high grade of finalty.
func (wallet *Wallet) WaitForTxConfirmation(txID utxo.TransactionID) (err error) {
// WaitForTxAcceptance waits for the given tx to be accepted.
func (wallet *Wallet) WaitForTxAcceptance(txID utxo.TransactionID) (err error) {
timeoutCounter := time.Duration(0)
for {
time.Sleep(wallet.ConfirmationPollInterval)
timeoutCounter += wallet.ConfirmationPollInterval
finality, fetchErr := wallet.connector.GetTransactionGoF(txID)
confirmationState, fetchErr := wallet.connector.GetTransactionConfirmationState(txID)
if fetchErr != nil {
return fetchErr
}
if finality == gof.High {
if confirmationState.IsAccepted() {
return
}
if timeoutCounter > wallet.ConfirmationTimeout {
Expand Down
Loading