The redhat-developer/rhdh-plugins
repository is designed as a collaborative space to host and manage plugins developed by Red Hat. This repository will provide plugin maintainers with tools for plugin management and publication. By contributing a plugin to this repository, maintainers agree to adhere to specific guidelines and a standardized release process detailed in this guide.
- Contributing to
redhat-developer/rhdh-plugins
The rhdh plugins repository is under Apache 2.0 license. All plugins added & moved to the repository will be kept under the same license. If you are moving a plugin over make sure that no other license file is in the plugin workspace & all package.json
files either have no version defined or explicitly use “Apache 2.0”.
Ok. So you're gonna want some code right? Go ahead and fork the repository into your own GitHub account and clone that code to your local machine. GitHub's Fork a repo documentation has a great step by step guide if you are not sure how to do this.
If you cloned a fork, you can add the upstream dependency like so:
git remote add upstream [email protected]:redhat-developer/rhdh-plugins.git
git pull upstream main
After you have cloned the RHDH Plugins repository, you should run the following commands once to set things up for development:
cd rhdh-plugins
yarn install
cd workspaces/noop
yarn install
Most plugins come with a standalone runner that you should be able to utilize in order to develop on your plugins in isolation. You can navigate to a workspace and a plugin inside the plugin folder and run yarn start
which should kick off the development standalone server for that plugin. It's also possible that this might not be setup for some plugins, in which case you can set them up following some prior art in the backstage/backstage
repository. backend plugin dev and frontend plugin dev examples.
There could be times when there is a need for a more rich development environment for a workspace. Say that the workspace and it's plugin depend on a full catalog, and maybe the kubernetes plugin already running too, that could be a bit of a pain to set up. In that case, there might be a full Backstage environment that you can run with yarn dev
in the workspace root, which will start up a full Backstage environment located in $WORKSPACE_ROOT/packages/app
and $WORKSPACE_ROOT/packages/backend
.
Important
Both the full Backstage environment and standalone runners are configured on a per-workspace basis. Be sure to check the workspace README.md
for specific instructions on setting up the development environment for each plugin.
All code is formatted with prettier
using the configuration in the repo. If possible we recommend configuring your editor to format automatically, but you can also use the yarn prettier --write <file>
command to format files.
For the versioning all packages in this repository are following the semantic versioning standard enforced through Changesets. This is the same approach as in the “backstage/community-plugins" repository. If this is your first time working with Changesets checkout this documentation or read a quick summary below.
We use changesets to help us prepare releases. They help us make sure that every package affected by a change gets a proper version number and an entry in its CHANGELOG.md
. To make the process of generating releases easy, it helps when contributors include changesets with their pull requests.
To create a changeset, follow these steps:
-
Make sure you are in the root directory of the workspace for the plugin you want to create a changeset for. For ex: if you are making changes on the
openshift-image-registry
plugin then you should be onworkspaces/openshift-image-registry
dir -
Run the following command to create a new changeset:
$ yarn changeset
-
You will be prompted to select the packages and the type of change you are making.
-
Enter a short description of the change when prompted. Refer to backstage/backstage CONTRIBUTING.md#writing-changesets for additional guidance on writing changesets.
-
Review the changeset file that was created. It should be located in the
.changeset
directory of your plugin's workspace. -
Commit the changeset file to your branch/PR.
Once the changeset is merged, it will trigger the release process for the plugin and create a "Version packages ($workspace_name)" PR. Once the PR is merged, a new version of the plugin will be published based on the type of change made.
Note
It's important to create a changeset for each individual change you make to a plugin. This ensures that the release process is properly managed and that dependencies between plugins are correctly updated.
As soon as a plugin is part of the rhdh plugins repository every PR with a change is expected to contain a changeset. As soon as the PR is merged a follow up PR will be created called “Version Packages (your-plugin-name)”. This version packages PR will remove the merged changeset & add it to the changelog for the specific plugin. Additionally the version in the package.json
is adjusted.
A release is automatically triggered by merging the plugins “Version Packages” PR.
Important
Please note that plugins with the private property set to 'true' will not be published upon merging the "Version Packages" PR. If you want full autonomy over the release process, you can mark your plugin as private. In this case, the release process will be managed by the plugin maintainer.
For workspaces the name should reflect the name of the plugins contained in a simple manner (e.g. for the plugins todo
& todo-backend
the workspace would be called todo
).
For plugins we will continue to follow the naming pattern suggested by the ADR on the backstage repository: https://backstage.io/docs/architecture-decisions/adrs-adr011.
You can create a workspace by running the following:
# jump in to the rhdh-plugins repo that you cloned
cd rhdh-plugins
# install the root dependencies so that you can create workspaces
yarn install
# create a workspace and follow the prompt
yarn create-workspace
From there, once the script has finished, you should have a new yarn workspace
with it's own changesets and releases. You can navigate to the workspace and start developing your plugin.
Once you have a workspace setup, the creation of new plugins and packages is just like any other Backstage repository. You can use the yarn new
command to run the prompt for creating new plugins or packages.
cd workspaces/openshift-image-registry
yarn new
Before proceeding with migrating a plugin, please review the following sections of the README
:
By migrating a plugin to this repository you will need to ensure you can meet certain requirements and adhere to some specific guidelines:
- Agree to publish the plugin to the
@red-hat-developer-hub
npm scope. - Adopt the Changesets workflow for releasing new plugin versions.
- Adhere to the repository security process for handling security-related issues.
- Plugins moved to the repository should be licensed under Apache 2.0.
- Prepare your environment by cloning both the repository you are migrating from and the
redhat-developer/rhdh-plugins
repository:
git clone https://github.com/source-repo/existing-plugins.git
git clone https://github.com/redhat-developer/rhdh-plugins.git
-
Identify the plugin(s) you wish to migrate. If you're migrating multiple plugins, is recommended to group the migration of these by workspace.
-
Within the
redhat-developer/rhdh-plugins
repository create a new branch for your changes:
git checkout -b migrate-workspace
- Create a new workspace in the rhdh plugins repository.
yarn create-workspace
- Copy the plugin files from the source repository to the
redhat-developer/rhdh-plugins
repository.
cd your-workspace-name
cp -r ../existing-plugins/plugins/plugin-name plugins/
-
Ensure all metadata files (
package.json
) are updated to reflect the new repository. This includes updating repository URLs, issues URLs, and other references. -
Add maintainers to the
CODEOWNERS
file for the new workspace.
Note: The
CODEOWNERS
file will have errors until you are a member of the Red Hat Developer GitHub organization. However, it is still useful to addCODEOWNERS
at this point as it provides a documented reference as to who owns/maintains the plugin.
-
Create a new pull request from your branch.
-
Update external references to the old plugin location such as documentation to point to the new location in the
redhat-developer/rhdh-plugins
repository. -
In the original repository, update the plugin to indicate that it has been moved to the
redhat-developer/rhdh-plugins
repository. You may wish to deprecate the old version on npm.
-
Prepare your environment by cloning a fork of both the
janus-idp/backstage-plugins
and thebackstage/rhdh-plugins
repositories -
In both repositories, create a new branch:
-
For
janus-idp/backstage-plugins
:git checkout -b "deprecate-workspace-name"
-
For
backstage/rhdh-plugins
:git checkout -b "migrate-workspace-name"
-
-
In the
backstage/rhdh-plugins
repository, execute the janus-plugin migrate command.- Usage:yarn rhdh-cli janus-plugin migrate --monorepo-path [path_to_backstage_plugins]--workspace-name [workspace_name] --branch [branch_name] --maintainers [maintainer1],[maintainer2],[maintainer3],...
-
The
path_to_backstage_plugins
is the path to thebackstage-plugins
project where the plugin(s) you want to migrate live. -
The
workspace-name
is the name of the workspace you wish to create in therhdh-plugins
project. All plugins in thebackstage-plugins
that either are exactly or start with@janus-idp/backstage-plugin-[workspace_name]
will be migrated to this new workspace. -
The
branch_name
is the name of the branch in thebackstage-plugins
project where the changes to add a deprecate note for the migrated plugins will be made. -
The
maintainers
array of arguments is the github usernames of those individuals that should be listed as the maintainers for the migrated plugins. Please separate each maintainer by a comma while supplying this value. -
example usage:
yarn rhdh-cli janus-plugin migrate --monorepo-path ../backstage-plugins --workspace-name workspace-name --branch deprecate-workspace-name --maintainers @maintainer1,@maintainer2,@maintainer3
-
-
The script will generate changesets in both repositories. Be sure to commit these changes and open pull requests.
Important
This script updates metadata commonly found across all plugins. Please review your migrated plugins to ensure that all references to "janus" have been updated to point to "rhdh-plugins."
-
If you run into CI issues take a look at this github gist which outlines the process taken to migrate argocd plugins in great detail.
-
Check if the migrated plugins need to be added to janus-idp/backstage-showcase. If they do, create a wrapper for them following the steps below:
- In
dynamic-plugins> wrappers
create a directory, name it based on your plugin (eg:backstage-community-plugin-3scale-backend
) - Create a
src
directory within it - Add a
index.ts
file to this src directory and export from the plugin package here. Eg:export * from '@backstage-community/plugin-3scale-backend';
- In
dynamic-plugins> wrappers > backstage-community-plugin-3scale-backend
(or whatever you named your wrapper directory), add apackage.json
file. Add your plugin package in dependencies. - run
yarn export-dynamic
to generate dist-dynamic directory
Once PRs are merged in the new repo, you should mark the old plugins deprecated, and delete the content - leaving only a README.md.
As only a single version will be migrated to the new repo, maintenance of older plugins for previous RHDH releases should continue to be done in the older repo, as the migrated versions will be aligned to newer versions of Backstage and may not be compatible.
This repository uses API Extractor and TSDoc comments to generate API Reports in Markdown format, similar to those used in Backstage. If you make changes to the API or add a new plugin then you will need either generate a new API Report or update an existing API Report. If you don't do this the CI build will fail when you create your Pull Request.
There are two ways you can do this:
- You can run
yarn build:api-reports
from the root of the project and it will go through all of the existing API Reports and update them or create new ones as needed. This may take a while but is generally the best method if you are new to this. - You can run
yarn build:api-reports plugins/<your-plugin-with-changes>
from the workspace root and it will update the existing API Report or create a new one.
Note: the above commands assume you've run
yarn install
before hand or recently
Each plugin/package has its own API Report which means you might see more than one file updated or created depending on your changes. These changes will then need to be committed as well.
To keep plugins in the various workspaces up to date with Backstage we have a Version Bump Workflow in place, similar to the one that is used in the backstage/community-plugins repository.
Note
To run this workflow, you will need write access to the repository. If you are a plugin owner and do not have write access, please reach out to one of the repository admins (@bethgriggs, @nickboldt, @04kash).
When a Plugin Owner wants to upgrade their workspace(s) to the latest version of Backstage they will simply need to do the following:
- Navigate to the Version Bump workflow
- On the right hand side click on the "Run workflow" button
- In the menu that appears use the following:
- For "Use workflow from" use the default "Branch: main"
- For "Release Line" use the default "main"
- For "Workspace (this much be a JSON array)" you will enter the name(s) of the workspace(s). For example for a single workspace it would look like this:
["bulk-import"]
and for multiple workspaces it would look like this:["lightspeed", "homepage", "marketplace"]
- For "Specifies the type of version update to apply" use the default "minor"
- Now click the "Run workflow" button
- The workflow will then run and create a PR to upgrade each of the specified workspaces to the latest
main
release of Backstage - Review and merge the generated PR(s)
When you've got your contribution working, tested, and committed to your branch it's time to create a Pull Request (PR). If you are unsure how to do this GitHub's Creating a pull request from a fork documentation will help you with that.