twirp

A simple RPC framework with protobuf service definitions

  • 所有者: twitchtv/twirp
  • 平台:
  • 許可證: Apache License 2.0
  • 分類:
  • 主題:
  • 喜歡:
    0
      比較:

Github星跟蹤圖

Twirp Logo Build Status Go Report Card GoDoc


Twirp is a framework for service-to-service communication emphasizing simplicity
and minimalism. It generates routing and serialization from API definition files
and lets you focus on your application's logic instead of thinking about
folderol like HTTP methods and paths and JSON.

Define your service in a
Protobuf file and
then Twirp autogenerates Go code with a server interface and fully functional
clients. It's similar to gRPC, but without the custom
HTTP server and transport implementations: it runs on the standard library's
extremely-well-tested-and-high-performance net/http Server. It can run on HTTP
1.1, not just http/2, and supports JSON clients for easy integrations across
languages

Twirp handles routing and serialization for you in a well-tested, standardized,
thoughtful way so you don't have to. Serialization and deserialization code is
error-prone and tricky, and you shouldn't be wasting your time deciding whether
it should be "POST /friends/:id/new" or "POST /:id/friend" or whatever. Just
get to the real work of building services!

Along the way, you get an autogenerated client and a simple, smart framework for
passing error messages. Nice!

For more on the motivation behind Twirp (and a comparison to REST APIs and gRPC), the
announcement blog post
is a good read.

Installation

Use go get to install the Go client-and-server generator:

go get github.com/twitchtv/twirp/protoc-gen-twirp

You will also need:

Documentation

Thorough documentation is
on the website.

Source for this documentation is in the docs subdirectory. The website
is generated from that folder using Docusaurus.

Implementations in other languages

This repo only has the official generators, which write out Go and Python code.
For other languages, there are third-party generators available:, Language, Clients, Servers, Repository, ----------------, ---------, ---------, ------------, Java, ✓, ✓, github.com/fajran/protoc-gen-twirp_java_jaxrs, Java, ✓, https://github.com/devork/flit, JavaScript, ✓, github.com/thechriswalker/protoc-gen-twirp_js, JavaScript, ✓, github.com/Xe/twirp-codegens/cmd/protoc-gen-twirp_jsbrowser, Typescript, ✓, github.com/larrymyers/protoc-gen-twirp_typescript, Ruby, ✓, ✓, github.com/twitchtv/twirp-ruby, Rust, ✓, ✓, github.com/cretz/prost-twirp, Swagger, ✓, ✓, github.com/elliots/protoc-gen-twirp_swagger, PHP, ✓, ✓, github.com/twirphp/twirp, Dart, ✓, github.com/apptreesoftware/protoc-gen-twirp_dart

This list isn't an endorsement, it's just a convenience to help you find stuff
for your language.

Support and Community

We have a channel on the Gophers slack, #twirp,
which is the best place to get quick answers to your questions. You can join the
Gopher slack here.

Releases

Twirp follows semantic versioning through git tags, and uses Github Releases for
release notes and upgrade guides:
Twirp Releases

Contributing

Check out CONTRIBUTING.md for notes on making contributions.

License

This library is licensed under the Apache 2.0 License.

主要指標

概覽
名稱與所有者twitchtv/twirp
主編程語言Go
編程語言Makefile (語言數: 5)
平台
許可證Apache License 2.0
所有者活动
創建於2018-01-16 16:37:30
推送於2024-08-05 21:36:11
最后一次提交
發布數30
最新版本名稱v8.1.3 (發布於 )
第一版名稱v5.0.0 (發布於 )
用户参与
星數7.3k
關注者數103
派生數327
提交數651
已啟用問題?
問題數190
打開的問題數8
拉請求數165
打開的拉請求數3
關閉的拉請求數44
项目设置
已啟用Wiki?
已存檔?
是復刻?
已鎖定?
是鏡像?
是私有?