Dagger
Search

gha

Daggerizing your CI makes your YAML configurations smaller, but they still exist,
and they're still a pain to maintain by hand.

This module aims to finish the job, by letting you generate your remaining
YAML configuration from a Dagger pipeline, written in your favorite language.

Installation

dagger install github.com/pythoninthegrass/dagger/modules/gha@82a8462b016a936ff979930e0adc35e7f04d9d6c

Entrypoint

Return Type
Gha !
Arguments
NameTypeDefault ValueDescription
jobDefaultsJob -No description provided
workflowDefaultsWorkflow -No description provided
Example
dagger -m github.com/pythoninthegrass/dagger/modules/gha@82a8462b016a936ff979930e0adc35e7f04d9d6c call \
func (m *MyModule) Example() *dagger.Gha  {
	return dag.
			Gha()
}
@function
def example() -> dagger.Gha:
	return (
		dag.gha()
	)
@func()
example(): Gha {
	return dag
		.gha()
}

Types

Gha 🔗

workflows() 🔗

Return Type
[Workflow ! ] !
Example
dagger -m github.com/pythoninthegrass/dagger/modules/gha@82a8462b016a936ff979930e0adc35e7f04d9d6c call \
 workflows
func (m *MyModule) Example() []*dagger.GhaWorkflow  {
	return dag.
			Gha().
			Workflows()
}
@function
def example() -> List[dagger.GhaWorkflow]:
	return (
		dag.gha()
		.workflows()
	)
@func()
example(): GhaWorkflow[] {
	return dag
		.gha()
		.workflows()
}

generate() 🔗

Return Type
Directory !
Arguments
NameTypeDefault ValueDescription
directoryDirectory -No description provided
asJsonBoolean -No description provided
fileExtensionString ".gen.yml"No description provided
Example
dagger -m github.com/pythoninthegrass/dagger/modules/gha@82a8462b016a936ff979930e0adc35e7f04d9d6c call \
 generate
func (m *MyModule) Example() *dagger.Directory  {
	return dag.
			Gha().
			Generate()
}
@function
def example() -> dagger.Directory:
	return (
		dag.gha()
		.generate()
	)
@func()
example(): Directory {
	return dag
		.gha()
		.generate()
}

withWorkflow() 🔗

Return Type
Gha !
Arguments
NameTypeDefault ValueDescription
workflowWorkflow !-No description provided
Example
echo 'Custom types are not supported in shell examples'
func (m *MyModule) Example(workflow *dagger.GhaWorkflow) *dagger.Gha  {
	return dag.
			Gha().
			WithWorkflow(workflow)
}
@function
def example(workflow: dagger.GhaWorkflow) -> dagger.Gha:
	return (
		dag.gha()
		.with_workflow(workflow)
	)
@func()
example(workflow: GhaWorkflow): Gha {
	return dag
		.gha()
		.withWorkflow(workflow)
}

workflow() 🔗

Add a workflow

Return Type
Workflow !
Arguments
NameTypeDefault ValueDescription
nameString !-Workflow name
pullRequestConcurrencyString -Configure this workflow's concurrency for each PR. This is triggered when the workflow is scheduled concurrently on the same PR. - allow: all instances are allowed to run concurrently - queue: new instances are queued, and run sequentially - preempt: new instances run immediately, older ones are canceled Possible values: "allow", "preempt", "queue"
noDispatchBoolean -Disable manual "dispatch" of this workflow
permissions[Enum ! ] -Permissions to grant the workflow
onIssueCommentBoolean -Run the workflow on any issue comment activity
onIssueCommentCreatedBoolean -No description provided
onIssueCommentEditedBoolean -No description provided
onIssueCommentDeletedBoolean -No description provided
onPullRequestBoolean -Run the workflow on any pull request activity
onPullRequestBranches[String ! ] -No description provided
onPullRequestPaths[String ! ] -No description provided
onPullRequestAssignedBoolean -No description provided
onPullRequestUnassignedBoolean -No description provided
onPullRequestLabeledBoolean -No description provided
onPullRequestUnlabeledBoolean -No description provided
onPullRequestOpenedBoolean -No description provided
onPullRequestEditedBoolean -No description provided
onPullRequestClosedBoolean -No description provided
onPullRequestReopenedBoolean -No description provided
onPullRequestSynchronizeBoolean -No description provided
onPullRequestConvertedToDraftBoolean -No description provided
onPullRequestLockedBoolean -No description provided
onPullRequestUnlockedBoolean -No description provided
onPullRequestEnqueuedBoolean -No description provided
onPullRequestDequeuedBoolean -No description provided
onPullRequestMilestonedBoolean -No description provided
onPullRequestDemilestonedBoolean -No description provided
onPullRequestReadyForReviewBoolean -No description provided
onPullRequestReviewRequestedBoolean -No description provided
onPullRequestReviewRequestRemovedBoolean -No description provided
onPullRequestAutoMergeEnabledBoolean -No description provided
onPullRequestAutoMergeDisabledBoolean -No description provided
onPushBoolean -Run the workflow on any git push
onPushTags[String ! ] -Run the workflow on git push to the specified tags
onPushBranches[String ! ] -Run the workflow on git push to the specified branches
onPushPaths[String ! ] -Run the workflow only if the paths match
onSchedule[String ! ] -Run the workflow at a schedule time
Example
dagger -m github.com/pythoninthegrass/dagger/modules/gha@82a8462b016a936ff979930e0adc35e7f04d9d6c call \
 workflow --name string
