src/backup/data_blob.rs - DataBlobWriter: impl. compressed encrypted blobs

This commit is contained in:
Dietmar Maurer 2019-08-12 10:16:42 +02:00
parent f4942e9ffd
commit 5622a3fcdb

View File

@ -399,6 +399,7 @@ enum BlobWriterState<'a, W: Write> {
Signed { csum_writer: ChecksumWriter<'a, W> }, Signed { csum_writer: ChecksumWriter<'a, W> },
SignedCompressed { compr: zstd::stream::write::Encoder<ChecksumWriter<'a, W>> }, SignedCompressed { compr: zstd::stream::write::Encoder<ChecksumWriter<'a, W>> },
Encrypted { crypt_writer: CryptWriter<ChecksumWriter<'a, W>> }, Encrypted { crypt_writer: CryptWriter<ChecksumWriter<'a, W>> },
EncryptedCompressed { compr: zstd::stream::write::Encoder<CryptWriter<ChecksumWriter<'a, W>>> },
} }
/// Write compressed data blobs /// Write compressed data blobs
@ -474,6 +475,23 @@ impl <'a, W: Write + Seek> DataBlobWriter<'a, W> {
Ok(Self { state: BlobWriterState::Encrypted { crypt_writer }}) Ok(Self { state: BlobWriterState::Encrypted { crypt_writer }})
} }
pub fn new_encrypted_compressed(mut writer: W, config: &'a CryptConfig) -> Result<Self, Error> {
writer.seek(SeekFrom::Start(0))?;
let head = EncryptedDataBlobHeader {
head: DataBlobHeader { magic: ENCR_COMPR_BLOB_MAGIC_1_0, crc: [0; 4] },
iv: [0u8; 16],
tag: [0u8; 16],
};
unsafe {
writer.write_le_value(head)?;
}
let csum_writer = ChecksumWriter::new(writer, None);
let crypt_writer = CryptWriter::new(csum_writer, config)?;
let compr = zstd::stream::write::Encoder::new(crypt_writer, 1)?;
Ok(Self { state: BlobWriterState::EncryptedCompressed { compr }})
}
pub fn finish(self) -> Result<W, Error> { pub fn finish(self) -> Result<W, Error> {
match self.state { match self.state {
BlobWriterState::Uncompressed { csum_writer } => { BlobWriterState::Uncompressed { csum_writer } => {
@ -545,6 +563,20 @@ impl <'a, W: Write + Seek> DataBlobWriter<'a, W> {
} }
return Ok(writer) return Ok(writer)
} }
BlobWriterState::EncryptedCompressed { compr } => {
let crypt_writer = compr.finish()?;
let (csum_writer, iv, tag) = crypt_writer.finish()?;
let (mut writer, crc, _) = csum_writer.finish()?;
let head = EncryptedDataBlobHeader {
head: DataBlobHeader { magic: ENCR_COMPR_BLOB_MAGIC_1_0, crc: crc.to_le_bytes() },
iv, tag,
};
unsafe {
writer.write_le_value(head)?;
}
return Ok(writer)
}
} }
} }
} }
@ -568,6 +600,9 @@ impl <'a, W: Write + Seek> Write for DataBlobWriter<'a, W> {
BlobWriterState::Encrypted { ref mut crypt_writer } => { BlobWriterState::Encrypted { ref mut crypt_writer } => {
crypt_writer.write(buf) crypt_writer.write(buf)
} }
BlobWriterState::EncryptedCompressed { ref mut compr } => {
compr.write(buf)
}
} }
} }
@ -588,6 +623,9 @@ impl <'a, W: Write + Seek> Write for DataBlobWriter<'a, W> {
BlobWriterState::Encrypted { ref mut crypt_writer } => { BlobWriterState::Encrypted { ref mut crypt_writer } => {
crypt_writer.flush() crypt_writer.flush()
} }
BlobWriterState::EncryptedCompressed { ref mut compr } => {
compr.flush()
}
} }
} }
} }