feat(grpc): call walk_dir from grpc service
This commit is contained in:
parent
f803aa92f7
commit
8cd4b4b10f
4 changed files with 41 additions and 9 deletions
|
|
@ -4,6 +4,7 @@ package juno;
|
|||
|
||||
service JunoRequest {
|
||||
rpc Ping (PingRequestMessage) returns (PingResponseMessage);
|
||||
rpc GetFiles (GetFilesRequest) returns (GetFilesResponse);
|
||||
}
|
||||
|
||||
message PingRequestMessage {
|
||||
|
|
@ -12,3 +13,11 @@ message PingRequestMessage {
|
|||
message PingResponseMessage {
|
||||
string message = 1;
|
||||
}
|
||||
|
||||
message GetFilesRequest {
|
||||
string path = 1;
|
||||
}
|
||||
|
||||
message GetFilesResponse {
|
||||
repeated string files = 1;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1,7 +1,7 @@
|
|||
use super::grpc_juno;
|
||||
|
||||
use grpc_juno::juno_request_client::JunoRequestClient;
|
||||
use grpc_juno::PingRequestMessage;
|
||||
use grpc_juno::GetFilesRequest;
|
||||
use tonic::async_trait;
|
||||
use tonic::Request;
|
||||
|
||||
|
|
@ -21,11 +21,13 @@ impl super::Connection for GRPCClient {
|
|||
async fn connect(&self) -> Result<(), Box<dyn std::error::Error>> {
|
||||
let mut client = JunoRequestClient::connect(format!("http://{}", self.address)).await?;
|
||||
|
||||
let request = Request::new(PingRequestMessage {});
|
||||
let request = Request::new(GetFilesRequest {
|
||||
path: "/home/aleidk/Music/".to_string(),
|
||||
});
|
||||
|
||||
let response = client.ping(request).await?;
|
||||
let response = client.get_files(request).await?.into_inner();
|
||||
|
||||
println!("RESPONSE={:?}", response);
|
||||
println!("RESPONSE={:?}", response.files);
|
||||
|
||||
Ok(())
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1,8 +1,12 @@
|
|||
use crate::file_explorer;
|
||||
|
||||
use super::grpc_juno;
|
||||
use grpc_juno::juno_request_server::{JunoRequest, JunoRequestServer};
|
||||
use grpc_juno::{PingRequestMessage, PingResponseMessage};
|
||||
use grpc_juno::{GetFilesRequest, GetFilesResponse, PingRequestMessage, PingResponseMessage};
|
||||
use std::error::Error;
|
||||
use std::net::SocketAddr;
|
||||
use std::path::PathBuf;
|
||||
use std::str::FromStr;
|
||||
use tonic::transport::Server;
|
||||
use tonic::{async_trait, Request, Response, Result, Status};
|
||||
|
||||
|
|
@ -29,6 +33,26 @@ impl JunoRequest for GRPCServer {
|
|||
|
||||
Ok(Response::new(reply))
|
||||
}
|
||||
|
||||
async fn get_files(
|
||||
&self,
|
||||
request: Request<GetFilesRequest>,
|
||||
) -> Result<Response<GetFilesResponse>, Status> {
|
||||
let path = PathBuf::from_str(request.into_inner().path.as_str())
|
||||
.expect("Failed to create pathbuf");
|
||||
|
||||
let files = match file_explorer::walk_dir(&path) {
|
||||
Ok(files) => files,
|
||||
Err(_err) => panic!("Error reading path: {:?}", path),
|
||||
};
|
||||
eprintln!("DEBUGPRINT[2]: server.rs:44: files={:#?}", files);
|
||||
|
||||
let reply = GetFilesResponse {
|
||||
files: files.iter().map(|x| x.display().to_string()).collect(),
|
||||
};
|
||||
|
||||
Ok(Response::new(reply))
|
||||
}
|
||||
}
|
||||
|
||||
#[async_trait]
|
||||
|
|
|
|||
|
|
@ -1,3 +1,4 @@
|
|||
use core::panic;
|
||||
use std::{env, path::PathBuf};
|
||||
|
||||
use clap::Parser;
|
||||
|
|
@ -20,10 +21,6 @@ async fn main() -> Result<(), Box<dyn Error>> {
|
|||
.path
|
||||
.unwrap_or(env::current_dir().expect("Current directory is not available."));
|
||||
|
||||
let files = file_explorer::walk_dir(&path).expect("error");
|
||||
|
||||
eprintln!("DEBUGPRINT[4]: main.rs:20: files={:#?}", files.len());
|
||||
|
||||
let server = grpc::run()?;
|
||||
|
||||
server.connect().await?;
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue