Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/turbot/flowpipe-mod-gitlab

GitLab pipeline library for the Flowpipe cloud scripting engine. Automation and workflows to connect GitLab to the people, systems and data that matters.
https://github.com/turbot/flowpipe-mod-gitlab

automation cloud devops flowpipe flowpipe-mod gitlab gitlab-api hacktoberfest integrations low-code orchestration pipelines security workflow workflow-automation workflow-engine

Last synced: 10 days ago
JSON representation

GitLab pipeline library for the Flowpipe cloud scripting engine. Automation and workflows to connect GitLab to the people, systems and data that matters.

Awesome Lists containing this project

README

        

# GitLab Mod for Flowpipe

GitLab pipeline library for [Flowpipe](https://flowpipe.io), enabling seamless integration of GitLab services into your workflows.

## Documentation

- **[Pipelines →](https://hub.flowpipe.io/mods/turbot/gitlab/pipelines)**

## Getting Started

### Installation

Download and install Flowpipe (https://flowpipe.io/downloads). Or use Brew:

```sh
brew tap turbot/tap
brew install flowpipe
```

### Connections

By default, the following environment variables will be used for authentication:

- `GITLAB_TOKEN`

You can also create `connection` resources in configuration files:

```sh
vi ~/.flowpipe/config/gitlab.fpc
```

```hcl
connection "gitlab" "default" {
token = "glpat-..."
}
```

For more information on connections in Flowpipe, please see [Managing Connections](https://flowpipe.io/docs/run/connections).

### Usage

[Initialize a mod](https://flowpipe.io/docs/build/index#initializing-a-mod):

```sh
mkdir my_mod
cd my_mod
flowpipe mod init
```

[Install the GitLab mod](https://flowpipe.io/docs/build/mod-dependencies#mod-dependencies) as a dependency:

```sh
flowpipe mod install github.com/turbot/flowpipe-mod-gitlab
```

[Use the dependency](https://flowpipe.io/docs/build/write-pipelines/index) in a pipeline step:

```sh
vi my_pipeline.fp
```

```hcl
pipeline "my_pipeline" {

step "pipeline" "get_project" {
pipeline = gitlab.pipeline.get_project
args = {
project_id = "99999999"
}
}
}
```

[Run the pipeline](https://flowpipe.io/docs/run/pipelines):

```sh
flowpipe pipeline run my_pipeline
```

### Developing

Clone:

```sh
git clone https://github.com/turbot/flowpipe-mod-gitlab.git
cd flowpipe-mod-gitlab
```

List pipelines:

```sh
flowpipe pipeline list
```

Run a pipeline:

```sh
flowpipe pipeline run get_project --arg 'project_id=99999999'
```

To use a specific `connection`, specify the `conn` pipeline argument:

```sh
flowpipe pipeline run get_project --arg 'project_id=99999999' --arg conn=connection.gitlab.gitlab_profile
```

## Open Source & Contributing

This repository is published under the [Apache 2.0 license](https://www.apache.org/licenses/LICENSE-2.0). Please see our [code of conduct](https://github.com/turbot/.github/blob/main/CODE_OF_CONDUCT.md). We look forward to collaborating with you!

[Flowpipe](https://flowpipe.io) is a product produced from this open source software, exclusively by [Turbot HQ, Inc](https://turbot.com). It is distributed under our commercial terms. Others are allowed to make their own distribution of the software, but cannot use any of the Turbot trademarks, cloud services, etc. You can learn more in our [Open Source FAQ](https://turbot.com/open-source).

## Get Involved

**[Join #flowpipe on Slack →](https://flowpipe.io/community/join)**

Want to help but not sure where to start? Pick up one of the `help wanted` issues:

- [Flowpipe](https://github.com/turbot/flowpipe/labels/help%20wanted)
- [GitLab Mod](https://github.com/turbot/flowpipe-mod-gitlab/labels/help%20wanted)