Dagger
Search

go

Copyright © 2024 Patrick Hermann patrick.hermann@sva.de

Installation

dagger install github.com/stuttgart-things/dagger/go@v0.4.0

Entrypoint

Return Type
Go !
Arguments
NameTypeDefault ValueDescription
goLangContainerContainer -golang container It need contain golang
koContainerContainer -No description provided
goLangVersionString "1.23.6"No description provided
srcDirectory -No description provided
Example
dagger -m github.com/stuttgart-things/dagger/go@b14196e380d680bfb71325fa12b2ece6aad7118f call \
func (m *myModule) example() *Go  {
	return dag.
			Go()
}
@function
def example() -> dag.Go:
	return (
		dag.go()
	)
@func()
example(): Go {
	return dag
		.go()
}

Types

Go 🔗

src() 🔗

Return Type
Directory !
Example
dagger -m github.com/stuttgart-things/dagger/go@b14196e380d680bfb71325fa12b2ece6aad7118f call \
 src
func (m *myModule) example() *Directory  {
	return dag.
			Go().
			Src()
}
@function
def example() -> dagger.Directory:
	return (
		dag.go()
		.src()
	)
@func()
example(): Directory {
	return dag
		.go()
		.src()
}

goLangContainer() 🔗

Return Type
Container !
Example
dagger -m github.com/stuttgart-things/dagger/go@b14196e380d680bfb71325fa12b2ece6aad7118f call \
 go-lang-container
func (m *myModule) example() *Container  {
	return dag.
			Go().
			GoLangContainer()
}
@function
def example() -> dagger.Container:
	return (
		dag.go()
		.go_lang_container()
	)
@func()
example(): Container {
	return dag
		.go()
		.goLangContainer()
}

koContainer() 🔗

Return Type
Container !
Example
dagger -m github.com/stuttgart-things/dagger/go@b14196e380d680bfb71325fa12b2ece6aad7118f call \
 ko-container
func (m *myModule) example() *Container  {
	return dag.
			Go().
			KoContainer()
}
@function
def example() -> dagger.Container:
	return (
		dag.go()
		.ko_container()
	)
@func()
example(): Container {
	return dag
		.go()
		.koContainer()
}

getGoLangContainer() 🔗

GetGoLangContainer return the default image for golang

Return Type
Container !
Arguments
NameTypeDefault ValueDescription
goVersionString !-No description provided
Example
dagger -m github.com/stuttgart-things/dagger/go@b14196e380d680bfb71325fa12b2ece6aad7118f call \
 get-go-lang-container --go-version string
func (m *myModule) example(goVersion string) *Container  {
	return dag.
			Go().
			GetGoLangContainer(goVersion)
}
@function
def example(go_version: str) -> dagger.Container:
	return (
		dag.go()
		.get_go_lang_container(go_version)
	)
@func()
example(goVersion: string): Container {
	return dag
		.go()
		.getGoLangContainer(goVersion)
}

getKoContainer() 🔗

Return Type
Container !
Arguments
NameTypeDefault ValueDescription
koVersionString "v0.17.1"No description provided
Example
dagger -m github.com/stuttgart-things/dagger/go@b14196e380d680bfb71325fa12b2ece6aad7118f call \
 get-ko-container
func (m *myModule) example() *Container  {
	return dag.
			Go().
			GetKoContainer()
}
@function
def example() -> dagger.Container:
	return (
		dag.go()
		.get_ko_container()
	)
@func()
example(): Container {
	return dag
		.go()
		.getKoContainer()
}

lint() 🔗

Lint runs the linter on the provided source code

Return Type
Container !
Arguments
NameTypeDefault ValueDescription
srcDirectory !-No description provided
timeoutString "500s"No description provided
Example
dagger -m github.com/stuttgart-things/dagger/go@b14196e380d680bfb71325fa12b2ece6aad7118f call \
 lint --src DIR_PATH
func (m *myModule) example(src *Directory) *Container  {
	return dag.
			Go().
			Lint(src)
}
@function
def example(src: dagger.Directory) -> dagger.Container:
	return (
		dag.go()
		.lint(src)
	)
