Celenium API is a powerful tool to access all blockchain data that is processed and indexed by our proprietary indexer. With Celenium API you can retrieve all historical data, off-chain data, blobs and statistics through our REST API. Celenium API indexer are open source, which allows you to not depend on third-party services. You can clone, build and run them independently, giving you full control over all components. If you have any questions or feature requests, please feel free to contact us. We appreciate your feedback!
This API client was generated by the OpenAPI Generator project. By using the OpenAPI-spec from a remote server, you can easily generate an API client.
- API version: 1.0
- Package version: 1.0.0
- Generator version: 7.11.0-SNAPSHOT
- Build package: org.openapitools.codegen.languages.GoClientCodegen For more information, please visit https://discord.gg/3k83Przqk8
Install the following dependencies:
go get github.com/stretchr/testify/assert
go get golang.org/x/net/context
Put the package under your project folder and add the following in import:
import celenium "github.com/celenium-io/celenium-api-go"
To use a proxy, set the environment variable HTTP_PROXY
:
os.Setenv("HTTP_PROXY", "http://proxy_name:proxy_port")
Default configuration comes with Servers
field that contains server objects as defined in the OpenAPI specification.
For using other server than the one defined on index 0 set context value celenium.ContextServerIndex
of type int
.
ctx := context.WithValue(context.Background(), celenium.ContextServerIndex, 1)
Templated server URL is formatted using default variables from configuration or from context value celenium.ContextServerVariables
of type map[string]string
.
ctx := context.WithValue(context.Background(), celenium.ContextServerVariables, map[string]string{
"basePath": "v2",
})
Note, enum values are always validated and all unused variables are silently ignored.
Each operation can use different server URL defined using OperationServers
map in the Configuration
.
An operation is uniquely identified by "{classname}Service.{nickname}"
string.
Similar rules for overriding default operation server index and variables applies by using celenium.ContextOperationServerIndices
and celenium.ContextOperationServerVariables
context maps.
ctx := context.WithValue(context.Background(), celenium.ContextOperationServerIndices, map[string]int{
"{classname}Service.{nickname}": 2,
})
ctx = context.WithValue(context.Background(), celenium.ContextOperationServerVariables, map[string]map[string]string{
"{classname}Service.{nickname}": {
"port": "8443",
},
})
All URIs are relative to https://api-mainnet.celenium.io/v1
Class | Method | HTTP request | Description |
---|---|---|---|
AddressAPI | AddressBlobs | Get /address/{hash}/blobs | Get blobs pushed by address |
AddressAPI | AddressDelegations | Get /address/{hash}/delegations | Get delegations made by address |
AddressAPI | AddressGrantee | Get /address/{hash}/granters | Get grants where address is grantee |
AddressAPI | AddressGrants | Get /address/{hash}/grants | Get grants made by address |
AddressAPI | AddressMessages | Get /address/{hash}/messages | Get address messages |
AddressAPI | AddressRedelegations | Get /address/{hash}/redelegations | Get redelegations made by address |
AddressAPI | AddressStats | Get /address/{hash}/stats/{name}/{timeframe} | Get address stats |
AddressAPI | AddressTransactions | Get /address/{hash}/txs | Get address transactions |
AddressAPI | AddressUndelegations | Get /address/{hash}/undelegations | Get undelegations made by address |
AddressAPI | AddressVesting | Get /address/{hash}/vestings | Get vesting for address |
AddressAPI | GetAddress | Get /address/{hash} | Get address info |
AddressAPI | GetAddressCount | Get /address/count | Get count of addresses in network |
AddressAPI | ListAddress | Get /address | List address info |
BlockAPI | BlockBlobsCount | Get /block/{height}/blobs/count | Count of blobs which was pushed by transaction |
BlockAPI | GetBlock | Get /block/{height} | Get block info |
BlockAPI | GetBlockBlobs | Get /block/{height}/blobs | List blobs which was pushed in the block |
BlockAPI | GetBlockCount | Get /block/count | Get count of blocks in network |
BlockAPI | GetBlockEvents | Get /block/{height}/events | Get events from begin and end of block |
BlockAPI | GetBlockMessages | Get /block/{height}/messages | Get messages contained in the block |
BlockAPI | GetBlockStats | Get /block/{height}/stats | Get block stats by height |
BlockAPI | ListBlock | Get /block | List blocks info |
GasAPI | GasEstimateForPfb | Get /gas/estimate_for_pfb | Get estimated gas for pay for blob |
GasAPI | GasPrice | Get /gas/price | Get estimated gas price |
GeneralAPI | GetConstants | Get /constants | Get network constants |
GeneralAPI | GetEnums | Get /enums | Get celenium enumerators |
GeneralAPI | Head | Get /head | Get current indexer head |
NamespaceAPI | GetBlob | Post /blob | Get namespace blob by commitment on height |
NamespaceAPI | GetBlobLogs | Get /namespace/{id}/{version}/blobs | Get blob changes for namespace |
NamespaceAPI | GetBlobMetadata | Post /blob/metadata | Get blob metadata by commitment on height |
NamespaceAPI | GetBlobProof | Get /blob/proofs | Get blob inclusion proofs |
NamespaceAPI | GetBlobs | Get /blob | List all blobs with filters |
NamespaceAPI | GetNamespace | Get /namespace/{id} | Get namespace info |
NamespaceAPI | GetNamespaceActive | Get /namespace/active | Get last used namespace |
NamespaceAPI | GetNamespaceBase64 | Get /namespace_by_hash/{hash} | Get namespace info by base64 |
NamespaceAPI | GetNamespaceBlobs | Get /namespace_by_hash/{hash}/{height} | Get namespace blobs on height |
NamespaceAPI | GetNamespaceByVersionAndId | Get /namespace/{id}/{version} | Get namespace info by id and version |
NamespaceAPI | GetNamespaceCount | Get /namespace/count | Get count of namespaces in network |
NamespaceAPI | GetNamespaceMessages | Get /namespace/{id}/{version}/messages | Get namespace messages by id and version |
NamespaceAPI | GetNamespaceRollups | Get /namespace/{id}/{version}/rollups | List rollups using the namespace |
NamespaceAPI | ListNamespace | Get /namespace | List namespace info |
RollupAPI | GetRollup | Get /rollup/{id} | Get rollup info |
RollupAPI | GetRollupAllSeries | Get /rollup/stats/series | Get series for all rollups |
RollupAPI | GetRollupBlobs | Get /rollup/{id}/blobs | Get rollup blobs |
RollupAPI | GetRollupBySlug | Get /rollup/slug/{slug} | Get rollup by slug |
RollupAPI | GetRollupDistribution | Get /rollup/{id}/distribution/{name}/{timeframe} | Get rollup distribution |
RollupAPI | GetRollupNamespaces | Get /rollup/{id}/namespaces | Get rollup namespaces info |
RollupAPI | GetRollupStats | Get /rollup/{id}/stats/{name}/{timeframe} | Get rollup stats |
RollupAPI | GetRollupsCount | Get /rollup/count | Get count of rollups in network |
RollupAPI | ListRollup | Get /rollup | List rollups info |
RollupAPI | ListRollup24h | Get /rollup/day | List rollups info with stats by previous 24 hours |
RollupAPI | RollupExport | Get /rollup/{id}/export | Export rollup blobs |
RollupAPI | RollupGroupedStatistics | Get /rollup/group | Rollup Grouped Statistics |
SearchAPI | Search | Get /search | Search by hash |
StatsAPI | Stats24hChanges | Get /stats/changes_24h | Get changes for 24 hours |
StatsAPI | StatsMessagesCount24h | Get /stats/messages_count_24h | Get messages distribution for the last 24 hours |
StatsAPI | StatsNamespaceUsage | Get /stats/namespace/usage | Get namespaces with sorting by size. |
StatsAPI | StatsNsSeries | Get /stats/namespace/series/{id}/{name}/{timeframe} | Get histogram for namespace with precomputed stats |
StatsAPI | StatsPriceCurrent | Get /stats/price/current | Get current TIA price |
StatsAPI | StatsPriceSeries | Get /stats/price/series/{timeframe} | Get histogram with TIA price |
StatsAPI | StatsRollup24h | Get /stats/rollup_stats_24h | Get rollups stats for last 24 hours |
StatsAPI | StatsSeries | Get /stats/series/{name}/{timeframe} | Get histogram with precomputed stats |
StatsAPI | StatsSeriesCumulative | Get /stats/series/{name}/{timeframe}/cumulative | Get cumulative histogram with precomputed stats |
StatsAPI | StatsSquareSize | Get /stats/square_size | Get histogram for square size distribution |
StatsAPI | StatsStakingSeries | Get /stats/staking/series/{id}/{name}/{timeframe} | Get histogram for staking with precomputed stats |
StatsAPI | StatsSummary | Get /stats/summary/{table}/{function} | Get value by table and function |
TransactionsAPI | GetTransaction | Get /tx/{hash} | Get transaction by hash |
TransactionsAPI | GetTransactionEvents | Get /tx/{hash}/events | Get transaction events |
TransactionsAPI | GetTransactionMessages | Get /tx/{hash}/messages | Get transaction messages |
TransactionsAPI | GetTransactionsCount | Get /tx/count | Get count of transactions in network |
TransactionsAPI | ListGenesisTransactions | Get /tx/genesis | List genesis transactions info |
TransactionsAPI | ListTransactionBlobs | Get /tx/{hash}/blobs | List blobs which was pushed by transaction |
TransactionsAPI | ListTransactions | Get /tx | List transactions info |
TransactionsAPI | TransactionBlobsCount | Get /tx/{hash}/blobs/count | Count of blobs which was pushed by transaction |
ValidatorAPI | GetValidator | Get /validators/{id} | Get validator info |
ValidatorAPI | GetValidatorBlocks | Get /validators/{id}/blocks | Get blocks which was proposed by validator |
ValidatorAPI | GetValidatorUptime | Get /validators/{id}/uptime | Get validator's uptime and history of signed block |
ValidatorAPI | ListValidator | Get /validators | List validators |
ValidatorAPI | ValidatorCount | Get /validators/count | Get validator's count by status |
ValidatorAPI | ValidatorDelegators | Get /validators/{id}/delegators | Get validator's delegators |
ValidatorAPI | ValidatorJails | Get /validators/{id}/jails | Get validator's jails |
VestingAPI | GetVestingPeriods | Get /vesting/{id}/periods | Periods vesting periods by id |
- GithubComCeleniumIoCelestiaIndexerInternalStorageTypesStatus
- HandlerError
- HandlerPostBlobRequest
- ResponsesAddress
- ResponsesBalance
- ResponsesBlob
- ResponsesBlobLog
- ResponsesBlock
- ResponsesBlockStats
- ResponsesChange24hBlockStats
- ResponsesConstants
- ResponsesCountItem
- ResponsesDelegation
- ResponsesDenomMetadata
- ResponsesDistributionItem
- ResponsesEnums
- ResponsesEvent
- ResponsesGasPrice
- ResponsesGrant
- ResponsesHistogramItem
- ResponsesJail
- ResponsesLightBlobLog
- ResponsesMessage
- ResponsesMessageForAddress
- ResponsesNamespace
- ResponsesNamespaceKind
- ResponsesNamespaceMessage
- ResponsesNamespaceUsage
- ResponsesODS
- ResponsesODSItem
- ResponsesPrice
- ResponsesRedelegation
- ResponsesRollup
- ResponsesRollupAllSeriesItem
- ResponsesRollupGroupedStats
- ResponsesRollupStats24h
- ResponsesRollupWithDayStats
- ResponsesRollupWithStats
- ResponsesSearchItem
- ResponsesSeriesItem
- ResponsesShortRollup
- ResponsesShortValidator
- ResponsesSignedBlocks
- ResponsesState
- ResponsesTPS
- ResponsesTimeValueItem
- ResponsesTx
- ResponsesTxForAddress
- ResponsesUndelegation
- ResponsesValidator
- ResponsesValidatorCount
- ResponsesValidatorUptime
- ResponsesVesting
- ResponsesVestingPeriod
- TypesEventType
- TypesMsgAddressType
- TypesMsgType
Authentication schemes defined for the API:
- Type: API key
- API key parameter name: apikey
- Location: HTTP header
Note, each API key must be added to a map of map[string]APIKey
where the key is: ApiKeyAuth and passed in as the auth context for each request.
Example
auth := context.WithValue(
context.Background(),
celenium.ContextAPIKeys,
map[string]celenium.APIKey{
"ApiKeyAuth": {Key: "API_KEY_STRING"},
},
)
r, err := client.Service.Operation(auth, args)
Due to the fact that model structure members are all pointers, this package contains a number of utility functions to easily obtain pointers to values of basic types. Each of these functions takes a value of the given basic type and returns a pointer to it:
PtrBool
PtrInt
PtrInt32
PtrInt64
PtrFloat
PtrFloat32
PtrFloat64
PtrString
PtrTime