hyperion_framework/network/serialiser.rs
1// -------------------------------------------------------------------------------------------------
2// Hyperion Framework
3// https://github.com/Bazzz-1/hyperion-framework
4//
5// A lightweight component-based TCP framework for building service-oriented Rust applications with
6// CLI control, async messaging, and lifecycle management.
7//
8// Copyright 2025 Robert Hannah
9//
10// Licensed under the Apache License, Version 2.0 (the "License");
11// you may not use this file except in compliance with the License.
12// You may obtain a copy of the License at
13//
14// http://www.apache.org/licenses/LICENSE-2.0
15//
16// Unless required by applicable law or agreed to in writing, software
17// distributed under the License is distributed on an "AS IS" BASIS,
18// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
19// See the License for the specific language governing permissions and
20// limitations under the License.
21// -------------------------------------------------------------------------------------------------
22
23// Package
24use serde::{Serialize, de::DeserializeOwned};
25use serde_json;
26
27// Serialises any message into a byte vector (JSON format).
28pub fn serialise_message<T: Serialize>(msg: &T) -> Result<Vec<u8>, serde_json::Error> {
29 serde_json::to_vec(msg)
30}
31
32// Deserialises a byte slice into any message type.
33pub fn deserialise_message<T: DeserializeOwned>(data: &[u8]) -> Result<T, serde_json::Error> {
34 serde_json::from_slice(data)
35}
36
37// Example usage:
38// Serialise
39// let bytes = serialise_message(&msg).expect("Serialisation failed");
40// println!("Serialized: {:?}", bytes);
41
42// Deserialise
43// let message: T = serialiser::deserialise_message(&buf[..n]).expect("Message deserialisation failed");
44// println!("Deserialized: {:?}", message);