Struct binstall_tar::Entry
source · pub struct Entry<'a, R: 'a + Read> { /* private fields */ }
Expand description
A read-only view into an entry of an archive.
This structure is a window into a portion of a borrowed archive which can be inspected. It acts as a file handle by implementing the Reader trait. An entry cannot be rewritten once inserted into an archive.
Implementations§
source§impl<'a, R: Read> Entry<'a, R>
impl<'a, R: Read> Entry<'a, R>
sourcepub fn path(&self) -> Result<Cow<'_, Path>>
pub fn path(&self) -> Result<Cow<'_, Path>>
Returns the path name for this entry.
This method may fail if the pathname is not valid Unicode and this is called on a Windows platform.
Note that this function will convert any \
characters to directory
separators, and it will not always return the same value as
self.header().path()
as some archive formats have support for longer
path names described in separate entries.
It is recommended to use this method instead of inspecting the header
directly to ensure that various archive formats are handled correctly.
sourcepub fn path_bytes(&self) -> Cow<'_, [u8]>
pub fn path_bytes(&self) -> Cow<'_, [u8]>
Returns the raw bytes listed for this entry.
Note that this function will convert any \
characters to directory
separators, and it will not always return the same value as
self.header().path_bytes()
as some archive formats have support for
longer path names described in separate entries.
sourcepub fn link_name(&self) -> Result<Option<Cow<'_, Path>>>
pub fn link_name(&self) -> Result<Option<Cow<'_, Path>>>
Returns the link name for this entry, if any is found.
This method may fail if the pathname is not valid Unicode and this is
called on a Windows platform. Ok(None)
being returned, however,
indicates that the link name was not present.
Note that this function will convert any \
characters to directory
separators, and it will not always return the same value as
self.header().link_name()
as some archive formats have support for
longer path names described in separate entries.
It is recommended to use this method instead of inspecting the header
directly to ensure that various archive formats are handled correctly.
sourcepub fn link_name_bytes(&self) -> Option<Cow<'_, [u8]>>
pub fn link_name_bytes(&self) -> Option<Cow<'_, [u8]>>
Returns the link name for this entry, in bytes, if listed.
Note that this will not always return the same value as
self.header().link_name_bytes()
as some archive formats have support for
longer path names described in separate entries.
sourcepub fn pax_extensions(&mut self) -> Result<Option<PaxExtensions<'_>>>
pub fn pax_extensions(&mut self) -> Result<Option<PaxExtensions<'_>>>
Returns an iterator over the pax extensions contained in this entry.
Pax extensions are a form of archive where extra metadata is stored in key/value pairs in entries before the entry they’re intended to describe. For example this can be used to describe long file name or other metadata like atime/ctime/mtime in more precision.
The returned iterator will yield key/value pairs for each extension.
None
will be returned if this entry does not indicate that it itself
contains extensions, or if there were no previous extensions describing
it.
Note that global pax extensions are intended to be applied to all archive entries.
Also note that this function will read the entire entry if the entry itself is a list of extensions.
sourcepub fn header(&self) -> &Header
pub fn header(&self) -> &Header
Returns access to the header of this entry in the archive.
This provides access to the metadata for this entry in the archive.
sourcepub fn size(&self) -> u64
pub fn size(&self) -> u64
Returns access to the size of this entry in the archive.
In the event the size is stored in a pax extension, that size value will be referenced. Otherwise, the entry size will be stored in the header.
sourcepub fn raw_header_position(&self) -> u64
pub fn raw_header_position(&self) -> u64
Returns the starting position, in bytes, of the header of this entry in the archive.
The header is always a contiguous section of 512 bytes, so if the
underlying reader implements Seek
, then the slice from header_pos
to
header_pos + 512
contains the raw header bytes.
sourcepub fn raw_file_position(&self) -> u64
pub fn raw_file_position(&self) -> u64
Returns the starting position, in bytes, of the file of this entry in the archive.
If the file of this entry is continuous (e.g. not a sparse file), and
if the underlying reader implements Seek
, then the slice from
file_pos
to file_pos + entry_size
contains the raw file bytes.
sourcepub fn unpack<P: AsRef<Path>>(&mut self, dst: P) -> Result<Unpacked>
pub fn unpack<P: AsRef<Path>>(&mut self, dst: P) -> Result<Unpacked>
Writes this file to the specified location.
This function will write the entire contents of this file into the
location specified by dst
. Metadata will also be propagated to the
path dst
.
This function will create a file at the path dst
, and it is required
that the intermediate directories are created. Any existing file at the
location dst
will be overwritten.
Note: This function does not have as many sanity checks as
Archive::unpack
orEntry::unpack_in
. As a result if you’re thinking of unpacking untrusted tarballs you may want to review the implementations of the previous two functions and perhaps implement similar logic yourself.
§Examples
use std::fs::File;
use binstall_tar::Archive;
let mut ar = Archive::new(File::open("foo.tar").unwrap());
for (i, file) in ar.entries().unwrap().enumerate() {
let mut file = file.unwrap();
file.unpack(format!("file-{}", i)).unwrap();
}
sourcepub fn unpack_in<P: AsRef<Path>>(&mut self, dst: P) -> Result<bool>
pub fn unpack_in<P: AsRef<Path>>(&mut self, dst: P) -> Result<bool>
Extracts this file under the specified path, avoiding security issues.
This function will write the entire contents of this file into the
location obtained by appending the path of this file in the archive to
dst
, creating any intermediate directories if needed. Metadata will
also be propagated to the path dst
. Any existing file at the location
dst
will be overwritten.
This function carefully avoids writing outside of dst
. If the file has
a ‘..’ in its path, this function will skip it and return false.
§Examples
use std::fs::File;
use binstall_tar::Archive;
let mut ar = Archive::new(File::open("foo.tar").unwrap());
for (i, file) in ar.entries().unwrap().enumerate() {
let mut file = file.unwrap();
file.unpack_in("target").unwrap();
}
sourcepub fn set_mask(&mut self, mask: u32)
pub fn set_mask(&mut self, mask: u32)
Set the mask of the permission bits when unpacking this entry.
The mask will be inverted when applying against a mode, similar to how
umask
works on Unix. In logical notation it looks like:
new_mode = old_mode & (~mask)
The mask is 0 by default and is currently only implemented on Unix.
sourcepub fn set_unpack_xattrs(&mut self, unpack_xattrs: bool)
pub fn set_unpack_xattrs(&mut self, unpack_xattrs: bool)
Indicate whether extended file attributes (xattrs on Unix) are preserved when unpacking this entry.
This flag is disabled by default and is currently only implemented on Unix using xattr support. This may eventually be implemented for Windows, however, if other archive implementations are found which do this as well.
sourcepub fn set_preserve_permissions(&mut self, preserve: bool)
pub fn set_preserve_permissions(&mut self, preserve: bool)
Indicate whether extended permissions (like suid on Unix) are preserved when unpacking this entry.
This flag is disabled by default and is currently only implemented on Unix.
sourcepub fn set_preserve_mtime(&mut self, preserve: bool)
pub fn set_preserve_mtime(&mut self, preserve: bool)
Indicate whether access time information is preserved when unpacking this entry.
This flag is enabled by default.
Trait Implementations§
source§impl<'a, R: Read> Read for Entry<'a, R>
impl<'a, R: Read> Read for Entry<'a, R>
source§fn read(&mut self, into: &mut [u8]) -> Result<usize>
fn read(&mut self, into: &mut [u8]) -> Result<usize>
1.36.0 · source§fn read_vectored(&mut self, bufs: &mut [IoSliceMut<'_>]) -> Result<usize, Error>
fn read_vectored(&mut self, bufs: &mut [IoSliceMut<'_>]) -> Result<usize, Error>
read
, except that it reads into a slice of buffers. Read moresource§fn is_read_vectored(&self) -> bool
fn is_read_vectored(&self) -> bool
can_vector
)1.0.0 · source§fn read_to_end(&mut self, buf: &mut Vec<u8>) -> Result<usize, Error>
fn read_to_end(&mut self, buf: &mut Vec<u8>) -> Result<usize, Error>
buf
. Read more1.0.0 · source§fn read_to_string(&mut self, buf: &mut String) -> Result<usize, Error>
fn read_to_string(&mut self, buf: &mut String) -> Result<usize, Error>
buf
. Read more1.6.0 · source§fn read_exact(&mut self, buf: &mut [u8]) -> Result<(), Error>
fn read_exact(&mut self, buf: &mut [u8]) -> Result<(), Error>
buf
. Read moresource§fn read_buf(&mut self, buf: BorrowedCursor<'_>) -> Result<(), Error>
fn read_buf(&mut self, buf: BorrowedCursor<'_>) -> Result<(), Error>
read_buf
)source§fn read_buf_exact(&mut self, cursor: BorrowedCursor<'_>) -> Result<(), Error>
fn read_buf_exact(&mut self, cursor: BorrowedCursor<'_>) -> Result<(), Error>
read_buf
)cursor
. Read more1.0.0 · source§fn by_ref(&mut self) -> &mut Selfwhere
Self: Sized,
fn by_ref(&mut self) -> &mut Selfwhere
Self: Sized,
Read
. Read more