schema

package
v0.9.8 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Feb 1, 2024 License: Apache-2.0 Imports: 52 Imported by: 1

README

Core API proposal

This directory contains a proposal for a complete GraphQL API for Dagger. It is written with the following goals in mind:

  1. Feature parity with Dagger 0.2
  2. Close to feature parity with Buildkit, with an incremental path to reaching full parity in the future
  3. Follow established graphql best practices
  4. Sove as many outstanding DX problems as possible

Reference

DX problems solved

Some problems in the DX that are not yet resolved, and this proposal would help solve, include:

  • Uncertainty as to how to express uploads in a graphql-friendly way (deployment, image push, git push, etc)
  • Chaining of FS operations greatly reduces verbosity, but cannot be applied all the time
  • Transitioning a script to an extension requires non-trivial refactoring, to tease apart the script-specific code from the underlying "API".
  • The API sandbox is amazing for prototyping small queries, but of limited use when multiple queries must reference each other. This is because the native code doing the stitching cannot be run by the playground, so filesystem IDs must be manually copy-pasted between queries.

Design highlights

withX and withoutX

To avoid the use of rpc-style verbs (a graphql best practice) and maximize chaining (a strength of our DX), we use the terminology withX and withoutX.

A field of the form withX returns the same object with content X added or changed.

Example:

