mirror of
https://github.com/linka-cloud/grpc.git
synced 2025-11-23 12:43:13 +00:00
feat(creds): retrieve peer credentials when using unix socket
Signed-off-by: Adphi <philippe.adrien.nousse@gmail.com>
This commit is contained in:
68
creds/peercreds/peercreds.go
Normal file
68
creds/peercreds/peercreds.go
Normal file
@@ -0,0 +1,68 @@
|
|||||||
|
package peercreds
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"errors"
|
||||||
|
"net"
|
||||||
|
|
||||||
|
"github.com/tailscale/peercred"
|
||||||
|
"google.golang.org/grpc/credentials"
|
||||||
|
)
|
||||||
|
|
||||||
|
var _ credentials.TransportCredentials = (*peerCreds)(nil)
|
||||||
|
|
||||||
|
var common = credentials.CommonAuthInfo{SecurityLevel: credentials.PrivacyAndIntegrity}
|
||||||
|
|
||||||
|
func New() credentials.TransportCredentials {
|
||||||
|
return &peerCreds{info: credentials.ProtocolInfo{
|
||||||
|
SecurityProtocol: "peercred",
|
||||||
|
ProtocolVersion: "0.1",
|
||||||
|
}}
|
||||||
|
}
|
||||||
|
|
||||||
|
type peerCreds struct {
|
||||||
|
info credentials.ProtocolInfo
|
||||||
|
}
|
||||||
|
|
||||||
|
// AuthInfo we’ll attach to the gRPC peer
|
||||||
|
type AuthInfo struct {
|
||||||
|
credentials.CommonAuthInfo
|
||||||
|
Creds *peercred.Creds
|
||||||
|
}
|
||||||
|
|
||||||
|
func (AuthInfo) AuthType() string { return "peercred" }
|
||||||
|
|
||||||
|
func (t *peerCreds) ClientHandshake(_ context.Context, _ string, conn net.Conn) (net.Conn, credentials.AuthInfo, error) {
|
||||||
|
return t.handshakeConn(conn)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (t *peerCreds) ServerHandshake(conn net.Conn) (net.Conn, credentials.AuthInfo, error) {
|
||||||
|
return t.handshakeConn(conn)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (t *peerCreds) Info() credentials.ProtocolInfo {
|
||||||
|
return t.info
|
||||||
|
}
|
||||||
|
|
||||||
|
func (t *peerCreds) Clone() credentials.TransportCredentials {
|
||||||
|
return &peerCreds{info: t.info}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (t *peerCreds) OverrideServerName(name string) error {
|
||||||
|
t.info.ServerName = name
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (t *peerCreds) handshakeConn(conn net.Conn) (net.Conn, credentials.AuthInfo, error) {
|
||||||
|
if conn.RemoteAddr().Network() != "unix" {
|
||||||
|
return nil, nil, errors.New("peercred only works with unix domain sockets")
|
||||||
|
}
|
||||||
|
creds, err := peercred.Get(conn)
|
||||||
|
if err != nil {
|
||||||
|
if errors.Is(err, peercred.ErrNotImplemented) {
|
||||||
|
return nil, nil, errors.New("peercred not implemented on this OS")
|
||||||
|
}
|
||||||
|
return nil, nil, err
|
||||||
|
}
|
||||||
|
return conn, AuthInfo{Creds: creds, CommonAuthInfo: common}, nil
|
||||||
|
}
|
||||||
1
go.mod
1
go.mod
@@ -31,6 +31,7 @@ require (
|
|||||||
github.com/spf13/cobra v1.3.0
|
github.com/spf13/cobra v1.3.0
|
||||||
github.com/spf13/pflag v1.0.5
|
github.com/spf13/pflag v1.0.5
|
||||||
github.com/stretchr/testify v1.10.0
|
github.com/stretchr/testify v1.10.0
|
||||||
|
github.com/tailscale/peercred v0.0.0-20250107143737-35a0c7bd7edc
|
||||||
github.com/tmc/grpc-websocket-proxy v0.0.0-20190109142713-0ad062ec5ee5
|
github.com/tmc/grpc-websocket-proxy v0.0.0-20190109142713-0ad062ec5ee5
|
||||||
github.com/traefik/grpc-web v0.16.0
|
github.com/traefik/grpc-web v0.16.0
|
||||||
github.com/uptrace/opentelemetry-go-extra/otellogrus v0.3.2
|
github.com/uptrace/opentelemetry-go-extra/otellogrus v0.3.2
|
||||||
|
|||||||
2
go.sum
2
go.sum
@@ -506,6 +506,8 @@ github.com/stretchr/testify v1.8.3/go.mod h1:sz/lmYIOXD/1dqDmKjjqLyZ2RngseejIcXl
|
|||||||
github.com/stretchr/testify v1.10.0 h1:Xv5erBjTwe/5IxqUQTdXv5kgmIvbHo3QQyRwhJsOfJA=
|
github.com/stretchr/testify v1.10.0 h1:Xv5erBjTwe/5IxqUQTdXv5kgmIvbHo3QQyRwhJsOfJA=
|
||||||
github.com/stretchr/testify v1.10.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY=
|
github.com/stretchr/testify v1.10.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY=
|
||||||
github.com/subosito/gotenv v1.2.0/go.mod h1:N0PQaV/YGNqwC0u51sEeR/aUtSLEXKX9iv69rRypqCw=
|
github.com/subosito/gotenv v1.2.0/go.mod h1:N0PQaV/YGNqwC0u51sEeR/aUtSLEXKX9iv69rRypqCw=
|
||||||
|
github.com/tailscale/peercred v0.0.0-20250107143737-35a0c7bd7edc h1:24heQPtnFR+yfntqhI3oAu9i27nEojcQ4NuBQOo5ZFA=
|
||||||
|
github.com/tailscale/peercred v0.0.0-20250107143737-35a0c7bd7edc/go.mod h1:f93CXfllFsO9ZQVq+Zocb1Gp4G5Fz0b0rXHLOzt/Djc=
|
||||||
github.com/tmc/grpc-websocket-proxy v0.0.0-20190109142713-0ad062ec5ee5 h1:LnC5Kc/wtumK+WB441p7ynQJzVuNRJiqddSIE3IlSEQ=
|
github.com/tmc/grpc-websocket-proxy v0.0.0-20190109142713-0ad062ec5ee5 h1:LnC5Kc/wtumK+WB441p7ynQJzVuNRJiqddSIE3IlSEQ=
|
||||||
github.com/tmc/grpc-websocket-proxy v0.0.0-20190109142713-0ad062ec5ee5/go.mod h1:ncp9v5uamzpCO7NfCPTXjqaC+bZgJeR0sMTm6dMHP7U=
|
github.com/tmc/grpc-websocket-proxy v0.0.0-20190109142713-0ad062ec5ee5/go.mod h1:ncp9v5uamzpCO7NfCPTXjqaC+bZgJeR0sMTm6dMHP7U=
|
||||||
github.com/traefik/grpc-web v0.16.0 h1:eeUWZaFg6ZU0I9dWOYE2D5qkNzRBmXzzuRlxdltascY=
|
github.com/traefik/grpc-web v0.16.0 h1:eeUWZaFg6ZU0I9dWOYE2D5qkNzRBmXzzuRlxdltascY=
|
||||||
|
|||||||
@@ -29,6 +29,7 @@ import (
|
|||||||
"google.golang.org/grpc/health/grpc_health_v1"
|
"google.golang.org/grpc/health/grpc_health_v1"
|
||||||
greflect "google.golang.org/grpc/reflection"
|
greflect "google.golang.org/grpc/reflection"
|
||||||
|
|
||||||
|
"go.linka.cloud/grpc-toolkit/creds/peercreds"
|
||||||
"go.linka.cloud/grpc-toolkit/interceptors/chain"
|
"go.linka.cloud/grpc-toolkit/interceptors/chain"
|
||||||
"go.linka.cloud/grpc-toolkit/internal/injectlogger"
|
"go.linka.cloud/grpc-toolkit/internal/injectlogger"
|
||||||
"go.linka.cloud/grpc-toolkit/logger"
|
"go.linka.cloud/grpc-toolkit/logger"
|
||||||
@@ -138,6 +139,9 @@ func newService(opts ...Option) (*service, error) {
|
|||||||
grpc.StreamInterceptor(si),
|
grpc.StreamInterceptor(si),
|
||||||
grpc.UnaryInterceptor(ui),
|
grpc.UnaryInterceptor(ui),
|
||||||
}
|
}
|
||||||
|
if _, ok := s.opts.lis.(*net.UnixListener); ok || strings.HasPrefix(s.opts.address, "unix://") {
|
||||||
|
gopts = append(gopts, grpc.Creds(peercreds.New()))
|
||||||
|
}
|
||||||
s.server = grpc.NewServer(append(gopts, s.opts.serverOpts...)...)
|
s.server = grpc.NewServer(append(gopts, s.opts.serverOpts...)...)
|
||||||
if s.opts.reflection {
|
if s.opts.reflection {
|
||||||
greflect.Register(s.server)
|
greflect.Register(s.server)
|
||||||
|
|||||||
Reference in New Issue
Block a user