2023-03-28 19:39:22 +01:00
|
|
|
// Copyright (c) HashiCorp, Inc.
|
2023-08-11 09:12:13 -04:00
|
|
|
// SPDX-License-Identifier: BUSL-1.1
|
2023-03-28 19:39:22 +01:00
|
|
|
|
2022-04-05 15:26:14 +01:00
|
|
|
package connectca
|
|
|
|
|
|
|
|
import (
|
2022-04-14 14:26:14 +01:00
|
|
|
"crypto/x509"
|
|
|
|
|
2022-04-05 15:26:14 +01:00
|
|
|
"google.golang.org/grpc"
|
2022-04-14 14:26:14 +01:00
|
|
|
"google.golang.org/grpc/codes"
|
|
|
|
"google.golang.org/grpc/status"
|
2022-04-05 15:26:14 +01:00
|
|
|
|
|
|
|
"github.com/hashicorp/go-hclog"
|
|
|
|
"github.com/hashicorp/go-memdb"
|
|
|
|
|
|
|
|
"github.com/hashicorp/consul/acl"
|
2022-06-17 10:24:43 +01:00
|
|
|
"github.com/hashicorp/consul/acl/resolver"
|
2022-04-12 09:47:42 -04:00
|
|
|
"github.com/hashicorp/consul/agent/consul/stream"
|
2022-04-05 15:26:14 +01:00
|
|
|
"github.com/hashicorp/consul/agent/structs"
|
|
|
|
"github.com/hashicorp/consul/proto-public/pbconnectca"
|
|
|
|
)
|
|
|
|
|
|
|
|
type Server struct {
|
|
|
|
Config
|
|
|
|
}
|
|
|
|
|
|
|
|
type Config struct {
|
2022-04-14 14:26:14 +01:00
|
|
|
Publisher EventPublisher
|
|
|
|
GetStore func() StateStore
|
|
|
|
Logger hclog.Logger
|
|
|
|
ACLResolver ACLResolver
|
|
|
|
CAManager CAManager
|
|
|
|
ForwardRPC func(structs.RPCInfo, func(*grpc.ClientConn) error) (bool, error)
|
|
|
|
ConnectEnabled bool
|
2022-04-05 15:26:14 +01:00
|
|
|
}
|
|
|
|
|
2022-04-12 09:47:42 -04:00
|
|
|
type EventPublisher interface {
|
|
|
|
Subscribe(*stream.SubscribeRequest) (*stream.Subscription, error)
|
|
|
|
}
|
|
|
|
|
2022-04-05 15:26:14 +01:00
|
|
|
type StateStore interface {
|
|
|
|
CAConfig(memdb.WatchSet) (uint64, *structs.CAConfiguration, error)
|
|
|
|
AbandonCh() <-chan struct{}
|
|
|
|
}
|
|
|
|
|
2022-04-21 09:48:21 -05:00
|
|
|
//go:generate mockery --name ACLResolver --inpackage
|
2022-04-05 15:26:14 +01:00
|
|
|
type ACLResolver interface {
|
2022-06-17 10:24:43 +01:00
|
|
|
ResolveTokenAndDefaultMeta(token string, entMeta *acl.EnterpriseMeta, authzContext *acl.AuthorizerContext) (resolver.Result, error)
|
2022-04-14 14:26:14 +01:00
|
|
|
}
|
|
|
|
|
2022-04-21 09:48:21 -05:00
|
|
|
//go:generate mockery --name CAManager --inpackage
|
2022-04-14 14:26:14 +01:00
|
|
|
type CAManager interface {
|
|
|
|
AuthorizeAndSignCertificate(csr *x509.CertificateRequest, authz acl.Authorizer) (*structs.IssuedCert, error)
|
2022-04-05 15:26:14 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func NewServer(cfg Config) *Server {
|
|
|
|
return &Server{cfg}
|
|
|
|
}
|
|
|
|
|
2024-01-12 11:54:07 -05:00
|
|
|
func (s *Server) Register(registrar grpc.ServiceRegistrar) {
|
|
|
|
pbconnectca.RegisterConnectCAServiceServer(registrar, s)
|
2022-04-05 15:26:14 +01:00
|
|
|
}
|
2022-04-14 14:26:14 +01:00
|
|
|
|
|
|
|
func (s *Server) requireConnect() error {
|
|
|
|
if s.ConnectEnabled {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
return status.Error(codes.FailedPrecondition, "Connect must be enabled in order to use this endpoint")
|
|
|
|
}
|