- Removed materialized view that is unnecessary and causes misdirection when debugging performance issues
- Add a caching interface for block and transaction queries that tend to be used often
- Optimize governance transaction fetching to return results in a timely fashion
- Resolve explorer service restarts due to database connection starvation caused by long running governance transaction queries
v6.0.0 - 2024-11-15
- Remove flow dependency and collect on-chain navs in local database #574
- Add hash price support for nav values from on chain events #543
- Integrate on-chain NAV data into historical hash price calculations #555
- Use on-chain NAV data for latest asset pricing on markers #556
- Add limit of 1 to missing block queries #544
- Removes the logic for calculating
running_count
andtotal_count
in themissed_blocks
#548 - Remove update block latency procedure call #550
- Docker images at tag
latest
for main branch merges #551 - Refactor account processing implementation to be more efficient #552
- Remove spotlight from caching to the database #532
- Update keep alive times for flow api grpc calls #558
- Updates to asset pricing table will set data column to null #562
- Remove
running_count
andtotal_count
columns from themissed_blocks
table #549 - Remove
spotlight_cache
table #559 - Remove the
data
column from theasset_pricing
table #563 - Updated Prov Protos to 1.20.1 #575
- Fix pagination off by one calls to flow grpc #561
v5.11.0 - 2024-08-27
- Updated Prov Protos to 1.19.0 #527
- Updated gRPC query to use
query
field instead ofevents
field #523 - Fixed transaction details endpoint by handling Base64 and string encoding changes #525
- Fixed issue with Proto deserialization incorrectly matching
cosmos.upgrade.v1beta1.CancelSoftwareUpgradeProposal
ascosmos.upgrade.v1beta1.SoftwareUpgradeProposal
, ensuring accurate type URL handling. #524 - Update osmosis pricing query with new required field
coinMinimalDenom
#526 - Fix group save tx processing #526, #526
- Fix validator proposer priority number type #530
v5.10.0 - 2024-06-11
- Update historical price data integration by removing figure's dlob and adding osmosis datasource #519
- Dynamic loading of proto descriptors #520
v5.9.0 - 2024-03-05
- Updated Prov Protos to 1.18.0 #515
v5.8.0 - 2024-03-05
- Updated Prov Protos to 1.18.0-rc2 #510
- Automate the registration of Provenance protobuf module descriptors #514
v5.7.0 - 2023-11-14
v5.6.0 - 2023-07-05
- Updated Prov Protos from 1.14.0-rc2 to 1.16.0 #490
v5.5.0 - 2023-05-19
- Validator Delegation Program metrics #482
- Added support to calculate and return validator metrics used by the Validator Delegation Program
- Added client support
- Add date parameters to
/api/v3/txs/heatmap
#462- Added
fromDate
,toDate
,timeframe
- Defaulting to
FOREVER
to return all data
- Added
- Fixed
/api/v3/validators
url - Now handling no fee amount in the tx
- Now handling Exec'd governance msgs, and properly handling weights from v1.Gov msgs
- Added object mapper and query parameters to
api-client
#487
- Migration 1.88 - Add
block_time_spread
,validator_metrics
#482- Adds view, table to support calculating and storing metrics for the Validator Delegation Program
v5.4.0 - 2022-12-15
- Add CSV download for Token Historical Pricing #453
- GET
/api/v3/utility_token/historical_pricing/download
- Using the given filters, exports the data behind the Hash Price History Chart
- GET
- Updated to Provenance version 1.13.0 #435
- Added support for groups data
- Added support for new governance v1 actions
- Added minimal support for IBC updates, nft module, rewards module
- TODO: Add in support for rewards module
- Publish API model set #464
- Publish API client set #468
- Updated Kotlin version
1.5.31
->1.6.21
#342- Gradle
7.3.3
->7.4.2
- SpringBoot
2.5.6
->2.6.6
- Kotlin Coroutines
1.5.2
->1.6.4
- Apache commons-text
1.9
->1.10
- Apache HttClient
4.5.12
->5.2
- BouncyCastle
1.69
->1.70
- Exposed
0.34.1
->0.38.2
- Jackson
2.12.5
->2.13.2
- Jackson Protobuf
0.9.12
->0.9.13
- Ktor
1.5.7
->2.1.3
- Grpc
1.40.1
->1.50.2
- Protobuf
3.19.1
->3.21.9
- NOTE: These updates had minimal impact, but Springfox 3.0.0 and Springboot 2.6.x do not play nicely. Had to add a hacky fix; will probably set some time aside to switch to SpringDoc.
- Gradle
- Added API to return only Account flags #447
- GET
/api/v3/accounts/{address}/flags
- returnsisContract
,isVesting
flags on the account
- GET
- Added Tx Msg logs to
/api/v2/txs/{hash}/msgs
#400 - Added Tx-level event logs to
/api/v2/txs/{hash}
#401- Decodes the data to human-readable strings
- Now caching FT/NFT counts per address #448
- This is done on the fly, asynchronously
- The Account detail API pulls from the cached values
- Deprecated a few APIs to align the API sets better #468
/api/v2/assets/detail/{denom}
->/api/v3/assets/{denom}
/api/v2/assets/detail/ibc/{hash}
->/api/v3/assets/ibc/{hash}
/api/v2/assets/holders
->/api/v3/assets/{denom}/holders
/api/v2/assets/metadata
->/api/v3/assets/metadata
/api/v2/gov/proposals/all
->/api/v3/gov/proposals
/api/v2/gov/address/{address}/votes
->/api/v3/gov/votes/{address}
/api/v2/smart_contract/codes/all
->/api/v3/smart_contract/code
/api/v2/smart_contract/contract/all
->/api/v3/smart_contract/contract
/api/v2/txs/types/tx/{hash}
->/api/v3/txs/{hash}/types
/api/v2/validators/recent
->/api/v3/validators/recent
- Migration 1.86 - Add
process_queue
,account_token_counts
#448- Adds both tables, inserts records for all accounts in the
account
table
- Adds both tables, inserts records for all accounts in the
- Migration 1.87 - 1.13.0 updates #435
- Added
owner
,is_group_policy
fields toaccount
- Updated
gov_proposal
,gov_vote
to hold new v1 data objects - Groups changes
- Ingest procedure updates where needed
- Inserts already-seen groups txs into the retry table to be reprocessed
- Added
v5.3.2 - 2022-11-14
- Slightly improved performance for processing the 1.11 fee bug range
- Fixed migration 1.83 to actually insert signature_tx records
v5.3.1 - 2022-11-11
- Fixed market cap calc #442
v5.3.0 - 2022-11-11
- Redesign of signature ingestion #416
- Now tracks idx, sequence of sigs on txs
- Now properly tracks base signature, idx for multisig keys
- Returns more informative signature objects on txs, accounts
- Now recursively searching within
MsgExec
,MsgGrant
,MsgRevoke
for associated info #417 - Saving tx subtypes for specific msg types #417
- Allows for searching within those subtypes as well
- Async task to update older msgs with the newly identified subtypes
- Swapped CMC pricing out in favor of DLOB pricing #436
- Fixed unending do-while loop on getting account balance for denom #433
- Fixed Proposal
eligibileAmount
for quorum percentages #432 - Fixed
/api/v3/accounts/tx_history
not returning any data #431 - Removed Account attribute parsing
- Now returning the object as seen on chain
- Migration 1.83 - Update
signature
, redo join tables #416- Dropped
signature.multi_sig_object
, Addedsignature.address
columns - Updated
signature
with new data - Added
signature_multi_join
,signature_tx
tables, updated with data
- Dropped
- Migration 1.84 - Update ingest procedure with new signature info #416
- Updated the ingest procedures
- Dropped
signature_join
table
- Migration 1.85 - Add msg subtypes #417
- Created table
tx_msg_type_subtype
, and populated with existing types - Updated views and ingest procedures
- Dropped column
tx_message_type_id
fromtx_message
- Created table
tx_msg_type_query
strictly for query purposes- Gets inserted on trigger from
tx_msg_type_subtype
, flatmapping the primary/secondary types for better querying purposes
- Gets inserted on trigger from
- Created table
v5.2.2 - 2022-11-07
- Removed invalid msg fee case, deleted invalid records
- Migration 1.82 - Deleted incorrect fees
v5.2.1 - 2022-11-02
- Updated the field type on asset pricing price
- This allows for better granularity on price for the token
v5.2.0 - 2022-10-28
- Added CSV downloads for the Tx History chart data #406
- Deprecated
/api/v2/txs/history
in favor of/api/v3/txs/history
- GET
/api/v3/txs/history/download
- Using the given filters, exports the data behind the Tx History chart - GET
/api/v3/accounts/tx_history
- Returns data for the Account Tx History chart - GET
/api/v3/accounts/tx_history/download
- Using the given filters, exports the data behind the Account Tx History chart - Added
MONTH
as a granularity option
- Deprecated
- Added APIs to get account balance for a single denom #418
- GET
/api/v3/accounts/{address}/balances/{denom}
- Returns balance for the given account and denom - GET
/api/v3/accounts/{address}/balances/utility_token
- Returns balance for the utility token for the given account /api/v3/accounts/{address}/balances/{height}
->/api/v3/accounts/{address}/balances_at_height
- Addeddenom
as query param
- GET
- Extracted
nhash
as the utility token out into an ENV to be configurable #399- Also extracted the base denom decimal places, voting power multiplier, floor gas price
- Merging DLOB and CMC volumes for more accurate values
- Now using the CMC price for the utility token instead of from PE #407
- Hotfix - Fixed fee calc on success with msg fees
- Fix error where weighted vote values were being exponentialized #424
- Migration 1.74 - Add index on
hash
totx_cache
- Migration 1.77 - Add
tx_timestamp
totx_fee
#406 - Migration 1.78 - Add
tx_timestamp
totx_feepayer
#406 - Migration 1.79 - Add
tx_timestamp
totx_message
#406 - Migration 1.80 - Add
tx_hash_id
totx_gas_cache
#406 - Migration 1.81 - Updating ingest procedures, add materialized views #406
- Updated associated ingest procedures
- Created
tx_history_chart_data_hourly
,tx_type_data_hourly
,fee_type_data_hourly
materialized views, with data
v5.1.0 - 2022-10-07
- Added APIs for CoinMarketCap data #388
- GET
/api/v3/utility_token/historical_pricing
- Returns a list of daily historical pricing for the utility token, queryable by date range - GET
/api/v3/utility_token/latest_pricing
- Returns the latest pricing for the utility token
- GET
- Added APIs for Authz grant and Feegrant data on an address #265
- GET
/api/v3/grants/authz/{address}/grantee
- Returns a paginated list of authz grants granted to the address - GET
/api/v3/grants/authz/{address}/granter
- Returns a paginated list of authz grants granted by the address - GET
/api/v3/grants/feegrant/{address}/grantee
- Returns a paginated list of feegrant allowances granted to the address - GET
/api/v3/grants/feegrant/{address}/granter
- Returns a 501 until the supporting gRPC query is applied to the chain
- GET
- Added dedicated API for getting Attribute Names by address #346
- GET
/api/v2/names/{address}/owned
- Returns attribute names owned by the address; applies to contracts as well
- GET
- Removed calls to Figment #385
- Added API to check account balance at height #387
- Updated Prov Protos from 1.11.0 to 1.12.0 #391
- Added proper exception on invalid JWT token #394
- Added caching on image urls from Keybase #396
- Reduces calls to Keybase so it doesnt yell at us
- Updated the MsgTypeSet enum to include an
additionalType
list that can be included in the module-based tx list #405- This allows assets created and traded via smart contract to show those transactions under the asset page
- Add list of associated values to a tx hash #340
- Swapped
Long
forBigDecimal
in places that will need it, specifically for large nhash quantities #380 - Rounding circulating supply, community pool values as those are whole
nhash
values #381 - Fix Null pointer on reading to EventFee object
- Fixed calcs for tx fees, including failed #387
- Updated tx hash uniqueness to include block height #384
- Added
blockHeight
query param to APIs where tx hash is used as the identifier - Updated the tx detail response to include a list of other blocks the hash was found in
- Added
- Fixed calc for tx fees, including success, during 1.11 block range #397
- Fixed error on validator fetch when validator is no longer in state #395
- Fixed IBC denom ingest when its a known denom instead of
ibc/...
- Migration 1.67 - Adding CMC data caching support #388
- Added
token_historical_daily
table - Inserted
cache_update
record forutility_token_latest
key
- Added
- Migration 1.68 - Fixing
tx_fee
data, again #387- Update
recipient
values that are blank tonull
- Delete duplicate fee records due to incorrect unique key
- Correct the unique key, and update the ingest procedure to use it
- Update
- Migration 1.69 - Adding height uniqueness to tx hash keys #384
- Addressed
tx_cache
,gov_deposit
,tx_address_join
,tx_feepayer
,tx_gas_cache
,tx_marker_join
,tx_nft_join
,tx_single_message_cache
,tx_sm_code
,tx_sm_contract
,validator_market_rate
,add_tx()
,add_tx_debug()
- Addressed
- Migration 1.70 - Update
tx_fee
records for non-fee failures #387- Updated
BASE_FEE_USED
fee type to0
- Deleted any extra records
- Updated
- Migration 1.71 - Update rollup functions #397
- Updated
update_gas_fee_volume()
function to aggregate fees fromtx_fee
table - Updated
insert_tx_gas_cache()
function to resetprocessed
to false and update the fee amount- This will ensure the rollups will be reaggregated
- Updated
insert_validator_market_rate()
to update the market rate value on duplicate - Updated
insert_tx_fees()
to delete all related fee records first, then insert - Inserted new
cache_update
record for 1.11 block range to reprocess those blocks for correct fees
- Updated
- Migration 1.72 - Update
validator_state
to include newremoved
field #395- Added
removed
column - Updated
current_validator_state
view to include the new column - Updated
get_validator_list()
function to include new column - Updated
get_all_validator_state()
function to include new column
- Added
- Migration 1.73 - Add
address_image
table to store image urls against an address #396- Added
address_image
table - Updated
current_validator_state
view to include the new table join - Updated
get_validator_list()
function to include new column from the view - Updated
get_all_validator_state()
function to include new column from the view
- Added
- Migration 1.74 - Update known IBC denoms
- Identifies known IBC denoms (NOT
ibc/...
) - Finds the base, updates records as needed, and deletes the errant known IBC denoms
- Identifies known IBC denoms (NOT
- Migration 1.75 - Add function to fetch associated values to a tx hash #340
- Added
get_tx_associated_values()
function
- Added
v5.0.0 - 2022-07-28
- Updated Provenance proto set to 1.11.0 #371
- Add Support for Tx Msg building #355
- Now supports building Tx msgs through API
- POST
/api/v3/gov/types/supported
- Gives list of proposal types supported for governance msgs - POST
/api/v3/gov/submit/{type}
- Crafts a Submit Proposal msg from the given data - POST
/api/v3/gov/deposit
- Crafts a Deposit msg - POST
/api/v3/gov/vote
- Crafts a Vote msg - POST
/api/v3/staking/delegate
- Crafts a Delegate msg - POST
/api/v3/staking/redelegate
- Crafts a Redelegate msg - POST
/api/v3/staking/undelegate
- Crafts an Undelegate msg - POST
/api/v3/staking/withdraw_rewards
- Crafts a Withdraw Rewards msg - POST
/api/v3/staking/withdraw_commission
- Crafts a Withdraw Commission msg - POST
/api/v2/accounts/send
- Crafts a Send msg
- POST
- Validations included to allow for better support
- Docs included to help with usage
- Now supports building Tx msgs through API
- Add Support for Vesting Accounts #366
- GET
/api/v3/accounts/{address}/balances
- Returns paginated balances, broken down by spendable vs locked - GET
/api/v3/accounts/{address}/vesting
- Returns Vesting detail and vesting schedule - Now ingests properly
- GET
- Add Support for Custom Msg Fees #367
- Updated fee ingestion to accommodate custom msg fees
- Also saves the original fee amount and denom for historical purposes
- Add APIs for CoinMarketCap #375
- GET
/api/v3/utility_token/stats
- Moved from/api/v2/token/stats
, returns breakdown of nhash allocation on a broader scale - GET
/api/v3/utility_token/distribution
- Moved from/api/v2/assets/distribution
, returns distribution of nhash across valid accounts- all accounts - nhash marker - zeroSeq - modules - contracts
- GET
/api/v3/utility_token/rich_list
- Returns the top X accounts rich in nhash- all accounts - nhash marker - zeroSeq - modules - contracts
- GET
/api/v3/utility_token/max_supply
- Returns the maximum supply ever of nhash on chain - GET
/api/v3/utility_token/total_supply
- Returns the total current supply of nhash- max - burned
- GET
/api/v3/utility_token/circulating_supply
- Returns the current circulating supply of nhash- max - burned - modules - zeroSeq - pool - nonspendable
- Updated
nhash
listview and detail supply values to use newtotal_supply
- Added
burned
amount,max_supply
amount to token stats chart data - Updated Chain Value AUM to use new
total_supply
fornhash
- GET
- Added Validation message collection to allow for multiple validations at once #355
- Updated Tx Type lists with new types
v4.3.1 - 2022-06-24
- Fixed blocks erroring out due to same Recv on 2 different txs within the same block
v4.3.0 - 2022-06-23
- Separated out Proposal votes into a paginated API #362
- Deprecated
/api/v2/gov/proposals/{id}/votes
in favor of/api/v3/gov/proposals/{id}/votes
- Moved Voting params and counts into the proposal detail / proposal listview responses
- Deprecated
- Add Name APIs #134
/api/v2/names/tree
- tree map of names on chain, including restriction and owner
- Now saving applicable block heights to pull governance param sets #341
- This is used to populate past proposals/votes/deposits based on the contemporary parameters on chain
- Now have the ability to fetch data at height from the chain
- Added Exposed functionality for Arrays and ArrayAgg Postgres function
- Fixed the Validator missed block count
- Added else case for IBC Recvs where the effected Recv is in the same tx as an uneffected Recv, which makes the block error out
- Added VoteWeighted msg type to
getGovMsgDetail()
function - Fixed how addresses were being associated with txs
- Migration 1.64 - Updates for gov params at height #341
- Updated
gov_proposal
withdeposit_param_check_height
,voting_param_check_height
, inserted data - Updated
insert_gov_proposal()
procedure - Created
get_last_block_before_timestamp()
function
- Updated
- Migration 1.65 - Add naming tree #134
- Created
name
table, and inserted records
- Created
v4.2.0 - 2022-05-24
- Add notification/announcement support #328
/api/v2/notifications/proposals
- List of NON-UPGRADE OPEN proposals, List of UPGRADE OPEN proposals/api/v2/notifications/upgrades
- List of expected, scheduled upgrades/api/v2/notifications/announcement
- PUT an announcement to be displayed in Explorer/api/v2/notifications/announcement/all
- Paginated list of announcements, can filter byfromDate
/api/v2/notifications/announcement/{id}
- GET an announcement by ID/api/v2/notifications/announcement/{id}
- DELETE an existing announcement
- Add new IBC APIs #336
/api/v2/txs/ibc/chain/{ibcChain}
- txs per IBC chain id, query params supporting narrowing by channel/api/v2/ibc/channels/src_port/{srcPort}/src_channel/{srcChannel}/relayers
- relayers by channel
- Update vote ingestion to include Weighted Votes #323
- Updated the Dockerfile to include support for Vault secrets
- IBC ingestion supports actual IBC flow #336
- Increased frequency for asset-price polling from every 30 minutes to every 15 minutes
- Removing 0-sequenced account balances from circulation totals #335
- Updated existing Smart Contract Code and Contract queries with new query params #339
/api/v2/smart_contract/codes/all
- added filters oncreator
,has_contracts
/api/v2/smart_contract/contract/all
- added filters oncreator
,admin
,label
/api/v2/smart_contract/code/{id}/contracts
- added filters oncreator
,admin
- Added API to fetch list of unique non-UUID contract labels #339
/api/v2/smart_contract/contract/labels
- Updated the Pricing Engine API pathing
- Added @jarrydallison as a CODEOWNER
- Updated how the service runs on an empty DB
- Fixed pagination on Validators at Height API #326
- Fixed how gov proposals were being processed if they hadn't gotten out of the deposit period #330
- Fixed processing of IBC msgs #331
- Related to incorrect value mapping
- Added sort to block retry so they process in height order
- Fixed how the weighted vote percentage was being ingested
- Fixed chain version fetch from Github #349
- Due to a limit of count on records from the Github API
- Fixed Validators' missed block count, bond height values #352
- Missed blocks -> incorrect values being calculated
- Bond Height -> query for signing infos was being limited, so not returning all records, thus missing some
- Migration 1.58 - Add weight to proposal votes #323
- Updated
gov_vote
to addweight
column - Split out tx ingestion pieces into their own routines for easier updating
- Inserting existing weighted votes
- Updated
- Migration 1.59 - Add
cache_update
records for spotlight processing, default avg block time- Used to ensure values are present for some initial data processing
- Migration 1.60 - Add
announcements
table #328 - Migration 1.61 - IBC Ledger updates #336
- Modifying
ibc_ledger
- addingsequence
,unique_hash
, removing acknowledgement columns - Inserting into new columns, updating unique key
- Created
ibc_ledger_ack
table to hold all corresponding response txs to a ledger record, and inserted records - Created
tx_ibc
table to hold all IBC-related txs, and inserted prelim records - Created
ibc_relayer
table to hold relayer addresses associated with a channel, and inserted records
- Modifying
- Migration 1.62 - Ingestion procedure updates #336
- Updated
insert_ibc_ledger()
procedure, created ingest procedures for new tables - Updated
add_tx_debug()
,add_tx()
procedures with new ingestions
- Updated
- Migration 1.63 - Add function for
uuid_or_null()
#339- Added function to determine if a string is a UUID, and if not, return null
v4.1.0 - 2022-03-24
- API for validator uptime statistics #260
/api/v2/validators/uptime
- API for chain AUM time series #291
/api/v2/chain/aum/list
- API for validator commission history #300
/api/v2/validators/{address}/commission/history
- Added uptime back to ValidatorSummary object #260
- Updated uptime calc for ValidatorDetail #260
- Removed
.isActive()
extension, which was inaccurate disregarding active set count #260 - Now inserting
tx_sm_code
record when a SC code is identified and correlated with a governance proposal #319 - Can now search by any marker's denom unit name #321
- Using pricing-engine pricing for
nhash
, made calcs uniform for all denoms and prices #321
- Fixed how the Array exposed set works #260
- Added single quote replacer function for transcribing objects for DB insertion #300
- Migration 1.52 - Creating procedure
get_all_validator_state()
#260- Used to fetch all validators with their current actual state
- replaces using an inaccurate extension
- Used to fetch all validators with their current actual state
- Migration 1.53 - Add Chain AUM table #291
- Added
chain_aum_hourly
table - Inserted data
- Added
- Migration 1.54 - Modify
validator_state
#300- Updated
validator_state
to includecommission_rate
column, updated with current data - Updated
current_validator_state
materialized view - Updated
get_validator_list()
,get_all_validator_state()
functions
- Updated
- Migration 1.55 - Add debug procedures #300
- Used to debug why a block/tx doesnt get saved correctly; needed for prod
- Migration 1.56 - Adding
tx_hash_id
to governance tables #319- Updated
gov_proposal
,gov_vote
,gov_deposit
to includetx_hash_id
- Updated
add_tx()
,add_tx_debug()
procedures to include the new fields - Inserting matching
tx_sm_code
records for SC codes created via governance proposal
- Updated
- Migration 1.57 - Adding
marker_unit
table #321
v4.0.0 - 2022-03-08
- Added attributes, UUID to NFT API #299
- Fully supporting msg based fee breakdown #299
- Updated Params API to include MsgFee params #299
- Added Msg-Based Fee API #299
- Now using provenance-io produced proto jar #199
- Dependency cleanup
- Updates to event scraping #299
- tied to increased Smart Contract usage
- Swagger cleanup
- Rewrote Migrations 1.49, 1.50 to make more sense #299
- Added procedure
update_market_rate()
to update market rate independently - Added procedure
update_market_rate_stats()
to update market rate stats tables independently - Removed fee updates via migration for now
- Added procedure
- Migration 1.51 - 1.8.0 updates #299
- Added
msg_type
totx_fee
table - Updated
add_tx()
procedure - Updated
tx_fee_unique_idx
- Added
update_tx_fees()
procedure to update tx fees at a specific block height- Did it this way so the migration is not dependent on a specific block height, and so future updates would only need to update the procedure with additional msg types/events for msg-based fees
- Added
v3.4.1 - 2022-02-28
- Fixed procedure stuff
- Fixed empty list null pointer exeptions
- Migration 1.51 - Updated Ingestion Procedures
- Dropped and rebuilt
tx_update
andblock_update
object types - Rebuilt the
add_block()
andadd_tx()
procedures
- Dropped and rebuilt
v3.4.0 - 2022-02-28
- Added Market Rate APIs #309
/api/v2/validators/{address}/market_rate/period
- time period of rates per validator/api/v2/chain/market_rate/period
- time period of rates for chainapi/v2/chain/market_rate
- avg values for chain for block count
- Added generic batch upsert functionality
- Expanded top 5 accounts on token distribution list
- Updated API naming to reflect current state
- Added doc to track all the statistics being presented
- Reworked Tx Fee calcs to align with how market rates are actually determined
- Added
validator_market_rate
- Removed
min_gas_fee
fromblock_proposer
- Renamed
validator_gas_fee_cache
tovalidator_market_rate_stats
- Renamed
chain_gas_fee_cache
tochain_market_rate_stats
- Added
- Migration 1.49 - Add validator market rate
- Added
validator_market_rate
table and indices - Inserted data into
validator_market_rate
- Dropped
block_proposer.min_gas_fee
- Renamed
validator_gas_fee_cache
tovalidator_market_rate_stats
, accompanying columns - Renamed
chain_gas_fee_cache
tochain_market_rate_stats
, accompanying columns - Updated procedure
add_block()
- Updated procedure
add_tx()
- Updated type
tx_update
- Added
- Migration 1.50 - Update tx fee records
- Deleted and rebuilt
tx_fee
records - Deleted
token_distribution_amounts
records - will be rebuilt by service
- Deleted and rebuilt
v3.3.2 - 2022-02-16
- Updated Migration 1.42 and 1.43 to work on a new database
- Fixed upgrade versions pulling releases that shouldnt be known
v3.3.1 - 2022-02-16
- Added sort to TxMessage response to order by msg idx as seen in the Tx object
- Fixed
proposal_monitor
buildInsert() to use correct value
v3.3.0 - 2022-02-15
- Added
24 Hr Power Change
to the Validator listview response #277
- Reworked block/transaction ingestion #274
- Created procedures to save all block/ tx data at once
- Should eliminate rogue data insertion
- Created procedures to save all block/ tx data at once
- Updated params to represent percentage values better
- Added value rollups to delegation/redelegation/unbonding APIS for both Accounts and Validators #290
- Generic map to add different values for different PagedResults responses as needed
- General cleanup of APIs
- Added
denom_trace
to IBC balance objects - Added error logging to pricing engine calls
- Updated pricing engine calls to be async, pulling new values and saving #296
- Updated NHASH pricing to pull from gecko API
- Updated Version Upgrade data to pull from GitHub API
- Removed unused fields from Validator listviews
- Updated param fields to use the correct param names
- Added caps to paginated APIs - set to 200 max count
- Updated token stats to use correct Bonded value
- Removing bad denoms #289
- For unknown denom types (NOT IBC), set status to
MARKER_STATUS_UNSPECIFIED
so they don't show up in listviews, but are still saved to the database for reference
- For unknown denom types (NOT IBC), set status to
- Updated Migration 1.41 to include exception handling in procedures
- Updated BlockRetry to use the main block insertion method rather than the intermediary, added exception handling
- Fixed logic to correctly show validator votes in a block
- Fixed the ingestion procedure re:
signature_join
data
- Migration 1.40 - Data clean up #274
- Removed duplicate data for
tx_message
,tx_msg_event
,tx_msg_event_attr
- Removed duplicate data for
- Migration 1.41 - Update
tx_msg_event_attr
table wth fields #274- Added
attr_idx
,attr_hash
totx_msg_event_attr
- Added
- Migration 1.42 - Update
tx_msg_event_attr
Part 1 #274- Updated
attr_idx
with data
- Updated
- Migration 1.43 - Update
tx_msg_event_attr
Part 2 #274- Updated
attr_hash
with data
- Updated
- Migration 1.44 - Added ingestion procedures #274
- Added unique indices for all tx-related tables
- Added types
tx_event
,tx_msg
,tx_update
,block_update
- Added procedures
add_tx(tx_update, integer, timestamp)
,add_block(block_update)
- Migration 1.45 - Invalid denom cleanup #289
- Updated
marker_cache.status
toMARKER_STATUS_UNSPECIFIED
for allmarker_cache.marker_type = 'DENOM'
- Updated
- Migration 1.46 - Update Ingestion procedure
- Fixed signature_join insertion to use the correct join key value
- Migration 1.47 - Add asset pricing tables #296
- Added tables
asset_pricing
andcache_update
- Inserted initial record for
pricing_update
cache record
- Added tables
- Migration 1.48 - Add cache update for chain versions
- Inserted initial record for
chain_releases
cache record
- Inserted initial record for
v3.2.0 - 2022-01-18
- Added pricing-engine call for Assets #276
- Added per token / total price values on asset listview and asset detail
- Added total AUM value to Spotlight record
- Added per token / total price values to account balances
- Added account AUM value
- Added per token / total price values to account delegation rewards response
- Updated returned prices to be null for unknown pricing #285
- Updated Gradle to 7.3.3
- Removed Jcenter
, replacing dependent build with JitPack for now - Replaced
khttp
withktor client
#281 - Added
api/v2/validators/recent/abbrev
so FE doesn't have to call the main validator query for all validators #282
v3.1.0 - 2022-01-07
- Added API for chain upgrades #246
- API under
/api/v2/chain/upgrades
- API under
- Added support for Tx Fee breakdown and Tx Feepayer identification #252
- Added
docs/txs/Feepayer.md
to lay out changes - Support for ingestion
- Added support on tx query responses - updated field
fee
and new fieldfeepayer
- Added
- Added API for chain prefixes #269
- API under
/api/v2/chain/prefixes
- API under
- Updated ingestion to use the same TxData object for block-related data
- Increased local DB connection size to 40 to match container connection size
- Added
EXPLORER_HIDDEN_APIS
to allowing hiding of maintenance APIs from Swagger #271 - Updated the Param set #270
- Updated
AccountDetail.publicKeys
to be a public key object showing the key and key type #267{ ... "publicKeys": { "pubKey": "AireALVFyk8k1alZLcJLEdfaDFuyDua9eZsswvYsHUGN", "type": "secp256k1" }, ... }
- Migration 1.39 - Added Tx fee and feepayer tables #252
tx_fee
,tx_feepayer
tables- Insertion logic to prep the tables
v3.0.0 - 2021-11-29
- Updated
/cosmos/base/tendermint/v1beta1/blocks/{height}
to come from Figment url instead of local node #231- Defaults to Figment, with local node as backup in case Figment call fails
- Added new properties
explorer.figment-apikey
,explorer.figment-url
defaulted to Figure's key and test url
- Added ingestion and API for Smart Contract msg types #70
- API under
/api/v2/smart_contract
- Proposal monitoring to find when a
StoreCodeProposal
is created
- API under
- Generating Kotlin protobuf classes using official Protobuf Kotlin DSL #254
- Added
/api/v2/validators/missed_blocks
and/api/v2/validators/missed_blocks/distinct
APIs #257- Used for devops validator monitoring
- Added a block tx retry table to store heights that failed to fetch txs #232
- Added async to then retry those blocks
- Decreased time to update proposal status
- from every day at 12 am to every hour at the 30-minute mark
- Reworked how events were scraped for denoms and addresses
- Reworked how msg type was being derived #248
- Now deriving
module
,type
fromproto.typeUrl
instead of scraping events for possible values
- Now deriving
- Reworked account insert/update to use upsert instead
- Adding initial use cases for Kotlin Coroutines #255
- Improved NFT API with additional data #253
- Added APIs for specification json responses
- Added additional MsgConverter lines to handle older tx msg types
- Downgraded Spring Boot Version: 2.5.4 -> 2.4.3
- Downgraded jackson-databind dependency: 2.12.2 -> 2.11.2
- Updated signature finding based on msg type #249
- Added API response handler for IllegalArgumentExceptions #245
- Fixed NullPointerException when
session_id_components
was actually null - Fixed bug in
update_gas_fee_volume()
procedure #258 - Fixed bug with active validator set not respecting staking param
max_validators
#261
- Migration 1.32 - Added
block_tx_retry
table #232 - Migration 1.33 - Added Smart Contract tables and keys #70
sm_code
,tx_sm_code
,sm_contract
,tx_sm_contract
tables- Updated
account
with columnis_contract
- Migration 1.34 - Added unique key to
tx_message_type
#248- Upserted records to make records uniform
- Migration 1.35 - Added
proposal_monitor
table #70 - Migration 1.36 - Updated
update_gas_fee_volume()
procedure #258 - Migration 1.37 - Added
missed_block_periods()
function to find missed blocks for inputs #257 - Migration 1.38 - Added
get_validator_list()
function to properly identify state, and gather list for inputs #261
v2.4.0 - 2021-09-15
- Upgraded versions #172, #236
- Provenance: v1.5.0 -> v1.7.0
- Cosmos SDK: v0.42.6 -> v0.44.0
- Added IBC Go: ** -> v1.1.0
- Kotlin: 1.4.30 -> 1.5.30
- Gradle: 6.8.3 -> 7.2.0
- SpringBoot: 2.4.3 -> 2.5.4
- With upgraded versions, added in support for new Msg types and pubkey
secp256r1
- Now pulling
wasmd
protos fromprovenance-io/wasmd
instead ofCosmWasm/wasmd
#238- Current version at v0.19.0
- Pinned CosmWasm/wasmd protos to
v0.17.0
for backwards compatibility
- Translated Smart Contract msg bytes to human-readable json
v2.3.1 - 2021-09-10
- Added checks to refresh the
current_validator_state
view- Should reduce the number of unnecessary refreshes
- Updated Spotlight Cache create to use the second top-most height actually in the database
- This will prevent a race condition for saving blocks
- Added
tx_message.msg_idx
to actually have message uniqueness - Fixed the hashing function for tx_message to be deterministic
v2.3.0 - 2021-08-31
- Added gas fee statistics (min, max, avg, std) per message type on single message transactions #185
- Added gas fee volume #186
- Added heatmap endpoint
/api/v2/txs/heatmap
of when txs are submitted during the day/week #187 - Added token statistics for circulation supply, community pool and bonded supply #188
- Updated Validators to return an image URL from Keybase for their profile image #200
- Added distribution of hash between sets of accounts #189
- Added validator block latency endpoint
/api/v2/validators/{id}/latency
#199
- Added global boolean to disregard historical data check once its no longer needed
- Reduces slowdown between block processing
- Reworked tx history count calcs to be more efficient #220
- Reworked how validator state was being stored #222
- No longer updates, instead append-only to reduce processing time
- Reworked
/api/v2/validators/recent
&/api/v2/validators/height/{blockHeight}
to be more efficient with data #222 - Reworked how spotlight data was being stored #221
- No longer updates, instead append-only to reduce processing time
- New record every 5 seconds -> no TTL for now
- Added
isProposer
anddidVote
flags to validators at height api #183- Broke out fetching validators are height from recent validators functions to be cleaner
- Fixed update of the daily gas stats causes hourly data to be missed #210
- Fixed nullable fields in Migration 26
- Fixed null pointer for bad Keybase identity #224
- Added image url to BlockSummery object #224
- Fixed Spotlight data to pull correct block votes vs validator set for block
- Added caching and aggregate tables for txs with single messages only #185
- Added
tx_single_message_cache
table - Added
tx_single_message_gas_stats_day
table - Added
tx_single_message_gas_stats_hour
table - Added
update_gas_fee_stats
stored procedure
- Added
- Added aggregate, cache table(s) and stored procedure for gas fee volume #186
- Added
tx_gas_cache
table - Added
tx_gas_fee_volume_day
table - Added
tx_gas_fee_volume_hour
table - Added
update_gas_fee_volume
stored procedure
- Added
- Added cache table, stored procedure for tx history counts #220
- Added
block_tx_count_cache
table - Added
update_block_cache_hourly_tx_counts
stored procedure
- Added
- Removed unused indices
- Added append-only cache table, materialized view for validator state #222
- Added
validator_state
table - Added
current_validator_state
materialized view - Dropped unused columns from
staking_validator_cache
table
- Added
- Updated
block_proposer
to includeblock_latency
#221- Added
update_block_latency()
stored procedure
- Added
v2.2.0 - 2021-07-29
- Added dedicated Gov Tx API at
/api/v2/txs/module/gov?address={address}&etc...
to fetch txs with specific data #193 - Added tables for tx events and event attributes that are populated when tx messages are saved #115
- Updated front-facing docs
- Ensure governance proposal votes take precedence by block height
- Use actual count of validator results for listview page count #201
- Fixed Refresh of Materialized View for Tx history slow down block saves #196
- Added
tx_msg_event
,tx_msg_event_attr
for tx event caching #115 - Removed
block_cache_tx_history_day
,block_cache_tx_history_hour
#196 - Added
block_cache_hourly_tx_counts
for better caching of tx counts #196
v2.1.0 - 2021-07-22
- Added
msgType={msgType}
to/api/v2/txs/{hash}/msgs
to allow for filtering based onmsgType
#146 - Added
/api/v2/txs/types/tx/{hash}
to fetch msg types applicable to a single tx #146 - Updated
/api/v2/accounts/{address}
to returnTokenCount
object #140- Shows count of fungible and non-fungible tokens
- Added
/api/v2/params
to return parameters from the Grpc clients #153
- Added
PagedResults.total
to return total record count #146 - Updated
/api/v2/nft/scope/owner/{address}
to return a listview rather than list ofScope.uuid
#140 - Updated
NFTs.md
design doc to match newer design doc layouts - Updated MissedBlocks insert to accommodate for out-of-sequence blocks (eg service playing catchup) #143
- Added Kotlin lint check to github actions and fixed incorrectly formatted kotlin code #61
- Created DB view for tx history data, making he UI chart faster #117
- Fixed wrong error message being populated on commission when an operator is jailed #156
- Handled 500 error from jailed operators and used default value of 0 instead #155
- Tx Msgs MetadataAddress types displayed as Base64 strings in UI #145
- Processing new protos from v1.5.0 #175
- Don't try to save missed blocks when current block height is 0 #167
- Now updating proposal status every day at 12 AM UTC #168
- Fixed NPE on .toObjectNode() for metadata call #180
- Fixed bug where a validator does not have any signing info (which is used to populate some fields) #178
- Affected the Validator listview, filtered on 'Candidate'
- Affected the Validator detail for the specific validator
- Added migration 20 for indices on
block_cache
#117 - Created
block_cache_tx_history_day
andblock_cache_tx_history_hour
as views for better caching #117
v2.0.1 - 2021-06-16
- HOTFIX: Removed tx msgs from listview and detail responses into a paginated API #142
/api/v2/txs/{hash}/msgs?page={page}&count={count}
v2.0.0 - 2021-06-14
- IBC denom API #97
/ibc/all
- Add get escrow account address method for ibc #119
- Gov Proposal API #64
/gov/proposals/all?page={page}&count={count}
/gov/proposals/{id}
/gov/proposals/{id}/votes
/gov/proposals/{id}/deposits?page={page}&count={count}
/gov/address/{address}/votes?page={page}&count={count}
- IBC Channel API #122
/ibc/channels/balances
/ibc/channels/status?status={status]
- IBC Balance API #132
/ibc/channels/balances
->/ibc/balances/channel
-> Balances broken down by chain/channel/denom/ibc/balances/chain
-> Balances broken down by chain/denom/ibc/balances/denom
-> Balances broken down by denom
- Address-owned Names API #92
/accounts/{address}/attributes/owned
- Removed hash conversion #66
- This will now be done on the frontend
- Ingesting denoms and addresses from IBC Txs #97
- Improved failure statuses for APIs #120
- Now returning 404s, no message -> Typically due to no record from the db
/api/v2/accounts/{address}
-> checks for a valid account address/api/v2/assets/detail/{id}
/api/v2/assets/detail/ibc/{id}
/api/v2/txs/{hash}
/api/v2/txs/{hash}/json
/api/v2/validators/height/{blockHeight}
/api/v2/validators/{id}
/api/v2/validators/{id}/commission
- Now returning 404s, with message -> This is due to the error coming from chain queries
/api/v2/accounts/{address}/balances
/api/v2/accounts/{address}/delegations
/api/v2/accounts/{address}/unbonding
/api/v2/accounts/{address}/redelegations
/api/v2/accounts/{address}/rewards
/api/v2/assets/holders?id={id}
/api/v2/assets/metadata?id={id}
/api/v2/blocks/height/{height}
/api/v2/nft/scope/{addr}
/api/v2/nft/scope/owner/{addr}
-> returns 404 if invalid address/api/v2/nft/scope/{addr}/records
/api/v2/nft/validators/{id}/delegations/bonded
/api/v2/nft/validators/{id}/delegations/unbonding
- Now returning 404s, no message -> Typically due to no record from the db
- Created a
docs
folder to store design docs - Ingesting proposals, votes, deposits for Gov tx msgs #64
- Updated protos - Provenance to v1.4.1, cosmos sdk to 0.42.5 #128
- Ingesting IBC channels for IBC tx msgs #122
- Added attributes assigned to an address, formatted to make sense #92
- Updated missed_blocks count to pull from DB #136
- Properly sorting Validator listview #112
- Removing
nft/scope/all
due to massive performance issues #118 - Filtering out blanks when associating addresses to txs
- Fixed boolean check on NFT delete messages
- Added an address check on unknown accounts being requested -> checking for proper address prefix
- Adding blank check to NFT uuids
- Added
markerType
to asset listview response #131 - Updated
AssetDetail.supply
from String to CoinStr #137 - Updated
AssetList.supply
from String to CoinStr #137 - Updated
AssetHolder.balance
to includedenom
#137 - Updated MsgConverter
typeUrl.contains()
totypeUrl.endsWith()
due to some msgs containing names of other msgs
- Account balances are now paginated #102
/{address}/balances?page={page}&count={count}
- Removed from Account Detail API
- Now handling IBC denoms in search #103
/assets/detail/{id}
,/assets/detail/ibc/{id}
-> as used by FE, these should resolve naturally/assets/{id}/holders
->/assets/holders?id={denom}
/assets/{id}/metadata
->/assets/metadata?id={denom}
withid
optional, returning full list of metadata
- Added migration 14 for token count to staking_validator_cache #112
- Added migration 15 for increasing denom length, marker_cache holding non-marker denoms #103
- Added migration 16 for storing Gov data #64
- Added migration 17 for storing IBC Channel data #122
- Added migration 18 for storing IBC Balance Ledger data #132
- Added migration 19 for storing missed blocks data #136
v1.5.0 - 2021-05-21
- Added MetadataAddress conversion class from Provenance repo #29
- Updated tx type listings, now sorted on module/type
- Casting grpc lists to mutable lists
- Added utility to search if accounts have a designated denom
- Casting fees to BigInteger now, as the number is too big for Int
- Asset detail now pulling supply from correct source #105
- Tx query with filter no applying distinct to get correct number of records #106
- Accounts now update with all info #107
- Handling account delegation error if no delegations for account #108
- Added tables for NFT data and tx joins #29
- Added migration to fix account records that have missing data #107
v1.4.0 - 2021-05-14
- Accounts can now be queried for delegations, unbonding delegations, redelegations, and rewards #96
- Updated tx type listing to group IBC calls together
- Updated Provenance protos to v1.3.0 #94
- Handle unknown accounts now #85
- Fixed where code was looking for non-existent denoms
- Fixed where a block's validators list was incorrect #91
- Added missing explicit IBC.header proto #93
- ValidatorDelegation object changes #96
- address -> delegatorAddr
- ADDED validatorSrcAddr, validatorDstAddr, initialBal -> Should not be breaking
- Removed queryDenom from CoinStr object #66
v1.3.0 - 2021-05-06
- Added name to AccountDetail object; applicable only for ModuleAccount type #83
- Added ModuleAccount name to applicable moniker lists #83
- Added pagination and status search to getAssets() API #78
- Removed
initial supply
as it was causing confusion, and left circulation as the current total on chain #78 - Updated gradle task
downloadProtos
to include CosmWasm/wasmd proto set, Cosmos ibc protos #62
- Fixed bug where Tx message types were being overwritten with "unknown"
v1.2.0 - 2021-04-30
- Updated Provenance protos to 1.2.0 #80
- Now handling no rewards on a validator #76
- Fixed no transaction on address lookup for txs #76
- Fixed erroring asset holder count #79
v1.1.0 - 2021-04-29
- On asset list and asset detail, the supply object now contains
initial
andcirculation
rather thancirculation
andtotal
#52 - All coin objects (with a balance and a denom) now have a
queryDenom
value to be used for querying based on that denom #52 /api/v2/assets/{id}/holders
now returns a paginated list #52- Asset's current supply now comes from bank module rather than the marker object #52
- Added tx/msg look up to block/tx queries to fill in missing info under the hood #71
- Now updating account signatures when updating accounts #63
- Added more indices for more complex joins #71
v1.0.0 - 2021-04-23
- Added a script to pull in protos used in the client #5
- Added a
build.gradle
to allow the protos to be compiled to java on build task #5 - Added support for multisig on transactions, accounts, and validators (limited) #9
- Added Validator-specific APIs #15
- Added Account-specific transaction API #11
- Added working docker-compose script #10
- Dockerize Database #36
- Added Min Gas Fee statistics #30
- Added templates and build workflow
- Updated
/api/v2/validators/height/{blockHeight}
to translate page to offset for proper searching - Upgraded to gRpc blockchain calls #17
- Upgraded to Kotlin gradle
- Updated the transaction database tables to allow for better searching #15
- Updated block queries to return the same object with updated info #13
- Updated native queries to use exposed query-building instead
- Updated transaction queries to return same objects as other similar queries #14
- Upgraded Exposed library from 0.17.1 to 0.29.1
- Updated the copy_proto script to be more intuitive
- Because we have a docker gha workflow that builds, I removed the branch-> main designation for build gha #34
- Added gradle custom
downloadProtos
task to download protos instead of shell script. - Updated Validator.bond_height to come from real numbers
- Added Asset status to the asset objects
- Added current gas fee to Validator objects
- Initial conversions from nhash to hash #44
- Changed ownership on assets #45
- Improved query performance #53
- Added release workflow #58
- Translated the signatures back to usable addresses
- Fixed
gas/statistics
from previous updates - Changed out Int to BigInteger in API return objects #34
- Added distinct to Tx query so it actually only brings back tx objects/counts #34
- Added total tx count to Spotlight object #34
- Made Block Hash look like a hash #34
- Updated a couple docker scripts cuz I moved things around in the last commit #34
- Fixed a bug where candidate/jailed validators were being filtered out of results
- Added missing protos #55
- Properly handling Multi Msg txs #56
- Added a db index on tx_cache.height
- Added additional db indices
- Added migrations for Tx, BlockProposer, TxMessage, and TxMessageType data points #57