Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nilslice/protolock
Protocol Buffer companion tool. Track your .proto files and prevent changes to messages and services which impact API compatibility.
https://github.com/nilslice/protolock
cli golang productivity proto-files protobuf protoc protocol-buffers tools
Last synced: 2 days ago
JSON representation
Protocol Buffer companion tool. Track your .proto files and prevent changes to messages and services which impact API compatibility.
- Host: GitHub
- URL: https://github.com/nilslice/protolock
- Owner: nilslice
- License: bsd-3-clause
- Created: 2018-05-10T03:44:29.000Z (over 6 years ago)
- Default Branch: main
- Last Pushed: 2024-02-12T21:22:32.000Z (11 months ago)
- Last Synced: 2025-01-12T14:05:53.863Z (9 days ago)
- Topics: cli, golang, productivity, proto-files, protobuf, protoc, protocol-buffers, tools
- Language: Go
- Homepage: https://protolock.dev
- Size: 528 KB
- Stars: 609
- Watchers: 11
- Forks: 37
- Open Issues: 20
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-grpc - protolock - Protocol Buffer companion tool to `protoc` and `git`. Track your .proto files and prevent changes to messages and services which impact API compatibilty. (Protocol Buffers / Tools)
README
# protolock
Track your .proto files and prevent changes to messages and services which impact API compatibility.
![Tests](https://github.com/nilslice/protolock/actions/workflows/test.yml/badge.svg)
[![GoDoc](https://img.shields.io/badge/godoc-reference-blue.svg?style=flat)](https://pkg.go.dev/github.com/nilslice/protolock)## Why
Ever _accidentally_ break your API compatibility while you're busy fixing problems? You may have forgotten to reserve the field number of a message or you re-ordered fields after removing a property. Maybe a new team member was not familiar with the backward-compatibility of Protocol Buffers and made an easy mistake.
`protolock` attempts to help prevent this from happening.
## Overview
1. **Initialize** your repository:
$ protolock init
# creates a `proto.lock` file3. **Add changes** to .proto messages or services, verify no breaking changes made:
$ protolock status
CONFLICT: "Channel" is missing ID: 108, which had been reserved [path/to/file.proto]
CONFLICT: "Channel" is missing ID: 109, which had been reserved [path/to/file.proto]2. **Commit** a new state of your .protos (rewrites `proto.lock` if no warnings):
$ protolock commit
# optionally provide --force flag to disregard warnings4. **Integrate** into your protobuf compilation step:
$ protolock status && protoc -I ...
In all, prevent yourself from compiling your protobufs and generating code if breaking changes have been made.
**Recommended:** commit the output `proto.lock` file into your version control system
## Install
If you have [Go](https://golang.org) installed, you can install `protolock` by running:- Go >= 1.17:
```bash
go install github.com/nilslice/protolock/cmd/protolock@latest
```- Go < 1.17:
```bash
go get github.com/nilslice/protolock/cmd/protolock
```Otherwise, download a pre-built binary for Windows, macOS, or Linux from the [latest release](https://github.com/nilslice/protolock/releases/latest) page.
## Usage
```
protolock [options]Commands:
-h, --help, help display the usage information for protolock
init initialize a proto.lock file from current tree
status check for breaking changes and report conflicts
commit rewrite proto.lock file with current tree if no conflicts (--force to override)Options:
--strict [true] enable strict mode and enforce all built-in rules
--debug [false] enable debug mode and output debug messages
--ignore comma-separated list of filepaths to ignore
--force [false] forces commit to rewrite proto.lock file and disregards warnings
--plugins comma-separated list of executable protolock plugin names
--lockdir [.] directory of proto.lock file
--protoroot [.] root of directory tree containing proto files
--uptodate [false] enforce that proto.lock file is up-to-date with proto files
```## Related Projects & Users
- [Apache Ozone](https://github.com/apache/ozone)
- [Fanatics](https://github.com/fanatics)
- [Salesforce](https://github.com/salesforce/proto-backwards-compat-maven-plugin)
- [Istio](https://github.com/istio/api)
- [Lyft](https://github.com/lyft)
- [Envoy](https://github.com/envoyproxy)
- [Netflix](https://github.com/Netflix)
- [VMware](https://github.com/vmware/hamlet)
- [Storj](https://github.com/storj/storj)
- [Token.io](https://github.com/tokenio/merchant-proxy)
- [Openbase](https://github.com/openbase/type)
- [Zeebee](https://github.com/zeebe-io/zeebe)## Rules Enforced
#### No Using Reserved Fields
Compares the current vs. updated Protolock definitions and will return a list of
warnings if any message's previously reserved fields or IDs are now being used
as part of the same message.#### No Removing Reserved Fields
Compares the current vs. updated Protolock definitions and will return a list of
warnings if any reserved field has been removed.**Note:** This rule is not enforced when strict mode is disabled.
#### No Changing Field IDs
Compares the current vs. updated Protolock definitions and will return a list of
warnings if any field ID number has been changed.#### No Changing Field Types
Compares the current vs. updated Protolock definitions and will return a list of
warnings if any field type has been changed.#### No Changing Field Names
Compares the current vs. updated Protolock definitions and will return a list of
warnings if any message's previous fields have been renamed.**Note:** This rule is not enforced when strict mode is disabled.
#### No Removing Fields Without Reserve
Compares the current vs. updated Protolock definitions and will return a list of
warnings if any field has been removed without a corresponding reservation of
that field name or ID.#### No Removing RPCs
Compares the current vs. updated Protolock definitions and will return a list of
warnings if any RPCs provided by a Service have been removed.**Note:** This rule is not enforced when strict mode is disabled.
#### No Changing RPC Signature
Compares the current vs. updated Protolock definitions and will return a list of
warnings if any RPC signature has been changed while using the same name.---
## Docker
```sh
docker pull nilslice/protolock:latest
docker run -v $(pwd):/protolock -w /protolock nilslice/protolock init
```---
## Plugins
The default rules enforced by `protolock` may not cover everything you want to
do. If you have custom checks you'd like run on your .proto files, create a
plugin, and have `protolock` run it and report your warnings. Read the wiki to
learn more about [creating and using plugins](https://github.com/nilslice/protolock/wiki/Plugins).---
## Contributing
Please feel free to make pull requests with better support for various rules,
optimized code and overall tests. Filing an issue when you encounter a bug or
any unexpected behavior is very much appreciated.For current issues, see: [open issues](https://github.com/nilslice/protolock/issues)
---
## Acknowledgement
Thank you to Ernest Micklei for his work on the excellent parser heavily relied upon by this tool and many more: [https://github.com/emicklei/proto](https://github.com/emicklei/proto)