Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/loblaw-sre/backstage-plugin-gitlab
Backstage plugin for Gitlab
https://github.com/loblaw-sre/backstage-plugin-gitlab
backstage backstage-plugin gitlab gitlabci
Last synced: 10 days ago
JSON representation
Backstage plugin for Gitlab
- Host: GitHub
- URL: https://github.com/loblaw-sre/backstage-plugin-gitlab
- Owner: loblaw-sre
- Created: 2021-08-17T19:10:16.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2023-04-24T05:13:09.000Z (almost 2 years ago)
- Last Synced: 2025-01-26T04:07:25.869Z (25 days ago)
- Topics: backstage, backstage-plugin, gitlab, gitlabci
- Language: TypeScript
- Homepage:
- Size: 1.09 MB
- Stars: 53
- Watchers: 8
- Forks: 31
- Open Issues: 25
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-starred - loblaw-sre/backstage-plugin-gitlab - Backstage plugin for Gitlab (others)
README
# Backstage GitLab Plugin
[data:image/s3,"s3://crabby-images/30a21/30a21e0fe28691782fcdb0def1e46bc6103ce517" alt="Version"](https://www.npmjs.com/package/@loblaw/backstage-plugin-gitlab)
data:image/s3,"s3://crabby-images/b56e2/b56e2db392a0374102e213a7db37b49ee8a1d762" alt="Contributions welcome"
[data:image/s3,"s3://crabby-images/b2cc1/b2cc194e817abfe77a86bd0d3c1d44d742644e65" alt="Downloads"](https://www.npmjs.com/package/@loblaw/backstage-plugin-gitlab)
[data:image/s3,"s3://crabby-images/b7c8b/b7c8b3aef4554d8a3db0017281194329be4e18fb" alt="License"](https://opensource.org/licenses/Apache_License_2.0)
data:image/s3,"s3://crabby-images/1e467/1e4677675e2b63e67a5f978d46954d0d529a7262" alt="Stars Badge"
[data:image/s3,"s3://crabby-images/96d44/96d447a7c3f0e855295a31c63570d40bcec4c880" alt="Maintenance"](https://github.com/loblaw-sre/backstage-plugin-gitlab)data:image/s3,"s3://crabby-images/fb6ea/fb6ea5adc582ef7415ab7a98a66b932b7a8f4db9" alt="Build Status"
data:image/s3,"s3://crabby-images/32a19/32a199f504302b319b774ebba586bb55faa65694" alt=""
data:image/s3,"s3://crabby-images/a45a2/a45a27440b7a4c225c50da6005041b9aafe480f1" alt=""
data:image/s3,"s3://crabby-images/2544f/2544f99c0089421ab884b68cb59fd07c5f24e355" alt=""data:image/s3,"s3://crabby-images/0ed0a/0ed0a21c97d66e895efcbf27bdc501c76acab337" alt="Language"
data:image/s3,"s3://crabby-images/aecb8/aecb8ab5406e0983686bc131101c07a6cd2411cc" alt=""
data:image/s3,"s3://crabby-images/71937/71937bea0f28b472f79c5022f01dae53e82e641c" alt=""
[data:image/s3,"s3://crabby-images/8f895/8f895774feb2433d271ce3b114fe5aeef4b24fd4" alt="Repo Size"](https://github.com/loblaw-sre/backstage-plugin-gitlab)
[data:image/s3,"s3://crabby-images/7f308/7f308a3d6fb8db5219f5e47ea02e1721c7dc5052" alt=""](https://github.com/loblaw-sre/backstage-plugin-gitlab)
[data:image/s3,"s3://crabby-images/14eac/14eac8eead5ec8efc544abca2e9e39ce01ae8f71" alt="Hits"](https://hits.seeyoufarm.com)Website: [https://gitlab.com/](https://gitlab.com/)
![]()
![]()
## Setup
1. If you have a standalone app (you didn't clone this repo), then do
```bash
# From your Backstage root directory
cd packages/app
yarn add @loblaw/backstage-plugin-gitlab
```2. Add a new GitLab tab to the entity page.
```tsx
// packages/app/src/components/catalog/EntityPage.tsximport { isGitlabAvailable, EntityGitlabContent } from '@loblaw/backstage-plugin-gitlab';
// Farther down at the serviceEntityPage declaration
const serviceEntityPage = (
{/* Place the following section where you want the tab to appear */}
);
```
3. Add the GitLab cards to the Overview tab on the entity page(Optional).```tsx
// packages/app/src/components/catalog/EntityPage.tsximport {
isGitlabAvailable,
EntityGitlabContent,
EntityGitlabLanguageCard,
EntityGitlabContributorsCard,
EntityGitlabMergeRequestsTable,
EntityGitlabMergeRequestStatsCard,
EntityGitlabPipelinesTable
} from '@loblaw/backstage-plugin-gitlab';//Farther down at the overviewContent declaration
//You can add only selected widgets or all of them.
const overviewContent = (
);
```4. Add integration:
In `app-config.yaml` add the integration for gitlab:
```
integrations:
gitlab:
- host: gitlab.com
token: ${GITLAB_TOKEN}
```5. Add proxy config:
```
'/gitlabci':
target: '${GITLAB_URL}/api/v4'
allowedMethods: ['GET']
headers:
PRIVATE-TOKEN: '${GITLAB_TOKEN}'
```* Default GitLab URL: `https://gitlab.com`
* GitLab Token should be with of scope `read_api` and can be generated from this [URL](https://gitlab.com/-/profile/personal_access_tokens)5. Add a `gitlab.com/project-id` annotation to your respective `catalog-info.yaml` files, on the [format](https://backstage.io/docs/architecture-decisions/adrs-adr002#format)
```yaml
# Example catalog-info.yaml entity definition file
apiVersion: backstage.io/v1alpha1
kind: Component
metadata:
# ...
annotations:
gitlab.com/project-id: 'project-id' #1234. This must be in quotes and can be found under Settings --> General
or
gitlab.com/project-slug: 'project-slug' # group_name/project_name
spec:
type: service
# ...
```**Note:** `spec.type` can take values in ['website','library','service'] but to render GitLab Entity, Catalog must be of type `service`
## Features
- List top 20 builds for a project
- List top 20 Merge Requests for a project
- List top 20 Issues for a project
- View Contributors for a project
- View Languages used for a project
- View Pipeline status for a project
- Works for both project and personal tokens
- Pagination for builds
- Pagination for Merge Requests
- Merge Requests Statistics