func (m *MyModule) Example(name string) *dagger.GhaWorkflow  {
	return dag.
			Gha().
			Workflow(name)
}
@function
def example(name: str) -> dagger.GhaWorkflow:
	return (
		dag.gha()
		.workflow(name)
	)
@func()
example(name: string): GhaWorkflow {
	return dag
		.gha()
		.workflow(name)
}

job() 🔗

Return Type
Job !
Arguments
NameTypeDefault ValueDescription
nameString !-No description provided
commandString !-No description provided
conditionString -Only run the job if this condition expression succeeds.
setupCommands[String ! ] -Additional commands to run before the main one.
teardownCommands[String ! ] -Additional commands to run after the main one.
publicTokenString -Public Dagger Cloud token, for open-source projects. DO NOT PASS YOUR PRIVATE DAGGER CLOUD TOKEN! This is for a special "public" token which can safely be shared publicly. To get one, contact support@dagger.io
stopEngineBoolean -Explicitly stop the dagger engine after completing the workflow.
timeoutMinutesInteger -The maximum number of minutes to run the workflow before killing the process
debugBoolean -Run the workflow in debug mode
secrets[String ! ] -Github secrets to inject into the workflow environment. For each secret, an env variable with the same name is created. Example: ["PROD_DEPLOY_TOKEN", "PRIVATE_SSH_KEY"]
env[String ! ] -Dagger secret URIs to load and assign as env variables. Example: ["OPENAI_API_KEY=op://CI/openai-api-key"]
runner[String ! ] -Dispatch jobs to the given runner Example: ["ubuntu-latest"]
moduleString -The Dagger module to load
daggerVersionString -Dagger version to run this workflow
daggerDevString -Dagger dev version to run this workflow.
cloudEngineBoolean -cloudEngine indicates whether to use Dagger Cloud Engine to run this workflow.
Example
dagger -m github.com/pythoninthegrass/dagger/modules/gha@82a8462b016a936ff979930e0adc35e7f04d9d6c call \
 job --name string --command string
func (m *MyModule) Example(name string, command string) *dagger.GhaJob  {
	return dag.
			Gha().
			Job(name, command)
}
@function
def example(name: str, command: str) -> dagger.GhaJob:
	return (
		dag.gha()
		.job(name, command)
	)
@func()
example(name: string, command: string): GhaJob {
	return dag
		.gha()
		.job(name, command)
}

Workflow 🔗

name() 🔗

Return Type
String !
Example
dagger -m github.com/pythoninthegrass/dagger/modules/gha@82a8462b016a936ff979930e0adc35e7f04d9d6c call \
 workflow --name string \
 name
func (m *MyModule) Example(ctx context.Context, name string) string  {
	return dag.
			Gha().
			Workflow(name).
			Name(ctx)
}
@function
async def example(name: str) -> str:
	return await (
		dag.gha()
		.workflow(name)
		.name()
	)
@func()
async example(name: string): Promise<string> {
	return dag
		.gha()
		.workflow(name)
		.name()
}

jobs() 🔗

Return Type
[Job ! ] !
Example
dagger -m github.com/pythoninthegrass/dagger/modules/gha@82a8462b016a936ff979930e0adc35e7f04d9d6c call \
 workflow --name string \
 jobs
func (m *MyModule) Example(name string) []*dagger.GhaJob  {
	return dag.
			Gha().
			Workflow(name).
			Jobs()
}
@function
def example(name: str) -> List[dagger.GhaJob]:
	return (
		dag.gha()
		.workflow(name)
		.jobs()
	)
