@rm3l/plugin-scaffolder-frontend-module-devfile-field
TypeScript icon, indicating that this package has built-in type declarations

0.16.7 • Public • Published

devfile-field-extension

This plugin is a Custom Field Extension for Backstage. It allows you to add a set of drop-down lists to pick a Devfile Stack version, a version, and a starter project. It interacts with the configured Devfile registry to load the list of available Devfile Stacks.

Preview

Devfile Selector Custom Field Extension Preview

Installation

From your Backstage instance root folder:

yarn add --cwd packages/app @rm3l/plugin-scaffolder-frontend-module-devfile-field

Configuration

  1. Add the import to your packages/app/src/App.tsx on the frontend package of your Backstage instance:
// packages/app/src/App.tsx

import { DevfileSelectorFieldExtension } from '@rm3l/plugin-scaffolder-frontend-module-devfile-field';
import { ScaffolderFieldExtensions } from '@backstage/plugin-scaffolder-react';
  1. Then add the imported field extension as a child of ScaffolderFieldExtensions inside Route, like so:
// packages/app/src/App.tsx

<Route path="/create" element={<ScaffolderPage />}>
  <ScaffolderFieldExtensions>
    <DevfileSelectorFieldExtension />
  </ScaffolderFieldExtensions>
</Route>
  1. This custom field extension populates the dropdown lists from a Devfile Registry, which is expected to be proxied by Backstage at the following path: /devfile-registry. As such, you need to add the appropriate configuration to your app-config.yaml file under the proxy.endpoints field, like so:
# app-config.yaml

proxy:
  endpoints:
    '/devfile-registry':
      target: 'https://registry.devfile.io'

You should now see the custom field DevfileSelectorExtension and its dropdown lists populated if you navigate to the Template Editor page at http://localhost:3000/create/edit.

Usage

To use the extension in a Backstage Software Template, you can add the ui:field field to the parameter. The output of the extension is an object made up of the following fields:

  • devfile: the Devfile Stack selected by the user.
  • version: the Devfile Stack version selected by the user
  • starter_project: the Devfile Starter Project selected by the user. Optional.
parameters:
    - title: Provide details about the Devfile
      required:
        - devfile_data
      properties:
        devfile_data:
          type: object
          required:
            - devfile
            - version
          properties:
            devfile:
              type: string
            version:
              type: string
            starter_project:
              type: string
          ui:field: DevfileSelectorExtension
          ui:autofocus: true
          ui:options:
            rows: 5

Versions

Current Tags

  • Version
    Downloads (Last 7 Days)
    • Tag
  • 0.16.7
    1
    • latest

Version History

Package Sidebar

Install

npm i @rm3l/plugin-scaffolder-frontend-module-devfile-field

Homepage

devfile.io

Weekly Downloads

1

Version

0.16.7

License

Apache-2.0

Unpacked Size

31.7 kB

Total Files

5

Last publish

Collaborators

  • rm3l