Struct deltachat::blob::BlobObject
source · pub struct BlobObject<'a> {
blobdir: &'a Path,
name: String,
}
Expand description
Represents a file in the blob directory.
The object has a name, which will always be valid UTF-8. Having a
blob object does not imply the respective file exists, however
when using one of the create*()
methods a unique file is
created.
Fields§
§blobdir: &'a Path
§name: String
Implementations§
source§impl<'a> BlobObject<'a>
impl<'a> BlobObject<'a>
sourcepub async fn create(
context: &'a Context,
suggested_name: &str,
data: &[u8],
) -> Result<BlobObject<'a>>
pub async fn create( context: &'a Context, suggested_name: &str, data: &[u8], ) -> Result<BlobObject<'a>>
Creates a new blob object with a unique name.
Creates a new file in the blob directory. The name will be
derived from the platform-agnostic basename of the suggested
name, followed by a random number and followed by a possible
extension. The data
will be written into the file without
race-conditions.
async fn create_new_file( context: &Context, dir: &Path, stem: &str, ext: &str, ) -> Result<(String, File)>
sourcepub async fn create_and_copy(
context: &'a Context,
src: &Path,
) -> Result<BlobObject<'a>>
pub async fn create_and_copy( context: &'a Context, src: &Path, ) -> Result<BlobObject<'a>>
Creates a new blob object with unique name by copying an existing file.
This creates a new blob as described in BlobObject::create but also copies an existing file into it. This is done in a in way which avoids race-conditions when multiple files are concurrently created.
sourcepub async fn new_from_path(
context: &'a Context,
src: &Path,
) -> Result<BlobObject<'a>>
pub async fn new_from_path( context: &'a Context, src: &Path, ) -> Result<BlobObject<'a>>
Creates a blob from a file, possibly copying it to the blobdir.
If the source file is not a path to into the blob directory the file will be copied into the blob directory first. If the source file is already in the blobdir it will not be copied and only be created if it is a valid blobname, that is no subdirectory is used and BlobObject::sanitise_name does not modify the filename.
Paths into the blob directory may be either defined by an absolute path
or by the relative prefix $BLOBDIR
.
sourcepub fn from_path(context: &'a Context, path: &Path) -> Result<BlobObject<'a>>
pub fn from_path(context: &'a Context, path: &Path) -> Result<BlobObject<'a>>
Returns a BlobObject for an existing blob from a path.
The path must designate a file directly in the blobdir and must use a valid blob name. That is after sanitisation the name must still be the same, that means it must be valid UTF-8 and not have any special characters in it.
sourcepub fn from_name(context: &'a Context, name: String) -> Result<BlobObject<'a>>
pub fn from_name(context: &'a Context, name: String) -> Result<BlobObject<'a>>
Returns a BlobObject for an existing blob.
The name
may optionally be prefixed with the $BLOBDIR/
prefixed, as returned by BlobObject::as_name. This is how
you want to create a BlobObject for a filename read from the
database.
sourcepub fn to_abs_path(&self) -> PathBuf
pub fn to_abs_path(&self) -> PathBuf
Returns the absolute path to the blob in the filesystem.
sourcepub fn as_name(&self) -> &str
pub fn as_name(&self) -> &str
Returns the blob name, as stored in the database.
This returns the blob in the $BLOBDIR/<name>
format used in
the database. Do not use this unless you’re about to store
this string in the database or Params. Eventually even
those conversions should be handled by the type system.
sourcepub fn as_file_name(&self) -> &str
pub fn as_file_name(&self) -> &str
Returns the filename of the blob.
sourcepub fn as_rel_path(&self) -> &Path
pub fn as_rel_path(&self) -> &Path
The path relative in the blob directory.
sourcepub fn suffix(&self) -> Option<&str>
pub fn suffix(&self) -> Option<&str>
Returns the extension of the blob.
If a blob’s filename has an extension, it is always guaranteed to be lowercase.
sourcefn sanitise_name(name: &str) -> (String, String)
fn sanitise_name(name: &str) -> (String, String)
Create a safe name based on a messy input string.
The safe name will be a valid filename on Unix and Windows and not contain any path separators. The input can contain path segments separated by either Unix or Windows path separators, the rightmost non-empty segment will be used as name, sanitised for special characters.
The resulting name is returned as a tuple, the first part
being the stem or basename and the second being an extension,
including the dot. E.g. “foo.txt” is returned as ("foo", ".txt")
while “bar” is returned as ("bar", "")
.
The extension part will always be lowercased.
sourcefn is_acceptible_blob_name(name: impl AsRef<OsStr>) -> bool
fn is_acceptible_blob_name(name: impl AsRef<OsStr>) -> bool
Checks whether a name is a valid blob name.
This is slightly less strict than stanitise_name, presumably someone already created a file with such a name so we just ensure it’s not actually a path in disguise is actually utf-8.
sourcepub(crate) async fn store_from_base64(
context: &Context,
data: &str,
suggested_file_stem: &str,
) -> Result<String>
pub(crate) async fn store_from_base64( context: &Context, data: &str, suggested_file_stem: &str, ) -> Result<String>
Returns path to the stored Base64-decoded blob.
If data
represents an image of known format, this adds the corresponding extension to
suggested_file_stem
.
pub async fn recode_to_avatar_size(&mut self, context: &Context) -> Result<()>
sourcepub async fn recode_to_image_size(
&mut self,
context: &Context,
maybe_sticker: &mut bool,
) -> Result<()>
pub async fn recode_to_image_size( &mut self, context: &Context, maybe_sticker: &mut bool, ) -> Result<()>
Recodes an image pointed by a BlobObject so that it fits into limits on the image width, height and file size specified by the config.
On some platforms images are passed to the core as crate::message::Viewtype::Sticker
in
which case maybe_sticker
flag should be set. We recheck if an image is a true sticker
assuming that it must have at least one fully transparent corner, otherwise this flag is
reset.
Trait Implementations§
source§impl<'a> Clone for BlobObject<'a>
impl<'a> Clone for BlobObject<'a>
source§fn clone(&self) -> BlobObject<'a>
fn clone(&self) -> BlobObject<'a>
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl<'a> Debug for BlobObject<'a>
impl<'a> Debug for BlobObject<'a>
source§impl<'a> Display for BlobObject<'a>
impl<'a> Display for BlobObject<'a>
source§impl<'a> PartialEq for BlobObject<'a>
impl<'a> PartialEq for BlobObject<'a>
source§fn eq(&self, other: &BlobObject<'a>) -> bool
fn eq(&self, other: &BlobObject<'a>) -> bool
self
and other
values to be equal, and is used
by ==
.impl<'a> Eq for BlobObject<'a>
impl<'a> StructuralPartialEq for BlobObject<'a>
Auto Trait Implementations§
impl<'a> Freeze for BlobObject<'a>
impl<'a> RefUnwindSafe for BlobObject<'a>
impl<'a> Send for BlobObject<'a>
impl<'a> Sync for BlobObject<'a>
impl<'a> Unpin for BlobObject<'a>
impl<'a> UnwindSafe for BlobObject<'a>
Blanket Implementations§
§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§default unsafe fn clone_to_uninit(&self, dst: *mut T)
default unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit
)§impl<T> Conv for T
impl<T> Conv for T
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.§impl<T> FmtForward for T
impl<T> FmtForward for T
§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
self
to use its Binary
implementation when Debug
-formatted.§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
self
to use its Display
implementation when
Debug
-formatted.§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
self
to use its LowerExp
implementation when
Debug
-formatted.§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
self
to use its LowerHex
implementation when
Debug
-formatted.§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
self
to use its Octal
implementation when Debug
-formatted.§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
self
to use its Pointer
implementation when
Debug
-formatted.§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
self
to use its UpperExp
implementation when
Debug
-formatted.§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
self
to use its UpperHex
implementation when
Debug
-formatted.§fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read more§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read more§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self
, then passes self.as_ref()
into the pipe function.§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self
, then passes self.as_mut()
into the pipe
function.§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self
, then passes self.deref()
into the pipe function.§impl<T> Tap for T
impl<T> Tap for T
§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B>
of a value. Read more§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B>
of a value. Read more§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R>
view of a value. Read more§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R>
view of a value. Read more§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target
of a value. Read more§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target
of a value. Read more§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap()
only in debug builds, and is erased in release builds.§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut()
only in debug builds, and is erased in release
builds.§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.tap_borrow()
only in debug builds, and is erased in release
builds.§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut()
only in debug builds, and is erased in release
builds.§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.tap_ref()
only in debug builds, and is erased in release
builds.§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut()
only in debug builds, and is erased in release
builds.§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref()
only in debug builds, and is erased in release
builds.