c4ced3e0d2
* Renamed fork_choice::process_attestation_from_block * Processing attestation in fork choice * Retrieving state from store and checking signature * Looser check on beacon state validity. * Cleaned up get_attestation_state * Expanded fork choice api to provide latest validator message. * Checking if the an attestation contains a latest message * Correct process_attestation error handling. * Copy paste error in comment fixed. * Tidy ancestor iterators * Getting attestation slot via helper method * Refactored attestation creation in test utils * Revert "Refactored attestation creation in test utils" This reverts commit 4d277fe4239a7194758b18fb5c00dfe0b8231306. * Integration tests for free attestation processing * Implicit conflicts resolved. * formatting * Do first pass on Grants code * Add another attestation processing test * Tidy attestation processing * Remove old code fragment * Add non-compiling half finished changes * Simplify, fix bugs, add tests for chain iters * Remove attestation processing from op pool * Fix bug with fork choice, tidy * Fix overly restrictive check in fork choice. * Ensure committee cache is build during attn proc * Ignore unknown blocks at fork choice * Various minor fixes * Make fork choice write lock in to read lock * Remove unused method * Tidy comments * Fix attestation prod. target roots change * Fix compile error in store iters * Reject any attestation prior to finalization * Begin metrics refactor * Move beacon_chain to new metrics structure. * Make metrics not panic if already defined * Use global prometheus gather at rest api * Unify common metric fns into a crate * Add heavy metering to block processing * Remove hypen from prometheus metric name * Add more beacon chain metrics * Add beacon chain persistence metric * Prune op pool on finalization * Add extra prom beacon chain metrics * Prefix BeaconChain metrics with "beacon_" * Add more store metrics * Add basic metrics to libp2p * Add metrics to HTTP server * Remove old `http_server` crate * Update metrics names to be more like standard * Fix broken beacon chain metrics, add slot clock metrics * Add lighthouse_metrics gather fn * Remove http args * Fix wrong state given to op pool prune * Make prom metric names more consistent * Add more metrics, tidy existing metrics * Fix store block read metrics * Tidy attestation metrics * Fix minor PR comments * Allow travis failures on beta (see desc) There's a non-backward compatible change in `cargo fmt`. Stable and beta do not agree. * Tidy `lighthouse_metrics` docs * Fix typo
47 lines
1.3 KiB
Rust
47 lines
1.3 KiB
Rust
use clap::ArgMatches;
|
|
use serde::{Deserialize, Serialize};
|
|
use std::net::Ipv4Addr;
|
|
|
|
/// HTTP REST API Configuration
|
|
#[derive(Debug, Clone, Serialize, Deserialize)]
|
|
pub struct Config {
|
|
/// Enable the REST API server.
|
|
pub enabled: bool,
|
|
/// The IPv4 address the REST API HTTP server will listen on.
|
|
pub listen_address: Ipv4Addr,
|
|
/// The port the REST API HTTP server will listen on.
|
|
pub port: u16,
|
|
}
|
|
|
|
impl Default for Config {
|
|
fn default() -> Self {
|
|
Config {
|
|
enabled: true, // rest_api enabled by default
|
|
listen_address: Ipv4Addr::new(127, 0, 0, 1),
|
|
port: 5052,
|
|
}
|
|
}
|
|
}
|
|
|
|
impl Config {
|
|
pub fn apply_cli_args(&mut self, args: &ArgMatches) -> Result<(), &'static str> {
|
|
if args.is_present("api") {
|
|
self.enabled = true;
|
|
}
|
|
|
|
if let Some(rpc_address) = args.value_of("api-address") {
|
|
self.listen_address = rpc_address
|
|
.parse::<Ipv4Addr>()
|
|
.map_err(|_| "api-address is not a valid IPv4 address.")?;
|
|
}
|
|
|
|
if let Some(rpc_port) = args.value_of("api-port") {
|
|
self.port = rpc_port
|
|
.parse::<u16>()
|
|
.map_err(|_| "api-port is not a valid u16.")?;
|
|
}
|
|
|
|
Ok(())
|
|
}
|
|
}
|