历史代币余额索引器
历史代币余额索引器(Historical token balance indexer)
Historical Portfolio Index 是一款面向钱包级别的历史余额索引器,可在指定时间范围内检索某个钱包的历史代币余额。在多个时间点给出资产构成与价值变化,支持按日收盘(EOD)、月末(EOM)、年末(EOY)以及自定义时间区间的余额快照,便于开展灵活、细致的历史分析。
功能特性
基于时间窗口的灵活余额跟踪(Flexible Timeframe-Based Balance Tracking): 在用户定义的日期范围内检索钱包的历史代币余额,支持 EOD/EOM/EOY 快照,便于周期性与精确评估。
历史洞察(Historical Insights): 在所选时间窗内返回特定时间点的余额数据,支持对资产组合表现、资产配置与历史价值趋势进行深度分析。
方法论
通过过滤器创建索引(Index Creation with Filters)
索引在初始化时可配置自定义过滤条件,用于限定数据范围:
Account ID:指定进行历史分析的目标钱包地址。
Time Range:通过起止时间戳设定分析时间窗,支持按日收盘(EOD)、月末(EOM)、年末(EOY)的余额快照。
Backfilling Historical Data: 索引创建后会触发回填流程,通过查询链上数据填充历史代币余额。该流程在指定期间内抓取持仓快照,并将转账、交易、质押等所有影响余额的事件纳入计算。
Data Retrieval: 用户可随时通过 API 端点获取聚合后的历史余额数据。数据既可按累计总额返回,也可按日拆分,并按代币组织,提供资产构成与余额波动的细粒度视图。
技术要点(Technical Insights)
数据采集(Data Collection):在设定时间窗内解析链上记录与交易历史,确保对钱包活动的准确、全面跟踪。
基于时间的余额追踪(Time-Based Balance Tracking):支持在所选区间内生成每日、每月、每年末的余额快照,形成结构化、周期性的组合洞察。
价格关联(Price Correlation):通过连续记录代币余额,用户可结合历史价格数据分析组合价值变化并评估绩效趋势。
应用场景(Use Cases)
历史资产组合分析(Historical Portfolio Analysis):回顾历史资产构成,识别持仓变化模式或结构迁移。
绩效跟踪(Performance Tracking):评估特定区间内单币种或整体组合的历史表现与增长。
税务与合规报告(Tax and Compliance Reporting):提供精确的历史余额记录,支持审计、纳税申报与合规要求。
API 文档(API Documentation)
admin-base-url:https://indexer.astralane.io/
index-dataset-url: https://graphql.astralane.io/
授权(Authorization)
每个请求都必须在请求头中包含 x-api-key 用于鉴权。请将 <your_api_key> 替换为你的实际 API Key。
索引创建流程(Index Creation Flow)
创建新索引(Create New Index)
POST {admin-base}/index/account用途:为指定钱包初始化历史资产组合索引,用于开始跟踪代币余额。启动回填任务(Start Backfill Job)
POST {admin-base}/backfill/{index_id}用途:为指定 index_id 启动回填任务,抓取并填充历史余额数据。查询回填状态(Check Backfill Status)
GET {admin-base}/backfill/{index_id}用途:获取回填进度与当前状态,便于监控任务执行。获取历史资产组合数据(Fetch Historical Portfolio Data)
POST {index-dataset-url}/api/v1/portfolio/{index_id}/graphql用途:在所选时间范围内返回指定 index_id 的历史代币余额数据。Create New Index
POST {admin-base}/index/accountHeaders:x-api-key: <your_api_key>请求体(Request Body) 示例配置 1(Example Config 1): 该配置为指定钱包建立索引,并在定义的时间范围内为每一天生成日终(EOD)余额快照。
示例配置 2(Example Config 2) 该配置为指定钱包建立索引,在给定时间范围内按天生成日终(EOD)余额快照。
说明: 为指定账户初始化一个用于跟踪历史资产组合数据的新索引。
示例响应:
2. 启动回填任务(Start Backfill Job)
POST {admin-base}/backfill/{index_id}
Headers:
x-api-key: <your_api_key>
URL 参数:
index_id: 上一步创建的索引唯一标识。
请求体(Request Body):
说明:为指定的 index_id 启动回填流程,在定义的时间范围内填充历史代币余额数据。
示例响应:
3. 查询回填状态(Check Backfill Status)
GET {admin-base}/backfill/{index_id}
Headers:
x-api-key: <your_api_key>
URL 参数:
index_id: 需要查询回填状态的索引唯一标识。
说明:获取回填任务的当前状态,包括进度更新与预计完成时间。
示例响应:
4. 获取历史资产组合数据(Fetch Historical Portfolio Data)
POST {index-dataset-url}/api/v1/portfolio/{index_id}/graphql
或在浏览器中使用 GraphQL Playground(将 {index_id} 替换为实际索引 ID):
GraphQL Playground URL:
https://graphql.astralane.io/api/v1/portfolio/{index_id}/graphql
Headers:
x-api-key: <your_api_key>
URL 参数:
index_id: 要检索历史资产组合数据的索引唯一标识。
说明: 获取指定 index 在定义日期范围内的历史资产组合数据。返回的内容包含随时间变化的各代币余额,便于对资产组合变化进行细致分析。
示例查询(sample Query):
按日收盘(EOD)代币余额的示例响应
月末(EOM)代币余额的示例响应
Demo : https://www.loom.com/share/f9419d418c504eb6a048937ce25e227e
最后更新于