Roadie
How to integrate Roadie with Cloudsmith
data:image/s3,"s3://crabby-images/01457/0145797c700e112e62d4bcdc21629e8bf469f25f" alt="roadie-banner-hd-150res.png 1740"
Roadie is a service catalog platform that allows users to integrate a number of different APIs into one dashboard for ease of tracking key metrics in one place. Roadie currently has many available plugins and we are happy to announce that Cloudsmith is one of them. An example picture of what is possible to have displayed through this integration:
Getting Started:
In order to get started please visit Roadie's GitHub Page and follow the steps of spinning up your own open-source instance.
Once setup and running, you can add Cloudsmith Plugins by inserting them into packages/app/src/components/home/HomePage.tsx
.
There are currently 4 available plugins:
CloudsmithStatsCard:
Displays how many packages are in use/inactive in the provided repository
data:image/s3,"s3://crabby-images/257d3/257d33d3bffab0c61d7b241c1582e5567eb051bc" alt="Screenshot 2022-12-27 at 16.43.20.png 1016"
Repository Stats
CloudsmithQuotaCard:
Displays the current bandwidth and storage usage and how much is available.
data:image/s3,"s3://crabby-images/b2d90/b2d90ab6d42e57ee1cd5d1653e2df6a3e8e3f26a" alt="Screenshot 2023-01-05 at 16.51.30.png 876"
Repository Stats
CloudsmithRepositoryAuditLogCard:
Displays audit logs for a specified repository.
data:image/s3,"s3://crabby-images/b3349/b33493aea8382736305b5fddcd570a3d4ecb2157" alt="Screenshot 2022-12-27 at 16.45.10.png 3064"
Repository Audit Logs
CloudsmithRepositorySecurityCard:
Displays Medium to Critical vulnerabilities found in a specified repository.
data:image/s3,"s3://crabby-images/5de2d/5de2d4af8dc859199785956138e9b197b8a7923b" alt="Screenshot 2022-12-27 at 16.46.16.png 1486"
Repository Security Scan Results
Integration
In order to use the plugins import them into HomePage.tsx
:
import { CloudsmithStatsCard, CloudsmithQuotaCard, CloudsmithRepositoryAuditLogCard, CloudsmithRepositorySecurityCard } from '@roadiehq/backstage-plugin-cloudsmith';
Once imported you can add them to your grid:
<Grid item xs={12} md={6}>
<CloudsmithStatsCard repo="repo-name" owner="org-name" />
</Grid>
<Grid item xs={12} md={6}>
<CloudsmithQuotaCard owner='org-name'/>
</Grid>
<Grid item xs={12} md={6}>
<CloudsmithRepositoryAuditLogCard owner='org-name' repo='repo-name'/>
</Grid>
<Grid item xs={12} md={6}>
<CloudsmithRepositorySecurityCard owner='org-name' repo='repo-name'/>
</Grid>
You can add multiple elements by copying and pasting the code above and changing CloudsmithStatsCard
. Some elements will only require owner
field and the syntax should highlight in red that it only takes one argument.
Then you can edit the app-config.yaml
for the backstage backend application, adding the following proxy configuration.
...
proxy:
...
'/cloudsmith':
target: 'https://api.cloudsmith.io/v1'
headers:
X-Api-Key: ${CLOUDSMITH_API_KEY}
When you run the backstage backend, you will need to set the CLOUDSMITH_API_KEY
environment variable.
Updated 7 months ago