Documentation
¶
Overview ¶
Provides types used for processing sti builds.
Index ¶
Constants ¶
View Source
const ( // Assemble is the name of the script responsible for build process of the resulting image. Assemble = "assemble" // Run is the name of the script responsible for running the final application. Run = "run" // SaveArtifacts is the name of the script responsible for storing dependencies etc. between builds. SaveArtifacts = "save-artifacts" // Usage is the name of the script responsible for printing the builder image's short info. Usage = "usage" // Environment contains list of key value pairs that will be set during the // STI build. Users can use this file to provide extra configuration // depending on the builder image used. Environment = "environment" )
View Source
const ( // UserScripts is the location of scripts downloaded from user provided URL (-s flag). UserScripts = "downloads" + string(os.PathSeparator) + "scripts" // DefaultScripts is the location of scripts downloaded from default location (io.openshift.s2i.scripts-url label). DefaultScripts = "downloads" + string(os.PathSeparator) + "defaultScripts" // SourceScripts is the location of scripts downloaded with application sources. SourceScripts = "upload" + string(os.PathSeparator) + "src" + string(os.PathSeparator) + ".sti" + string(os.PathSeparator) + "bin" // UploadScripts is the location of scripts that will be uploaded to the image during STI build. UploadScripts = "upload" + string(os.PathSeparator) + "scripts" // Source is the location of application sources. Source = "upload" + string(os.PathSeparator) + "src" // ContextTmp is the location of applications sources off of a supplied context dir ContextTmp = "upload" + string(os.PathSeparator) + "tmp" // Ignorefile is the s2i version for ignore files like we see with .gitignore or .dockerignore .. initial impl mirrors documented .dockerignore capabilities IgnoreFile = ".s2iignore" )
View Source
const ( DefaultNamespace = "io.openshift.s2i." KubernetesNamespace = "io.k8s." )
Image label namespace constants
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type CloneConfig ¶ added in v1.0.6
CloneConfig specifies the options used when cloning the application source code.
type Config ¶
type Config struct {
// DisplayName is a result image display-name label. This defaults to the
// output image name.
DisplayName string
// Description is a result image description label. The default is no
// description.
Description string
// BuilderImage describes which image is used for building the result images.
BuilderImage string
// BuilderImageVersion provides optional version information about the builder image.
BuilderImageVersion string
// BuilderBaseImageVersion provides optional version information about the builder base image.
BuilderBaseImageVersion string
// DockerConfig describes how to access host docker daemon.
DockerConfig *DockerConfig
// DockerCfgPath provides the path to the .dockercfg file
DockerCfgPath string
// PullAuthentication holds the authentication information for pulling the
// Docker images from private repositories
PullAuthentication docker.AuthConfiguration
// IncrementalAuthentication holds the authentication information for pulling the
// previous image from private repositories
IncrementalAuthentication docker.AuthConfiguration
// PreserveWorkingDir describes if working directory should be left after processing.
PreserveWorkingDir bool
// DisableRecursive disables the --recursive option for the git clone that
// allows to use the GIT without requiring the git submodule to be called.
DisableRecursive bool
// Source URL describing the location of sources used to build the result image.
Source string
// Ref is a tag/branch to be used for build.
Ref string
// Tag is a result image tag name.
Tag string
// Incremental describes whether to try to perform incremental build.
Incremental bool
// RemovePreviousImage describes if previous image should be removed after successful build.
// This applies only to incremental builds.
RemovePreviousImage bool
// Environment is a map of environment variables to be passed to the image.
Environment map[string]string
// EnvironmentFile provides the path to a file with list of environment
// variables.
EnvironmentFile string
// LabelNamespace provides the namespace under which the labels will be generated.
LabelNamespace string
// CallbackURL is a URL which is called upon successful build to inform about that fact.
CallbackURL string
// ScriptsURL is a URL describing the localization of STI scripts used during build process.
ScriptsURL string
// Destination specifies a location where the untar operation will place its artifacts.
Destination string
// ForcePull describes if the builder should pull the images from registry prior to building.
ForcePull bool
// WorkingDir describes temporary directory used for downloading sources, scripts and tar operations.
WorkingDir string
// WorkingSourceDir describes the subdirectory off of WorkingDir set up during the repo download
// that is later used as the root for ignore processing
WorkingSourceDir string
// LayeredBuild describes if this is build which layered scripts and sources on top of BuilderImage.
LayeredBuild bool
// Operate quietly. Progress and assemble script output are not reported, only fatal errors.
// (default: false).
Quiet bool
// Specify a relative directory inside the application repository that should
// be used as a root directory for the application.
ContextDir string
// AllowedUIDs is a list of user ranges of users allowed to run the builder image.
// If a range is specified and the builder image uses a non-numeric user or a user
// that is outside the specified range, then the build fails.
AllowedUIDs user.RangeList
// RunImage will trigger a "docker run ..." invocation of the produced image so the user
// can see if it operates as he would expect
RunImage bool
}
Config contains essential fields for performing build.
type DockerConfig ¶
type DockerConfig struct {
// Endpoint is the docker network endpoint or socket
Endpoint string
// CertFile is the certificate file path for a TLS connection
CertFile string
// KeyFile is the key file path for a TLS connection
KeyFile string
// CAFile is the certificate authority file path for a TLS connection
CAFile string
}
DockerConfig contains the configuration for a Docker connection
type InstallResult ¶
type InstallResult struct {
// Script describes which script this result refers to
Script string
// URL describes from where the script was taken
URL string
// Downloaded describes if download operation happened, this will be true for
// external scripts, but false for scripts from inside the image
Downloaded bool
// Installed describes if script was installed to upload directory
Installed bool
// Error describes last error encountered during install operation
Error error
}
InstallResult structure describes the result of install operation
type Result ¶
type Result struct {
// Success describes whether the build was successful.
Success bool
// Messages is a list of messages from build process.
Messages []string
// WorkingDir describes temporary directory used for downloading sources, scripts and tar operations.
WorkingDir string
// ImageID describes resulting image ID.
ImageID string
}
Result structure contains information from build process.
type SourceInfo ¶ added in v1.0.2
type SourceInfo struct {
// Ref represents a commit SHA-1, valid GIT branch name or a GIT tag
// The output image will contain this information as 'io.openshift.build.commit.ref' label.
Ref string
// CommitID represents an arbitrary extended object reference in GIT as SHA-1
// The output image will contain this information as 'io.openshift.build.commit.id' label.
CommitID string
// Date contains a date when the committer created the commit.
// The output image will contain this information as 'io.openshift.build.commit.date' label.
Date string
// Author contains information about the committer name and email address.
// The output image will contain this information as 'io.openshift.build.commit.author' label.
Author string
// Message represents the first 80 characters from the commit message.
// The output image will contain this information as 'io.openshift.build.commit.message' label.
Message string
// Location contains a valid URL to the original repository.
// The output image will contain this information as 'io.openshift.build.source-location' label.
Location string
// ContextDir contains path inside the Location directory that
// contains the application source code.
// The output image will contain this information as 'io.openshift.build.source-context-dir'
// label.
ContextDir string
}
SourceInfo stores information about the source code
Click to show internal directories.
Click to hide internal directories.