@func()
example(name: string): GhaJob[] {
	return dag
		.gha()
		.workflow(name)
		.jobs()
}

withJob() 🔗

Return Type
Workflow !
Arguments
NameTypeDefault ValueDescription
jobJob !-No description provided
Example
echo 'Custom types are not supported in shell examples'
func (m *MyModule) Example(name string, job *dagger.GhaJob) *dagger.GhaWorkflow  {
	return dag.
			Gha().
			Workflow(name).
			WithJob(job)
}
@function
def example(name: str, job: dagger.GhaJob) -> dagger.GhaWorkflow:
	return (
		dag.gha()
		.workflow(name)
		.with_job(job)
	)
@func()
example(name: string, job: GhaJob): GhaWorkflow {
	return dag
		.gha()
		.workflow(name)
		.withJob(job)
}

check() 🔗

Check that the workflow is valid, in a best effort way

Return Type
Void !
Arguments
NameTypeDefault ValueDescription
repoDirectory -No description provided
Example
dagger -m github.com/pythoninthegrass/dagger/modules/gha@82a8462b016a936ff979930e0adc35e7f04d9d6c call \
 workflow --name string \
 check
func (m *MyModule) Example(ctx context.Context, name string)   {
	return dag.
			Gha().
			Workflow(name).
			Check(ctx)
}
@function
async def example(name: str) -> None:
	return await (
		dag.gha()
		.workflow(name)
		.check()
	)
@func()
async example(name: string): Promise<void> {
	return dag
		.gha()
		.workflow(name)
		.check()
}

Job 🔗

name() 🔗

Return Type
String !
Example
dagger -m github.com/pythoninthegrass/dagger/modules/gha@82a8462b016a936ff979930e0adc35e7f04d9d6c call \
 job --name string --command string \
 name
func (m *MyModule) Example(ctx context.Context, name string, command string) string  {
	return dag.
			Gha().
			Job(name, command).
			Name(ctx)
}
@function
async def example(name: str, command: str) -> str:
	return await (
		dag.gha()
		.job(name, command)
		.name()
	)
@func()
async example(name: string, command: string): Promise<string> {
	return dag
		.gha()
		.job(name, command)
		.name()
}

command() 🔗

Return Type
String !
Example
dagger -m github.com/pythoninthegrass/dagger/modules/gha@82a8462b016a936ff979930e0adc35e7f04d9d6c call \
 job --name string --command string \
 command
func (m *MyModule) Example(ctx context.Context, name string, command string) string  {
	return dag.
			Gha().
			Job(name, command).
			Command(ctx)
}
@function
async def example(name: str, command: str) -> str:
	return await (
		dag.gha()
		.job(name, command)
		.command()
	)
@func()
async example(name: string, command: string): Promise<string> {
	return dag
		.gha()
		.job(name, command)
		.command()
}

condition() 🔗

Make the job conditional on an expression

Return Type
String !
Example
dagger -m github.com/pythoninthegrass/dagger/modules/gha@82a8462b016a936ff979930e0adc35e7f04d9d6c call \
 job --name string --command string \
 condition
func (m *MyModule) Example(ctx context.Context, name string, command string) string  {
	return dag.
			Gha().
			Job(name, command).
			Condition(ctx)
}
@function
async def example(name: str, command: str) -> str:
	return await (
		dag.gha()
		.job(name, command)
		.condition()
	)
@func()
async example(name: string, command: string): Promise<string> {
	return dag
		.gha()
		.job(name, command)
		.condition()
}

setupCommands() 🔗

Additional commands to run before the main one

Return Type
[String ! ] !
Example
dagger -m github.com/pythoninthegrass/dagger/modules/gha@82a8462b016a936ff979930e0adc35e7f04d9d6c call \
 job --name string --command string \
 setup-commands
func (m *MyModule) Example(ctx context.Context, name string, command string) []string  {
	return dag.
			Gha().
			Job(name, command).
			SetupCommands(ctx)
}
@function
async def example(name: str, command: str) -> List[str]:
	return await (
		dag.gha()
		.job(name, command)
		.setup_commands()
	)
@func()
async example(name: string, command: string): Promise<string[]> {
	return dag
		.gha()
		.job(name, command)
		.setupCommands()
}

teardownCommands() 🔗

Additional commands to run after the main one

