mirror of
https://github.com/status-im/consul.git
synced 2025-01-15 16:26:06 +00:00
9da8c51ac5
The fallback method would still work but it would get into a state where it would let the certificate expire for 10s before getting a new one. And the new one used the less secure RPC endpoint. This is also a pretty large refactoring of the auto encrypt code. I was going to write some tests around the certificate monitoring but it was going to be impossible to get a TestAgent configured in such a way that I could write a test that ran in less than an hour or two to exercise the functionality. Moving the certificate monitoring into its own package will allow for dependency injection and in particular mocking the cache types to control how it hands back certificates and how long those certificates should live. This will allow for exercising the main loop more than would be possible with it coupled so tightly with the Agent.
47 lines
1.1 KiB
Go
47 lines
1.1 KiB
Go
package connect
|
|
|
|
import (
|
|
"fmt"
|
|
"net/url"
|
|
|
|
"github.com/hashicorp/consul/agent/structs"
|
|
)
|
|
|
|
// SpiffeIDService is the structure to represent the SPIFFE ID for a service.
|
|
type SpiffeIDService struct {
|
|
Host string
|
|
Namespace string
|
|
Datacenter string
|
|
Service string
|
|
}
|
|
|
|
// URI returns the *url.URL for this SPIFFE ID.
|
|
func (id *SpiffeIDService) URI() *url.URL {
|
|
var result url.URL
|
|
result.Scheme = "spiffe"
|
|
result.Host = id.Host
|
|
result.Path = fmt.Sprintf("/ns/%s/dc/%s/svc/%s",
|
|
id.Namespace, id.Datacenter, id.Service)
|
|
return &result
|
|
}
|
|
|
|
// CertURI impl.
|
|
func (id *SpiffeIDService) Authorize(ixn *structs.Intention) (bool, bool) {
|
|
if ixn.SourceNS != structs.WildcardSpecifier && ixn.SourceNS != id.Namespace {
|
|
// Non-matching namespace
|
|
return false, false
|
|
}
|
|
|
|
if ixn.SourceName != structs.WildcardSpecifier && ixn.SourceName != id.Service {
|
|
// Non-matching name
|
|
return false, false
|
|
}
|
|
|
|
// Match, return allow value
|
|
return ixn.Action == structs.IntentionActionAllow, true
|
|
}
|
|
|
|
func (id *SpiffeIDService) CommonName() string {
|
|
return ServiceCN(id.Service, id.Namespace, id.Host)
|
|
}
|