rs_transfer 8.0.0

A simple crate to handle downloads and uploads on multiple providers
Documentation
mod file_writer;
mod ftp_writer;
mod gcs_writer;
mod s3_writer;
mod sftp_writer;

use crate::{StreamData, error::Error};
use async_std::channel::Receiver;
use async_trait::async_trait;

#[async_trait]
pub trait StreamWriter {
  async fn write_stream(
    &self,
    path: &str,
    receiver: Receiver<StreamData>,
    job_and_notification: &dyn WriteJob,
  ) -> Result<(), Error>;
}

pub trait WriteJob: Send + Sync {
  fn get_str_job_id(&self) -> String {
    "".to_string()
  }
  fn progress(&self, progress: u8) -> Result<(), Error> {
    log::info!(target: &self.get_str_job_id(), "Received progress {progress}/100");
    Ok(())
  }

  fn is_stopped(&self) -> bool {
    false
  }
}

pub struct DummyWriteJob {}

impl WriteJob for DummyWriteJob {}