Struct Exec

Source
pub struct Exec { /* private fields */ }
Expand description

Implementations§

Source§

impl Exec

Source

pub fn id(&self) -> &Id

A getter for Exec id

Source§

impl Exec

Source

pub async fn start<'exec>( &'exec self, opts: &'exec ExecStartOpts, ) -> Result<Option<Multiplexer<'exec>>>

Api Reference

Starts a previously set up exec instance. If detach is true, this endpoint returns immediately after starting the command. Otherwise, it sets up an interactive session with the command.

To create an exec instance use Container::create_exec.

Examples:

async {
    use podman_api::Podman;
    use futures_util::StreamExt;
    let podman = Podman::unix("/run/user/1000/podman/podman.sock");
    let container = podman.containers().get("451b27c6b9d3");

    let exec = container
        .create_exec(
            &podman_api::opts::ExecCreateOpts::builder()
                .command(["cat", "/some/path/in/container"])
                .build(),
        )
        .await
        .unwrap();

    let opts = Default::default();
    let mut stream = exec.start(&opts).await.unwrap().unwrap();

    while let Some(chunk) = stream.next().await {
        println!("{:?}", chunk.unwrap());
    }
};
Source

pub async fn inspect(&self) -> Result<Value>

Api Reference

Returns low-level information about an exec instance.

Examples:

async {
    use podman_api::Podman;
    use futures_util::StreamExt;
    let podman = Podman::unix("/run/user/1000/podman/podman.sock");
    let container = podman.containers().get("451b27c6b9d3");

    let exec = container
        .create_exec(
            &podman_api::opts::ExecCreateOpts::builder()
                .command(["cat", "/some/path/in/container"])
                .build(),
        )
        .await
        .unwrap();

    match exec.inspect().await {
        Ok(info) => println!("{:?}", info),
        Err(e) => eprintln!("{}", e)
    }
};
Source

pub async fn resize(&self, width: usize, heigth: usize) -> Result<()>

Api Reference

Resize the TTY session used by an exec instance. This endpoint only works if tty was specified as part of creating and starting the exec instance.

Examples:

use futures_util::StreamExt;
async {
    use podman_api::Podman;
    let podman = Podman::unix("/run/user/1000/podman/podman.sock");
    let container = podman.containers().get("451b27c6b9d3");

    let exec = container
        .create_exec(
            &podman_api::opts::ExecCreateOpts::builder()
                .command(["cat", "/some/path/in/container"])
                .build(),
        )
        .await
        .unwrap();

    if let Err(e) = exec.resize(1280, 720).await {
        eprintln!("{}", e);
    }
};

Trait Implementations§

Source§

impl Debug for Exec

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl Freeze for Exec

§

impl !RefUnwindSafe for Exec

§

impl Send for Exec

§

impl Sync for Exec

§

impl Unpin for Exec

§

impl !UnwindSafe for Exec

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> ErasedDestructor for T
where T: 'static,

Source§

impl<T> MaybeSendSync for T