Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
20 changes: 10 additions & 10 deletions .dagger/debugger.go
Original file line number Diff line number Diff line change
Expand Up @@ -20,37 +20,37 @@ func (g *Greetings) DebugTests(

// Check if backend is broken
if _, berr := g.Backend.CheckDirectory(ctx, g.Backend.Source()); berr != nil {
ws := dag.Workspace(
ws := dag.CodeWorkspace(
g.Backend.Source(),
g.Backend.AsWorkspaceCheckable(),
g.Backend.AsCodeWorkspaceCheckable(),
)
env := dag.Env().
WithWorkspaceInput("workspace", ws, "workspace to read, write, and test code").
WithWorkspaceOutput("fixed", "workspace with fixed tests")
WithCodeWorkspaceInput("workspace", ws, "workspace to read, write, and test code").
WithCodeWorkspaceOutput("fixed", "workspace with fixed tests")
return dag.LLM(dagger.LLMOpts{Model: model}).
WithEnv(env).
WithPromptFile(prompt).
Env().
Output("fixed").
AsWorkspace().
AsCodeWorkspace().
Diff(ctx)
}

// Check if frontend is broken
if _, ferr := g.Frontend.CheckDirectory(ctx, g.Frontend.Source()); ferr != nil {
ws := dag.Workspace(
ws := dag.CodeWorkspace(
g.Frontend.Source(),
g.Frontend.AsWorkspaceCheckable(),
g.Frontend.AsCodeWorkspaceCheckable(),
)
env := dag.Env().
WithWorkspaceInput("workspace", ws, "workspace to read, write, and test code").
WithWorkspaceOutput("fixed", "workspace with fixed tests")
WithCodeWorkspaceInput("workspace", ws, "workspace to read, write, and test code").
WithCodeWorkspaceOutput("fixed", "workspace with fixed tests")
return dag.LLM(dagger.LLMOpts{Model: model}).
WithEnv(env).
WithPromptFile(prompt).
Env().
Output("fixed").
AsWorkspace().
AsCodeWorkspace().
Diff(ctx)
}

Expand Down
20 changes: 10 additions & 10 deletions .dagger/develop.go
Original file line number Diff line number Diff line change
Expand Up @@ -20,16 +20,16 @@ func (g *Greetings) Develop(
) *dagger.Directory {
prompt := dag.CurrentModule().Source().File("prompts/assignment.md")

ws := dag.Workspace(
ws := dag.CodeWorkspace(
g.Source,
// FIXME: no great way to determine which checker without submodule or self calls
g.Backend.AsWorkspaceCheckable(),
g.Backend.AsCodeWorkspaceCheckable(),
)

env := dag.Env().
WithWorkspaceInput("workspace", ws, "workspace to read, write, and test code").
WithCodeWorkspaceInput("workspace", ws, "workspace to read, write, and test code").
WithStringInput("assignment", assignment, "the assignment to complete").
WithWorkspaceOutput("completed", "workspace with developed solution")
WithCodeWorkspaceOutput("completed", "workspace with developed solution")
agent := dag.LLM(dagger.LLMOpts{Model: model}).
WithEnv(env).
WithPromptFile(prompt).
Expand All @@ -40,7 +40,7 @@ func (g *Greetings) Develop(
}
work := agent.Env().
Output("completed").
AsWorkspace()
AsCodeWorkspace()

return work.Work()
}
Expand Down Expand Up @@ -113,25 +113,25 @@ func (g *Greetings) DevelopFeedback(
// Run the agent
prompt := dag.CurrentModule().Source().File("prompts/feedback.md")

ws := dag.Workspace(
ws := dag.CodeWorkspace(
source,
// FIXME: no great way to determine which checker without submodule or self calls
g.Backend.AsWorkspaceCheckable(),
g.Backend.AsCodeWorkspaceCheckable(),
)

env := dag.Env().
WithWorkspaceInput("workspace", ws, "workspace to read, write, and test code").
WithCodeWorkspaceInput("workspace", ws, "workspace to read, write, and test code").
WithStringInput("description", assignment, "the description of the pull request").
WithStringInput("feedback", feedback, "the feedback on the pull request").
WithStringInput("diff", diff, "the git diff of the pull request code changes so far").
WithWorkspaceOutput("completed", "workspace result with the feedback implemented")
WithCodeWorkspaceOutput("completed", "workspace result with the feedback implemented")
agent := dag.LLM(dagger.LLMOpts{Model: model}).
WithEnv(env).
WithPromptFile(prompt).
Loop()
completed := agent.Env().
Output("completed").
AsWorkspace().
AsCodeWorkspace().
Work()
return completed, nil
}
Expand Down
79 changes: 41 additions & 38 deletions .dagger/go.mod
Original file line number Diff line number Diff line change
@@ -1,53 +1,56 @@
module github.com/kpenfound/greetings-api/.dagger

go 1.23.0

toolchain go1.23.6
go 1.25.0

require (
github.com/99designs/gqlgen v0.17.75
github.com/Khan/genqlient v0.8.1
golang.org/x/sync v0.15.0
github.com/dagger/otel-go v1.43.0
)

require (
dagger.io/dagger v0.20.6-0.20260415192040-7058e9313c72
github.com/99designs/gqlgen v0.17.89 // indirect
golang.org/x/sync v0.20.0 // indirect
)

require (
github.com/cenkalti/backoff/v4 v4.3.0 // indirect
github.com/cenkalti/backoff/v5 v5.0.2 // indirect
github.com/go-logr/logr v1.4.2 // indirect
github.com/cenkalti/backoff/v5 v5.0.3 // indirect
github.com/cespare/xxhash/v2 v2.3.0 // indirect
github.com/go-logr/logr v1.4.3 // indirect
github.com/go-logr/stdr v1.2.2 // indirect
github.com/google/uuid v1.6.0 // indirect
github.com/grpc-ecosystem/grpc-gateway/v2 v2.26.3 // indirect
github.com/sosodev/duration v1.3.1 // indirect
github.com/vektah/gqlparser/v2 v2.5.28
go.opentelemetry.io/auto/sdk v1.1.0 // indirect
go.opentelemetry.io/otel v1.36.0
go.opentelemetry.io/otel/exporters/otlp/otlplog/otlploggrpc v0.12.2
go.opentelemetry.io/otel/exporters/otlp/otlplog/otlploghttp v0.12.2
go.opentelemetry.io/otel/exporters/otlp/otlpmetric/otlpmetricgrpc v1.32.0
go.opentelemetry.io/otel/exporters/otlp/otlpmetric/otlpmetrichttp v1.32.0
go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.32.0 // indirect
go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracegrpc v1.32.0
go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp v1.32.0
go.opentelemetry.io/otel/log v0.12.2
go.opentelemetry.io/otel/metric v1.36.0
go.opentelemetry.io/otel/sdk v1.36.0
go.opentelemetry.io/otel/sdk/log v0.12.2
go.opentelemetry.io/otel/sdk/metric v1.36.0
go.opentelemetry.io/otel/trace v1.36.0
go.opentelemetry.io/proto/otlp v1.6.0
golang.org/x/net v0.41.0 // indirect
golang.org/x/sys v0.33.0 // indirect
golang.org/x/text v0.26.0 // indirect
google.golang.org/genproto/googleapis/api v0.0.0-20250519155744-55703ea1f237 // indirect
google.golang.org/genproto/googleapis/rpc v0.0.0-20250519155744-55703ea1f237 // indirect
google.golang.org/grpc v1.73.0
google.golang.org/protobuf v1.36.6 // indirect
github.com/grpc-ecosystem/grpc-gateway/v2 v2.28.0 // indirect
github.com/sosodev/duration v1.4.0 // indirect
github.com/vektah/gqlparser/v2 v2.5.32
go.opentelemetry.io/auto/sdk v1.2.1 // indirect
go.opentelemetry.io/otel v1.43.0
go.opentelemetry.io/otel/exporters/otlp/otlplog/otlploggrpc v0.17.0 // indirect
go.opentelemetry.io/otel/exporters/otlp/otlplog/otlploghttp v0.17.0 // indirect
go.opentelemetry.io/otel/exporters/otlp/otlpmetric/otlpmetricgrpc v1.41.0 // indirect
go.opentelemetry.io/otel/exporters/otlp/otlpmetric/otlpmetrichttp v1.41.0 // indirect
go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.41.0 // indirect
go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracegrpc v1.41.0 // indirect
go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp v1.41.0 // indirect
go.opentelemetry.io/otel/log v0.17.0 // indirect
go.opentelemetry.io/otel/metric v1.43.0 // indirect
go.opentelemetry.io/otel/sdk v1.43.0
go.opentelemetry.io/otel/sdk/log v0.17.0 // indirect
go.opentelemetry.io/otel/sdk/metric v1.43.0 // indirect
go.opentelemetry.io/otel/trace v1.43.0
go.opentelemetry.io/proto/otlp v1.9.0 // indirect
golang.org/x/net v0.51.0 // indirect
golang.org/x/sys v0.43.0 // indirect
golang.org/x/text v0.34.0 // indirect
google.golang.org/genproto/googleapis/api v0.0.0-20260226221140-a57be14db171 // indirect
google.golang.org/genproto/googleapis/rpc v0.0.0-20260226221140-a57be14db171 // indirect
google.golang.org/grpc v1.79.3 // indirect
google.golang.org/protobuf v1.36.11 // indirect
)

replace go.opentelemetry.io/otel/exporters/otlp/otlplog/otlploggrpc => go.opentelemetry.io/otel/exporters/otlp/otlplog/otlploggrpc v0.12.2
replace go.opentelemetry.io/otel/exporters/otlp/otlplog/otlploggrpc => go.opentelemetry.io/otel/exporters/otlp/otlplog/otlploggrpc v0.16.0

replace go.opentelemetry.io/otel/exporters/otlp/otlplog/otlploghttp => go.opentelemetry.io/otel/exporters/otlp/otlplog/otlploghttp v0.12.2
replace go.opentelemetry.io/otel/exporters/otlp/otlplog/otlploghttp => go.opentelemetry.io/otel/exporters/otlp/otlplog/otlploghttp v0.16.0

replace go.opentelemetry.io/otel/log => go.opentelemetry.io/otel/log v0.12.2
replace go.opentelemetry.io/otel/log => go.opentelemetry.io/otel/log v0.16.0

replace go.opentelemetry.io/otel/sdk/log => go.opentelemetry.io/otel/sdk/log v0.12.2
replace go.opentelemetry.io/otel/sdk/log => go.opentelemetry.io/otel/sdk/log v0.16.0
Loading
Loading