@func()
example(src: Directory): Container {
	return dag
		.go()
		.lint(src)
}

scanTarBallImage() 🔗

Lint runs the linter on the provided source code

Return Type
File !
Arguments
NameTypeDefault ValueDescription
fileFile !-No description provided
Example
dagger -m github.com/stuttgart-things/dagger/go@b14196e380d680bfb71325fa12b2ece6aad7118f call \
 scan-tar-ball-image --file file:path
func (m *myModule) example(file *File) *File  {
	return dag.
			Go().
			ScanTarBallImage(file)
}
@function
def example(file: dagger.File) -> dagger.File:
	return (
		dag.go()
		.scan_tar_ball_image(file)
	)
@func()
example(file: File): File {
	return dag
		.go()
		.scanTarBallImage(file)
}

koBuildAndScan() 🔗

Return Type
String !
Arguments
NameTypeDefault ValueDescription
srcDirectory !-No description provided
tokenNameString "GITHUB_TOKEN"No description provided
tokenSecret !-No description provided
repoString "ko.local"No description provided
buildArgString "."No description provided
koVersionString "v0.17.1"No description provided
pushString "true"No description provided
severityFilterString "HIGH,CRITICAL"Comma-separated list of severities to filter (e.g., "HIGH,CRITICAL")
Example
dagger -m github.com/stuttgart-things/dagger/go@b14196e380d680bfb71325fa12b2ece6aad7118f call \
 ko-build-and-scan --src DIR_PATH --token env:MYSECRET
func (m *myModule) example(ctx context.Context, src *Directory, token *Secret) string  {
	return dag.
			Go().
			KoBuildAndScan(ctx, src, token)
}
@function
async def example(src: dagger.Directory, token: dagger.Secret) -> str:
	return await (
		dag.go()
		.ko_build_and_scan(src, token)
	)
@func()
async example(src: Directory, token: Secret): Promise<string> {
	return dag
		.go()
		.koBuildAndScan(src, token)
}

searchVulnerabilities() 🔗

SearchVulnerabilities parses the Trivy scan report and filters vulnerabilities by severity

Return Type
[String ! ] !
Arguments
NameTypeDefault ValueDescription
scanResultFile !-No description provided
severityFilterString !-Comma-separated list of severities (e.g., "HIGH,CRITICAL")
Example
dagger -m github.com/stuttgart-things/dagger/go@b14196e380d680bfb71325fa12b2ece6aad7118f call \
 search-vulnerabilities --scan-result file:path --severity-filter string
func (m *myModule) example(ctx context.Context, scanResult *File, severityFilter string) []string  {
	return dag.
			Go().
			SearchVulnerabilities(ctx, scanResult, severityFilter)
}
@function
async def example(scan_result: dagger.File, severity_filter: str) -> List[str]:
	return await (
		dag.go()
		.search_vulnerabilities(scan_result, severity_filter)
	)
@func()
async example(scanResult: File, severityFilter: string): Promise<string[]> {
	return dag
		.go()
		.searchVulnerabilities(scanResult, severityFilter)
}

runWorkflowEntryStage() 🔗

Return Type
File !
Arguments
NameTypeDefault ValueDescription
srcDirectory !-No description provided
lintTimeoutString "500s"No description provided
goVersionString "1.23.6"No description provided
osString "linux"No description provided
archString "amd64"No description provided
goMainFileString "main.go"No description provided
binNameString "main"No description provided
lintCanFailBoolean "false"If true, linting can fail without stopping the workflow
testArgString "./..."Arguments for `go test`
securityScanCanFailBoolean "false"If true, security scan can fail without stopping the workflow
trivyScanCanFailBoolean "false"If true, Trivy scan can fail without stopping the workflow
Example
dagger -m github.com/stuttgart-things/dagger/go@b14196e380d680bfb71325fa12b2ece6aad7118f call \
 run-workflow-entry-stage --src DIR_PATH
func (m *myModule) example(src *Directory) *File  {
	return dag.
			Go().
			RunWorkflowEntryStage(src)
}
@function
def example(src: dagger.Directory) -> dagger.File:
	return (
		dag.go()
		.run_workflow_entry_stage(src)
	)
