dagger-rs/crates/dagger-sdk/src/gen.rs

2726 lines
90 KiB
Rust
Raw Normal View History

2023-02-05 23:44:06 +01:00
use crate::client::graphql_client;
use crate::querybuilder::Selection;
use dagger_core::connect_params::ConnectParams;
use derive_builder::Builder;
use serde::{Deserialize, Serialize};
use std::sync::Arc;
2023-02-20 11:42:03 +01:00
use tokio::process::Child;
2023-02-05 23:44:06 +01:00
#[derive(Serialize, Deserialize, PartialEq, Debug, Clone)]
pub struct CacheId(String);
#[derive(Serialize, Deserialize, PartialEq, Debug, Clone)]
pub struct ContainerId(String);
#[derive(Serialize, Deserialize, PartialEq, Debug, Clone)]
pub struct DirectoryId(String);
#[derive(Serialize, Deserialize, PartialEq, Debug, Clone)]
pub struct FileId(String);
#[derive(Serialize, Deserialize, PartialEq, Debug, Clone)]
pub struct Platform(String);
#[derive(Serialize, Deserialize, PartialEq, Debug, Clone)]
pub struct SecretId(String);
#[derive(Serialize, Deserialize, PartialEq, Debug, Clone)]
pub struct SocketId(String);
#[derive(Serialize, Deserialize, Debug, PartialEq, Clone)]
2023-01-30 20:44:48 +01:00
pub struct BuildArg {
pub name: String,
2023-02-22 23:09:20 +01:00
pub value: String,
}
2023-02-22 22:38:15 +01:00
#[derive(Debug, Clone)]
pub struct CacheVolume {
pub proc: Arc<Child>,
pub selection: Selection,
pub conn: ConnectParams,
2023-01-30 20:44:48 +01:00
}
2023-02-22 23:09:20 +01:00
2023-02-01 16:34:59 +01:00
impl CacheVolume {
2023-02-22 22:38:15 +01:00
pub async fn id(&self) -> eyre::Result<CacheId> {
let mut query = self.selection.select("id");
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
2023-02-01 15:32:38 +01:00
}
2023-02-01 16:34:59 +01:00
}
2023-02-22 22:38:15 +01:00
#[derive(Debug, Clone)]
2023-02-05 23:44:06 +01:00
pub struct Container {
pub proc: Arc<Child>,
pub selection: Selection,
pub conn: ConnectParams,
}
2023-02-22 23:09:20 +01:00
#[derive(Builder, Debug, PartialEq)]
pub struct ContainerBuildOpts<'a> {
2023-02-19 22:38:36 +01:00
/// Path to the Dockerfile to use.
/// Default: './Dockerfile'.
#[builder(setter(into, strip_option))]
pub dockerfile: Option<&'a str>,
2023-02-19 22:38:36 +01:00
/// Additional build arguments.
#[builder(setter(into, strip_option))]
pub build_args: Option<Vec<BuildArg>>,
2023-02-19 22:38:36 +01:00
/// Target build stage to build.
#[builder(setter(into, strip_option))]
pub target: Option<&'a str>,
}
#[derive(Builder, Debug, PartialEq)]
pub struct ContainerEndpointOpts<'a> {
/// The exposed port number for the endpoint
#[builder(setter(into, strip_option))]
pub port: Option<isize>,
/// Return a URL with the given scheme, eg. http for http://
#[builder(setter(into, strip_option))]
pub scheme: Option<&'a str>,
}
#[derive(Builder, Debug, PartialEq)]
pub struct ContainerExecOpts<'a> {
/// Command to run instead of the container's default command (e.g., ["run", "main.go"]).
#[builder(setter(into, strip_option))]
pub args: Option<Vec<&'a str>>,
/// Content to write to the command's standard input before closing (e.g., "Hello world").
#[builder(setter(into, strip_option))]
pub stdin: Option<&'a str>,
/// Redirect the command's standard output to a file in the container (e.g., "/tmp/stdout").
#[builder(setter(into, strip_option))]
pub redirect_stdout: Option<&'a str>,
/// Redirect the command's standard error to a file in the container (e.g., "/tmp/stderr").
#[builder(setter(into, strip_option))]
pub redirect_stderr: Option<&'a str>,
2023-02-19 22:38:36 +01:00
/// Provide dagger access to the executed command.
/// Do not use this option unless you trust the command being executed.
/// The command being executed WILL BE GRANTED FULL ACCESS TO YOUR HOST FILESYSTEM.
#[builder(setter(into, strip_option))]
pub experimental_privileged_nesting: Option<bool>,
}
#[derive(Builder, Debug, PartialEq)]
2023-02-19 17:29:59 +01:00
pub struct ContainerExportOpts {
2023-02-19 22:38:36 +01:00
/// Identifiers for other platform specific containers.
/// Used for multi-platform image.
#[builder(setter(into, strip_option))]
pub platform_variants: Option<Vec<ContainerId>>,
}
#[derive(Builder, Debug, PartialEq)]
pub struct ContainerPipelineOpts<'a> {
#[builder(setter(into, strip_option))]
pub description: Option<&'a str>,
}
#[derive(Builder, Debug, PartialEq)]
2023-02-19 17:29:59 +01:00
pub struct ContainerPublishOpts {
2023-02-19 22:38:36 +01:00
/// Identifiers for other platform specific containers.
/// Used for multi-platform image.
#[builder(setter(into, strip_option))]
pub platform_variants: Option<Vec<ContainerId>>,
}
#[derive(Builder, Debug, PartialEq)]
pub struct ContainerWithDefaultArgsOpts<'a> {
/// Arguments to prepend to future executions (e.g., ["-v", "--no-cache"]).
#[builder(setter(into, strip_option))]
pub args: Option<Vec<&'a str>>,
}
#[derive(Builder, Debug, PartialEq)]
pub struct ContainerWithDirectoryOpts<'a> {
/// Patterns to exclude in the written directory (e.g., ["node_modules/**", ".gitignore", ".git/"]).
#[builder(setter(into, strip_option))]
pub exclude: Option<Vec<&'a str>>,
/// Patterns to include in the written directory (e.g., ["*.go", "go.mod", "go.sum"]).
#[builder(setter(into, strip_option))]
pub include: Option<Vec<&'a str>>,
2023-02-19 12:19:43 +01:00
}
#[derive(Builder, Debug, PartialEq)]
pub struct ContainerWithExecOpts<'a> {
/// Content to write to the command's standard input before closing (e.g., "Hello world").
#[builder(setter(into, strip_option))]
pub stdin: Option<&'a str>,
/// Redirect the command's standard output to a file in the container (e.g., "/tmp/stdout").
#[builder(setter(into, strip_option))]
pub redirect_stdout: Option<&'a str>,
/// Redirect the command's standard error to a file in the container (e.g., "/tmp/stderr").
#[builder(setter(into, strip_option))]
pub redirect_stderr: Option<&'a str>,
/// Provides dagger access to the executed command.
2023-02-19 22:38:36 +01:00
/// Do not use this option unless you trust the command being executed.
/// The command being executed WILL BE GRANTED FULL ACCESS TO YOUR HOST FILESYSTEM.
#[builder(setter(into, strip_option))]
pub experimental_privileged_nesting: Option<bool>,
}
#[derive(Builder, Debug, PartialEq)]
pub struct ContainerWithExposedPortOpts<'a> {
/// Transport layer network protocol
#[builder(setter(into, strip_option))]
pub protocol: Option<NetworkProtocol>,
/// Optional port description
#[builder(setter(into, strip_option))]
pub description: Option<&'a str>,
}
#[derive(Builder, Debug, PartialEq)]
2023-02-19 17:29:59 +01:00
pub struct ContainerWithFileOpts {
/// Permission given to the copied file (e.g., 0600).
/// Default: 0644.
#[builder(setter(into, strip_option))]
pub permissions: Option<isize>,
}
#[derive(Builder, Debug, PartialEq)]
2023-02-19 17:29:59 +01:00
pub struct ContainerWithMountedCacheOpts {
/// Identifier of the directory to use as the cache volume's root.
#[builder(setter(into, strip_option))]
pub source: Option<DirectoryId>,
2023-02-19 22:38:36 +01:00
/// Sharing mode of the cache volume.
#[builder(setter(into, strip_option))]
2023-02-19 12:16:48 +01:00
pub sharing: Option<CacheSharingMode>,
}
#[derive(Builder, Debug, PartialEq)]
pub struct ContainerWithNewFileOpts<'a> {
/// Content of the file to write (e.g., "Hello world!").
#[builder(setter(into, strip_option))]
pub contents: Option<&'a str>,
/// Permission given to the written file (e.g., 0600).
/// Default: 0644.
#[builder(setter(into, strip_option))]
pub permissions: Option<isize>,
2023-02-05 23:44:06 +01:00
}
#[derive(Builder, Debug, PartialEq)]
pub struct ContainerWithoutExposedPortOpts {
/// Port protocol to unexpose
#[builder(setter(into, strip_option))]
pub protocol: Option<NetworkProtocol>,
}
2023-02-22 23:09:20 +01:00
2023-02-01 16:34:59 +01:00
impl Container {
/// Initializes this container from a Dockerfile build.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `context` - Directory context used by the Dockerfile.
2023-02-19 22:38:36 +01:00
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn build(&self, context: DirectoryId) -> Container {
let mut query = self.selection.select("build");
2023-02-22 23:09:20 +01:00
query = query.arg("context", context);
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
2023-02-22 23:09:20 +01:00
/// Initializes this container from a Dockerfile build.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `context` - Directory context used by the Dockerfile.
2023-02-19 22:38:36 +01:00
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn build_opts<'a>(&self, context: DirectoryId, opts: ContainerBuildOpts<'a>) -> Container {
let mut query = self.selection.select("build");
2023-02-22 23:09:20 +01:00
query = query.arg("context", context);
if let Some(dockerfile) = opts.dockerfile {
query = query.arg("dockerfile", dockerfile);
}
if let Some(build_args) = opts.build_args {
query = query.arg("buildArgs", build_args);
}
if let Some(target) = opts.target {
query = query.arg("target", target);
}
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-01 15:32:38 +01:00
}
2023-02-19 22:38:36 +01:00
/// Retrieves default arguments for future commands.
2023-02-22 22:38:15 +01:00
pub async fn default_args(&self) -> eyre::Result<Vec<String>> {
let mut query = self.selection.select("defaultArgs");
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
2023-02-01 15:32:38 +01:00
}
/// Retrieves a directory at the given path.
/// Mounts are included.
///
/// # Arguments
///
/// * `path` - The path of the directory to retrieve (e.g., "./src").
2023-02-22 22:38:15 +01:00
pub fn directory(&self, path: impl Into<String>) -> Directory {
let mut query = self.selection.select("directory");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
2023-02-22 23:09:20 +01:00
return Directory {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-01-30 20:53:53 +01:00
}
/// Retrieves an endpoint that clients can use to reach this container.
/// If no port is specified, the first exposed port is used. If none exist an error is returned.
/// If a scheme is specified, a URL is returned. Otherwise, a host:port pair is returned.
///
/// # Arguments
///
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
pub async fn endpoint(&self) -> eyre::Result<String> {
let mut query = self.selection.select("endpoint");
query.execute(&graphql_client(&self.conn)).await
}
/// Retrieves an endpoint that clients can use to reach this container.
/// If no port is specified, the first exposed port is used. If none exist an error is returned.
/// If a scheme is specified, a URL is returned. Otherwise, a host:port pair is returned.
///
/// # Arguments
///
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
pub async fn endpoint_opts<'a>(&self, opts: ContainerEndpointOpts<'a>) -> eyre::Result<String> {
let mut query = self.selection.select("endpoint");
if let Some(port) = opts.port {
query = query.arg("port", port);
}
if let Some(scheme) = opts.scheme {
query = query.arg("scheme", scheme);
}
query.execute(&graphql_client(&self.conn)).await
}
2023-02-19 22:38:36 +01:00
/// Retrieves entrypoint to be prepended to the arguments of all commands.
2023-02-22 22:38:15 +01:00
pub async fn entrypoint(&self) -> eyre::Result<Vec<String>> {
let mut query = self.selection.select("entrypoint");
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
2023-01-30 20:53:53 +01:00
}
2023-02-19 22:38:36 +01:00
/// Retrieves the value of the specified environment variable.
///
/// # Arguments
///
/// * `name` - The name of the environment variable to retrieve (e.g., "PATH").
2023-02-22 22:38:15 +01:00
pub async fn env_variable(&self, name: impl Into<String>) -> eyre::Result<String> {
let mut query = self.selection.select("envVariable");
2023-02-22 23:09:20 +01:00
query = query.arg("name", name.into());
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
}
2023-02-19 22:38:36 +01:00
/// Retrieves the list of environment variables passed to commands.
2023-02-22 22:38:15 +01:00
pub fn env_variables(&self) -> Vec<EnvVariable> {
let mut query = self.selection.select("envVariables");
2023-02-22 23:09:20 +01:00
return vec![EnvVariable {
2023-02-05 23:44:06 +01:00
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
}];
}
2023-02-19 22:38:36 +01:00
/// Retrieves this container after executing the specified command inside it.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn exec(&self) -> Container {
let mut query = self.selection.select("exec");
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
2023-02-22 23:09:20 +01:00
2023-02-19 22:38:36 +01:00
/// Retrieves this container after executing the specified command inside it.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn exec_opts<'a>(&self, opts: ContainerExecOpts<'a>) -> Container {
let mut query = self.selection.select("exec");
2023-02-22 23:09:20 +01:00
if let Some(args) = opts.args {
query = query.arg("args", args);
}
if let Some(stdin) = opts.stdin {
query = query.arg("stdin", stdin);
}
if let Some(redirect_stdout) = opts.redirect_stdout {
query = query.arg("redirectStdout", redirect_stdout);
}
if let Some(redirect_stderr) = opts.redirect_stderr {
query = query.arg("redirectStderr", redirect_stderr);
}
if let Some(experimental_privileged_nesting) = opts.experimental_privileged_nesting {
2023-02-22 22:38:15 +01:00
query = query.arg(
"experimentalPrivilegedNesting",
experimental_privileged_nesting,
);
2023-02-05 23:44:06 +01:00
}
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-01-30 20:44:48 +01:00
}
2023-02-19 22:38:36 +01:00
/// Exit code of the last executed command. Zero means success.
/// Null if no command has been executed.
2023-02-22 22:38:15 +01:00
pub async fn exit_code(&self) -> eyre::Result<isize> {
let mut query = self.selection.select("exitCode");
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
2023-02-01 15:27:44 +01:00
}
/// Writes the container as an OCI tarball to the destination file path on the host for the specified platform variants.
2023-02-19 22:38:36 +01:00
/// Return true on success.
/// It can also publishes platform variants.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `path` - Host's destination path (e.g., "./tarball").
2023-02-19 22:38:36 +01:00
/// Path can be relative to the engine's workdir or absolute.
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub async fn export(&self, path: impl Into<String>) -> eyre::Result<bool> {
let mut query = self.selection.select("export");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
}
2023-02-22 23:09:20 +01:00
/// Writes the container as an OCI tarball to the destination file path on the host for the specified platform variants.
2023-02-19 22:38:36 +01:00
/// Return true on success.
/// It can also publishes platform variants.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `path` - Host's destination path (e.g., "./tarball").
2023-02-19 22:38:36 +01:00
/// Path can be relative to the engine's workdir or absolute.
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
pub async fn export_opts(
&self,
path: impl Into<String>,
2023-02-22 22:38:15 +01:00
opts: ContainerExportOpts,
) -> eyre::Result<bool> {
let mut query = self.selection.select("export");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
if let Some(platform_variants) = opts.platform_variants {
query = query.arg("platformVariants", platform_variants);
}
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
2023-02-01 15:27:44 +01:00
}
/// Retrieves the list of exposed ports
pub fn exposed_ports(&self) -> Vec<Port> {
let mut query = self.selection.select("exposedPorts");
return vec![Port {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
}];
}
/// Retrieves a file at the given path.
/// Mounts are included.
///
/// # Arguments
///
/// * `path` - The path of the file to retrieve (e.g., "./README.md").
2023-02-22 22:38:15 +01:00
pub fn file(&self, path: impl Into<String>) -> File {
let mut query = self.selection.select("file");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
2023-02-22 23:09:20 +01:00
return File {
2023-02-05 23:44:06 +01:00
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-01 15:27:44 +01:00
}
/// Initializes this container from a pulled base image.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `address` - Image's address from its registry.
///
/// Formatted as [host]/[user]/[repo]:[tag] (e.g., "docker.io/dagger/dagger:main").
2023-02-22 22:38:15 +01:00
pub fn from(&self, address: impl Into<String>) -> Container {
let mut query = self.selection.select("from");
2023-02-22 23:09:20 +01:00
query = query.arg("address", address.into());
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-01-30 20:44:48 +01:00
}
2023-02-19 22:38:36 +01:00
/// Retrieves this container's root filesystem. Mounts are not included.
2023-02-22 22:38:15 +01:00
pub fn fs(&self) -> Directory {
let mut query = self.selection.select("fs");
2023-02-22 23:09:20 +01:00
return Directory {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-01 15:32:38 +01:00
}
/// Retrieves a hostname which can be used by clients to reach this container.
pub async fn hostname(&self) -> eyre::Result<String> {
let mut query = self.selection.select("hostname");
query.execute(&graphql_client(&self.conn)).await
}
2023-02-19 22:38:36 +01:00
/// A unique identifier for this container.
2023-02-22 22:38:15 +01:00
pub async fn id(&self) -> eyre::Result<ContainerId> {
let mut query = self.selection.select("id");
query.execute(&graphql_client(&self.conn)).await
}
/// The unique image reference which can only be retrieved immediately after the 'Container.From' call.
pub async fn image_ref(&self) -> eyre::Result<String> {
let mut query = self.selection.select("imageRef");
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
2023-01-30 20:53:53 +01:00
}
2023-02-19 22:38:36 +01:00
/// Retrieves the value of the specified label.
2023-02-22 22:38:15 +01:00
pub async fn label(&self, name: impl Into<String>) -> eyre::Result<String> {
let mut query = self.selection.select("label");
2023-02-22 23:09:20 +01:00
query = query.arg("name", name.into());
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
2023-01-30 20:53:53 +01:00
}
2023-02-19 22:38:36 +01:00
/// Retrieves the list of labels passed to container.
2023-02-22 22:38:15 +01:00
pub fn labels(&self) -> Vec<Label> {
let mut query = self.selection.select("labels");
2023-02-22 23:09:20 +01:00
return vec![Label {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
}];
2023-01-30 20:53:53 +01:00
}
2023-02-19 22:38:36 +01:00
/// Retrieves the list of paths where a directory is mounted.
2023-02-22 22:38:15 +01:00
pub async fn mounts(&self) -> eyre::Result<Vec<String>> {
let mut query = self.selection.select("mounts");
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
2023-02-01 15:27:44 +01:00
}
2023-02-19 22:38:36 +01:00
/// Creates a named sub-pipeline
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn pipeline(&self, name: impl Into<String>) -> Container {
let mut query = self.selection.select("pipeline");
2023-02-22 23:09:20 +01:00
query = query.arg("name", name.into());
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
2023-02-22 23:09:20 +01:00
2023-02-19 22:38:36 +01:00
/// Creates a named sub-pipeline
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
pub fn pipeline_opts<'a>(
&self,
name: impl Into<String>,
2023-02-22 22:38:15 +01:00
opts: ContainerPipelineOpts<'a>,
) -> Container {
let mut query = self.selection.select("pipeline");
2023-02-22 23:09:20 +01:00
query = query.arg("name", name.into());
if let Some(description) = opts.description {
query = query.arg("description", description);
}
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-01 15:27:44 +01:00
}
2023-02-19 22:38:36 +01:00
/// The platform this container executes and publishes as.
2023-02-22 22:38:15 +01:00
pub async fn platform(&self) -> eyre::Result<Platform> {
let mut query = self.selection.select("platform");
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
2023-01-30 20:53:53 +01:00
}
/// Publishes this container as a new image to the specified address.
/// Publish returns a fully qualified ref.
/// It can also publish platform variants.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `address` - Registry's address to publish the image to.
///
/// Formatted as [host]/[user]/[repo]:[tag] (e.g. "docker.io/dagger/dagger:main").
2023-02-19 22:38:36 +01:00
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub async fn publish(&self, address: impl Into<String>) -> eyre::Result<String> {
let mut query = self.selection.select("publish");
2023-02-22 23:09:20 +01:00
query = query.arg("address", address.into());
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
}
2023-02-22 23:09:20 +01:00
/// Publishes this container as a new image to the specified address.
/// Publish returns a fully qualified ref.
/// It can also publish platform variants.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `address` - Registry's address to publish the image to.
///
/// Formatted as [host]/[user]/[repo]:[tag] (e.g. "docker.io/dagger/dagger:main").
2023-02-19 22:38:36 +01:00
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
pub async fn publish_opts(
&self,
address: impl Into<String>,
2023-02-22 22:38:15 +01:00
opts: ContainerPublishOpts,
) -> eyre::Result<String> {
let mut query = self.selection.select("publish");
2023-02-22 23:09:20 +01:00
query = query.arg("address", address.into());
if let Some(platform_variants) = opts.platform_variants {
query = query.arg("platformVariants", platform_variants);
}
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
2023-01-30 20:44:48 +01:00
}
2023-02-19 22:38:36 +01:00
/// Retrieves this container's root filesystem. Mounts are not included.
2023-02-22 22:38:15 +01:00
pub fn rootfs(&self) -> Directory {
let mut query = self.selection.select("rootfs");
2023-02-22 23:09:20 +01:00
return Directory {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
2023-02-19 22:38:36 +01:00
/// The error stream of the last executed command.
/// Null if no command has been executed.
2023-02-22 22:38:15 +01:00
pub async fn stderr(&self) -> eyre::Result<String> {
let mut query = self.selection.select("stderr");
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
2023-02-01 15:06:28 +01:00
}
2023-02-19 22:38:36 +01:00
/// The output stream of the last executed command.
/// Null if no command has been executed.
2023-02-22 22:38:15 +01:00
pub async fn stdout(&self) -> eyre::Result<String> {
let mut query = self.selection.select("stdout");
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
2023-02-01 15:06:28 +01:00
}
2023-02-19 22:38:36 +01:00
/// Retrieves the user to be set for all commands.
2023-02-22 22:38:15 +01:00
pub async fn user(&self) -> eyre::Result<String> {
let mut query = self.selection.select("user");
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
2023-02-01 15:27:44 +01:00
}
2023-02-19 22:38:36 +01:00
/// Configures default arguments for future commands.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn with_default_args(&self) -> Container {
let mut query = self.selection.select("withDefaultArgs");
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
2023-02-22 23:09:20 +01:00
2023-02-19 22:38:36 +01:00
/// Configures default arguments for future commands.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn with_default_args_opts<'a>(&self, opts: ContainerWithDefaultArgsOpts<'a>) -> Container {
let mut query = self.selection.select("withDefaultArgs");
2023-02-22 23:09:20 +01:00
if let Some(args) = opts.args {
query = query.arg("args", args);
}
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
2023-02-19 22:38:36 +01:00
/// Retrieves this container plus a directory written at the given path.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `path` - Location of the written directory (e.g., "/tmp/directory").
/// * `directory` - Identifier of the directory to write
2023-02-22 23:09:20 +01:00
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn with_directory(&self, path: impl Into<String>, directory: DirectoryId) -> Container {
let mut query = self.selection.select("withDirectory");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
query = query.arg("directory", directory);
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
2023-02-22 23:09:20 +01:00
2023-02-19 22:38:36 +01:00
/// Retrieves this container plus a directory written at the given path.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `path` - Location of the written directory (e.g., "/tmp/directory").
/// * `directory` - Identifier of the directory to write
2023-02-22 23:09:20 +01:00
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
pub fn with_directory_opts<'a>(
2023-02-01 16:34:59 +01:00
&self,
path: impl Into<String>,
directory: DirectoryId,
2023-02-22 22:38:15 +01:00
opts: ContainerWithDirectoryOpts<'a>,
2023-02-01 16:34:59 +01:00
) -> Container {
let mut query = self.selection.select("withDirectory");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
query = query.arg("directory", directory);
if let Some(exclude) = opts.exclude {
query = query.arg("exclude", exclude);
}
if let Some(include) = opts.include {
query = query.arg("include", include);
}
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-01-30 20:53:53 +01:00
}
2023-02-19 22:38:36 +01:00
/// Retrieves this container but with a different command entrypoint.
///
/// # Arguments
///
/// * `args` - Entrypoint to use for future executions (e.g., ["go", "run"]).
2023-02-22 22:38:15 +01:00
pub fn with_entrypoint(&self, args: Vec<impl Into<String>>) -> Container {
let mut query = self.selection.select("withEntrypoint");
2023-02-22 23:09:20 +01:00
2023-02-22 22:38:15 +01:00
query = query.arg(
"args",
args.into_iter().map(|i| i.into()).collect::<Vec<String>>(),
);
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-01-30 20:53:53 +01:00
}
2023-02-19 22:38:36 +01:00
/// Retrieves this container plus the given environment variable.
///
/// # Arguments
///
/// * `name` - The name of the environment variable (e.g., "HOST").
/// * `value` - The value of the environment variable. (e.g., "localhost").
pub fn with_env_variable(
&self,
name: impl Into<String>,
value: impl Into<String>,
) -> Container {
let mut query = self.selection.select("withEnvVariable");
2023-02-22 23:09:20 +01:00
query = query.arg("name", name.into());
query = query.arg("value", value.into());
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-01 15:06:28 +01:00
}
2023-02-19 22:38:36 +01:00
/// Retrieves this container after executing the specified command inside it.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `args` - Command to run instead of the container's default command (e.g., ["run", "main.go"]).
2023-02-19 22:38:36 +01:00
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn with_exec(&self, args: Vec<impl Into<String>>) -> Container {
let mut query = self.selection.select("withExec");
2023-02-22 23:09:20 +01:00
2023-02-22 22:38:15 +01:00
query = query.arg(
"args",
args.into_iter().map(|i| i.into()).collect::<Vec<String>>(),
);
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
2023-02-22 23:09:20 +01:00
2023-02-19 22:38:36 +01:00
/// Retrieves this container after executing the specified command inside it.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `args` - Command to run instead of the container's default command (e.g., ["run", "main.go"]).
2023-02-19 22:38:36 +01:00
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
pub fn with_exec_opts<'a>(
&self,
args: Vec<impl Into<String>>,
2023-02-22 22:38:15 +01:00
opts: ContainerWithExecOpts<'a>,
) -> Container {
let mut query = self.selection.select("withExec");
2023-02-22 23:09:20 +01:00
2023-02-22 22:38:15 +01:00
query = query.arg(
"args",
args.into_iter().map(|i| i.into()).collect::<Vec<String>>(),
);
if let Some(stdin) = opts.stdin {
query = query.arg("stdin", stdin);
}
if let Some(redirect_stdout) = opts.redirect_stdout {
query = query.arg("redirectStdout", redirect_stdout);
}
if let Some(redirect_stderr) = opts.redirect_stderr {
query = query.arg("redirectStderr", redirect_stderr);
}
if let Some(experimental_privileged_nesting) = opts.experimental_privileged_nesting {
2023-02-22 22:38:15 +01:00
query = query.arg(
"experimentalPrivilegedNesting",
experimental_privileged_nesting,
);
}
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-01-30 20:44:48 +01:00
}
/// Expose a network port.
/// Exposed ports serve two purposes:
/// - For health checks and introspection, when running services
/// - For setting the EXPOSE OCI field when publishing the container
///
/// # Arguments
///
/// * `port` - Port number to expose
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
pub fn with_exposed_port(&self, port: isize) -> Container {
let mut query = self.selection.select("withExposedPort");
query = query.arg("port", port);
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
};
}
/// Expose a network port.
/// Exposed ports serve two purposes:
/// - For health checks and introspection, when running services
/// - For setting the EXPOSE OCI field when publishing the container
///
/// # Arguments
///
/// * `port` - Port number to expose
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
pub fn with_exposed_port_opts<'a>(
&self,
port: isize,
opts: ContainerWithExposedPortOpts<'a>,
) -> Container {
let mut query = self.selection.select("withExposedPort");
query = query.arg("port", port);
if let Some(protocol) = opts.protocol {
query = query.arg("protocol", protocol);
}
if let Some(description) = opts.description {
query = query.arg("description", description);
}
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
};
}
2023-02-19 22:38:36 +01:00
/// Initializes this container from this DirectoryID.
2023-02-22 22:38:15 +01:00
pub fn with_fs(&self, id: DirectoryId) -> Container {
let mut query = self.selection.select("withFS");
2023-02-22 23:09:20 +01:00
query = query.arg("id", id);
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
2023-02-19 22:38:36 +01:00
/// Retrieves this container plus the contents of the given file copied to the given path.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `path` - Location of the copied file (e.g., "/tmp/file.txt").
/// * `source` - Identifier of the file to copy.
2023-02-22 23:09:20 +01:00
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn with_file(&self, path: impl Into<String>, source: FileId) -> Container {
let mut query = self.selection.select("withFile");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
query = query.arg("source", source);
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
2023-02-22 23:09:20 +01:00
2023-02-19 22:38:36 +01:00
/// Retrieves this container plus the contents of the given file copied to the given path.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `path` - Location of the copied file (e.g., "/tmp/file.txt").
/// * `source` - Identifier of the file to copy.
2023-02-22 23:09:20 +01:00
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
pub fn with_file_opts(
2023-02-05 23:44:06 +01:00
&self,
path: impl Into<String>,
source: FileId,
2023-02-22 22:38:15 +01:00
opts: ContainerWithFileOpts,
2023-02-05 23:44:06 +01:00
) -> Container {
let mut query = self.selection.select("withFile");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
query = query.arg("source", source);
if let Some(permissions) = opts.permissions {
query = query.arg("permissions", permissions);
}
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-01-30 20:44:48 +01:00
}
2023-02-19 22:38:36 +01:00
/// Retrieves this container plus the given label.
///
/// # Arguments
///
/// * `name` - The name of the label (e.g., "org.opencontainers.artifact.created").
/// * `value` - The value of the label (e.g., "2023-01-01T00:00:00Z").
2023-02-22 22:38:15 +01:00
pub fn with_label(&self, name: impl Into<String>, value: impl Into<String>) -> Container {
let mut query = self.selection.select("withLabel");
2023-02-22 23:09:20 +01:00
query = query.arg("name", name.into());
query = query.arg("value", value.into());
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
2023-02-19 22:38:36 +01:00
/// Retrieves this container plus a cache volume mounted at the given path.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `path` - Location of the cache directory (e.g., "/cache/node_modules").
/// * `cache` - Identifier of the cache volume to mount.
2023-02-19 22:38:36 +01:00
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn with_mounted_cache(&self, path: impl Into<String>, cache: CacheId) -> Container {
let mut query = self.selection.select("withMountedCache");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
query = query.arg("cache", cache);
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
2023-02-22 23:09:20 +01:00
2023-02-19 22:38:36 +01:00
/// Retrieves this container plus a cache volume mounted at the given path.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `path` - Location of the cache directory (e.g., "/cache/node_modules").
/// * `cache` - Identifier of the cache volume to mount.
2023-02-19 22:38:36 +01:00
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
pub fn with_mounted_cache_opts(
2023-02-01 16:34:59 +01:00
&self,
path: impl Into<String>,
cache: CacheId,
2023-02-22 22:38:15 +01:00
opts: ContainerWithMountedCacheOpts,
2023-02-01 16:34:59 +01:00
) -> Container {
let mut query = self.selection.select("withMountedCache");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
query = query.arg("cache", cache);
if let Some(source) = opts.source {
query = query.arg("source", source);
}
if let Some(sharing) = opts.sharing {
query = query.arg("sharing", sharing);
}
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-01-30 20:44:48 +01:00
}
2023-02-19 22:38:36 +01:00
/// Retrieves this container plus a directory mounted at the given path.
///
/// # Arguments
///
/// * `path` - Location of the mounted directory (e.g., "/mnt/directory").
/// * `source` - Identifier of the mounted directory.
pub fn with_mounted_directory(
&self,
path: impl Into<String>,
source: DirectoryId,
) -> Container {
let mut query = self.selection.select("withMountedDirectory");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
query = query.arg("source", source);
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-01-30 20:44:48 +01:00
}
2023-02-19 22:38:36 +01:00
/// Retrieves this container plus a file mounted at the given path.
///
/// # Arguments
///
/// * `path` - Location of the mounted file (e.g., "/tmp/file.txt").
/// * `source` - Identifier of the mounted file.
2023-02-22 22:38:15 +01:00
pub fn with_mounted_file(&self, path: impl Into<String>, source: FileId) -> Container {
let mut query = self.selection.select("withMountedFile");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
query = query.arg("source", source);
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-01-30 20:44:48 +01:00
}
2023-02-19 22:38:36 +01:00
/// Retrieves this container plus a secret mounted into a file at the given path.
///
/// # Arguments
///
/// * `path` - Location of the secret file (e.g., "/tmp/secret.txt").
/// * `source` - Identifier of the secret to mount.
2023-02-22 22:38:15 +01:00
pub fn with_mounted_secret(&self, path: impl Into<String>, source: SecretId) -> Container {
let mut query = self.selection.select("withMountedSecret");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
query = query.arg("source", source);
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-01-30 20:44:48 +01:00
}
2023-02-19 22:38:36 +01:00
/// Retrieves this container plus a temporary directory mounted at the given path.
///
/// # Arguments
///
/// * `path` - Location of the temporary directory (e.g., "/tmp/temp_dir").
2023-02-22 22:38:15 +01:00
pub fn with_mounted_temp(&self, path: impl Into<String>) -> Container {
let mut query = self.selection.select("withMountedTemp");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-01-30 20:44:48 +01:00
}
2023-02-19 22:38:36 +01:00
/// Retrieves this container plus a new file written at the given path.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `path` - Location of the written file (e.g., "/tmp/file.txt").
2023-02-22 23:09:20 +01:00
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn with_new_file(&self, path: impl Into<String>) -> Container {
let mut query = self.selection.select("withNewFile");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
2023-02-22 23:09:20 +01:00
2023-02-19 22:38:36 +01:00
/// Retrieves this container plus a new file written at the given path.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `path` - Location of the written file (e.g., "/tmp/file.txt").
2023-02-22 23:09:20 +01:00
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
pub fn with_new_file_opts<'a>(
&self,
path: impl Into<String>,
2023-02-22 22:38:15 +01:00
opts: ContainerWithNewFileOpts<'a>,
) -> Container {
let mut query = self.selection.select("withNewFile");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
if let Some(contents) = opts.contents {
query = query.arg("contents", contents);
}
if let Some(permissions) = opts.permissions {
query = query.arg("permissions", permissions);
}
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-01-30 20:44:48 +01:00
}
2023-02-19 22:38:36 +01:00
/// Retrieves this container with a registry authentication for a given address.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `address` - Registry's address to bind the authentication to.
2023-02-19 22:38:36 +01:00
/// Formatted as [host]/[user]/[repo]:[tag] (e.g. docker.io/dagger/dagger:main).
/// * `username` - The username of the registry's account (e.g., "Dagger").
/// * `secret` - The API key, password or token to authenticate to this registry.
2023-02-19 12:16:48 +01:00
pub fn with_registry_auth(
&self,
address: impl Into<String>,
username: impl Into<String>,
2023-02-19 12:16:48 +01:00
secret: SecretId,
) -> Container {
let mut query = self.selection.select("withRegistryAuth");
2023-02-22 23:09:20 +01:00
query = query.arg("address", address.into());
query = query.arg("username", username.into());
query = query.arg("secret", secret);
2023-02-22 23:09:20 +01:00
2023-02-19 12:16:48 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-19 12:16:48 +01:00
}
2023-02-19 22:38:36 +01:00
/// Initializes this container from this DirectoryID.
2023-02-22 22:38:15 +01:00
pub fn with_rootfs(&self, id: DirectoryId) -> Container {
let mut query = self.selection.select("withRootfs");
2023-02-22 23:09:20 +01:00
query = query.arg("id", id);
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-01 16:42:50 +01:00
}
2023-02-19 22:38:36 +01:00
/// Retrieves this container plus an env variable containing the given secret.
///
/// # Arguments
///
/// * `name` - The name of the secret variable (e.g., "API_SECRET").
/// * `secret` - The identifier of the secret value.
2023-02-22 22:38:15 +01:00
pub fn with_secret_variable(&self, name: impl Into<String>, secret: SecretId) -> Container {
let mut query = self.selection.select("withSecretVariable");
2023-02-22 23:09:20 +01:00
query = query.arg("name", name.into());
query = query.arg("secret", secret);
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-01 16:42:50 +01:00
}
/// Establish a runtime dependency on a service. The service will be started automatically when needed and detached when it is no longer needed.
/// The service will be reachable from the container via the provided hostname alias.
/// The service dependency will also convey to any files or directories produced by the container.
///
/// # Arguments
///
/// * `alias` - A name that can be used to reach the service from the container
/// * `service` - Identifier of the service container
pub fn with_service_binding(
&self,
alias: impl Into<String>,
service: ContainerId,
) -> Container {
let mut query = self.selection.select("withServiceBinding");
query = query.arg("alias", alias.into());
query = query.arg("service", service);
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
};
}
2023-02-19 22:38:36 +01:00
/// Retrieves this container plus a socket forwarded to the given Unix socket path.
///
/// # Arguments
///
/// * `path` - Location of the forwarded Unix socket (e.g., "/tmp/socket").
/// * `source` - Identifier of the socket to forward.
2023-02-22 22:38:15 +01:00
pub fn with_unix_socket(&self, path: impl Into<String>, source: SocketId) -> Container {
let mut query = self.selection.select("withUnixSocket");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
query = query.arg("source", source);
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-01 16:42:50 +01:00
}
/// Retrieves this container with a different command user.
///
/// # Arguments
///
/// * `name` - The user to set (e.g., "root").
2023-02-22 22:38:15 +01:00
pub fn with_user(&self, name: impl Into<String>) -> Container {
let mut query = self.selection.select("withUser");
2023-02-22 23:09:20 +01:00
query = query.arg("name", name.into());
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-01 16:42:50 +01:00
}
2023-02-19 22:38:36 +01:00
/// Retrieves this container with a different working directory.
///
/// # Arguments
///
/// * `path` - The path to set as the working directory (e.g., "/app").
2023-02-22 22:38:15 +01:00
pub fn with_workdir(&self, path: impl Into<String>) -> Container {
let mut query = self.selection.select("withWorkdir");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-01 16:42:50 +01:00
}
2023-02-19 22:38:36 +01:00
/// Retrieves this container minus the given environment variable.
///
/// # Arguments
///
/// * `name` - The name of the environment variable (e.g., "HOST").
2023-02-22 22:38:15 +01:00
pub fn without_env_variable(&self, name: impl Into<String>) -> Container {
let mut query = self.selection.select("withoutEnvVariable");
2023-02-22 23:09:20 +01:00
query = query.arg("name", name.into());
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-01 16:42:50 +01:00
}
/// Unexpose a previously exposed port.
///
/// # Arguments
///
/// * `port` - Port number to unexpose
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
pub fn without_exposed_port(&self, port: isize) -> Container {
let mut query = self.selection.select("withoutExposedPort");
query = query.arg("port", port);
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
};
}
/// Unexpose a previously exposed port.
///
/// # Arguments
///
/// * `port` - Port number to unexpose
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
pub fn without_exposed_port_opts(
&self,
port: isize,
opts: ContainerWithoutExposedPortOpts,
) -> Container {
let mut query = self.selection.select("withoutExposedPort");
query = query.arg("port", port);
if let Some(protocol) = opts.protocol {
query = query.arg("protocol", protocol);
}
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
};
}
2023-02-19 22:38:36 +01:00
/// Retrieves this container minus the given environment label.
///
/// # Arguments
///
/// * `name` - The name of the label to remove (e.g., "org.opencontainers.artifact.created").
2023-02-22 22:38:15 +01:00
pub fn without_label(&self, name: impl Into<String>) -> Container {
let mut query = self.selection.select("withoutLabel");
2023-02-22 23:09:20 +01:00
query = query.arg("name", name.into());
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-01 16:42:50 +01:00
}
2023-02-19 22:38:36 +01:00
/// Retrieves this container after unmounting everything at the given path.
///
/// # Arguments
///
/// * `path` - Location of the cache directory (e.g., "/cache/node_modules").
2023-02-22 22:38:15 +01:00
pub fn without_mount(&self, path: impl Into<String>) -> Container {
let mut query = self.selection.select("withoutMount");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-01 16:42:50 +01:00
}
2023-02-19 22:38:36 +01:00
/// Retrieves this container without the registry authentication of a given address.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `address` - Registry's address to remove the authentication from.
2023-02-19 22:38:36 +01:00
/// Formatted as [host]/[user]/[repo]:[tag] (e.g. docker.io/dagger/dagger:main).
2023-02-22 22:38:15 +01:00
pub fn without_registry_auth(&self, address: impl Into<String>) -> Container {
2023-02-19 12:16:48 +01:00
let mut query = self.selection.select("withoutRegistryAuth");
2023-02-22 23:09:20 +01:00
query = query.arg("address", address.into());
2023-02-22 23:09:20 +01:00
2023-02-19 12:16:48 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-19 12:16:48 +01:00
}
2023-02-19 22:38:36 +01:00
/// Retrieves this container with a previously added Unix socket removed.
///
/// # Arguments
///
/// * `path` - Location of the socket to remove (e.g., "/tmp/socket").
2023-02-22 22:38:15 +01:00
pub fn without_unix_socket(&self, path: impl Into<String>) -> Container {
let mut query = self.selection.select("withoutUnixSocket");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-01 16:42:50 +01:00
}
2023-02-19 22:38:36 +01:00
/// Retrieves the working directory for all commands.
2023-02-22 22:38:15 +01:00
pub async fn workdir(&self) -> eyre::Result<String> {
let mut query = self.selection.select("workdir");
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
2023-02-01 16:42:50 +01:00
}
}
2023-02-22 22:38:15 +01:00
#[derive(Debug, Clone)]
pub struct Directory {
pub proc: Arc<Child>,
pub selection: Selection,
pub conn: ConnectParams,
}
2023-02-22 23:09:20 +01:00
#[derive(Builder, Debug, PartialEq)]
pub struct DirectoryDockerBuildOpts<'a> {
/// Path to the Dockerfile to use (e.g., "frontend.Dockerfile").
/// Defaults: './Dockerfile'.
#[builder(setter(into, strip_option))]
pub dockerfile: Option<&'a str>,
2023-02-19 22:38:36 +01:00
/// The platform to build.
#[builder(setter(into, strip_option))]
pub platform: Option<Platform>,
/// Build arguments to use in the build.
#[builder(setter(into, strip_option))]
pub build_args: Option<Vec<BuildArg>>,
2023-02-19 22:38:36 +01:00
/// Target build stage to build.
#[builder(setter(into, strip_option))]
pub target: Option<&'a str>,
}
#[derive(Builder, Debug, PartialEq)]
pub struct DirectoryEntriesOpts<'a> {
/// Location of the directory to look at (e.g., "/src").
#[builder(setter(into, strip_option))]
pub path: Option<&'a str>,
}
#[derive(Builder, Debug, PartialEq)]
pub struct DirectoryPipelineOpts<'a> {
#[builder(setter(into, strip_option))]
pub description: Option<&'a str>,
}
#[derive(Builder, Debug, PartialEq)]
pub struct DirectoryWithDirectoryOpts<'a> {
/// Exclude artifacts that match the given pattern (e.g., ["node_modules/", ".git*"]).
#[builder(setter(into, strip_option))]
pub exclude: Option<Vec<&'a str>>,
/// Include only artifacts that match the given pattern (e.g., ["app/", "package.*"]).
#[builder(setter(into, strip_option))]
pub include: Option<Vec<&'a str>>,
}
#[derive(Builder, Debug, PartialEq)]
2023-02-19 17:29:59 +01:00
pub struct DirectoryWithFileOpts {
/// Permission given to the copied file (e.g., 0600).
/// Default: 0644.
#[builder(setter(into, strip_option))]
pub permissions: Option<isize>,
}
#[derive(Builder, Debug, PartialEq)]
2023-02-19 17:29:59 +01:00
pub struct DirectoryWithNewDirectoryOpts {
/// Permission granted to the created directory (e.g., 0777).
/// Default: 0755.
#[builder(setter(into, strip_option))]
pub permissions: Option<isize>,
}
#[derive(Builder, Debug, PartialEq)]
2023-02-19 17:29:59 +01:00
pub struct DirectoryWithNewFileOpts {
/// Permission given to the copied file (e.g., 0600).
/// Default: 0644.
#[builder(setter(into, strip_option))]
pub permissions: Option<isize>,
}
2023-02-22 23:09:20 +01:00
2023-02-01 16:42:50 +01:00
impl Directory {
2023-02-19 22:38:36 +01:00
/// Gets the difference between this directory and an another directory.
///
/// # Arguments
///
/// * `other` - Identifier of the directory to compare.
2023-02-22 22:38:15 +01:00
pub fn diff(&self, other: DirectoryId) -> Directory {
let mut query = self.selection.select("diff");
2023-02-22 23:09:20 +01:00
query = query.arg("other", other);
2023-02-22 23:09:20 +01:00
return Directory {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-01 16:42:50 +01:00
}
2023-02-19 22:38:36 +01:00
/// Retrieves a directory at the given path.
///
/// # Arguments
///
/// * `path` - Location of the directory to retrieve (e.g., "/src").
2023-02-22 22:38:15 +01:00
pub fn directory(&self, path: impl Into<String>) -> Directory {
let mut query = self.selection.select("directory");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
2023-02-22 23:09:20 +01:00
return Directory {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-01 16:42:50 +01:00
}
2023-02-19 22:38:36 +01:00
/// Builds a new Docker container from this directory.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn docker_build(&self) -> Container {
let mut query = self.selection.select("dockerBuild");
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
2023-02-22 23:09:20 +01:00
2023-02-19 22:38:36 +01:00
/// Builds a new Docker container from this directory.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn docker_build_opts<'a>(&self, opts: DirectoryDockerBuildOpts<'a>) -> Container {
let mut query = self.selection.select("dockerBuild");
2023-02-22 23:09:20 +01:00
if let Some(dockerfile) = opts.dockerfile {
query = query.arg("dockerfile", dockerfile);
}
if let Some(platform) = opts.platform {
query = query.arg("platform", platform);
}
if let Some(build_args) = opts.build_args {
query = query.arg("buildArgs", build_args);
}
if let Some(target) = opts.target {
query = query.arg("target", target);
}
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-01 16:42:50 +01:00
}
2023-02-19 22:38:36 +01:00
/// Returns a list of files and directories at the given path.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub async fn entries(&self) -> eyre::Result<Vec<String>> {
let mut query = self.selection.select("entries");
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
}
2023-02-22 23:09:20 +01:00
2023-02-19 22:38:36 +01:00
/// Returns a list of files and directories at the given path.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
pub async fn entries_opts<'a>(
&self,
2023-02-22 22:38:15 +01:00
opts: DirectoryEntriesOpts<'a>,
) -> eyre::Result<Vec<String>> {
let mut query = self.selection.select("entries");
2023-02-22 23:09:20 +01:00
if let Some(path) = opts.path {
query = query.arg("path", path);
}
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
2023-02-01 16:42:50 +01:00
}
2023-02-19 22:38:36 +01:00
/// Writes the contents of the directory to a path on the host.
///
/// # Arguments
///
/// * `path` - Location of the copied directory (e.g., "logs/").
2023-02-22 22:38:15 +01:00
pub async fn export(&self, path: impl Into<String>) -> eyre::Result<bool> {
let mut query = self.selection.select("export");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
2023-02-01 16:42:50 +01:00
}
2023-02-19 22:38:36 +01:00
/// Retrieves a file at the given path.
///
/// # Arguments
///
/// * `path` - Location of the file to retrieve (e.g., "README.md").
2023-02-22 22:38:15 +01:00
pub fn file(&self, path: impl Into<String>) -> File {
let mut query = self.selection.select("file");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
2023-02-22 23:09:20 +01:00
return File {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-01 16:42:50 +01:00
}
2023-02-19 22:38:36 +01:00
/// The content-addressed identifier of the directory.
2023-02-22 22:38:15 +01:00
pub async fn id(&self) -> eyre::Result<DirectoryId> {
let mut query = self.selection.select("id");
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
2023-02-01 16:42:50 +01:00
}
2023-02-19 22:38:36 +01:00
/// load a project's metadata
2023-02-22 22:38:15 +01:00
pub fn load_project(&self, config_path: impl Into<String>) -> Project {
let mut query = self.selection.select("loadProject");
2023-02-22 23:09:20 +01:00
query = query.arg("configPath", config_path.into());
2023-02-22 23:09:20 +01:00
return Project {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-01 16:42:50 +01:00
}
2023-02-19 22:38:36 +01:00
/// Creates a named sub-pipeline.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn pipeline(&self, name: impl Into<String>) -> Directory {
let mut query = self.selection.select("pipeline");
2023-02-22 23:09:20 +01:00
query = query.arg("name", name.into());
2023-02-22 23:09:20 +01:00
return Directory {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
2023-02-22 23:09:20 +01:00
2023-02-19 22:38:36 +01:00
/// Creates a named sub-pipeline.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
pub fn pipeline_opts<'a>(
&self,
name: impl Into<String>,
2023-02-22 22:38:15 +01:00
opts: DirectoryPipelineOpts<'a>,
) -> Directory {
let mut query = self.selection.select("pipeline");
2023-02-22 23:09:20 +01:00
query = query.arg("name", name.into());
if let Some(description) = opts.description {
query = query.arg("description", description);
}
2023-02-22 23:09:20 +01:00
return Directory {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
2023-02-19 22:38:36 +01:00
/// Retrieves this directory plus a directory written at the given path.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `path` - Location of the written directory (e.g., "/src/").
/// * `directory` - Identifier of the directory to copy.
2023-02-22 23:09:20 +01:00
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn with_directory(&self, path: impl Into<String>, directory: DirectoryId) -> Directory {
let mut query = self.selection.select("withDirectory");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
query = query.arg("directory", directory);
2023-02-22 23:09:20 +01:00
return Directory {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
2023-02-22 23:09:20 +01:00
2023-02-19 22:38:36 +01:00
/// Retrieves this directory plus a directory written at the given path.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `path` - Location of the written directory (e.g., "/src/").
/// * `directory` - Identifier of the directory to copy.
2023-02-22 23:09:20 +01:00
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
pub fn with_directory_opts<'a>(
2023-02-01 16:42:50 +01:00
&self,
path: impl Into<String>,
directory: DirectoryId,
2023-02-22 22:38:15 +01:00
opts: DirectoryWithDirectoryOpts<'a>,
2023-02-01 16:42:50 +01:00
) -> Directory {
let mut query = self.selection.select("withDirectory");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
query = query.arg("directory", directory);
if let Some(exclude) = opts.exclude {
query = query.arg("exclude", exclude);
}
if let Some(include) = opts.include {
query = query.arg("include", include);
}
2023-02-22 23:09:20 +01:00
return Directory {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
2023-02-19 22:38:36 +01:00
/// Retrieves this directory plus the contents of the given file copied to the given path.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `path` - Location of the copied file (e.g., "/file.txt").
/// * `source` - Identifier of the file to copy.
2023-02-22 23:09:20 +01:00
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn with_file(&self, path: impl Into<String>, source: FileId) -> Directory {
let mut query = self.selection.select("withFile");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
query = query.arg("source", source);
2023-02-22 23:09:20 +01:00
return Directory {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
2023-02-22 23:09:20 +01:00
2023-02-19 22:38:36 +01:00
/// Retrieves this directory plus the contents of the given file copied to the given path.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `path` - Location of the copied file (e.g., "/file.txt").
/// * `source` - Identifier of the file to copy.
2023-02-22 23:09:20 +01:00
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
pub fn with_file_opts(
2023-02-05 23:44:06 +01:00
&self,
path: impl Into<String>,
source: FileId,
2023-02-22 22:38:15 +01:00
opts: DirectoryWithFileOpts,
2023-02-05 23:44:06 +01:00
) -> Directory {
let mut query = self.selection.select("withFile");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
query = query.arg("source", source);
if let Some(permissions) = opts.permissions {
query = query.arg("permissions", permissions);
}
2023-02-22 23:09:20 +01:00
return Directory {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-01 16:42:50 +01:00
}
2023-02-19 22:38:36 +01:00
/// Retrieves this directory plus a new directory created at the given path.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `path` - Location of the directory created (e.g., "/logs").
2023-02-22 23:09:20 +01:00
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn with_new_directory(&self, path: impl Into<String>) -> Directory {
let mut query = self.selection.select("withNewDirectory");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
2023-02-22 23:09:20 +01:00
return Directory {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
2023-02-22 23:09:20 +01:00
2023-02-19 22:38:36 +01:00
/// Retrieves this directory plus a new directory created at the given path.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `path` - Location of the directory created (e.g., "/logs").
2023-02-22 23:09:20 +01:00
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
pub fn with_new_directory_opts(
&self,
path: impl Into<String>,
2023-02-22 22:38:15 +01:00
opts: DirectoryWithNewDirectoryOpts,
) -> Directory {
let mut query = self.selection.select("withNewDirectory");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
if let Some(permissions) = opts.permissions {
query = query.arg("permissions", permissions);
}
2023-02-22 23:09:20 +01:00
return Directory {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
2023-02-19 22:38:36 +01:00
/// Retrieves this directory plus a new file written at the given path.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `path` - Location of the written file (e.g., "/file.txt").
/// * `contents` - Content of the written file (e.g., "Hello world!").
2023-02-22 23:09:20 +01:00
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn with_new_file(&self, path: impl Into<String>, contents: impl Into<String>) -> Directory {
let mut query = self.selection.select("withNewFile");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
query = query.arg("contents", contents.into());
2023-02-22 23:09:20 +01:00
return Directory {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
2023-02-22 23:09:20 +01:00
2023-02-19 22:38:36 +01:00
/// Retrieves this directory plus a new file written at the given path.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `path` - Location of the written file (e.g., "/file.txt").
/// * `contents` - Content of the written file (e.g., "Hello world!").
2023-02-22 23:09:20 +01:00
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
pub fn with_new_file_opts(
2023-02-01 16:42:50 +01:00
&self,
path: impl Into<String>,
contents: impl Into<String>,
2023-02-22 22:38:15 +01:00
opts: DirectoryWithNewFileOpts,
2023-02-01 16:42:50 +01:00
) -> Directory {
let mut query = self.selection.select("withNewFile");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
query = query.arg("contents", contents.into());
if let Some(permissions) = opts.permissions {
query = query.arg("permissions", permissions);
}
2023-02-22 23:09:20 +01:00
return Directory {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-01 16:42:50 +01:00
}
/// Retrieves this directory with all file/dir timestamps set to the given time.
///
/// # Arguments
///
/// * `timestamp` - Timestamp to set dir/files in.
///
/// Formatted in seconds following Unix epoch (e.g., 1672531199).
2023-02-22 22:38:15 +01:00
pub fn with_timestamps(&self, timestamp: isize) -> Directory {
let mut query = self.selection.select("withTimestamps");
2023-02-22 23:09:20 +01:00
query = query.arg("timestamp", timestamp);
2023-02-22 23:09:20 +01:00
return Directory {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-01-30 20:44:48 +01:00
}
2023-02-19 22:38:36 +01:00
/// Retrieves this directory with the directory at the given path removed.
///
/// # Arguments
///
/// * `path` - Location of the directory to remove (e.g., ".github/").
2023-02-22 22:38:15 +01:00
pub fn without_directory(&self, path: impl Into<String>) -> Directory {
let mut query = self.selection.select("withoutDirectory");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
2023-02-22 23:09:20 +01:00
return Directory {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-01-30 20:44:48 +01:00
}
2023-02-19 22:38:36 +01:00
/// Retrieves this directory with the file at the given path removed.
///
/// # Arguments
///
/// * `path` - Location of the file to remove (e.g., "/file.txt").
2023-02-22 22:38:15 +01:00
pub fn without_file(&self, path: impl Into<String>) -> Directory {
let mut query = self.selection.select("withoutFile");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
2023-02-22 23:09:20 +01:00
return Directory {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
}
2023-02-22 22:38:15 +01:00
#[derive(Debug, Clone)]
pub struct EnvVariable {
pub proc: Arc<Child>,
pub selection: Selection,
pub conn: ConnectParams,
}
2023-02-22 23:09:20 +01:00
2023-02-01 16:42:50 +01:00
impl EnvVariable {
2023-02-19 22:38:36 +01:00
/// The environment variable name.
2023-02-22 22:38:15 +01:00
pub async fn name(&self) -> eyre::Result<String> {
let mut query = self.selection.select("name");
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
}
2023-02-19 22:38:36 +01:00
/// The environment variable value.
2023-02-22 22:38:15 +01:00
pub async fn value(&self) -> eyre::Result<String> {
let mut query = self.selection.select("value");
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
2023-01-30 20:44:48 +01:00
}
2023-02-01 16:42:50 +01:00
}
2023-02-22 22:38:15 +01:00
#[derive(Debug, Clone)]
pub struct File {
pub proc: Arc<Child>,
pub selection: Selection,
pub conn: ConnectParams,
}
2023-02-22 23:09:20 +01:00
2023-02-01 16:42:50 +01:00
impl File {
2023-02-19 22:38:36 +01:00
/// Retrieves the contents of the file.
2023-02-22 22:38:15 +01:00
pub async fn contents(&self) -> eyre::Result<String> {
let mut query = self.selection.select("contents");
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
2023-01-30 20:44:48 +01:00
}
2023-02-19 22:38:36 +01:00
/// Writes the file to a file path on the host.
///
/// # Arguments
///
/// * `path` - Location of the written directory (e.g., "output.txt").
2023-02-22 22:38:15 +01:00
pub async fn export(&self, path: impl Into<String>) -> eyre::Result<bool> {
let mut query = self.selection.select("export");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
2023-01-30 20:44:48 +01:00
}
2023-02-19 22:38:36 +01:00
/// Retrieves the content-addressed identifier of the file.
2023-02-22 22:38:15 +01:00
pub async fn id(&self) -> eyre::Result<FileId> {
let mut query = self.selection.select("id");
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
}
2023-02-19 22:38:36 +01:00
/// Retrieves a secret referencing the contents of this file.
2023-02-22 22:38:15 +01:00
pub fn secret(&self) -> Secret {
let mut query = self.selection.select("secret");
2023-02-22 23:09:20 +01:00
return Secret {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-01 16:34:59 +01:00
}
2023-02-19 22:38:36 +01:00
/// Gets the size of the file, in bytes.
2023-02-22 22:38:15 +01:00
pub async fn size(&self) -> eyre::Result<isize> {
let mut query = self.selection.select("size");
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
2023-01-30 20:44:48 +01:00
}
/// Retrieves this file with its created/modified timestamps set to the given time.
///
/// # Arguments
///
/// * `timestamp` - Timestamp to set dir/files in.
///
/// Formatted in seconds following Unix epoch (e.g., 1672531199).
2023-02-22 22:38:15 +01:00
pub fn with_timestamps(&self, timestamp: isize) -> File {
let mut query = self.selection.select("withTimestamps");
2023-02-22 23:09:20 +01:00
query = query.arg("timestamp", timestamp);
2023-02-22 23:09:20 +01:00
return File {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-01-30 20:44:48 +01:00
}
2023-02-01 15:32:38 +01:00
}
2023-02-22 22:38:15 +01:00
#[derive(Debug, Clone)]
pub struct GitRef {
pub proc: Arc<Child>,
pub selection: Selection,
pub conn: ConnectParams,
}
2023-02-22 23:09:20 +01:00
#[derive(Builder, Debug, PartialEq)]
pub struct GitRefTreeOpts<'a> {
#[builder(setter(into, strip_option))]
pub ssh_known_hosts: Option<&'a str>,
#[builder(setter(into, strip_option))]
pub ssh_auth_socket: Option<SocketId>,
}
2023-02-22 23:09:20 +01:00
2023-02-01 16:34:59 +01:00
impl GitRef {
2023-02-19 22:38:36 +01:00
/// The digest of the current value of this ref.
2023-02-22 22:38:15 +01:00
pub async fn digest(&self) -> eyre::Result<String> {
let mut query = self.selection.select("digest");
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
2023-01-30 20:44:48 +01:00
}
2023-02-19 22:38:36 +01:00
/// The filesystem tree at this ref.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn tree(&self) -> Directory {
let mut query = self.selection.select("tree");
2023-02-22 23:09:20 +01:00
return Directory {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
2023-02-22 23:09:20 +01:00
2023-02-19 22:38:36 +01:00
/// The filesystem tree at this ref.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn tree_opts<'a>(&self, opts: GitRefTreeOpts<'a>) -> Directory {
let mut query = self.selection.select("tree");
2023-02-22 23:09:20 +01:00
if let Some(ssh_known_hosts) = opts.ssh_known_hosts {
query = query.arg("sshKnownHosts", ssh_known_hosts);
}
if let Some(ssh_auth_socket) = opts.ssh_auth_socket {
query = query.arg("sshAuthSocket", ssh_auth_socket);
}
2023-02-22 23:09:20 +01:00
return Directory {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-01-30 20:44:48 +01:00
}
2023-02-01 16:34:59 +01:00
}
2023-02-22 22:38:15 +01:00
#[derive(Debug, Clone)]
pub struct GitRepository {
pub proc: Arc<Child>,
pub selection: Selection,
pub conn: ConnectParams,
}
2023-02-22 23:09:20 +01:00
impl GitRepository {
2023-02-19 22:38:36 +01:00
/// Returns details on one branch.
///
/// # Arguments
///
/// * `name` - Branch's name (e.g., "main").
2023-02-22 22:38:15 +01:00
pub fn branch(&self, name: impl Into<String>) -> GitRef {
let mut query = self.selection.select("branch");
2023-02-22 23:09:20 +01:00
query = query.arg("name", name.into());
2023-02-22 23:09:20 +01:00
return GitRef {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-01-30 20:44:48 +01:00
}
2023-02-19 22:38:36 +01:00
/// Lists of branches on the repository.
2023-02-22 22:38:15 +01:00
pub async fn branches(&self) -> eyre::Result<Vec<String>> {
let mut query = self.selection.select("branches");
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
2023-02-01 16:42:50 +01:00
}
2023-02-19 22:38:36 +01:00
/// Returns details on one commit.
///
/// # Arguments
///
/// * `id` - Identifier of the commit (e.g., "b6315d8f2810962c601af73f86831f6866ea798b").
2023-02-22 22:38:15 +01:00
pub fn commit(&self, id: impl Into<String>) -> GitRef {
let mut query = self.selection.select("commit");
2023-02-22 23:09:20 +01:00
query = query.arg("id", id.into());
2023-02-22 23:09:20 +01:00
return GitRef {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-01 16:42:50 +01:00
}
2023-02-19 22:38:36 +01:00
/// Returns details on one tag.
///
/// # Arguments
///
/// * `name` - Tag's name (e.g., "v0.3.9").
2023-02-22 22:38:15 +01:00
pub fn tag(&self, name: impl Into<String>) -> GitRef {
let mut query = self.selection.select("tag");
2023-02-22 23:09:20 +01:00
query = query.arg("name", name.into());
2023-02-22 23:09:20 +01:00
return GitRef {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
2023-02-19 22:38:36 +01:00
/// Lists of tags on the repository.
2023-02-22 22:38:15 +01:00
pub async fn tags(&self) -> eyre::Result<Vec<String>> {
let mut query = self.selection.select("tags");
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
2023-01-30 20:44:48 +01:00
}
2023-02-01 16:34:59 +01:00
}
2023-02-22 22:38:15 +01:00
#[derive(Debug, Clone)]
pub struct Host {
pub proc: Arc<Child>,
pub selection: Selection,
pub conn: ConnectParams,
}
2023-02-22 23:09:20 +01:00
#[derive(Builder, Debug, PartialEq)]
pub struct HostDirectoryOpts<'a> {
/// Exclude artifacts that match the given pattern (e.g., ["node_modules/", ".git*"]).
#[builder(setter(into, strip_option))]
pub exclude: Option<Vec<&'a str>>,
/// Include only artifacts that match the given pattern (e.g., ["app/", "package.*"]).
#[builder(setter(into, strip_option))]
pub include: Option<Vec<&'a str>>,
}
#[derive(Builder, Debug, PartialEq)]
pub struct HostWorkdirOpts<'a> {
/// Exclude artifacts that match the given pattern (e.g., ["node_modules/", ".git*"]).
#[builder(setter(into, strip_option))]
pub exclude: Option<Vec<&'a str>>,
/// Include only artifacts that match the given pattern (e.g., ["app/", "package.*"]).
#[builder(setter(into, strip_option))]
pub include: Option<Vec<&'a str>>,
}
2023-02-22 23:09:20 +01:00
2023-02-01 16:34:59 +01:00
impl Host {
2023-02-19 22:38:36 +01:00
/// Accesses a directory on the host.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `path` - Location of the directory to access (e.g., ".").
2023-02-22 23:09:20 +01:00
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn directory(&self, path: impl Into<String>) -> Directory {
let mut query = self.selection.select("directory");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
2023-02-22 23:09:20 +01:00
return Directory {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
2023-02-22 23:09:20 +01:00
2023-02-19 22:38:36 +01:00
/// Accesses a directory on the host.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `path` - Location of the directory to access (e.g., ".").
2023-02-22 23:09:20 +01:00
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
pub fn directory_opts<'a>(
&self,
path: impl Into<String>,
2023-02-22 22:38:15 +01:00
opts: HostDirectoryOpts<'a>,
) -> Directory {
let mut query = self.selection.select("directory");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
if let Some(exclude) = opts.exclude {
query = query.arg("exclude", exclude);
}
if let Some(include) = opts.include {
query = query.arg("include", include);
}
2023-02-22 23:09:20 +01:00
return Directory {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-01-30 20:44:48 +01:00
}
2023-02-19 22:38:36 +01:00
/// Accesses an environment variable on the host.
///
/// # Arguments
///
/// * `name` - Name of the environment variable (e.g., "PATH").
2023-02-22 22:38:15 +01:00
pub fn env_variable(&self, name: impl Into<String>) -> HostVariable {
let mut query = self.selection.select("envVariable");
2023-02-22 23:09:20 +01:00
query = query.arg("name", name.into());
2023-02-22 23:09:20 +01:00
return HostVariable {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-01-30 20:44:48 +01:00
}
2023-02-19 22:38:36 +01:00
/// Accesses a Unix socket on the host.
///
/// # Arguments
///
/// * `path` - Location of the Unix socket (e.g., "/var/run/docker.sock").
2023-02-22 22:38:15 +01:00
pub fn unix_socket(&self, path: impl Into<String>) -> Socket {
let mut query = self.selection.select("unixSocket");
2023-02-22 23:09:20 +01:00
query = query.arg("path", path.into());
2023-02-22 23:09:20 +01:00
return Socket {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-01-30 20:44:48 +01:00
}
2023-02-19 22:38:36 +01:00
/// Retrieves the current working directory on the host.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn workdir(&self) -> Directory {
let mut query = self.selection.select("workdir");
2023-02-22 23:09:20 +01:00
return Directory {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
2023-02-22 23:09:20 +01:00
2023-02-19 22:38:36 +01:00
/// Retrieves the current working directory on the host.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn workdir_opts<'a>(&self, opts: HostWorkdirOpts<'a>) -> Directory {
let mut query = self.selection.select("workdir");
2023-02-22 23:09:20 +01:00
if let Some(exclude) = opts.exclude {
query = query.arg("exclude", exclude);
}
if let Some(include) = opts.include {
query = query.arg("include", include);
}
2023-02-22 23:09:20 +01:00
return Directory {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
}
2023-02-22 22:38:15 +01:00
#[derive(Debug, Clone)]
pub struct HostVariable {
pub proc: Arc<Child>,
pub selection: Selection,
pub conn: ConnectParams,
}
2023-02-22 23:09:20 +01:00
2023-02-01 16:42:50 +01:00
impl HostVariable {
2023-02-19 22:38:36 +01:00
/// A secret referencing the value of this variable.
2023-02-22 22:38:15 +01:00
pub fn secret(&self) -> Secret {
let mut query = self.selection.select("secret");
2023-02-22 23:09:20 +01:00
return Secret {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
2023-02-19 22:38:36 +01:00
/// The value of this variable.
2023-02-22 22:38:15 +01:00
pub async fn value(&self) -> eyre::Result<String> {
let mut query = self.selection.select("value");
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
2023-01-30 20:44:48 +01:00
}
2023-02-01 15:32:38 +01:00
}
2023-02-22 22:38:15 +01:00
#[derive(Debug, Clone)]
pub struct Label {
pub proc: Arc<Child>,
pub selection: Selection,
pub conn: ConnectParams,
}
2023-02-22 23:09:20 +01:00
2023-02-01 16:42:50 +01:00
impl Label {
2023-02-19 22:38:36 +01:00
/// The label name.
2023-02-22 22:38:15 +01:00
pub async fn name(&self) -> eyre::Result<String> {
let mut query = self.selection.select("name");
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
}
2023-02-19 22:38:36 +01:00
/// The label value.
2023-02-22 22:38:15 +01:00
pub async fn value(&self) -> eyre::Result<String> {
let mut query = self.selection.select("value");
query.execute(&graphql_client(&self.conn)).await
}
}
#[derive(Debug, Clone)]
pub struct Port {
pub proc: Arc<Child>,
pub selection: Selection,
pub conn: ConnectParams,
}
impl Port {
/// The port description.
pub async fn description(&self) -> eyre::Result<String> {
let mut query = self.selection.select("description");
query.execute(&graphql_client(&self.conn)).await
}
/// The port number.
pub async fn port(&self) -> eyre::Result<isize> {
let mut query = self.selection.select("port");
query.execute(&graphql_client(&self.conn)).await
}
/// The transport layer network protocol.
pub async fn protocol(&self) -> eyre::Result<NetworkProtocol> {
let mut query = self.selection.select("protocol");
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
2023-01-30 20:44:48 +01:00
}
2023-02-01 16:42:50 +01:00
}
2023-02-22 22:38:15 +01:00
#[derive(Debug, Clone)]
pub struct Project {
pub proc: Arc<Child>,
pub selection: Selection,
pub conn: ConnectParams,
}
2023-02-22 23:09:20 +01:00
2023-02-01 16:42:50 +01:00
impl Project {
2023-02-19 22:38:36 +01:00
/// extensions in this project
2023-02-22 22:38:15 +01:00
pub fn extensions(&self) -> Vec<Project> {
let mut query = self.selection.select("extensions");
2023-02-22 23:09:20 +01:00
return vec![Project {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
}];
2023-02-01 16:34:59 +01:00
}
2023-02-19 22:38:36 +01:00
/// Code files generated by the SDKs in the project
2023-02-22 22:38:15 +01:00
pub fn generated_code(&self) -> Directory {
let mut query = self.selection.select("generatedCode");
2023-02-22 23:09:20 +01:00
return Directory {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-01 16:42:50 +01:00
}
2023-02-19 22:38:36 +01:00
/// install the project's schema
2023-02-22 22:38:15 +01:00
pub async fn install(&self) -> eyre::Result<bool> {
let mut query = self.selection.select("install");
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
}
2023-02-19 22:38:36 +01:00
/// name of the project
2023-02-22 22:38:15 +01:00
pub async fn name(&self) -> eyre::Result<String> {
let mut query = self.selection.select("name");
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
2023-02-01 16:42:50 +01:00
}
2023-02-19 22:38:36 +01:00
/// schema provided by the project
2023-02-22 22:38:15 +01:00
pub async fn schema(&self) -> eyre::Result<String> {
let mut query = self.selection.select("schema");
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
2023-02-01 16:42:50 +01:00
}
2023-02-19 22:38:36 +01:00
/// sdk used to generate code for and/or execute this project
2023-02-22 22:38:15 +01:00
pub async fn sdk(&self) -> eyre::Result<String> {
let mut query = self.selection.select("sdk");
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
2023-01-30 20:44:48 +01:00
}
}
2023-02-22 22:38:15 +01:00
#[derive(Debug, Clone)]
2023-02-05 23:44:06 +01:00
pub struct Query {
pub proc: Arc<Child>,
pub selection: Selection,
pub conn: ConnectParams,
}
2023-02-22 23:09:20 +01:00
#[derive(Builder, Debug, PartialEq)]
2023-02-19 17:29:59 +01:00
pub struct QueryContainerOpts {
#[builder(setter(into, strip_option))]
pub id: Option<ContainerId>,
#[builder(setter(into, strip_option))]
pub platform: Option<Platform>,
}
#[derive(Builder, Debug, PartialEq)]
2023-02-19 17:29:59 +01:00
pub struct QueryDirectoryOpts {
#[builder(setter(into, strip_option))]
pub id: Option<DirectoryId>,
}
#[derive(Builder, Debug, PartialEq)]
2023-02-19 17:29:59 +01:00
pub struct QueryGitOpts {
/// Set to true to keep .git directory.
#[builder(setter(into, strip_option))]
pub keep_git_dir: Option<bool>,
/// A service which must be started before the repo is fetched.
#[builder(setter(into, strip_option))]
pub experimental_service_host: Option<ContainerId>,
}
#[derive(Builder, Debug, PartialEq)]
pub struct QueryHttpOpts {
/// A service which must be started before the URL is fetched.
#[builder(setter(into, strip_option))]
pub experimental_service_host: Option<ContainerId>,
}
#[derive(Builder, Debug, PartialEq)]
pub struct QueryPipelineOpts<'a> {
#[builder(setter(into, strip_option))]
pub description: Option<&'a str>,
}
#[derive(Builder, Debug, PartialEq)]
2023-02-19 17:29:59 +01:00
pub struct QuerySocketOpts {
#[builder(setter(into, strip_option))]
pub id: Option<SocketId>,
2023-02-05 23:44:06 +01:00
}
2023-02-22 23:09:20 +01:00
2023-02-01 16:42:50 +01:00
impl Query {
2023-02-19 22:38:36 +01:00
/// Constructs a cache volume for a given cache key.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `key` - A string identifier to target this cache volume (e.g., "modules-cache").
2023-02-22 22:38:15 +01:00
pub fn cache_volume(&self, key: impl Into<String>) -> CacheVolume {
let mut query = self.selection.select("cacheVolume");
2023-02-22 23:09:20 +01:00
query = query.arg("key", key.into());
2023-02-22 23:09:20 +01:00
return CacheVolume {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-01 16:42:50 +01:00
}
2023-02-19 22:38:36 +01:00
/// Loads a container from ID.
/// Null ID returns an empty container (scratch).
/// Optional platform argument initializes new containers to execute and publish as that platform.
/// Platform defaults to that of the builder's host.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn container(&self) -> Container {
let mut query = self.selection.select("container");
2023-02-22 23:09:20 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
2023-02-22 23:09:20 +01:00
2023-02-19 22:38:36 +01:00
/// Loads a container from ID.
/// Null ID returns an empty container (scratch).
/// Optional platform argument initializes new containers to execute and publish as that platform.
/// Platform defaults to that of the builder's host.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn container_opts(&self, opts: QueryContainerOpts) -> Container {
let mut query = self.selection.select("container");
2023-02-22 23:09:20 +01:00
if let Some(id) = opts.id {
query = query.arg("id", id);
}
if let Some(platform) = opts.platform {
query = query.arg("platform", platform);
}
2023-02-22 23:09:20 +01:00
2023-02-05 23:44:06 +01:00
return Container {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-01 16:42:50 +01:00
}
2023-02-19 22:38:36 +01:00
/// The default platform of the builder.
2023-02-22 22:38:15 +01:00
pub async fn default_platform(&self) -> eyre::Result<Platform> {
let mut query = self.selection.select("defaultPlatform");
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
2023-02-01 16:42:50 +01:00
}
2023-02-19 22:38:36 +01:00
/// Load a directory by ID. No argument produces an empty directory.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn directory(&self) -> Directory {
let mut query = self.selection.select("directory");
2023-02-22 23:09:20 +01:00
return Directory {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
2023-02-22 23:09:20 +01:00
2023-02-19 22:38:36 +01:00
/// Load a directory by ID. No argument produces an empty directory.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn directory_opts(&self, opts: QueryDirectoryOpts) -> Directory {
let mut query = self.selection.select("directory");
2023-02-22 23:09:20 +01:00
if let Some(id) = opts.id {
query = query.arg("id", id);
}
2023-02-22 23:09:20 +01:00
return Directory {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-01 16:42:50 +01:00
}
2023-02-19 22:38:36 +01:00
/// Loads a file by ID.
2023-02-22 22:38:15 +01:00
pub fn file(&self, id: FileId) -> File {
let mut query = self.selection.select("file");
2023-02-22 23:09:20 +01:00
query = query.arg("id", id);
2023-02-22 23:09:20 +01:00
return File {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-01 16:42:50 +01:00
}
2023-02-19 22:38:36 +01:00
/// Queries a git repository.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `url` - Url of the git repository.
/// Can be formatted as https://{host}/{owner}/{repo}, git@{host}/{owner}/{repo}
/// Suffix ".git" is optional.
2023-02-22 23:09:20 +01:00
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn git(&self, url: impl Into<String>) -> GitRepository {
let mut query = self.selection.select("git");
2023-02-22 23:09:20 +01:00
query = query.arg("url", url.into());
2023-02-22 23:09:20 +01:00
return GitRepository {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
2023-02-22 23:09:20 +01:00
2023-02-19 22:38:36 +01:00
/// Queries a git repository.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `url` - Url of the git repository.
/// Can be formatted as https://{host}/{owner}/{repo}, git@{host}/{owner}/{repo}
/// Suffix ".git" is optional.
2023-02-22 23:09:20 +01:00
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn git_opts(&self, url: impl Into<String>, opts: QueryGitOpts) -> GitRepository {
let mut query = self.selection.select("git");
2023-02-22 23:09:20 +01:00
query = query.arg("url", url.into());
if let Some(keep_git_dir) = opts.keep_git_dir {
query = query.arg("keepGitDir", keep_git_dir);
}
if let Some(experimental_service_host) = opts.experimental_service_host {
query = query.arg("experimentalServiceHost", experimental_service_host);
}
2023-02-22 23:09:20 +01:00
return GitRepository {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-01 16:42:50 +01:00
}
2023-02-19 22:38:36 +01:00
/// Queries the host environment.
2023-02-22 22:38:15 +01:00
pub fn host(&self) -> Host {
let mut query = self.selection.select("host");
2023-02-22 23:09:20 +01:00
return Host {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-01 16:42:50 +01:00
}
2023-02-19 22:38:36 +01:00
/// Returns a file containing an http remote url content.
///
/// # Arguments
///
/// * `url` - HTTP url to get the content from (e.g., "https://docs.dagger.io").
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn http(&self, url: impl Into<String>) -> File {
let mut query = self.selection.select("http");
2023-02-22 23:09:20 +01:00
query = query.arg("url", url.into());
2023-02-22 23:09:20 +01:00
return File {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-01 16:42:50 +01:00
}
/// Returns a file containing an http remote url content.
///
/// # Arguments
///
/// * `url` - HTTP url to get the content from (e.g., "https://docs.dagger.io").
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
pub fn http_opts(&self, url: impl Into<String>, opts: QueryHttpOpts) -> File {
let mut query = self.selection.select("http");
query = query.arg("url", url.into());
if let Some(experimental_service_host) = opts.experimental_service_host {
query = query.arg("experimentalServiceHost", experimental_service_host);
}
return File {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
};
}
2023-02-19 22:38:36 +01:00
/// Creates a named sub-pipeline
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn pipeline(&self, name: impl Into<String>) -> Query {
let mut query = self.selection.select("pipeline");
2023-02-22 23:09:20 +01:00
query = query.arg("name", name.into());
2023-02-22 23:09:20 +01:00
return Query {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
2023-02-22 23:09:20 +01:00
2023-02-19 22:38:36 +01:00
/// Creates a named sub-pipeline
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn pipeline_opts<'a>(&self, name: impl Into<String>, opts: QueryPipelineOpts<'a>) -> Query {
let mut query = self.selection.select("pipeline");
2023-02-22 23:09:20 +01:00
query = query.arg("name", name.into());
if let Some(description) = opts.description {
query = query.arg("description", description);
}
2023-02-22 23:09:20 +01:00
return Query {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-01 16:42:50 +01:00
}
2023-02-19 22:38:36 +01:00
/// Look up a project by name
2023-02-22 22:38:15 +01:00
pub fn project(&self, name: impl Into<String>) -> Project {
let mut query = self.selection.select("project");
2023-02-22 23:09:20 +01:00
query = query.arg("name", name.into());
2023-02-22 23:09:20 +01:00
return Project {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-01 16:42:50 +01:00
}
2023-02-19 22:38:36 +01:00
/// Loads a secret from its ID.
2023-02-22 22:38:15 +01:00
pub fn secret(&self, id: SecretId) -> Secret {
let mut query = self.selection.select("secret");
2023-02-22 23:09:20 +01:00
query = query.arg("id", id);
2023-02-22 23:09:20 +01:00
return Secret {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
2023-02-01 16:42:50 +01:00
}
2023-02-19 22:38:36 +01:00
/// Loads a socket by its ID.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn socket(&self) -> Socket {
let mut query = self.selection.select("socket");
2023-02-22 23:09:20 +01:00
return Socket {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
2023-02-22 23:09:20 +01:00
2023-02-19 22:38:36 +01:00
/// Loads a socket by its ID.
2023-02-22 23:09:20 +01:00
///
/// # Arguments
///
/// * `opt` - optional argument, see inner type for documentation, use <func>_opts to use
2023-02-22 22:38:15 +01:00
pub fn socket_opts(&self, opts: QuerySocketOpts) -> Socket {
let mut query = self.selection.select("socket");
2023-02-22 23:09:20 +01:00
if let Some(id) = opts.id {
query = query.arg("id", id);
}
2023-02-22 23:09:20 +01:00
return Socket {
proc: self.proc.clone(),
selection: query,
conn: self.conn.clone(),
2023-02-22 22:38:15 +01:00
};
}
}
2023-02-22 22:38:15 +01:00
#[derive(Debug, Clone)]
pub struct Secret {
pub proc: Arc<Child>,
pub selection: Selection,
pub conn: ConnectParams,
}
2023-02-22 23:09:20 +01:00
2023-02-01 16:42:50 +01:00
impl Secret {
2023-02-19 22:38:36 +01:00
/// The identifier for this secret.
2023-02-22 22:38:15 +01:00
pub async fn id(&self) -> eyre::Result<SecretId> {
let mut query = self.selection.select("id");
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
}
2023-02-19 22:38:36 +01:00
/// The value of this secret.
2023-02-22 22:38:15 +01:00
pub async fn plaintext(&self) -> eyre::Result<String> {
let mut query = self.selection.select("plaintext");
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
2023-02-01 16:42:50 +01:00
}
}
2023-02-22 22:38:15 +01:00
#[derive(Debug, Clone)]
pub struct Socket {
pub proc: Arc<Child>,
pub selection: Selection,
pub conn: ConnectParams,
}
2023-02-22 23:09:20 +01:00
2023-02-01 16:42:50 +01:00
impl Socket {
2023-02-19 22:38:36 +01:00
/// The content-addressed identifier of the socket.
2023-02-22 22:38:15 +01:00
pub async fn id(&self) -> eyre::Result<SocketId> {
let mut query = self.selection.select("id");
2023-02-22 23:09:20 +01:00
query.execute(&graphql_client(&self.conn)).await
2023-02-01 16:42:50 +01:00
}
}
#[derive(Serialize, Clone, PartialEq, Debug)]
2023-02-19 12:16:48 +01:00
pub enum CacheSharingMode {
PRIVATE,
2023-02-19 12:16:48 +01:00
LOCKED,
2023-02-22 22:38:15 +01:00
SHARED,
}
#[derive(Serialize, Clone, PartialEq, Debug)]
pub enum NetworkProtocol {
TCP,
UDP,
2023-02-19 12:16:48 +01:00
}