View Repository
Browse the reusable GitHub Actions workflows repository
Already have a build pipeline? You can use individual reusable actions (like
notify-cnap) to integrate CNAP notifications into your existing workflows. See Using Individual Actions → for details.What It Does
The CNAP GitHub Actions workflows automate the entire build and deployment pipeline:- Checkout code - Retrieves your repository code
- Language detection - Railpack automatically detects your language and framework
- Build configuration - Automatically configures build and runtime settings
- Image building - Builds a production-ready Docker image using Railpack
- Registry push - Pushes the image to GitHub Container Registry (GHCR)
- CNAP notification - Automatically notifies CNAP about the new image
Quick Start
Add the workflow to your repository with zero configuration:- Detects your application’s language and framework
- Builds a Docker image using Railpack
- Pushes to
ghcr.io/your-username/your-repo:sha-<commit-sha> - Notifies CNAP about the new build
Configuration Options
You can customize the workflow behavior with optional inputs:Directory containing your application code. Use this for monorepos or projects with multiple applications.
Override Railpack’s automatically detected build command. If not specified, Railpack analyzes your code to determine the build command.
Override Railpack’s automatically detected start command. If not specified, Railpack analyzes your code to determine the start command.
Space-separated list of additional apt packages needed during the build phase (e.g.,
python3-dev libpq-dev).Space-separated list of additional apt packages needed at runtime (e.g.,
postgresql-client curl).Custom Build Context
For monorepos or projects with multiple applications:Custom Dependencies
Add system packages for build or runtime:Supported Languages
Railpack supports 10+ languages and frameworks with automatic detection:- Node.js - Express, Next.js, SvelteKit, Remix, Nuxt
- Python - Django, FastAPI, Flask
- Go - Gin, Echo, Chi
- PHP - Laravel, Symfony
- Java - Spring Boot, Quarkus
- Ruby - Rails, Sinatra
- Rust - Actix, Rocket, Axum
- Deno - Web frameworks
- Elixir - Phoenix
- Static files - HTML, CSS, JavaScript
- Shell scripts - Bash applications
How It Works with CNAP
When you connect a GitHub repository to CNAP and the workflow runs:- Workflow builds image - The GitHub Actions workflow builds your application using Railpack
- Image pushed to GHCR - The built image is pushed to GitHub Container Registry
- CNAP notified - The workflow automatically notifies CNAP about the new build
- Build appears in CNAP - The build shows up in your product’s build history
- Ready to deploy - You can select the new build when creating or updating installations
The workflow uses OIDC authentication to securely notify CNAP without requiring API keys or secrets. The
id-token: write permission enables this secure authentication method.Integration with CNAP Products
When you create a product in CNAP using a GitHub repository source:- Repository connected - CNAP connects to your GitHub repository via GitHub App
- Builds detected - CNAP automatically detects builds from the workflow
- Images available - Built images appear in the build selection interface
- Automatic updates - New builds automatically appear when the workflow runs
Using Individual Actions
The reusable workflow is composed of individual reusable actions that you can use independently in your existing pipelines. This is useful when you already have a build process and just need to notify CNAP about new images.Notify CNAP After Existing Build
If you already have a workflow that builds Docker images, you can use thenotify-cnap action to notify CNAP at the end of your pipeline:
notify-cnap Action Parameters
Full Docker image name including registry and tag (e.g.,
ghcr.io/owner/repo:sha-abc123).Image tag, usually the commit SHA. This is used by CNAP to identify the specific build.
CNAP API URL for build notifications. Only change this if you’re using a custom CNAP instance.
Available Actions
The repository provides these reusable actions:| Action | Description | Use Case |
|---|---|---|
notify-cnap | Sends build notification to CNAP API | Use at the end of any pipeline that builds Docker images |
build-railpack | Builds a Docker image using Railpack | Use when you want Railpack builds but need custom workflow steps |
setup-buildkit | Starts a BuildKit container | Use when you need BuildKit for custom builds |
stop-buildkit | Stops the BuildKit container | Use to clean up BuildKit after builds |
generate-railpack-config | Generates Railpack configuration file | Use when you need custom Railpack config |
Using Build-Railpack Action
If you want to use Railpack for building but need more control over your workflow:build-railpack Action Parameters
Full Docker image name including registry and tag (e.g.,
ghcr.io/owner/repo:sha-abc123).Directory containing application code. Use this for monorepos or projects with multiple applications.
Override Railpack’s automatically detected build command. If not specified, Railpack analyzes your code to determine the build command.
Override Railpack’s automatically detected start command. If not specified, Railpack analyzes your code to determine the start command.
Advanced Usage
Custom Build Commands
Override Railpack’s automatic detection:Multiple Environments
Deploy different branches to different environments:Related Topics
- GitHub Integration → - Learn how to connect GitHub repositories to CNAP
- Application Sources → - Understand GitHub repository sources
- Generic App Chart → - See how GitHub deployments use the generic chart
- Create a Product → - Create products from GitHub repositories