Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/squiddy/gitlab-to-sqlite
Save data from GitLab to a SQLite database.
https://github.com/squiddy/gitlab-to-sqlite
datasette datasette-tool gitlab sqlite
Last synced: 24 days ago
JSON representation
Save data from GitLab to a SQLite database.
- Host: GitHub
- URL: https://github.com/squiddy/gitlab-to-sqlite
- Owner: squiddy
- License: apache-2.0
- Created: 2022-07-27T17:18:46.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2024-06-21T10:52:39.000Z (5 months ago)
- Last Synced: 2024-10-10T22:22:34.031Z (about 1 month ago)
- Topics: datasette, datasette-tool, gitlab, sqlite
- Language: Python
- Homepage:
- Size: 31.3 KB
- Stars: 2
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# gitlab-to-sqlite
[![PyPI](https://img.shields.io/pypi/v/gitlab-to-sqlite.svg)](https://pypi.org/project/gitlab-to-sqlite/)
[![License](https://img.shields.io/badge/license-Apache%202.0-blue.svg)](https://github.com/squiddy/gitlab-to-sqlite/blob/main/LICENSE)Save data from GitLab to a SQLite database.
## Attribution
The overall structure and CLI is taken from
https://github.com/dogsheep/github-to-sqlite/.- [How to install](#how-to-install)
- [Authentication](#authentication)
- [Using custom gitlab instance](#using-custom-gitlab-instance)
- [Fetching projects](#fetching-projects)
- [Fetching merge requests](#fetching-merge-requests)
- [Fetching pipelines](#fetching-pipelines)
- [Fetching environments](#fetching-environments)
- [Fetching deployments](#fetching-deployments)
- [Fetching commits](#fetching-commits)## How to install
$ pip install gitlab-to-sqlite
## Authentication
Create a GitLab personal access token: https://gitlab.com/-/profile/personal_access_tokens
Run this command and paste in your new token:
$ gitlab-to-sqlite auth
This will create a file called auth.json in your current directory containing
the required value. To save the file at a different path or filename, use the
--auth=myauth.json option.As an alternative to using an auth.json file you can add your access token to an
environment variable called GITLAB_TOKEN.## Using custom gitlab instance
When running ``auth`` you may specify an optional ``--host`` parameter pointing
to a custom instance.$ gitlab-to-sqlite auth --host gitlab.internal
## Fetching projects
The `projects` command retrieves a single project.
$ gitlab-to-sqlite projects gitlab.db group/project-name
## Fetching merge requests
The `merge-requests` command retrieves updated or created merge requests.
$ gitlab-to-sqlite merge-requests gitlab.db group/project-name
This command can be run regularly. Based on the most recent created or updated
merge request it only fetches changes that happened afterwards.## Fetching pipelines
The `pipelines` command retrieves updated or created pipelines with their
corresponding jobs.$ gitlab-to-sqlite pipelines gitlab.db group/project-name
This command can be run regularly. Based on the most recent created or updated
pipeline it only fetches changes that happened afterwards.## Fetching environments
The `environments` command retrieves all environments of a single project.
$ gitlab-to-sqlite projects gitlab.db group/project-name
## Fetching deployments
The `deployments` command retrieves all deployments of a specific environment in
a single project.$ gitlab-to-sqlite deployments gitlab.db group/project-name environment-name
This command can be run regularly. Based on the most recent created or updated
deployment it only fetches changes that happened afterwards.## Fetching commits
The `commits` command retrieves all commits of a single project.
$ gitlab-to-sqlite commits gitlab.db group/project-name