diff --git a/.devcontainer/Dockerfile b/.devcontainer/Dockerfile new file mode 100644 index 0000000000..b7d7f41873 --- /dev/null +++ b/.devcontainer/Dockerfile @@ -0,0 +1,2 @@ +ARG VARIANT="dev-1.26-bookworm" +FROM mcr.microsoft.com/vscode/devcontainers/go:${VARIANT} diff --git a/.devcontainer/devcontainer.json b/.devcontainer/devcontainer.json new file mode 100644 index 0000000000..8de0b02988 --- /dev/null +++ b/.devcontainer/devcontainer.json @@ -0,0 +1,57 @@ +// For format details, see https://aka.ms/devcontainer.json. For config options, see the README at: +// https://github.com/microsoft/vscode-dev-containers/tree/v0.231.6/containers/go +{ + "name": "Go", + "build": { + "dockerfile": "Dockerfile", + "args": { + // Update the VARIANT arg to pick a version of Go: 1, 1.18, 1.17 + // Append -bullseye or -buster to pin to an OS version. + // Use -bullseye variants on local arm64/Apple Silicon. + "VARIANT": "dev-1.26-bookworm", + // Options + "NODE_VERSION": "none" + } + }, + // Note: Avoid elevated container privileges by default, especially in CI. + // If you *must* enable debugging that requires ptrace locally, you can + // temporarily add: + // "runArgs": [ "--cap-add=SYS_PTRACE", "--security-opt", "seccomp=unconfined" ], + + // Set *default* container specific settings.json values on container create. + "settings": { + "go.toolsManagement.checkForUpdates": "local", + "go.useLanguageServer": true, + "go.gopath": "/go" + }, + + // Add the IDs of extensions you want installed when the container is created. + "extensions": [ + "golang.Go" + ], + "containerEnv": { + // Access key of a token + "SCW_ACCESS_KEY": "${localEnv:SCW_ACCESS_KEY}", + // Secret key of a token + "SCW_SECRET_KEY": "${localEnv:SCW_SECRET_KEY}", + // Url of the API + //"SCW_API_URL": "${localEnv:SCW_API_URL}", + // Your default availability zone (fr-par-1, nl-ams-1, ...) + //"SCW_DEFAULT_ZONE": "${localEnv:SCW_DEFAULT_ZONE}", + // Your default region (fr-par, nl-ams, ...) + //"SCW_DEFAULT_REGION": "${localEnv:SCW_DEFAULT_REGION}", + // Your default project ID + "SCW_DEFAULT_PROJECT_ID": "${localEnv:SCW_DEFAULT_PROJECT_ID}", + // Your default organization ID + "SCW_DEFAULT_ORGANIZATION_ID": "${localEnv:SCW_DEFAULT_ORGANIZATION_ID}" + }, + + // Use 'forwardPorts' to make a list of ports inside the container available locally. + // "forwardPorts": [], + + // Use 'postCreateCommand' to run commands after the container is created. + // "postCreateCommand": "go version", + + // Comment out to connect as root instead. More info: https://aka.ms/vscode-remote/containers/non-root. + "remoteUser": "vscode" +} diff --git a/.github/dependabot.yml b/.github/dependabot.yml index f74f5dd007..e765353a20 100644 --- a/.github/dependabot.yml +++ b/.github/dependabot.yml @@ -27,3 +27,8 @@ updates: directory: "/wasm" schedule: interval: monthly + + - package-ecosystem: devcontainers + directory: "/" + schedule: + interval: monthly diff --git a/.github/workflows/devcontainer.yml b/.github/workflows/devcontainer.yml new file mode 100644 index 0000000000..5a59e8dc35 --- /dev/null +++ b/.github/workflows/devcontainer.yml @@ -0,0 +1,20 @@ +name: Dev Container Check + +permissions: + contents: read + +on: + pull_request: + merge_group: + +jobs: + build: + runs-on: ubuntu-latest + steps: + - name: Checkout code + uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 + + - name: Build and Run Dev Container + uses: devcontainers/ci@8bf61b26e9c3a98f69cb6ce2f88d24ff59b785c6 # v0.3.1900000417 + with: + runCmd: go run ./cmd/scw --help