use crate::errors::Result;
use crate::types::*;
use uuid::Uuid;
use std::fmt::Debug;
pub trait TDLogStream: Debug + RObject {}
#[derive(Debug, Clone, Deserialize, Serialize, Default)]
#[serde(tag = "@type")]
pub enum LogStream {
#[doc(hidden)]
#[default]
_Default,
#[serde(rename = "getLogStream")]
GetLogStream(GetLogStream),
#[serde(rename = "logStreamDefault")]
Default(LogStreamDefault),
#[serde(rename = "logStreamEmpty")]
Empty(LogStreamEmpty),
#[serde(rename = "logStreamFile")]
File(LogStreamFile),
}
impl RObject for LogStream {
#[doc(hidden)]
fn extra(&self) -> Option<&str> {
match self {
LogStream::GetLogStream(t) => t.extra(),
LogStream::Default(t) => t.extra(),
LogStream::Empty(t) => t.extra(),
LogStream::File(t) => t.extra(),
_ => None,
}
}
#[doc(hidden)]
fn client_id(&self) -> Option<i32> {
match self {
LogStream::GetLogStream(t) => t.client_id(),
LogStream::Default(t) => t.client_id(),
LogStream::Empty(t) => t.client_id(),
LogStream::File(t) => t.client_id(),
_ => None,
}
}
}
impl LogStream {
pub fn from_json<S: AsRef<str>>(json: S) -> Result<Self> {
Ok(serde_json::from_str(json.as_ref())?)
}
#[doc(hidden)]
pub fn _is_default(&self) -> bool {
matches!(self, LogStream::_Default)
}
}
impl AsRef<LogStream> for LogStream {
fn as_ref(&self) -> &LogStream {
self
}
}
#[derive(Debug, Clone, Default, Serialize, Deserialize)]
pub struct LogStreamDefault {
#[doc(hidden)]
#[serde(rename(serialize = "@extra", deserialize = "@extra"))]
extra: Option<String>,
#[serde(rename(serialize = "@client_id", deserialize = "@client_id"))]
client_id: Option<i32>,
}
impl RObject for LogStreamDefault {
#[doc(hidden)]
fn extra(&self) -> Option<&str> {
self.extra.as_deref()
}
#[doc(hidden)]
fn client_id(&self) -> Option<i32> {
self.client_id
}
}
impl TDLogStream for LogStreamDefault {}
impl LogStreamDefault {
pub fn from_json<S: AsRef<str>>(json: S) -> Result<Self> {
Ok(serde_json::from_str(json.as_ref())?)
}
pub fn builder() -> LogStreamDefaultBuilder {
let mut inner = LogStreamDefault::default();
inner.extra = Some(Uuid::new_v4().to_string());
LogStreamDefaultBuilder { inner }
}
}
#[doc(hidden)]
pub struct LogStreamDefaultBuilder {
inner: LogStreamDefault,
}
#[deprecated]
pub type RTDLogStreamDefaultBuilder = LogStreamDefaultBuilder;
impl LogStreamDefaultBuilder {
pub fn build(&self) -> LogStreamDefault {
self.inner.clone()
}
}
impl AsRef<LogStreamDefault> for LogStreamDefault {
fn as_ref(&self) -> &LogStreamDefault {
self
}
}
impl AsRef<LogStreamDefault> for LogStreamDefaultBuilder {
fn as_ref(&self) -> &LogStreamDefault {
&self.inner
}
}
#[derive(Debug, Clone, Default, Serialize, Deserialize)]
pub struct LogStreamEmpty {
#[doc(hidden)]
#[serde(rename(serialize = "@extra", deserialize = "@extra"))]
extra: Option<String>,
#[serde(rename(serialize = "@client_id", deserialize = "@client_id"))]
client_id: Option<i32>,
}
impl RObject for LogStreamEmpty {
#[doc(hidden)]
fn extra(&self) -> Option<&str> {
self.extra.as_deref()
}
#[doc(hidden)]
fn client_id(&self) -> Option<i32> {
self.client_id
}
}
impl TDLogStream for LogStreamEmpty {}
impl LogStreamEmpty {
pub fn from_json<S: AsRef<str>>(json: S) -> Result<Self> {
Ok(serde_json::from_str(json.as_ref())?)
}
pub fn builder() -> LogStreamEmptyBuilder {
let mut inner = LogStreamEmpty::default();
inner.extra = Some(Uuid::new_v4().to_string());
LogStreamEmptyBuilder { inner }
}
}
#[doc(hidden)]
pub struct LogStreamEmptyBuilder {
inner: LogStreamEmpty,
}
#[deprecated]
pub type RTDLogStreamEmptyBuilder = LogStreamEmptyBuilder;
impl LogStreamEmptyBuilder {
pub fn build(&self) -> LogStreamEmpty {
self.inner.clone()
}
}
impl AsRef<LogStreamEmpty> for LogStreamEmpty {
fn as_ref(&self) -> &LogStreamEmpty {
self
}
}
impl AsRef<LogStreamEmpty> for LogStreamEmptyBuilder {
fn as_ref(&self) -> &LogStreamEmpty {
&self.inner
}
}
#[derive(Debug, Clone, Default, Serialize, Deserialize)]
pub struct LogStreamFile {
#[doc(hidden)]
#[serde(rename(serialize = "@extra", deserialize = "@extra"))]
extra: Option<String>,
#[serde(rename(serialize = "@client_id", deserialize = "@client_id"))]
client_id: Option<i32>,
#[serde(default)]
path: String,
#[serde(default)]
max_file_size: i64,
#[serde(default)]
redirect_stderr: bool,
}
impl RObject for LogStreamFile {
#[doc(hidden)]
fn extra(&self) -> Option<&str> {
self.extra.as_deref()
}
#[doc(hidden)]
fn client_id(&self) -> Option<i32> {
self.client_id
}
}
impl TDLogStream for LogStreamFile {}
impl LogStreamFile {
pub fn from_json<S: AsRef<str>>(json: S) -> Result<Self> {
Ok(serde_json::from_str(json.as_ref())?)
}
pub fn builder() -> LogStreamFileBuilder {
let mut inner = LogStreamFile::default();
inner.extra = Some(Uuid::new_v4().to_string());
LogStreamFileBuilder { inner }
}
pub fn path(&self) -> &String {
&self.path
}
pub fn max_file_size(&self) -> i64 {
self.max_file_size
}
pub fn redirect_stderr(&self) -> bool {
self.redirect_stderr
}
}
#[doc(hidden)]
pub struct LogStreamFileBuilder {
inner: LogStreamFile,
}
#[deprecated]
pub type RTDLogStreamFileBuilder = LogStreamFileBuilder;
impl LogStreamFileBuilder {
pub fn build(&self) -> LogStreamFile {
self.inner.clone()
}
pub fn path<T: AsRef<str>>(&mut self, path: T) -> &mut Self {
self.inner.path = path.as_ref().to_string();
self
}
pub fn max_file_size(&mut self, max_file_size: i64) -> &mut Self {
self.inner.max_file_size = max_file_size;
self
}
pub fn redirect_stderr(&mut self, redirect_stderr: bool) -> &mut Self {
self.inner.redirect_stderr = redirect_stderr;
self
}
}
impl AsRef<LogStreamFile> for LogStreamFile {
fn as_ref(&self) -> &LogStreamFile {
self
}
}
impl AsRef<LogStreamFile> for LogStreamFileBuilder {
fn as_ref(&self) -> &LogStreamFile {
&self.inner
}
}