Welcome! This is the official template for creating and publishing packages for Rayforge. A "package" can be a code-based plugin, a collection of assets (like recipes and machine profiles), or both.
This template includes a pre-configured GitHub Actions workflow that automatically announces your new releases to the central Rayforge Registry.
Follow these steps to get your package published.
Click the "Use this template" button at the top of this repository's page on GitHub. Ensure the new repository is public, as the Rayforge app will need to be able to clone it.
Private repositories are not supported.
Open the rayforge-package.yaml file and edit the placeholder values to describe
your package.
- Code: Place your Python source code in the folder you used in
rayforge-package.yaml. - Assets: Place your assets (recipes, profiles, etc.) in the
assets/directory and ensure the paths inrayforge-package.yamlare correct.
The automated release workflow needs a token with minimal permissions to announce your releases.
-
Create a Personal Access Token (PAT):
- Go to your GitHub Settings > Developer settings > Personal access tokens > Tokens (classic).
- Click "Generate new token" (classic).
- Give it a descriptive name (e.g.,
Rayforge Registry Announcer). - Set an expiration date (e.g., 1 year).
- Under "Select scopes," check only the box for
repo. - Click "Generate token" and copy the token immediately. You will not see it again.
-
Add the Token to Your Repository Secrets:
- Go to your new repository's Settings > Secrets and variables > Actions.
- Click "New repository secret".
- For the Name, enter
REGISTRY_ACCESS_TOKEN. - For the Secret, paste the Personal Access Token you just copied.
- Click "Add secret".
You're all set! To publish a version, all you need to do is create and push a Git tag.
# Commit all your changes first
git add .
git commit -m "feat: Initial release v1.0.0"
# Create and push a semantic version tag
git tag v1.0.0
git push origin v1.0.0That's it! The GitHub Action in this repository will automatically run and submit your new version to the central Rayforge Registry.
- Use Semantic Versioning: Your tags must follow the
vX.Y.Zformat (e.g.,v1.0.0,v1.2.3). - Keep Your Repository Public: The Rayforge client needs to be able to clone your repository to install the package.
- Don't Modify the Workflow: The
.github/workflows/release.ymlfile is designed to work out-of-the-box. - Choose a License: This template includes a placeholder
LICENSEfile. Please replace it with an open-source license of your choice.