Files
backstage/plugins/sonarqube
github-actions[bot] 326cbd7408 Version Packages
2021-08-05 00:24:56 +00:00
..
2021-06-22 10:07:18 +02:00
2021-08-03 21:49:08 +05:30
2021-08-05 00:24:56 +00:00
2021-06-18 20:26:42 +02:00
2021-08-05 00:24:56 +00:00

SonarQube Plugin

The SonarQube Plugin displays code statistics from SonarCloud or SonarQube.

Sonar Card

Getting Started

  1. Install the SonarQube Plugin:
# From your Backstage root directory
cd packages/app
yarn add @backstage/plugin-sonarqube
  1. Add the EntitySonarQubeCard to the EntityPage:
  // packages/app/src/components/catalog/EntityPage.tsx
+ import { EntitySonarQubeCard } from '@backstage/plugin-sonarqube';

 ...

 const overviewContent = (
   <Grid container spacing={3} alignItems="stretch">
     <Grid item md={6}>
       <EntityAboutCard variant="gridItem" />
     </Grid>
+    <Grid item md={6}>
+      <EntitySonarQubeCard variant="gridItem" />
+    </Grid>
   </Grid>
 );
  1. Add the proxy config:

    Provide a method for your Backstage backend to get to your SonarQube API end point. Add configuration to your app-config.yaml file depending on the product you use.

SonarCloud

proxy:
  '/sonarqube':
    target: https://sonarcloud.io/api
    allowedMethods: ['GET']
    headers:
      Authorization: Basic ${SONARQUBE_AUTH}
      # Content: 'base64("<api-key>:")' <-- note the trailing ':'
      # Example: bXktYXBpLWtleTo=

SonarQube

proxy:
  '/sonarqube':
    target: https://your.sonarqube.instance.com/api
    allowedMethods: ['GET']
    headers:
      Authorization: Basic ${SONARQUBE_AUTH}
      # Environmental variable: SONARQUBE_AUTH
      # Value: 'base64("<sonar-auth-token>:")'
      # Encode the "<sonar-auth-token>:" string using base64 encoder.
      # Note the trailing colon (:) at the end of the token.
      # Example environmental config: SONARQUBE_AUTH=bXktYXBpLWtleTo=
      # Fetch the sonar-auth-token from https://sonarcloud.io/account/security/

sonarQube:
  baseUrl: https://your.sonarqube.instance.com
  1. Get and provide SONARQUBE_AUTH as an env variable (https://sonarcloud.io/account/security or https://docs.sonarqube.org/latest/user-guide/user-token/)

  2. Run the following commands in the root folder of the project to install and compile the changes.

yarn install
yarn tsc
  1. Add the sonarqube.org/project-key annotation to the catalog-info.yaml file of the target repo for which code quality analysis is needed.
apiVersion: backstage.io/v1alpha1
kind: Component
metadata:
  name: backstage
  description: |
    Backstage is an open-source developer portal that puts the developer experience first.
  annotations:
    sonarqube.org/project-key: YOUR_PROJECT_KEY
spec:
  type: library
  owner: CNCF
  lifecycle: experimental