grpc.go 1.2 KB
Newer Older
Y
Yaron Schneider 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58
package grpc

import (
	"fmt"
	"sync"

	"google.golang.org/grpc"

	"github.com/actionscore/actions/pkg/channel"
	grpc_channel "github.com/actionscore/actions/pkg/channel/grpc"
)

type GRPCManager struct {
	AppClient      *grpc.ClientConn
	lock           *sync.Mutex
	connectionPool map[string]*grpc.ClientConn
}

func NewGRPCManager() *GRPCManager {
	return &GRPCManager{
		lock:           &sync.Mutex{},
		connectionPool: map[string]*grpc.ClientConn{},
	}
}

func (g *GRPCManager) CreateLocalChannel(port int) (channel.AppChannel, error) {
	conn, err := g.GetGRPCConnection(fmt.Sprintf("127.0.0.1:%v", port))
	if err != nil {
		return nil, fmt.Errorf("error establishing connection to app grpc on port %v: %s", port, err)
	}

	g.AppClient = conn
	ch := grpc_channel.CreateLocalChannel(port, conn)
	return ch, nil
}

func (g *GRPCManager) GetGRPCConnection(address string) (*grpc.ClientConn, error) {
	if val, ok := g.connectionPool[address]; ok {
		return val, nil
	}

	g.lock.Lock()
	if val, ok := g.connectionPool[address]; ok {
		g.lock.Unlock()
		return val, nil
	}

	conn, err := grpc.Dial(address, grpc.WithInsecure())
	if err != nil {
		g.lock.Unlock()
		return nil, err
	}

	g.connectionPool[address] = conn
	g.lock.Unlock()

	return conn, nil
}