"An empty directory with a README copied to it"
query readmeDir($readme: FileID!) {
  directory {
    withFile(source: $readme, path: "README.md") {
      id
    }
}

"An empty container with an app directory mounted into it"
query appContainer($app: DirectoryID!) {
  container {
    withMountedDirectory(source: $app, path: "/app") {
      id
    }
  }
}

A field of the form withoutX returns the same object with content X removed.

"Remove node_modules from a JS project"
query removeNodeModules($dir: DirectoryID!) {
  directory(id: $dir) {
    withoutDirectory(path: "node_modules") {
      id
    }
  }
}
Secrets

Secret handling has been simplified and made more consistent with Directory handling.

  • Secrets have an ID, and can be loaded by ID in the standard graphql manner
  • Secrets can be created in one of two ways:
    1. From an environment variable: type Environment { secret }
    2. From a file: type Directory { secret }
Embrace the llb / Dockerfile model

The Container type proposes an expansive definition of the container, similar to the Buildkit/Dockerfile model. A Container is:

  1. A filesystem state
  2. An OCI artifact which can be pulled from, and pushed to a repository at any time
  3. A persistent configuration to be applied to all commands executed inside it

This is similar to how buildkit models llb state, and how the Dockerfile language models stage state. Note that Dagger extends this model to include even mount configuration (which are scoped to exec in buildkit, but scoped to container in dagger).

Examples:

"""
Download a file over HTTP in a very convoluted way:

1. Download a base linux container
2. Install curl
3. Download the file into the container
4. Load and return the file
"""
query convolutedDownload($url: String!) {
  container {
    from(address: "index.docker.io/alpine:latest") {
      exec(args: ["apk", "add", "curl"]) {
        exec(args: ["curl", "-o", "/tmp/download", $url) {
          file(path: "/tmp/download") {
            id
         }
      }
    }
  }
}

"""
Specialize two containers from a common base
"""
query twoContainers {
  container {
    from(address: "alpine") {
      debug: withVariable(name: "DEBUG", value: "1") {
        id
        exec(args: ["env"]) {
          stdout
        }
      }
      noDebug: withVariable(name: "DEBUG", value: "0") {
        id
        exec(args: ["env"]) {
          stdout
        }
      }
    }
  }
}

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func Syncer added in v0.9.7

func Syncer[T Evaluatable]() dagql.Field[T]

Types

type APIServer added in v0.9.4

type APIServer struct {
	// contains filtered or unexported fields
}

func New

func New(ctx context.Context, params InitializeArgs) (*APIServer, error)

func (*APIServer) CurrentServedDeps added in v0.9.6

func (s *APIServer) CurrentServedDeps(ctx context.Context) (*core.ModDeps, error)

func (*APIServer) Introspect added in v0.9.7

func (s *APIServer) Introspect(ctx context.Context) (string, error)

func (*APIServer) ServeHTTP added in v0.9.4

func (s *APIServer) ServeHTTP(w http.ResponseWriter, r *http.Request)

func (*APIServer) ShutdownClient added in v0.9.4

func (s *APIServer) ShutdownClient(ctx context.Context, client *engine.ClientMetadata) error

type CoreMod added in v0.9.4

type CoreMod struct {
	// contains filtered or unexported fields
}

CoreMod is a special implementation of Mod for our core API, which is not *technically* a true module yet but can be treated as one in terms of dependencies. It has no dependencies itself and is currently an implicit dependency of every user module.

func (*CoreMod) Dependencies added in v0.9.4

func (m *CoreMod) Dependencies() []core.Mod

func (*CoreMod) Install added in v0.9.7

func (m *CoreMod) Install(ctx context.Context, dag *dagql.Server) error

func (*CoreMod) ModTypeFor added in v0.9.4

func (m *CoreMod) ModTypeFor(ctx context.Context, typeDef *core.TypeDef, checkDirectDeps bool) (core.ModType, bool, error)

func (*CoreMod) Name added in v0.9.4

func (m *CoreMod) Name() string

func (*CoreMod) TypeDefs added in v0.9.6

func (m *CoreMod) TypeDefs(ctx context.Context) ([]*core.TypeDef, error)

type CoreModObject added in v0.9.4

type CoreModObject struct {
	// contains filtered or unexported fields
}

CoreModObject represents objects from core (Container, Directory, etc.)

func (*CoreModObject) ConvertFromSDKResult added in v0.9.4

func (obj *CoreModObject) ConvertFromSDKResult(ctx context.Context, value any) (dagql.Typed, error)

func (*CoreModObject) ConvertToSDKInput added in v0.9.4

func (obj *CoreModObject) ConvertToSDKInput(ctx context.Context, value dagql.Typed) (any, error)

func (*CoreModObject) SourceMod added in v0.9.4

func (obj *CoreModObject) SourceMod() core.Mod

func (*CoreModObject) TypeDef added in v0.9.6

func (obj *CoreModObject) TypeDef() *core.TypeDef

type EnvVariable

type EnvVariable struct {
	Name  string `field:"true" doc:"The environment variable name."`
	Value string `field:"true" doc:"The environment variable value."`
}

func (EnvVariable) Description added in v0.9.7

func (EnvVariable) Description() string

func (EnvVariable) Type added in v0.9.7

func (EnvVariable) Type() *ast.Type

func (EnvVariable) TypeDescription added in v0.9.7

func (EnvVariable) TypeDescription() string

type Evaluatable added in v0.9.7

type Evaluatable interface {
	dagql.Typed
	Evaluate(context.Context) (*buildkit.Result, error)
}

type InitializeArgs

type InitializeArgs struct {
	BuildkitClient *buildkit.Client
	Platform       specs.Platform
	ProgSockPath   string
	OCIStore       content.Store
	LeaseManager   *leaseutil.Manager
	Auth           *auth.RegistryAuthProvider
	Secrets        *core.SecretStore
}

type Label added in v0.3.10

type Label struct {
	Name  string `field:"true" doc:"The label name."`
	Value string `field:"true" doc:"The label value."`
}

func (Label) Type added in v0.9.7

func (Label) Type() *ast.Type

func (Label) TypeDescription added in v0.9.7

func (Label) TypeDescription() string

type SchemaResolvers added in v0.9.4

type SchemaResolvers interface {
	Install()
}

type WithDirectoryArgs added in v0.9.7

type WithDirectoryArgs struct {
	Path      string
	Directory core.DirectoryID

	core.CopyFilter
}

type WithFileArgs added in v0.9.7

type WithFileArgs struct {
	Path        string
	Source      core.FileID
	Permissions *int
}

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL