docs: deploy using dagger

Signed-off-by: Andrea Luzzardi <aluzzardi@gmail.com>
This commit is contained in:
Andrea Luzzardi 2021-05-28 20:11:17 -07:00
parent 39527b761d
commit c95b5d2bae
7 changed files with 229 additions and 0 deletions

2
.dagger/env/docs/.gitignore vendored Normal file
View File

@ -0,0 +1,2 @@
# dagger state
state/**

95
.dagger/env/docs/plan/main.cue vendored Normal file
View File

@ -0,0 +1,95 @@
package main
import (
"encoding/json"
"dagger.io/dagger"
"dagger.io/os"
"dagger.io/js/yarn"
"dagger.io/git"
"dagger.io/docker"
"dagger.io/aws"
"dagger.io/aws/s3"
)
// dagger repository
repository: dagger.#Artifact @dagger(input)
// docs version
version: string | *"devel" @dagger(input)
// if repository is checked out at a tag, use it as the version
tag: git.#CurrentBranch & {
"repository": repository
}
if (tag.name & =~"^v") != _|_ {
version: tag.name
}
// AWS credentials
awsConfig: aws.#Config @dagger(input)
// Lint the markdowns
lint: os.#Container & {
image: docker.#Pull & {
from: "tmknom/markdownlint:0.23.1"
}
command: "markdownlint ./docs"
dir: "/src"
mount: "/src": from: repository
}
// Build the docs website
docs: yarn.#Package & {
source: repository
cwd: "./tools/gendocs"
buildDir: "./tools/gendocs/public"
args: ["--prefix-paths"]
env: VERSION: version
}
// Upload to S3
website: s3.#Sync & {
config: awsConfig
source: docs.build
delete: true
target: "s3://docs.dagger.io/\(version)/"
}
// generate and upload a `tags.json` file for the navbar version selector
tags: git.#Tags & {
"repository": repository
}
versions: [ for name in tags.tags {tag: name}, {
tag: "devel"
}]
versionsObject: s3.#Put & {
config: awsConfig
sourceInline: json.Marshal(versions)
contentType: "application/json"
target: "s3://docs.dagger.io/tags.json"
}
// if we're building a release, redirect the docs website to this page
if version != "devel" {
redirect: s3.#Put & {
config: awsConfig
sourceInline: #"""
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="refresh" content="0; url=/\#(version)">
</head>
<body>
Nothing to see here; <a href="/\#(version)">see the latest version of the docs</a>.
</body>
</html>
"""#
contentType: "text/html"
target: "s3://docs.dagger.io/index.html"
}
}

35
.dagger/env/docs/values.yaml vendored Normal file
View File

@ -0,0 +1,35 @@
name: docs
inputs:
awsConfig.accessKey:
secret: ENC[AES256_GCM,data:/KR+mkBb51etyZqiQnl4kxIl4vw=,iv:lFBuaqK9MVr5fYGMM8bN/XyZ9/oUInDWvzhYuK8Yj20=,tag:sHwcSTJ1lKzIDRYzr4Z/yg==,type:str]
awsConfig.region:
text: us-east-1
awsConfig.secretKey:
secret: ENC[AES256_GCM,data:0bHcnNwbKR2F+PKB/Xzs06zsvJHENPZHEcx9SUN3Sn2/fzf0fA2G2w==,iv:A306R2ldjigteL6c0jkvOxZbHtxhlobP2FuPknuf+N4=,tag:CvDqdrej34Kbh8Y7zG5O8Q==,type:str]
repository:
dir:
path: .
exclude:
- '**/node_modules'
- cmd/dagger/dagger
- cmd/dagger/dagger-debug
sops:
kms: []
gcp_kms: []
azure_kv: []
hc_vault: []
age:
- recipient: age1gxwmtwahzwdmrskhf90ppwlnze30lgpm056kuesrxzeuyclrwvpsupwtpk
enc: |
-----BEGIN AGE ENCRYPTED FILE-----
YWdlLWVuY3J5cHRpb24ub3JnL3YxCi0+IFgyNTUxOSBaZVVuYThsYk9YcWhYb0g4
TDhZQ21YN0FCRExKV2tqbVVUNTg5MWRUVUJzCndjc28yVUZEK3ZoQzVDQkk4emZQ
WGx2bUxSZlBENXlibzQ1MVkvc2I2MVkKLS0tIFJKS0ZENFhuVmdUM2h1a2xrK01a
ejRKQXNFZzBTbUxpc05acnkxQ2U2UkEKX1byNj64xOiRGAJ9lwh55d/mlasI3H6H
b+o3HbXSbV0G0UwQxEOisntR6o27ry/l12ai/sOQ4f9MXm6FRw2XTg==
-----END AGE ENCRYPTED FILE-----
lastmodified: "2021-05-29T02:37:17Z"
mac: ENC[AES256_GCM,data:mXlkcR6U0sQwXdk4mYMKmA6/tcZWVtQt76RVfYOj3uE89XgIUQhk5qts/fp8DMpOB90KZtUJB2Im2+ppqdhtKQO2xcp0Cj6WN1omYRdGbSAMBMPtIbbAdzMcZwvCScRvfDn1ecCSeHikTpDlvUImmoOJLH4ItvLq7JK3oUgPvUs=,iv:ckI70eAguY4p8eTI2W5Iws1zYaqkZuHcNWwjGBjbVYk=,tag:/hoRjWxK/5oxbmia4TgcKA==,type:str]
pgp: []
encrypted_suffix: secret
version: 3.7.1