Return Type
[String ! ] !
Example
dagger -m github.com/pythoninthegrass/dagger/modules/gha@82a8462b016a936ff979930e0adc35e7f04d9d6c call \
 job --name string --command string \
 teardown-commands
func (m *MyModule) Example(ctx context.Context, name string, command string) []string  {
	return dag.
			Gha().
			Job(name, command).
			TeardownCommands(ctx)
}
@function
async def example(name: str, command: str) -> List[str]:
	return await (
		dag.gha()
		.job(name, command)
		.teardown_commands()
	)
@func()
async example(name: string, command: string): Promise<string[]> {
	return dag
		.gha()
		.job(name, command)
		.teardownCommands()
}

timeoutMinutes() 🔗

The maximum number of minutes to run the workflow before killing the process

Return Type
Integer !
Example
dagger -m github.com/pythoninthegrass/dagger/modules/gha@82a8462b016a936ff979930e0adc35e7f04d9d6c call \
 job --name string --command string \
 timeout-minutes
func (m *MyModule) Example(ctx context.Context, name string, command string) int  {
	return dag.
			Gha().
			Job(name, command).
			TimeoutMinutes(ctx)
}
@function
async def example(name: str, command: str) -> int:
	return await (
		dag.gha()
		.job(name, command)
		.timeout_minutes()
	)
@func()
async example(name: string, command: string): Promise<number> {
	return dag
		.gha()
		.job(name, command)
		.timeoutMinutes()
}

debug() 🔗

Run the workflow in debug mode

Return Type
Boolean !
Example
dagger -m github.com/pythoninthegrass/dagger/modules/gha@82a8462b016a936ff979930e0adc35e7f04d9d6c call \
 job --name string --command string \
 debug
func (m *MyModule) Example(ctx context.Context, name string, command string) bool  {
	return dag.
			Gha().
			Job(name, command).
			Debug(ctx)
}
@function
async def example(name: str, command: str) -> bool:
	return await (
		dag.gha()
		.job(name, command)
		.debug()
	)
@func()
async example(name: string, command: string): Promise<boolean> {
	return dag
		.gha()
		.job(name, command)
		.debug()
}

secrets() 🔗

Github secrets to inject into the workflow environment. For each secret, an env variable with the same name is created. Example: [“PROD_DEPLOY_TOKEN”, “PRIVATE_SSH_KEY”]

Return Type
[String ! ] !
Example
dagger -m github.com/pythoninthegrass/dagger/modules/gha@82a8462b016a936ff979930e0adc35e7f04d9d6c call \
 job --name string --command string \
 secrets
func (m *MyModule) Example(ctx context.Context, name string, command string) []string  {
	return dag.
			Gha().
			Job(name, command).
			Secrets(ctx)
}
@function
async def example(name: str, command: str) -> List[str]:
	return await (
		dag.gha()
		.job(name, command)
		.secrets()
	)
@func()
async example(name: string, command: string): Promise<string[]> {
	return dag
		.gha()
		.job(name, command)
		.secrets()
}

env() 🔗