@func()
example(src: Directory): File {
	return dag
		.go()
		.runWorkflowEntryStage(src)
}

build() 🔗

Returns lines that match a pattern in the files of the provided Directory

Return Type
Directory !
Arguments
NameTypeDefault ValueDescription
goVersionString "1.23.6"No description provided
osString "linux"No description provided
archString "amd64"No description provided
goMainFileString "main.go"No description provided
binNameString "main"No description provided
srcDirectory !-No description provided
Example
dagger -m github.com/stuttgart-things/dagger/go@b14196e380d680bfb71325fa12b2ece6aad7118f call \
 build --src DIR_PATH
func (m *myModule) example(src *Directory) *Directory  {
	return dag.
			Go().
			Build(src)
}
@function
def example(src: dagger.Directory) -> dagger.Directory:
	return (
		dag.go()
		.build(src)
	)
@func()
example(src: Directory): Directory {
	return dag
		.go()
		.build(src)
}

koBuild() 🔗

Returns lines that match a pattern in the files of the provided Directory

Return Type
Directory !
Arguments
NameTypeDefault ValueDescription
srcDirectory !-No description provided
tokenNameString "GITHUB_TOKEN"No description provided
tokenSecret !-No description provided
repoString "ko.local"No description provided
buildArgString "."No description provided
koVersionString "v0.17.1"No description provided
pushString "true"No description provided
Example
dagger -m github.com/stuttgart-things/dagger/go@b14196e380d680bfb71325fa12b2ece6aad7118f call \
 ko-build --src DIR_PATH --token env:MYSECRET
func (m *myModule) example(src *Directory, token *Secret) *Directory  {
	return dag.
			Go().
			KoBuild(src, token)
}
@function
def example(src: dagger.Directory, token: dagger.Secret) -> dagger.Directory:
	return (
		dag.go()
		.ko_build(src, token)
	)
@func()
example(src: Directory, token: Secret): Directory {
	return dag
		.go()
		.koBuild(src, token)
}

test() 🔗

Return Type
String !
Arguments
NameTypeDefault ValueDescription
srcDirectory !-No description provided
goVersionString !-Go version to use for testing
testArgString "./..."Arguments for `go test`
Example
dagger -m github.com/stuttgart-things/dagger/go@b14196e380d680bfb71325fa12b2ece6aad7118f call \
 test --src DIR_PATH --go-version string
func (m *myModule) example(ctx context.Context, src *Directory, goVersion string) string  {
	return dag.
			Go().
			Test(ctx, src, goVersion)
}
@function
async def example(src: dagger.Directory, go_version: str) -> str:
	return await (
		dag.go()
		.test(src, go_version)
	)
@func()
async example(src: Directory, goVersion: string): Promise<string> {
	return dag
		.go()
		.test(src, goVersion)
}

trivyScan() 🔗

Return Type
String !
Arguments
NameTypeDefault ValueDescription
srcDirectory !-No description provided
Example
dagger -m github.com/stuttgart-things/dagger/go@b14196e380d680bfb71325fa12b2ece6aad7118f call \
 trivy-scan --src DIR_PATH
func (m *myModule) example(ctx context.Context, src *Directory) string  {
	return dag.
			Go().
			TrivyScan(ctx, src)
}
@function
async def example(src: dagger.Directory) -> str:
	return await (
		dag.go()
		.trivy_scan(src)
	)
@func()
async example(src: Directory): Promise<string> {
	return dag
		.go()
		.trivyScan(src)
}

securityScan() 🔗

Return Type
String !
Arguments
NameTypeDefault ValueDescription
srcDirectory !-No description provided
Example
dagger -m github.com/stuttgart-things/dagger/go@b14196e380d680bfb71325fa12b2ece6aad7118f call \
 security-scan --src DIR_PATH
func (m *myModule) example(ctx context.Context, src *Directory) string  {
	return dag.
			Go().
			SecurityScan(ctx, src)
}
@function
async def example(src: dagger.Directory) -> str:
	return await (
		dag.go()
		.security_scan(src)
	)
@func()
async example(src: Directory): Promise<string> {
	return dag
		.go()
		.securityScan(src)
}