mirror of
https://github.com/mimblewimble/grin.git
synced 2025-01-21 03:21:08 +03:00
Add version endpoint to node API, rename pool/push (#2897)
* add node version API, tweak pool/push parameter * rustfmt
This commit is contained in:
parent
e15cffbbd0
commit
c2153fada2
4 changed files with 59 additions and 3 deletions
|
@ -18,6 +18,7 @@ mod peers_api;
|
|||
mod pool_api;
|
||||
mod server_api;
|
||||
mod transactions_api;
|
||||
mod version_api;
|
||||
mod utils;
|
||||
|
||||
use self::blocks_api::BlockHandler;
|
||||
|
@ -34,6 +35,7 @@ use self::pool_api::PoolPushHandler;
|
|||
use self::server_api::IndexHandler;
|
||||
use self::server_api::StatusHandler;
|
||||
use self::server_api::KernelDownloadHandler;
|
||||
use self::version_api::VersionHandler;
|
||||
use self::transactions_api::TxHashSetHandler;
|
||||
use crate::auth::{BasicAuthMiddleware, GRIN_BASIC_REALM};
|
||||
use crate::chain;
|
||||
|
@ -104,12 +106,13 @@ pub fn build_router(
|
|||
"get txhashset/outputs?start_index=1&max=100".to_string(),
|
||||
"get txhashset/merkleproof?n=1".to_string(),
|
||||
"get pool".to_string(),
|
||||
"post pool/push".to_string(),
|
||||
"post pool/push_tx".to_string(),
|
||||
"post peers/a.b.c.d:p/ban".to_string(),
|
||||
"post peers/a.b.c.d:p/unban".to_string(),
|
||||
"get peers/all".to_string(),
|
||||
"get peers/connected".to_string(),
|
||||
"get peers/a.b.c.d".to_string(),
|
||||
"get version".to_string(),
|
||||
];
|
||||
let index_handler = IndexHandler { list: route_list };
|
||||
|
||||
|
@ -157,6 +160,7 @@ pub fn build_router(
|
|||
let peer_handler = PeerHandler {
|
||||
peers: Arc::downgrade(&peers),
|
||||
};
|
||||
let version_handler = VersionHandler;
|
||||
|
||||
let mut router = Router::new();
|
||||
|
||||
|
@ -171,9 +175,10 @@ pub fn build_router(
|
|||
router.add_route("/v1/status", Arc::new(status_handler))?;
|
||||
router.add_route("/v1/kerneldownload", Arc::new(kernel_download_handler))?;
|
||||
router.add_route("/v1/pool", Arc::new(pool_info_handler))?;
|
||||
router.add_route("/v1/pool/push", Arc::new(pool_push_handler))?;
|
||||
router.add_route("/v1/pool/push_tx", Arc::new(pool_push_handler))?;
|
||||
router.add_route("/v1/peers/all", Arc::new(peers_all_handler))?;
|
||||
router.add_route("/v1/peers/connected", Arc::new(peers_connected_handler))?;
|
||||
router.add_route("/v1/peers/**", Arc::new(peer_handler))?;
|
||||
router.add_route("/v1/version", Arc::new(version_handler))?;
|
||||
Ok(router)
|
||||
}
|
||||
|
|
|
@ -53,7 +53,7 @@ struct TxWrapper {
|
|||
}
|
||||
|
||||
/// Push new transaction to our local transaction pool.
|
||||
/// POST /v1/pool/push
|
||||
/// POST /v1/pool/push_tx
|
||||
pub struct PoolPushHandler {
|
||||
pub tx_pool: Weak<RwLock<pool::TransactionPool>>,
|
||||
}
|
||||
|
|
42
api/src/handlers/version_api.rs
Normal file
42
api/src/handlers/version_api.rs
Normal file
|
@ -0,0 +1,42 @@
|
|||
// Copyright 2018 The Grin Developers
|
||||
//
|
||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||
// you may not use this file except in compliance with the License.
|
||||
// You may obtain a copy of the License at
|
||||
//
|
||||
// http://www.apache.org/licenses/LICENSE-2.0
|
||||
//
|
||||
// Unless required by applicable law or agreed to in writing, software
|
||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
// See the License for the specific language governing permissions and
|
||||
// limitations under the License.
|
||||
|
||||
use crate::core::core::block::HeaderVersion;
|
||||
|
||||
use crate::rest::*;
|
||||
use crate::router::{Handler, ResponseFuture};
|
||||
use crate::types::Version;
|
||||
use crate::web::*;
|
||||
use hyper::{Body, Request};
|
||||
|
||||
const CRATE_VERSION: &'static str = env!("CARGO_PKG_VERSION");
|
||||
|
||||
/// Version handler. Get running node API version
|
||||
/// GET /v1/version
|
||||
pub struct VersionHandler;
|
||||
|
||||
impl VersionHandler {
|
||||
fn get_version(&self) -> Result<Version, Error> {
|
||||
Ok(Version {
|
||||
node_version: CRATE_VERSION.to_owned(),
|
||||
block_header_version: HeaderVersion::default().into(),
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
impl Handler for VersionHandler {
|
||||
fn get(&self, _req: Request<Body>) -> ResponseFuture {
|
||||
result_to_response(self.get_version())
|
||||
}
|
||||
}
|
|
@ -34,6 +34,15 @@ macro_rules! no_dup {
|
|||
};
|
||||
}
|
||||
|
||||
/// API Version Information
|
||||
#[derive(Serialize, Deserialize, Debug, Clone)]
|
||||
pub struct Version {
|
||||
/// Current node API Version (api crate version)
|
||||
pub node_version: String,
|
||||
/// Block header version
|
||||
pub block_header_version: u16,
|
||||
}
|
||||
|
||||
/// The state of the current fork tip
|
||||
#[derive(Serialize, Deserialize, Debug, Clone)]
|
||||
pub struct Tip {
|
||||
|
|
Loading…
Reference in a new issue