-
Notifications
You must be signed in to change notification settings - Fork 276
Migration path for Service Identity #3170
Migration path for Service Identity #3170
Conversation
9713f3e
to
7e80190
Compare
186ccad
to
5581dc0
Compare
Signed-off-by: Delyan Raychev <[email protected]>
5581dc0
to
6ba1e6a
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Overall this is my understanding from the change:
- XDS extracts k8s service account from XDS cert
- While making calls to catalog, XDS convert k8s service account to the service identity FQDN (trust domain hardcoded to cluster.local)
- Catalog implementation performs conversions between the 2 types (k8s service account and service identity FQDN) as necessary
I was wondering what you had in mind for the following:
- Directly retrieve the ServiceIdentity from the proxy XDS cert, so this would skip 1 above
- Converting from ServiceAccount -> ServiceIdentity is not precise because the trust domain information is lost. Do you see this to work differently for multicluster?
@@ -61,15 +63,17 @@ func (mc *MeshCatalog) listInboundPoliciesFromTrafficTargets(upstreamIdentity id | |||
// listInboundPoliciesForTrafficSplits loops through all SMI TrafficTarget resources and returns inbound policies for apex services based on the following conditions: | |||
// 1. the given upstream identity matches the destination specified in a TrafficTarget resource | |||
// 2. the given list of upstream services are backends specified in a TrafficSplit resource | |||
func (mc *MeshCatalog) listInboundPoliciesForTrafficSplits(upstreamIdentity identity.K8sServiceAccount, upstreamServices []service.MeshService) []*trafficpolicy.InboundTrafficPolicy { | |||
func (mc *MeshCatalog) listInboundPoliciesForTrafficSplits(upstreamIdentity identity.ServiceIdentity, upstreamServices []service.MeshService) []*trafficpolicy.InboundTrafficPolicy { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could you add in comments what upstreamIdentity
should look like: foo.bar
vs foo.bar.cluster.local
.
This comment applies to any function that takes a ServiceIdentity
type as an argument.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@shashankram I do not agree that there should be such comment. We created ServiceIdentity
as a type to give us the flexibility to define these things in the type itself.
I comment with the sample string would only be needed because ServiceIdentity
is still just a string alias. When we design and implement something more complex type ServiceIdentity struct
we would have this information encoded in the struct.
So in the short term I could go around sprinkling comments, but these would be relevant for a short period of time while ServiceIdentity
is a string.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think there needs to be a comment, otherwise authors not familiar with the concept of ServiceIdentity are going to wonder what should be passed as an argument to functions that accept a ServiceIdentity
type (foo.bar
vs foo.bar.cluster.local
). Even just adding this to the interface will suffice for now, so its clear what the catalog interface expects at this moment.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@shashankram I'll add the comment and look forward to sophisticating ServiceIdentity
from a string
to a struct
, which would be explicit about the components of this string (now implied and relying on comments). We can discuss and tackle this going forward with the following GitHub Issue:
- identity: Change (sophisticate) ServiceIdentity from a string to a struct{} so it can capture more context identity: Change (sophisticate) ServiceIdentity from a string to a struct{} so it can capture more context #3188
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks @draychev, the new issues make sense.
@shashankram, thank you so much for taking the time to go through this monster PR. Sincere apologies for the size of it - it is tough to chop it up into pieces. My responses are inline:
This is mostly to preserve the current state of the system. I think of it as 0.5 steps forward. I want to avoid making drastic changes all at once. The Envoy xDS cert points to a K8s Service Account. I want to leave that as is and debate/design it separatel. So decided to preserve the flow of cert -> CN -> K8sServiceAccount -> ServiceIdentity -- just to make a small step forward to overhauling the types.
I believe this preserves the current state of the system as of
And the point of this is just to provide a bridge between the two types co-existing. (I suspect they will continue to co-exist in some shape). This is just to allow for as small PR as possible to change the types of the Mesh Catalog interfaces, which we agree should not be Kubernetes aware.
I agree this needs to happen at some point. I made this new GitHub issue, and summarized this there:
I see the hard-coding of
|
edd1114
to
35a7b69
Compare
Codecov Report
@@ Coverage Diff @@
## main #3170 +/- ##
==========================================
+ Coverage 66.29% 66.36% +0.06%
==========================================
Files 161 161
Lines 7390 7405 +15
==========================================
+ Hits 4899 4914 +15
Misses 2464 2464
Partials 27 27
Flags with carried forward coverage won't be shown. Click here to find out more.
Continue to review full report at Codecov.
|
@@ -53,11 +54,11 @@ func (mc *MeshCatalog) ListAllowedEndpointsForService(downstreamIdentity identit | |||
return nil, err | |||
} | |||
|
|||
// allowedEndpoints comprises of only those endpoints from outboundEndpoints that matches the endpoints from listEndpointsforIdentity | |||
// allowedEndpoints comprises of only those endpoints from outboundEndpoints that matches the endpoints from listEndpointsForServiceIdentity |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
we should go back and clarify this comment. Was a bit difficult for me to understand.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
🤔 This might be the wrong abstraction... Thanks for challenging this! I'll dig into it.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@michelleN I started by merely trying to change the type here so it does not reference K8sServiceAccount
and uses ServiceIdentity
.
I see that we have bigger problems with ListAllowedEndpointsforService
. I recorded these in:
- catalog: Simplify ListAllowedEndpointsForService catalog: Simplify ListAllowedEndpointsForService #3190
Would you agree it would be better to tackle simplifying this function in a separate PR (as part of #3190) - not to muddy the waters here?
Alternatively - I could revert the changes to ListAllowedEndpointsForService
and keep it in its original form (by using the .ToK8sServiceAccount()
and .ToServiceIdentity()
temporary helpers), but not sure this would be any different.
I propose we work on this as a fast-follow to this PR here.
pkg/envoy/ads/secrets.go
Outdated
@@ -67,7 +67,7 @@ func makeRequestForAllSecrets(proxy *envoy.Proxy, meshCatalog catalog.MeshCatalo | |||
|
|||
// Create an SDS validation cert corresponding to each upstream service that this proxy can connect to. | |||
// Each cert is used to validate the certificate presented by the corresponding upstream service. | |||
upstreamServices := meshCatalog.ListAllowedOutboundServicesForIdentity(proxyIdentity) | |||
upstreamServices := meshCatalog.ListAllowedOutboundServicesForIdentity(proxyIdentity.ToServiceIdentity()) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
we might want to rename proxyIdentity
to serviceAccount
to make this more clear.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@michelleN I renamed proxyIdentity
to serviceAccount
. Also left a comment - we need to continue work on this as part of:
- certificates: Envoy xDS Certs should have a ServiceIdentity in the CN; not ServiceAccount certificates: Envoy xDS Certs should have a ServiceIdentity in the CN; not ServiceAccount #3186
…uture improvements w/ GitHub Issue 3186
This PR replaces the usage of
K8sServiceAccount
withServiceIdentity
in most functions inpkg/catalog
andpkg/envoy
.As part of #2218 we determined that the
ServiceAccount
primitive is something specific to Kubernetes, and neither Mash Catalog, nor Envoy xDS should be Kubernetes specific.With #3179 we created
K8sServiceAccount.ToServiceIdentity()
andServiceIdentity.ToK8sServiceAccount()
, which allow for a service account to be converted to a service identity and vice versa. This is not a problem in the current state of OSM - there is only one kind ofServiceIdentity
- a KubernetesServiceAccount
.This PR uses
ToK8sServiceAccount()
andToServiceIdentity()
as crutches to avoid making too many changes - it is already very difficult to review these large changes. Both of these functions are annotated with a// TODO
and a link to #2218. These should be used sparingly and perhaps even completely removed before #2218 is completed.This is part of: