Skip to content

Latest commit

 

History

History
127 lines (85 loc) · 3.48 KB

README.md

File metadata and controls

127 lines (85 loc) · 3.48 KB

Spacelift Backstage Plugins

Maintainability

backstage-plugin-spacelift: npm version

backstage-plugin-spacelift-backend: npm version

An unofficial Backstage plugin for Spacelift to view statuses of runs and stacks through Backstage

This repository contains two Backstage plugins for integrating with the Spacelift platform:

  • spacelift: a plugin that displays a table of all Spacelift stacks and runs
  • spacelift-backend: a plugin that provides a simple wrapper for the Spacelift API.

Disclaimer: I do not work for Spacelift.io. I am simply interested in the tool and want to make a part of it accessible via backstage

Stacks

Runs

Installation

To use these plugins, you'll first need to install them in your Backstage app.

yarn add @scott-the-programmer/backstage-plugin-spacelift @scott-the-programmer/backstage-plugin-spacelift-backend

Backend

Create the following file under packages/backend/src/plugins/spacelift.ts

import { createRouter } from '@scott-the-programmer/backstage-plugin-spacelift-backend';
import { Router } from 'express';
import { PluginEnvironment } from '../types';

export default async function createPlugin({
  logger,
  config,
}: PluginEnvironment): Promise<Router> {
  return await createRouter({ logger: logger, config: config });
}

Add the following snippets to packages/backend/src/index.ts

import spacelift from './plugins/spacelift';
...
const spaceliftEnv = useHotMemoize(module, () => createEnv('spacelift'));
...
  apiRouter.use('/spacelift', await spacelift(spaceliftEnv));

Frontend

Add the following snippets to packages/app/src/App.tsx

import { SpaceliftPage } from '@scott-the-programmer/backstage-plugin-spacelift';
...
<Route path="/spacelift" element={<SpaceliftPage />} />

Add the following snippets to Root.tsx to add spacelift to the home sidebar

<SidebarItem icon={LibraryBooks} to="spacelift" text="Spacelift" />

Config

Add the following config to your app-config.yaml

spacelift:
  org: your-spacelift-org
  id: your-spacelift-id
  secret: your-spacelift-secret

Contributing

Feel free to contribute to this project in any shape or form, whether it's raising issues, feature requests, or even creating PRs yourself.

Any help is appreciated!

Install Dependencies

Install the frontend dependencies:

make install-frontend

Install the backend dependencies:

make install-backend

Development

Run the frontend development server:

make run-frontend

Run the backend development server:

make run-backend

Run the frontend tests:

make test-frontend

Run the backend tests:

make test-backend