Skip to content

Commit

Permalink
✨ Build WorldServiceServer
Browse files Browse the repository at this point in the history
  • Loading branch information
H1rono committed Jan 22, 2025
1 parent 450759f commit 20256f5
Show file tree
Hide file tree
Showing 2 changed files with 100 additions and 1 deletion.
17 changes: 16 additions & 1 deletion server/src/world.rs
Original file line number Diff line number Diff line change
@@ -1,8 +1,11 @@
//! `world.proto`
pub mod error;
pub mod grpc;
mod r#impl;

use std::sync::Arc;

use futures::future::BoxFuture;
use serde::{Deserialize, Serialize};

Expand Down Expand Up @@ -83,5 +86,17 @@ pub trait ProvideWorldService: Send + Sync + 'static {
self.world_service().check_coordinate(ctx, req)
}

// TODO: build_server(this: Arc<Self>) -> WorldServiceServer<...>
fn build_server(this: Arc<Self>) -> WorldServiceServer<Self>
where
Self: Sized,
{
let service = grpc::ServiceImpl::new(this);
WorldServiceServer::new(service)
}
}

#[derive(Debug, Clone, Copy)]
pub struct WorldServiceImpl;

pub type WorldServiceServer<State> =
schema::world::world_service_server::WorldServiceServer<grpc::ServiceImpl<State>>;
84 changes: 84 additions & 0 deletions server/src/world/grpc.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,84 @@
use std::sync::Arc;

use schema::world as schema;

use crate::prelude::IntoStatus;

// MARK: type conversions

impl From<super::Coordinate> for schema::Coordinate {
fn from(value: super::Coordinate) -> Self {
let super::Coordinate { x, y } = value;
Self { x, y }
}
}

impl From<schema::Coordinate> for super::Coordinate {
fn from(value: schema::Coordinate) -> Self {
let schema::Coordinate { x, y } = value;
Self { x, y }
}
}

impl From<super::Size> for schema::Size {
fn from(value: super::Size) -> Self {
let super::Size { width, height } = value;
Self { width, height }
}
}

impl From<schema::Size> for super::Size {
fn from(value: schema::Size) -> Self {
let schema::Size { width, height } = value;
Self { width, height }
}
}

// MARK: ServiceImpl

pub struct ServiceImpl<State> {
state: Arc<State>,
}

impl<State> Clone for ServiceImpl<State>
where
State: super::ProvideWorldService,
{
fn clone(&self) -> Self {
Self {
state: Arc::clone(&self.state),
}
}
}

impl<State> ServiceImpl<State>
where
State: super::ProvideWorldService,
{
pub(super) fn new(state: Arc<State>) -> Self {
Self { state }
}
}

#[async_trait::async_trait]
impl<State> schema::world_service_server::WorldService for ServiceImpl<State>
where
State: super::ProvideWorldService,
{
async fn get_world(
&self,
request: tonic::Request<schema::GetWorldRequest>,
) -> tonic::Result<tonic::Response<schema::GetWorldResponse>> {
let (_, _, schema::GetWorldRequest {}) = request.into_parts();
let req = super::GetWorldSize {};
let size = self
.state
.get_world_size(req)
.await
.map_err(IntoStatus::into_status)?
.into();
let world = schema::World { size: Some(size) };
let res = schema::GetWorldResponse { world: Some(world) };
Ok(tonic::Response::new(res))
}
}

0 comments on commit 20256f5

Please sign in to comment.