Documentation ¶
Index ¶
- Variables
- type BuildInfo
- type BuildRequest
- type Client
- func (c *Client) Cancel(ctx context.Context, buildID string) error
- func (c *Client) GetOutput(ctx context.Context, buildID string, or OutputReader) error
- func (c *Client) GetStatus(ctx context.Context, buildID string) (bi BuildInfo, err error)
- func (c *Client) GetVersion(ctx context.Context) (vi VersionInfo, err error)
- func (c *Client) Submit(ctx context.Context, br BuildRequest) (bi BuildInfo, err error)
- type Config
- type OutputReader
- type VersionInfo
Constants ¶
This section is empty.
Variables ¶
var DefaultConfig = &Config{}
DefaultConfig is a configuration that uses default values.
Functions ¶
This section is empty.
Types ¶
type BuildInfo ¶ added in v0.0.2
type BuildInfo struct { ID string `json:"id"` SubmitTime time.Time `json:"submitTime"` StartTime *time.Time `json:"startTime,omitempty"` IsComplete bool `json:"isComplete"` CompleteTime *time.Time `json:"completeTime,omitempty"` ImageSize int64 `json:"imageSize,omitempty"` ImageChecksum string `json:"imageChecksum,omitempty"` LibraryRef string `json:"libraryRef"` LibraryURL string `json:"libraryURL"` CallbackURL string `json:"callbackURL"` DefinitionRaw []byte `json:"definitionRaw"` }
BuildInfo contains the details of an individual build
type BuildRequest ¶ added in v0.0.2
type BuildRequest struct { LibraryRef string `json:"libraryRef"` LibraryURL string `json:"libraryURL"` CallbackURL string `json:"callbackURL"` DefinitionRaw []byte `json:"definitionRaw"` BuilderRequirements map[string]string `json:"builderRequirements"` }
BuildRequest contains the info necessary for submitting a build to build service
type Client ¶
type Client struct { // Base URL of the service. BaseURL *url.URL // Auth token to include in the Authorization header of each request (if supplied). AuthToken string // User agent to include in each request (if supplied). UserAgent string // HTTPClient to use to make HTTP requests. HTTPClient *http.Client // Logger to be used when output is generated Logger log.Logger }
Client describes the client details.
func New ¶ added in v0.0.2
New sets up a new build service client with the specified base URL and auth token.
func (*Client) Cancel ¶ added in v0.1.0
Cancel cancels an existing build. The context controls the lifetime of the request.
func (*Client) GetOutput ¶ added in v0.0.2
GetOutput reads the build output log for the provided buildID - streaming to OutputReader. The context controls the lifetime of the request.
func (*Client) GetStatus ¶ added in v0.0.2
GetStatus gets the status of a build from the Build Service by build ID
func (*Client) GetVersion ¶
func (c *Client) GetVersion(ctx context.Context) (vi VersionInfo, err error)
GetVersion gets version information from the build service. The context controls the lifetime of the request.
type Config ¶
type Config struct { // Base URL of the service (https://build.sylabs.io is used if not supplied). BaseURL string // Auth token to include in the Authorization header of each request (if supplied). AuthToken string // User agent to include in each request (if supplied). UserAgent string // HTTPClient to use to make HTTP requests (if supplied). HTTPClient *http.Client // Logger to be used when output is generated Logger log.Logger }
Config contains the client configuration.
type OutputReader ¶ added in v0.0.2
type OutputReader interface { // Read is called when a websocket message is received Read(messageType int, p []byte) (int, error) }
OutputReader interface is used to read the websocket output from the stream
type VersionInfo ¶
type VersionInfo struct {
Version string `json:"version"`
}
VersionInfo contains version information.