View File

@ -213,6 +213,8 @@ func (p *Pipeline) doOp(ctx context.Context, op *compiler.Value, st llb.State) (
return p.Local(ctx, op, st)
case "load":
return p.Load(ctx, op, st)
case "workdir":
return p.Workdir(ctx, op, st)
case "subdir":
return p.Subdir(ctx, op, st)
case "docker-build":
@ -232,6 +234,14 @@ func (p *Pipeline) vertexNamef(format string, a ...interface{}) string {
return prefix + " " + name
}
func (p *Pipeline) Workdir(ctx context.Context, op *compiler.Value, st llb.State) (llb.State, error) {
path, err := op.Lookup("path").String()
if err != nil {
return st, err
}
return st.Dir(path), nil
}
func (p *Pipeline) Subdir(ctx context.Context, op *compiler.Value, st llb.State) (llb.State, error) {
// FIXME: this could be more optimized by carrying subdir path as metadata,
// and using it in copy, load or mount.

View File

@ -40,6 +40,11 @@ package op
dir: string
}
#Workdir: {
do: "workdir"
path: string
}
#Exec: {
do: "exec"
args: [...string]

View File

@ -12,6 +12,7 @@ package op
#Copy |
#Load |
#Subdir |
#Workdir |
#WriteFile |
#Mkdir |
#DockerBuild) & {do: string}

View File

@ -1,7 +1,9 @@
package git
import (
"dagger.io/dagger"
"dagger.io/dagger/op"
"dagger.io/alpine"
)
// A git repository
@ -23,3 +25,82 @@ import (
},
]
}
// Get the name of the current checked out branch or tag
#CurrentBranch: {
repository: dagger.#Artifact @dagger(input)
name: {
string
@dagger(output)
#up: [
op.#Load & {
from: alpine.#Image & {
package: bash: "=~5.1"
package: git: "=~2.30"
}
},
op.#Exec & {
mount: "/repository": from: repository
dir: "/repository"
args: [
"/bin/bash",
"--noprofile",
"--norc",
"-eo",
"pipefail",
"-c",
#"""
printf "$(git symbolic-ref -q --short HEAD || git describe --tags --exact-match)" > /name.txt
"""#,
]
},
op.#Export & {
source: "/name.txt"
format: "string"
},
]
}
}
// List tags of a repository
#Tags: {
repository: dagger.#Artifact @dagger(input)
tags: {
[...string]
@dagger(output)
#up: [
op.#Load & {
from: alpine.#Image & {
package: bash: "=~5.1"
package: jq: "=~1.6"
package: git: "=~2.30"
}
},
op.#Exec & {
mount: "/repository": from: repository
dir: "/repository"
args: [
"/bin/bash",
"--noprofile",
"--norc",
"-eo",
"pipefail",
"-c",
#"""
git tag -l | jq --raw-input --slurp 'split("\n") | map(select(. != ""))' > /tags.json
"""#,
]
},
op.#Export & {
source: "/tags.json"
format: "json"
},
]
}
}