Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/fluent-ci-templates/buf-pipeline

A ready-to-use CI/CD Pipeline for linting and pushing Protobuf files to the Buf Registry.
https://github.com/fluent-ci-templates/buf-pipeline

cicd dagger deno fluentci pipeline protobuf typescript wasm

Last synced: 10 days ago
JSON representation

A ready-to-use CI/CD Pipeline for linting and pushing Protobuf files to the Buf Registry.

Awesome Lists containing this project

README

        

# Buf Pipeline

[![fluentci pipeline](https://shield.fluentci.io/x/buf_pipeline)](https://pkg.fluentci.io/buf_pipeline)
![deno compatibility](https://shield.deno.dev/deno/^1.42)
[![dagger-min-version](https://shield.fluentci.io/dagger/v0.11.7)](https://dagger.io)
[![](https://jsr.io/badges/@fluentci/buf)](https://jsr.io/@fluentci/buf)
[![](https://img.shields.io/codecov/c/gh/fluent-ci-templates/buf-pipeline)](https://codecov.io/gh/fluent-ci-templates/buf-pipeline)
[![ci](https://github.com/fluent-ci-templates/buf-pipeline/actions/workflows/ci.yml/badge.svg)](https://github.com/fluent-ci-templates/buf-pipeline/actions/workflows/ci.yml)

A ready-to-use CI/CD Pipeline for linting and pushing Protobuf files to the [Buf](https://buf.build/) Registry.

## 🚀 Usage

Run the following command in your project:

```bash
fluentci run buf_pipeline
```

Or, if you want to use it as a template:

```bash
fluentci init -t buf
```

This will create a `.fluentci` folder in your project.

Now you can run the pipeline with:

```bash
fluentci run .
```

## 🧩 Dagger Module

Use as a [Dagger](https://dagger.io) Module:

```bash
dagger install github.com/fluent-ci-templates/buf-pipeline@main
```

Call a function from this module:

```bash
dagger call format --src .
dagger call lint --src .
dagger call push --src . --token env:BUF_TOKEN
```

## 🛠️ Environment variables

| Variable | Description |
| --------- | ------------------------ |
| BUF_TOKEN | The Buf Registry token. |

## ✨ Jobs

| Job | Description |
| ------ | --------------------------------------------- |
| lint | Lint your Protobuf files with buf. |
| format | Format your Protobuf files with buf. |
| push | Push your Protobuf files to the Buf Registry. |

```typescript
push(
src: Directory | string,
token: Secret | string
): Promise

format(
src: Directory | string
): Promise

lint(src: Directory | string): Promise
```

## 👨‍💻 Programmatic usage

You can also use this pipeline programmatically:

```ts
import { lint, push } from "jsr:@fluentci/buf";

await lint(".");
await push(".", Deno.env.get("BUF_TOKEN")!);
```