Skip to content

Commit

Permalink
Tracking tangle abstraction rework (#1049)
Browse files Browse the repository at this point in the history
* Add InputSource and some other glue

* Restructuring tangle abstraction and fixing errors (#1050)

* Restructuring and fix errors

* wip

* Add `MilestoneRange` (#1051)

* Add `MilestoneRange`

* PR comments

* `*Message` types (#1052)

* `*Message` types

* rename

* fix

* fmt

* Impl `milestone_stream` and `cone_stream` (#1053)

* Impl `milestone_stream` and `cone_stream`

* Make `ledger_updates` async again

* Clippy and fmt

* use `RangeBounds`

* fix `Send`

* wip

* Remove `unspent_outputs`

* remove memory stuff

* Impl ledger queries for MongoDb input source (#1056)

* Impl `milestone_stream` and `cone_stream`

* Make `ledger_updates` async again

* Clippy and fmt

* use `RangeBounds`

* Impl ledger updates query

* fix `Send`

* Impl unspent outputs query for mongodb

* Format

* Small refactor

* Nit

* Clippy + Format

* Collect into HashMap directly

* Return ledger updates as stream

Co-authored-by: Jochen Görtler <[email protected]>
Co-authored-by: Jochen Görtler <[email protected]>

* Add impls for INX and in-memory data (#1054)

* Add impls for INX and in-memory data

* Update src/tangle/sources/inx.rs

Co-authored-by: Jochen Görtler <[email protected]>

* Fix merge issues

* clippy

Co-authored-by: Jochen Görtler <[email protected]>

* Implement incremental in-memory analytics (#1061)

* Wip

* fmt

* wip

* wip

* Add `BaseTokenActivityAnalytics` analytics

* wip

* wip

* fmt

* Remove `inputs` from `handle_block`

* restructure

* Add ledger outputs

* Implement daily active addresses

* address some pr comments

* fix base token

* documentation

* Add moar analytics (#1066)

* Add ledger size analytic

* Remove context

* Add output activity analytic (part 1)

* Filter asset

* Handle implicit ids

* Add output activity analytic (part 2)

* Document unwraps

* Impl TryFrom OutputId for Nft and Alias ids

* Cleanup and docs

* Clippy

* Add milestone size analytic

* Fix docs

* Slice instead of Vec

* Fix CI

* Fix CI (this time?)

* usize instead of u64

* format

* Use `BlockData` struct in `BlockAnalytics` trait (#1073)

* Add ledger size analytic

* Remove context

* Add output activity analytic (part 1)

* Filter asset

* Handle implicit ids

* Add output activity analytic (part 2)

* Document unwraps

* Impl TryFrom OutputId for Nft and Alias ids

* Cleanup and docs

* Clippy

* Add milestone size analytic

* Fix docs

* Slice instead of Vec

* Fix CI

* Fix CI (this time?)

* usize instead of u64

* format

* Use BlockData type in BlockAnalytics trait

* Review comments

* Initial implementation of fill-analytics (and inx too 🤷) (#1070)

* Initial implementation of fill-analytics (and inx too 🤷)

* PR suggestions

* Handle missing outputs when getting analytics

* impl protocol params analytic

* More merges

* impl milestone size

* impl more analytics

* more impls

* impl milestone stream for mongo

* impl mongo ledger updates source

* Cleanup and feature gating

* implement in-memory unlock condition analytics (#1079)

* implement in-memory unlock condition analytic

* actually use new impl

* Small fix

* reduce redundancy

* Cleanup and unpublify analytics

* clippy + docs

---------

Co-authored-by: Alex Coats <[email protected]>

* `Vec`-based `LedgerUpdateStore` (#1091)

* `Vec`-based `LedgerUpdateStore`

* revert error

* Cache ledger updates (#1093)

Cache ledger updates in the milestone

* implement foundry activity analytics and cleanup output activity impl (#1090)

* Remove old analytics queries (#1094)

* Implement analytics using dyn Traits (#1095)

* Implement analytics using dyn Traits

* Simplify Measurement

* Reduce reuse recycle

* Add analytics context

* Clippy

* More cleanup. Fix usage of inner fields

* AddFields helper trait to invert call

* Rename `OuputAmount` to `TokenAmount` (#1096)

* Implement analytics using dyn Traits

* Add analytics context

* Rename `OuputAmount` to `TokenAmount`

* Rename `value` to `amount`

* fmt

* rename more

---------

Co-authored-by: Alex Coats <[email protected]>

* Fix ledger state for new analytics

* fox docs

* Fix analytic tests and clippy

* Fix in-memory analytics (#1099)

* Implement analytics using dyn Traits

* Add analytics context

* Rename `OuputAmount` to `TokenAmount`

* Rename `value` to `amount`

* fmt

* rename more

* Implement analytics using dyn Traits

* Add analytics context

* wip

* wip

* errors

* Only calculate analytics for included transactions

* timing

* Better database connection

* fix ci

* fmt

* remove dependency on INX

* fmt (comment)

* refactor num tasks

* fix overflow?

* fix again...

* fix measurement names

* fix feature

* remove feature gate

---------

Co-authored-by: Alex Coats <[email protected]>

* Fix unit test

* clippy

* Cleanup tangle impls

* Add INX backend for fill analytics (#1115)

* Add INX backend for fill analytics

* Add --help docs for fill-analytics

* Simplify

* Lifetimes

* Less moves

* Small refactor

* Set input source default

* Fixes everything

* Fix live INX analytics

* Cleanup

---------

Co-authored-by: Alex Coats <[email protected]>

* Cleanup error types

---------

Co-authored-by: Jochen Görtler <[email protected]>
Co-authored-by: /alex/ <[email protected]>

* Cleanup

* Update src/analytics/ledger/base_token.rs

Co-authored-by: /alex/ <[email protected]>

---------

Co-authored-by: /alex/ <[email protected]>
Co-authored-by: Alexandcoats <[email protected]>

* Allow more CLI variables in ENV (#1124)

Improve CLI env availability

* Add token distribution analytic (#1123)

* Starting impl

* Integrate token distribution into address balance analytic

* Ensure complete distribution

* Fix comment

* Small refactor

* Add dashboard

* cleanup

* Variable buckets

* Little more cleanups

---------

Co-authored-by: Alex Coats <[email protected]>

* wrap values in analytics (#1121)

* Wip

* fmt

* wip

* wip

* Add `BaseTokenActivityAnalytics` analytics

* wip

* wip

* fmt

* Remove `inputs` from `handle_block`

* restructure

* Add ledger outputs

* Implement daily active addresses

* address some pr comments

* fix base token

* documentation

* Add moar analytics (#1066)

* Add ledger size analytic

* Remove context

* Add output activity analytic (part 1)

* Filter asset

* Handle implicit ids

* Add output activity analytic (part 2)

* Document unwraps

* Impl TryFrom OutputId for Nft and Alias ids

* Cleanup and docs

* Clippy

* Add milestone size analytic

* Fix docs

* Slice instead of Vec

* Fix CI

* Fix CI (this time?)

* usize instead of u64

* format

* Use `BlockData` struct in `BlockAnalytics` trait (#1073)

* Add ledger size analytic

* Remove context

* Add output activity analytic (part 1)

* Filter asset

* Handle implicit ids

* Add output activity analytic (part 2)

* Document unwraps

* Impl TryFrom OutputId for Nft and Alias ids

* Cleanup and docs

* Clippy

* Add milestone size analytic

* Fix docs

* Slice instead of Vec

* Fix CI

* Fix CI (this time?)

* usize instead of u64

* format

* Use BlockData type in BlockAnalytics trait

* Review comments

* Initial implementation of fill-analytics (and inx too 🤷) (#1070)

* Initial implementation of fill-analytics (and inx too 🤷)

* PR suggestions

* Handle missing outputs when getting analytics

* impl protocol params analytic

* More merges

* impl milestone size

* impl more analytics

* more impls

* impl milestone stream for mongo

* impl mongo ledger updates source

* Cleanup and feature gating

* implement in-memory unlock condition analytics (#1079)

* implement in-memory unlock condition analytic

* actually use new impl

* Small fix

* reduce redundancy

* Cleanup and unpublify analytics

* clippy + docs

---------

Co-authored-by: Alex Coats <[email protected]>

* `Vec`-based `LedgerUpdateStore` (#1091)

* `Vec`-based `LedgerUpdateStore`

* revert error

* Cache ledger updates (#1093)

Cache ledger updates in the milestone

* implement foundry activity analytics and cleanup output activity impl (#1090)

* Remove old analytics queries (#1094)

* Implement analytics using dyn Traits (#1095)

* Implement analytics using dyn Traits

* Simplify Measurement

* Reduce reuse recycle

* Add analytics context

* Clippy

* More cleanup. Fix usage of inner fields

* AddFields helper trait to invert call

* Rename `OuputAmount` to `TokenAmount` (#1096)

* Implement analytics using dyn Traits

* Add analytics context

* Rename `OuputAmount` to `TokenAmount`

* Rename `value` to `amount`

* fmt

* rename more

---------

Co-authored-by: Alex Coats <[email protected]>

* Fix ledger state for new analytics

* fox docs

* Fix analytic tests and clippy

* Fix in-memory analytics (#1099)

* Implement analytics using dyn Traits

* Add analytics context

* Rename `OuputAmount` to `TokenAmount`

* Rename `value` to `amount`

* fmt

* rename more

* Implement analytics using dyn Traits

* Add analytics context

* wip

* wip

* errors

* Only calculate analytics for included transactions

* timing

* Better database connection

* fix ci

* fmt

* remove dependency on INX

* fmt (comment)

* refactor num tasks

* fix overflow?

* fix again...

* fix measurement names

* fix feature

* remove feature gate

---------

Co-authored-by: Alex Coats <[email protected]>

* Fix unit test

* clippy

* Cleanup tangle impls

* Add INX backend for fill analytics (#1115)

* Add INX backend for fill analytics

* Add --help docs for fill-analytics

* Simplify

* Lifetimes

* Less moves

* Small refactor

* Set input source default

* Fixes everything

* Fix live INX analytics

* Cleanup

---------

Co-authored-by: Alex Coats <[email protected]>

* Cleanup error types

---------

Co-authored-by: Jochen Görtler <[email protected]>
Co-authored-by: /alex/ <[email protected]>

* Cleanup

* impl wrapping analytics

---------

Co-authored-by: Jochen Görtler <[email protected]>
Co-authored-by: /alex/ <[email protected]>
Co-authored-by: Jochen Görtler <[email protected]>

* Create base token test case (#1122)

* Create base token test case

* Weird comment

* cleanup

* Add transaction size distribution analytic (#1117)

* Wip

* fmt

* wip

* wip

* Add `BaseTokenActivityAnalytics` analytics

* wip

* wip

* fmt

* Remove `inputs` from `handle_block`

* restructure

* Add ledger outputs

* Implement daily active addresses

* address some pr comments

* fix base token

* documentation

* Add moar analytics (#1066)

* Add ledger size analytic

* Remove context

* Add output activity analytic (part 1)

* Filter asset

* Handle implicit ids

* Add output activity analytic (part 2)

* Document unwraps

* Impl TryFrom OutputId for Nft and Alias ids

* Cleanup and docs

* Clippy

* Add milestone size analytic

* Fix docs

* Slice instead of Vec

* Fix CI

* Fix CI (this time?)

* usize instead of u64

* format

* Use `BlockData` struct in `BlockAnalytics` trait (#1073)

* Add ledger size analytic

* Remove context

* Add output activity analytic (part 1)

* Filter asset

* Handle implicit ids

* Add output activity analytic (part 2)

* Document unwraps

* Impl TryFrom OutputId for Nft and Alias ids

* Cleanup and docs

* Clippy

* Add milestone size analytic

* Fix docs

* Slice instead of Vec

* Fix CI

* Fix CI (this time?)

* usize instead of u64

* format

* Use BlockData type in BlockAnalytics trait

* Review comments

* Initial implementation of fill-analytics (and inx too 🤷) (#1070)

* Initial implementation of fill-analytics (and inx too 🤷)

* PR suggestions

* Handle missing outputs when getting analytics

* impl protocol params analytic

* More merges

* impl milestone size

* impl more analytics

* more impls

* impl milestone stream for mongo

* impl mongo ledger updates source

* Cleanup and feature gating

* implement in-memory unlock condition analytics (#1079)

* implement in-memory unlock condition analytic

* actually use new impl

* Small fix

* reduce redundancy

* Cleanup and unpublify analytics

* clippy + docs

---------

Co-authored-by: Alex Coats <[email protected]>

* `Vec`-based `LedgerUpdateStore` (#1091)

* `Vec`-based `LedgerUpdateStore`

* revert error

* Cache ledger updates (#1093)

Cache ledger updates in the milestone

* implement foundry activity analytics and cleanup output activity impl (#1090)

* Remove old analytics queries (#1094)

* Implement analytics using dyn Traits (#1095)

* Implement analytics using dyn Traits

* Simplify Measurement

* Reduce reuse recycle

* Add analytics context

* Clippy

* More cleanup. Fix usage of inner fields

* AddFields helper trait to invert call

* Rename `OuputAmount` to `TokenAmount` (#1096)

* Implement analytics using dyn Traits

* Add analytics context

* Rename `OuputAmount` to `TokenAmount`

* Rename `value` to `amount`

* fmt

* rename more

---------

Co-authored-by: Alex Coats <[email protected]>

* Fix ledger state for new analytics

* fox docs

* Fix analytic tests and clippy

* Fix in-memory analytics (#1099)

* Implement analytics using dyn Traits

* Add analytics context

* Rename `OuputAmount` to `TokenAmount`

* Rename `value` to `amount`

* fmt

* rename more

* Implement analytics using dyn Traits

* Add analytics context

* wip

* wip

* errors

* Only calculate analytics for included transactions

* timing

* Better database connection

* fix ci

* fmt

* remove dependency on INX

* fmt (comment)

* refactor num tasks

* fix overflow?

* fix again...

* fix measurement names

* fix feature

* remove feature gate

---------

Co-authored-by: Alex Coats <[email protected]>

* Fix unit test

* clippy

* Cleanup tangle impls

* Add INX backend for fill analytics (#1115)

* Add INX backend for fill analytics

* Add --help docs for fill-analytics

* Simplify

* Lifetimes

* Less moves

* Small refactor

* Set input source default

* Fixes everything

* Fix live INX analytics

* Cleanup

---------

Co-authored-by: Alex Coats <[email protected]>

* Cleanup error types

---------

Co-authored-by: Jochen Görtler <[email protected]>
Co-authored-by: /alex/ <[email protected]>

* Cleanup

* Starting impl

* Rename analytics choice

* Format

* Fix calculation

* Rework analytic (#1125)

* Rework analytic

* dashboard tweaks

* more tweaks

* fine, clippy, fine

* rename

* rename

* Add more buckets

* Rename

* Refactor

---------

Co-authored-by: Alexander Schmidt <[email protected]>

* Fix dashboard 1

* Fix dashboard 2

---------

Co-authored-by: Jochen Görtler <[email protected]>
Co-authored-by: Jochen Görtler <[email protected]>
Co-authored-by: Alexandcoats <[email protected]>

* Small refactor (#1130)

---------

Co-authored-by: Alexander Schmidt <[email protected]>

* Fix dashboard 1

* Fix dashboard 2

* Fix dashboard 3

* Rename panel title; Remove unit

* Change panel titles

---------

Co-authored-by: Jochen Görtler <[email protected]>
Co-authored-by: Jochen Görtler <[email protected]>
Co-authored-by: Alexandcoats <[email protected]>

* fix(api): refactor block queries to avoid lookups (#1133)

* Refactor block queries to avoid lookups

* 🙏

* Add shimmer test data

* Fix paths

* PR suggestion

* Revert applied query

* feat(analytics): rename value fields to amount (#1132)

rename value fields to amount

* chore(docs): Update env var docs (#1136)

Update docs with latest env vars

* fix(metrics): Start measurement before fetching milestone (#1137)

Start timer before milestone fetch

* fix(analytics): fill daily analytics (#1131)

* fix daily addresses

* Separate daily/per-milestone, cleanup traits

* Remove unnecessary tags

* Change daily to interval

* Fix another bug in chunking

* parallelism improvements for mongo source

* Capitalization

* cleanup

* Simplify chunking (#1139)

* Set up buckets only once for Transaction Size analytic (#1138)

* Set up buckets only once

* No more hashmaps

* bump indexes by one

* Remove once_cell

* suggestions and comments

* clippy

---------

Co-authored-by: Alex Coats <[email protected]>

---------

Co-authored-by: /alex/ <[email protected]>

* Clap cleanup

* fix(analytic): Fix base token analytic (#1144)

Sum it up

* feat(analytics): unit tests (#1145)

* Add unit tests for analytics with shimmer test data. Simplify analytics.

* Fix transaction size influx query. Cleanup tests for clippy.

* Further simplification of analytics trait

* Remove pub

* chore(deps): bump deps (#1147)

bump dependencies

---------

Co-authored-by: Alex Coats <[email protected]>
Co-authored-by: /alex/ <[email protected]>
  • Loading branch information
3 people authored Feb 28, 2023
1 parent 14a67e9 commit 8870176
Show file tree
Hide file tree
Showing 71 changed files with 20,499 additions and 3,370 deletions.
352 changes: 205 additions & 147 deletions Cargo.lock

Large diffs are not rendered by default.

3 changes: 2 additions & 1 deletion Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ async-trait = { version = "0.1", default-features = false }
bytesize = { version = "1.1", default-features = false }
clap = { version = "4.1", default-features = false, features = ["env", "derive", "std", "help", "usage", "error-context", "wrap_help"] }
decimal = { version = "2.1", default-features = false, features = [ "serde" ] }
derive_more = { version = "0.99", default-features = false, features = [ "add", "add_assign", "deref", "deref_mut" ] }
derive_more = { version = "0.99", default-features = false, features = [ "add", "add_assign", "deref", "deref_mut", "sum" ] }
dotenvy = { version = "0.15", default-features = false }
eyre = { version = "0.6", default-features = false, features = [ "track-caller", "auto-install" ] }
futures = { version = "0.3", default-features = false }
Expand Down Expand Up @@ -78,6 +78,7 @@ tonic = { version = "0.8", default-features = false, optional = true }
[dev-dependencies]
iota-types = { version = "1.0.0-rc.5", default-features = false, features = [ "api", "block", "std", "rand" ] }
rand = { version = "0.8", default-features = false, features = [ "std" ] }
ron = { version = "0.8", default-features = false }

[features]
default = [
Expand Down
Loading

0 comments on commit 8870176

Please sign in to comment.