nimbus-eth2/beacon_chain/spec/eth2_apis/rest_validator_calls.nim
Jacek Sieka 3d7bee8502
REST API client, JSON-RPC cleanups (#2756)
This refactoring puts the JSON-RPC and REST APIs on more equal footing
by renaming and moving things around, creating a separation between
client and server, and documenting what they are - the aim is to have a
simple-to-use base to start from when developing API clients, as well as
make it easier to navigate the code when looking for the legacy JSON-RPC
interface vs the new REST API.

* move REST client, serialization and supporting types to spec/eth2_apis
* REST stuff now starts with `rest_`, JSON-RPC stuff starts with `rpc_`,
more or less
* simplify imports such that there's a simple module to import for both
server and client
* map REST type and proc names to yaml spec more closely - in
particular, reuse operation and type names in `rest_types` to make
comparisons against spec more easy
* cleaner separation between client and server modules - modules common
between server and client such as `rest_types` and serialization move to
the spec folder - this allows the client to be built with less knowledge
about server internals
2021-08-03 17:17:11 +02:00

90 lines
4.1 KiB
Nim

# Copyright (c) 2018-2021 Status Research & Development GmbH
# Licensed and distributed under either of
# * MIT license (license terms in the root directory or at https://opensource.org/licenses/MIT).
# * Apache v2 license (license terms in the root directory or at https://www.apache.org/licenses/LICENSE-2.0).
# at your option. This file may not be copied, modified, or distributed except according to those terms.
{.push raises: [Defect].}
import
presto/client,
"."/[rest_types, eth2_rest_serialization]
export client, rest_types, eth2_rest_serialization
proc getAttesterDuties*(epoch: Epoch,
body: seq[ValidatorIndex]
): RestResponse[GetAttesterDutiesResponse] {.
rest, endpoint: "/eth/v1/validator/duties/attester/{epoch}",
meth: MethodPost.}
## https://ethereum.github.io/eth2.0-APIs/#/Validator/getAttesterDuties
proc getProposerDuties*(epoch: Epoch): RestResponse[GetProposerDutiesResponse] {.
rest, endpoint: "/eth/v1/validator/duties/proposer/{epoch}",
meth: MethodGet.}
## https://ethereum.github.io/eth2.0-APIs/#/Validator/getProposerDuties
# TODO altair
# proc getSyncCommitteeDuties*(epoch: Epoch): RestResponse[DataRestSyncCommitteeDuties] {.
# rest, endpoint: "/eth/v1/validator/duties/sync/{epoch}",
# meth: MethodPost.}
# ## https://ethereum.github.io/eth2.0-APIs/#/Validator/getSyncCommitteeDuties
proc produceBlock*(slot: Slot, randao_reveal: ValidatorSig,
graffiti: GraffitiBytes
): RestResponse[ProduceBlockResponse] {.
rest, endpoint: "/eth/v1/validator/blocks/{slot}",
meth: MethodGet.}
## https://ethereum.github.io/eth2.0-APIs/#/Validator/produceBlock
# TODO altair
# proc produceBlockV2*(slot: Slot, randao_reveal: ValidatorSig,
# graffiti: GraffitiBytes
# ): RestResponse[DataRestBlockV2] {.
# rest, endpoint: "/eth/v2/validator/blocks/{slot}",
# meth: MethodGet.}
# ## https://ethereum.github.io/eth2.0-APIs/#/Validator/produceBlockV2
proc produceAttestationData*(slot: Slot,
committee_index: CommitteeIndex
): RestResponse[ProduceAttestationDataResponse] {.
rest, endpoint: "/eth/v1/validator/attestation_data",
meth: MethodGet.}
## https://ethereum.github.io/eth2.0-APIs/#/Validator/produceAttestationData
proc getAggregatedAttestation*(attestation_data_root: Eth2Digest,
slot: Slot): RestResponse[GetAggregatedAttestationResponse] {.
rest, endpoint: "/eth/v1/validator/aggregate_attestation"
meth: MethodGet.}
## https://ethereum.github.io/eth2.0-APIs/#/Validator/getAggregatedAttestation
proc publishAggregateAndProofs*(body: seq[SignedAggregateAndProof]
): RestPlainResponse {.
rest, endpoint: "/eth/v1/validator/aggregate_and_proofs",
meth: MethodPost.}
## https://ethereum.github.io/eth2.0-APIs/#/Validator/publishAggregateAndProofs
proc prepareBeaconCommitteeSubnet*(body: seq[RestCommitteeSubscription]): RestPlainResponse {.
rest, endpoint: "/eth/v1/validator/beacon_committee_subscriptions",
meth: MethodPost.}
## https://ethereum.github.io/eth2.0-APIs/#/Validator/prepareBeaconCommitteeSubnet
# TODO altair
# proc prepareSyncCommitteeSubnets*(body: seq[int]
# ): RestPlainResponse {.
# rest, endpoint: "/eth/v1/validator/sync_committee_subscriptions",
# meth: MethodPost.}
# ## https://ethereum.github.io/eth2.0-APIs/#/Validator/prepareSyncCommitteeSubnets
# proc produceSyncCommitteeContribution*(body: seq[int]
# ): RestPlainResponse {.
# rest, endpoint: "/eth/v1/validator/sync_committee_contribution",
# meth: MethodPost.}
# ## https://ethereum.github.io/eth2.0-APIs/#/Validator/produceSyncCommitteeContribution
# proc publishContributionAndProofs*(body: seq[RestCommitteeSubscription]
# ): RestPlainResponse {.
# rest, endpoint: "/eth/v1/validator/contribution_and_proofs",
# meth: MethodPost.}
# ## https://ethereum.github.io/eth2.0-APIs/#/Validator/publishContributionAndProofs