Go to file
2021-11-23 13:12:49 +01:00
certs remove transport draft, add grpc web and gateway support 2021-09-18 01:44:08 +02:00
client add client address option, fix noop resolver 2021-11-22 14:04:47 +01:00
config add minimal config interface and file implementation 2021-11-23 12:00:58 +01:00
errors reformat error funcs, improved logger 2021-11-18 20:21:30 +01:00
example add client address option, fix noop resolver 2021-11-22 14:04:47 +01:00
google/api remove transport draft, add grpc web and gateway support 2021-09-18 01:44:08 +02:00
interceptors update validation interceptor interfaces 2021-11-23 13:12:49 +01:00
logger reformat error funcs, improved logger 2021-11-18 20:21:30 +01:00
registry add client address option, fix noop resolver 2021-11-22 14:26:05 +01:00
resolver add client address option, fix noop resolver 2021-11-22 14:26:05 +01:00
service options: fix interceptors, add defaulter and recovery 2021-11-21 16:13:43 +01:00
signals add metrics, tracing, validation interceptors, add options: WithInterceptors, With{Client,Server}Interceptors 2021-11-21 14:58:49 +01:00
transport add missing transport folder 2021-09-30 12:00:30 +02:00
utils add registry base interface, mdns, noop implementations, add resolver, client 2020-11-15 15:54:46 +01:00
.gitignore add missing transport folder 2021-09-30 12:00:30 +02:00
go.mod add sentry interceptors 2021-11-21 16:24:22 +01:00
go.sum add sentry interceptors 2021-11-21 16:24:22 +01:00
LICENSE Add LICENSE 2020-11-06 17:32:45 +00:00
Makefile remove transport draft, add grpc web and gateway support 2021-09-18 01:44:08 +02:00
README.md add sentry interceptors 2021-11-21 16:24:22 +01:00
tools.go remove transport draft, add grpc web and gateway support 2021-09-18 01:44:08 +02:00

gRPC

A utility module, largely taken from the go-micro patterns (and a good amount of code too...) with pure gRPC ecosystem modules.

Principles:

  • Pluggable
  • No singleton

Features:

  • simple configuration with options
  • embedded gorm database with options (branch db)
  • simple TLS configuration
  • TLS auth
  • client connection pool
  • registry / resolver resolution
    • mdns
    • kubernetes
  • default interceptors implementation:
    • context request id
    • defaulter
    • validation
    • health
    • context logger
    • sentry
    • rate-limiting
    • ban
    • auth claim in context
    • recovery (server side only)
    • tracing (open-tracing)
    • metrics (prometheus)
    • retries
    • context DB / transaction
    • ...
  • grpc web / api gateway with middleware:
    • auth
    • cors
    • logging
    • tracing
    • metrics
  • broker, based on nats-streaming

Used modules: