use crate::error_code::ErrorCode;
use anyhow::anyhow;
use eric_bindings::{
EricReturnBufferApi, EricRueckgabepufferErzeugen, EricRueckgabepufferFreigeben,
EricRueckgabepufferInhalt,
};
use std::ffi::CStr;
use tracing::debug;
#[derive(Debug, Clone)]
pub struct EricApiPayload {
pub validation_response: String,
pub server_response: String,
}
impl EricApiPayload {
pub fn new(validation_response: String, server_response: String) -> Self {
Self {
validation_response,
server_response,
}
}
}
#[derive(Debug)]
pub struct EricResponse {
pub payload: EricApiPayload,
}
impl EricResponse {
pub fn new(payload: EricApiPayload) -> Self {
Self { payload }
}
pub fn validation_response(&self) -> &str {
self.payload.validation_response.as_str()
}
pub fn server_response(&self) -> &str {
self.payload.server_response.as_str()
}
}
pub struct ResponseBuffer {
ctx: *mut EricReturnBufferApi,
}
impl ResponseBuffer {
pub fn new() -> Result<Self, anyhow::Error> {
let response_buffer = unsafe { EricRueckgabepufferErzeugen() };
if response_buffer.is_null() {
return Err(anyhow!("EricRueckgabepufferErzeugen returned null"));
}
Ok(ResponseBuffer {
ctx: response_buffer,
})
}
pub fn as_ptr(&self) -> *mut EricReturnBufferApi {
self.ctx
}
pub fn read(&self) -> Result<&str, anyhow::Error> {
let buffer = unsafe {
let ptr = EricRueckgabepufferInhalt(self.ctx);
if ptr.is_null() {
return Err(anyhow!("EricRueckgabepufferInhalt returned null"));
}
CStr::from_ptr(ptr)
};
Ok(buffer.to_str()?)
}
}
impl Drop for ResponseBuffer {
fn drop(&mut self) {
debug!("Cleaning up response buffer");
let error_code = unsafe { EricRueckgabepufferFreigeben(self.ctx) };
match error_code {
x if x == ErrorCode::ERIC_OK as i32 => (),
error_code => panic!("Can't drop reponse buffer: {}", error_code),
}
}
}