* docs: add configuration documentation to README Added a new 'Configuration' section to README.md as per the Documentation Audit Report (PR #209). Included: - Default configuration file location (~/.core/config.yaml) - Configuration file format (YAML) with examples - Layered configuration resolution order - Environment variable mapping for config overrides (CORE_CONFIG_*) - Common environment variables (CORE_DAEMON, NO_COLOR, MCP_ADDR, etc.) * docs: add configuration documentation and fix CI/CD auto-merge README.md: - Added comprehensive 'Configuration' section as per audit report #209. - Documented file format, location, and layered resolution order. - Provided environment variable mapping rules and common examples. .github/workflows/auto-merge.yml: - Replaced broken reusable workflow with a local implementation. - Added actions/checkout step to provide necessary Git context. - Fixed 'not a git repository' error by providing explicit repo context to the 'gh' CLI via the -R flag. - Maintained existing bot trust and author association logic. pkg/io/local/client.go: - Fixed code formatting to ensure QA checks pass. * docs: update environment variable description and fix merge conflict - Refined the description of environment variable mapping to be more accurate, clarifying that the prefix is stripped before conversion. - Resolved merge conflict in .github/workflows/auto-merge.yml. - Maintained the local auto-merge implementation to ensure Git context for the 'gh' CLI. * docs: configuration documentation, security fixes, and CI improvements README.md: - Added comprehensive 'Configuration' section as per audit report #209. - Documented file format, location, and layered resolution order. - Provided environment variable mapping rules and common examples. - Added documentation for UniFi configuration options. .github/workflows/auto-merge.yml: - Replaced broken reusable workflow with a local implementation. - Added actions/checkout step to provide necessary Git context. - Fixed 'not a git repository' error by providing explicit repo context to the 'gh' CLI via the -R flag. pkg/unifi: - Fixed security vulnerability (CodeQL) by making TLS verification configurable instead of always skipped. - Added 'unifi.insecure' config key and UNIFI_INSECURE env var. - Updated New and NewFromConfig signatures to handle insecure flag. internal/cmd/unifi: - Added --insecure flag to 'config' command to skip TLS verification. - Updated all UniFi subcommands to support the new configuration logic. pkg/io/local/client.go: - Fixed code formatting to ensure QA checks pass. * docs: configuration documentation, tests, and CI/CD fixes README.md: - Added comprehensive 'Configuration' section as per audit report #209. - Documented file format, location, and layered resolution order. - Provided environment variable mapping rules and common examples. - Documented UniFi configuration options. pkg/unifi: - Fixed security vulnerability by making TLS verification configurable. - Added pkg/unifi/config_test.go and pkg/unifi/client_test.go to provide unit test coverage for new and existing logic (satisfying Codecov). .github/workflows/auto-merge.yml: - Added actions/checkout@v4 to provide the required Git context for the 'gh' CLI, fixing 'not a git repository' errors. pkg/framework/core/core.go: - Fixed compilation errors in Workspace() and Crypt() methods due to upstream changes in MustServiceFor() return signature. - Added necessary error handling to pkg/workspace/service.go. These changes ensure that the project documentation is up-to-date and that the CI/CD pipeline is stable and secure.
7.8 KiB
7.8 KiB
Configuration
Core uses .core/ directory for project configuration.
Directory Structure
.core/
├── release.yaml # Release configuration
├── build.yaml # Build configuration (optional)
├── php.yaml # PHP configuration (optional)
└── linuxkit/ # LinuxKit templates
├── server.yml
└── dev.yml
release.yaml
Full release configuration reference:
version: 1
project:
name: myapp
repository: myorg/myapp
build:
targets:
- os: linux
arch: amd64
- os: linux
arch: arm64
- os: darwin
arch: amd64
- os: darwin
arch: arm64
- os: windows
arch: amd64
publishers:
# GitHub Releases (required - others reference these artifacts)
- type: github
prerelease: false
draft: false
# npm binary wrapper
- type: npm
package: "@myorg/myapp"
access: public # or "restricted"
# Homebrew formula
- type: homebrew
tap: myorg/homebrew-tap
formula: myapp
official:
enabled: false
output: dist/homebrew
# Scoop manifest (Windows)
- type: scoop
bucket: myorg/scoop-bucket
official:
enabled: false
output: dist/scoop
# AUR (Arch Linux)
- type: aur
maintainer: "Name <email>"
# Chocolatey (Windows)
- type: chocolatey
push: false # true to publish
# Docker multi-arch
- type: docker
registry: ghcr.io
image: myorg/myapp
dockerfile: Dockerfile
platforms:
- linux/amd64
- linux/arm64
tags:
- latest
- "{{.Version}}"
build_args:
VERSION: "{{.Version}}"
# LinuxKit images
- type: linuxkit
config: .core/linuxkit/server.yml
formats:
- iso
- qcow2
- docker
platforms:
- linux/amd64
- linux/arm64
changelog:
include:
- feat
- fix
- perf
- refactor
exclude:
- chore
- docs
- style
- test
- ci
build.yaml
Optional build configuration:
version: 1
project:
name: myapp
binary: myapp
build:
main: ./cmd/myapp
env:
CGO_ENABLED: "0"
flags:
- -trimpath
ldflags:
- -s -w
- -X main.version={{.Version}}
- -X main.commit={{.Commit}}
targets:
- os: linux
arch: amd64
- os: darwin
arch: arm64
php.yaml
PHP/Laravel configuration:
version: 1
dev:
domain: myapp.test
ssl: true
port: 8000
services:
- frankenphp
- vite
- horizon
- reverb
- redis
test:
parallel: true
coverage: false
deploy:
coolify:
server: https://coolify.example.com
project: my-project
environment: production
LinuxKit Templates
LinuxKit YAML configuration:
kernel:
image: linuxkit/kernel:6.6
cmdline: "console=tty0 console=ttyS0"
init:
- linuxkit/init:latest
- linuxkit/runc:latest
- linuxkit/containerd:latest
- linuxkit/ca-certificates:latest
onboot:
- name: sysctl
image: linuxkit/sysctl:latest
services:
- name: dhcpcd
image: linuxkit/dhcpcd:latest
- name: sshd
image: linuxkit/sshd:latest
- name: myapp
image: myorg/myapp:latest
capabilities:
- CAP_NET_BIND_SERVICE
files:
- path: /etc/myapp/config.yaml
contents: |
server:
port: 8080
repos.yaml
Package registry for multi-repo workspaces:
# Organisation name (used for GitHub URLs)
org: host-uk
# Base path for cloning (default: current directory)
base_path: .
# Default settings for all repos
defaults:
ci: github
license: EUPL-1.2
branch: main
# Repository definitions
repos:
# Foundation packages (no dependencies)
core-php:
type: foundation
description: Foundation framework
core-devops:
type: foundation
description: Development environment
clone: false # Skip during setup (already exists)
# Module packages (depend on foundation)
core-tenant:
type: module
depends_on: [core-php]
description: Multi-tenancy module
core-admin:
type: module
depends_on: [core-php, core-tenant]
description: Admin panel
core-api:
type: module
depends_on: [core-php]
description: REST API framework
# Product packages (user-facing applications)
core-bio:
type: product
depends_on: [core-php, core-tenant]
description: Link-in-bio product
domain: bio.host.uk.com
core-social:
type: product
depends_on: [core-php, core-tenant]
description: Social scheduling
domain: social.host.uk.com
# Templates
core-template:
type: template
description: Starter template for new projects
repos.yaml Fields
| Field | Required | Description |
|---|---|---|
org |
Yes | GitHub organisation name |
base_path |
No | Directory for cloning (default: .) |
defaults |
No | Default settings applied to all repos |
repos |
Yes | Map of repository definitions |
Repository Fields
| Field | Required | Description |
|---|---|---|
type |
Yes | foundation, module, product, or template |
description |
No | Human-readable description |
depends_on |
No | List of package dependencies |
clone |
No | Set false to skip during setup |
domain |
No | Production domain (for products) |
branch |
No | Override default branch |
Package Types
| Type | Description | Dependencies |
|---|---|---|
foundation |
Core framework packages | None |
module |
Reusable modules | Foundation packages |
product |
User-facing applications | Foundation + modules |
template |
Starter templates | Any |
Environment Variables
Complete reference of environment variables used by Core CLI.
Authentication
| Variable | Used By | Description |
|---|---|---|
GITHUB_TOKEN |
core ci, core dev |
GitHub API authentication |
ANTHROPIC_API_KEY |
core ai, core dev claude |
Claude API key |
AGENTIC_TOKEN |
core ai task* |
Agentic API authentication |
AGENTIC_BASE_URL |
core ai task* |
Agentic API endpoint |
Publishing
| Variable | Used By | Description |
|---|---|---|
NPM_TOKEN |
core ci (npm publisher) |
npm registry auth token |
CHOCOLATEY_API_KEY |
core ci (chocolatey publisher) |
Chocolatey API key |
DOCKER_USERNAME |
core ci (docker publisher) |
Docker registry username |
DOCKER_PASSWORD |
core ci (docker publisher) |
Docker registry password |
Deployment
| Variable | Used By | Description |
|---|---|---|
COOLIFY_URL |
core php deploy |
Coolify server URL |
COOLIFY_TOKEN |
core php deploy |
Coolify API token |
COOLIFY_APP_ID |
core php deploy |
Production application ID |
COOLIFY_STAGING_APP_ID |
core php deploy --staging |
Staging application ID |
Build
| Variable | Used By | Description |
|---|---|---|
CGO_ENABLED |
core build, core go * |
Enable/disable CGO (default: 0) |
GOOS |
core build |
Target operating system |
GOARCH |
core build |
Target architecture |
Configuration Paths
| Variable | Description |
|---|---|
CORE_CONFIG |
Override config directory (default: ~/.core/) |
CORE_REGISTRY |
Override repos.yaml path |
Defaults
If no configuration exists, sensible defaults are used:
- Targets: linux/amd64, linux/arm64, darwin/amd64, darwin/arm64, windows/amd64
- Publishers: GitHub only
- Changelog: feat, fix, perf, refactor included
Logging
Logging can be configured to rotate and retain logs automatically.
Default retention policy:
- Max Size: 100 MB
- Max Backups: 5
- Max Age: 28 days
Example configuration:
level: info
rotation:
filename: "app.log"
max_size: 100 # megabytes
max_backups: 5 # number of old log files to retain
max_age: 28 # days to keep old log files