Lines to append to .env. Example: [“OPENAI_API_KEY=op://CI/openai-api-key”]

Return Type
[String ! ] !
Example
dagger -m github.com/pythoninthegrass/dagger/modules/gha@82a8462b016a936ff979930e0adc35e7f04d9d6c call \
 job --name string --command string \
 env
func (m *MyModule) Example(ctx context.Context, name string, command string) []string  {
	return dag.
			Gha().
			Job(name, command).
			Env(ctx)
}
@function
async def example(name: str, command: str) -> List[str]:
	return await (
		dag.gha()
		.job(name, command)
		.env()
	)
@func()
async example(name: string, command: string): Promise<string[]> {
	return dag
		.gha()
		.job(name, command)
		.env()
}

runner() 🔗

Dispatch jobs to the given runner Example: [“ubuntu-latest”]

Return Type
[String ! ] !
Example
dagger -m github.com/pythoninthegrass/dagger/modules/gha@82a8462b016a936ff979930e0adc35e7f04d9d6c call \
 job --name string --command string \
 runner
func (m *MyModule) Example(ctx context.Context, name string, command string) []string  {
	return dag.
			Gha().
			Job(name, command).
			Runner(ctx)
}
@function
async def example(name: str, command: str) -> List[str]:
	return await (
		dag.gha()
		.job(name, command)
		.runner()
	)
@func()
async example(name: string, command: string): Promise<string[]> {
	return dag
		.gha()
		.job(name, command)
		.runner()
}

module() 🔗

The Dagger module to load

Return Type
String !
Example
dagger -m github.com/pythoninthegrass/dagger/modules/gha@82a8462b016a936ff979930e0adc35e7f04d9d6c call \
 job --name string --command string \
 module
func (m *MyModule) Example(ctx context.Context, name string, command string) string  {
	return dag.
			Gha().
			Job(name, command).
			Module(ctx)
}
@function
async def example(name: str, command: str) -> str:
	return await (
		dag.gha()
		.job(name, command)
		.module()
	)
@func()
async example(name: string, command: string): Promise<string> {
	return dag
		.gha()
		.job(name, command)
		.module()
}

daggerVersion() 🔗

Dagger version to run this workflow

Return Type
String !
Example
dagger -m github.com/pythoninthegrass/dagger/modules/gha@82a8462b016a936ff979930e0adc35e7f04d9d6c call \
 job --name string --command string \
 dagger-version
func (m *MyModule) Example(ctx context.Context, name string, command string) string  {
	return dag.
			Gha().
			Job(name, command).
			DaggerVersion(ctx)
}
@function
async def example(name: str, command: str) -> str:
	return await (
		dag.gha()
		.job(name, command)
		.dagger_version()
	)
@func()
async example(name: string, command: string): Promise<string> {
	return dag
		.gha()
		.job(name, command)
		.daggerVersion()
}

daggerDev() 🔗

Build the dagger engine from scratch.

Return Type
String !
Example
dagger -m github.com/pythoninthegrass/dagger/modules/gha@82a8462b016a936ff979930e0adc35e7f04d9d6c call \
 job --name string --command string \
 dagger-dev
func (m *MyModule) Example(ctx context.Context, name string, command string) string  {
	return dag.
			Gha().
			Job(name, command).
			DaggerDev(ctx)
}
@function
async def example(name: str, command: str) -> str:
	return await (
		dag.gha()
		.job(name, command)
		.dagger_dev()
	)
@func()
async example(name: string, command: string): Promise<string> {
	return dag
		.gha()
		.job(name, command)
		.daggerDev()
}

publicToken() 🔗

Public Dagger Cloud token, for open-source projects. DO NOT PASS YOUR PRIVATE DAGGER CLOUD TOKEN! This is for a special “public” token which can safely be shared publicly. To get one, contact support@dagger.io

Return Type
String !
Example
dagger -m github.com/pythoninthegrass/dagger/modules/gha@82a8462b016a936ff979930e0adc35e7f04d9d6c call \
 job --name string --command string \
 public-token
func (m *MyModule) Example(ctx context.Context, name string, command string) string  {
	return dag.
			Gha().
			Job(name, command).
			PublicToken(ctx)
}
@function
async def example(name: str, command: str) -> str:
	return await (
		dag.gha()
		.job(name, command)
		.public_token()
	)
@func()
async example(name: string, command: string): Promise<string> {
	return dag
		.gha()
		.job(name, command)
		.publicToken()
}

cloudEngine() 🔗

CloudEngine indicates whether to use Dagger Cloud Engine to run this workflow.

Return Type
Boolean !
Example
dagger -m github.com/pythoninthegrass/dagger/modules/gha@82a8462b016a936ff979930e0adc35e7f04d9d6c call \
 job --name string --command string \
 cloud-engine
func (m *MyModule) Example(ctx context.Context, name string, command string) bool  {
	return dag.
			Gha().
			Job(name, command).
			CloudEngine(ctx)
}
@function
async def example(name: str, command: str) -> bool:
	return await (
		dag.gha()
		.job(name, command)
		.cloud_engine()
	)
@func()
async example(name: string, command: string): Promise<boolean> {
	return dag
		.gha()
		.job(name, command)
		.cloudEngine()
}

stopEngine() 🔗

Explicitly stop the dagger engine after completing the workflow.

Return Type
Boolean !
Example
dagger -m github.com/pythoninthegrass/dagger/modules/gha@82a8462b016a936ff979930e0adc35e7f04d9d6c call \
 job --name string --command string \
 stop-engine
func (m *MyModule) Example(ctx context.Context, name string, command string) bool  {
	return dag.
			Gha().
			Job(name, command).
			StopEngine(ctx)
}
@function
async def example(name: str, command: str) -> bool:
	return await (
		dag.gha()
		.job(name, command)
		.stop_engine()
	)
@func()
async example(name: string, command: string): Promise<boolean> {
	return dag
		.gha()
		.job(name, command)
		.stopEngine()
}