Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

frontend: Details: Make multi cluster aware #2520

Open
wants to merge 5 commits into
base: main
Choose a base branch
from
Open

Conversation

illume
Copy link
Collaborator

@illume illume commented Nov 4, 2024

This makes Details views work with multiple cluster.

The ?cluster is passed via a URL query parameter. Because in the normal cluster part of the URL is the group of clusters, and the details view needs to know which of the clusters the resource is in.

Here you can see details views being clicked on and the work (even though multiple clusters are active).

multi-cluster-small.mp4
  • frontend: DetailsGrid: Fix for using a specific cluster
  • frontend: router: Fix createRouteURL to take query params
  • frontend: KubeObject: Add cluster query param to getDetailsLink
  • frontend: k8s: Add useClusterFromURLVar to get cluster
  • frontend: Details: Add support for cluster via URL var

@illume illume force-pushed the details-multi branch 3 times, most recently from a6d342a to e139586 Compare November 4, 2024 13:53
@illume illume marked this pull request as ready for review November 4, 2024 13:56
@dosubot dosubot bot added the size:M This PR changes 30-99 lines, ignoring generated files. label Nov 4, 2024
@illume illume added multi Multi cluster aggregated view enhancement New feature or request frontend Issues related to the frontend labels Nov 4, 2024
@illume illume requested review from a team and knrt10 November 4, 2024 14:23
@joaquimrocha
Copy link
Collaborator

joaquimrocha commented Nov 8, 2024

Please look into this branch, since I think I had also added a way to llink to resources details without having to create a new URL query param:
https://github.com/headlamp-k8s/headlamp/tree/aggregated-view-original-rebased

Copy link
Collaborator

@joaquimrocha joaquimrocha left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think (haven't double checked) that in https://github.com/headlamp-k8s/headlamp/tree/aggregated-view-original-rebased , I had computed the route directly from the resource in ResourceLink, thus using the known URLs without a cluster param.

@illume
Copy link
Collaborator Author

illume commented Nov 8, 2024

frontend: Automatically add the cluster param to ResourceLink 0e2f0f3
IIUC, this replaces that 1st PR from the list you shared earlier

That's included already. It adds to the cluster param AFAIK. Which is /c//
Thanks for the tip though. Let me try running that branch and see if I can find it that way.

Yes, and that's okay because when you go into a resource details view, you want to see only one cluster.
When you press back, it goes back to whatever the URL was, including the c/SOMEGROUP

The problem with only relying on this is that:

  • the URL has only one cluster in it, which means sharing/using links loses the cluster group
  • if a person clicks on another link in the detail view(or in the navigation) then they lose the cluster group

This PR makes these things work.

@illume illume requested a review from joaquimrocha November 8, 2024 09:53
@joaquimrocha
Copy link
Collaborator

I see, and it's a good idea to keep the group context. But for that, I think it makes more sense to do it the other way around: keep the URL for the details view matching the normal details URL (i.e. /c/SINGLE_CLUSTER/resource-kind/my-resource) and use the query param for a group association: /c/SINGLE_CLUSTER/resource-kind/my-resource?cluster-group=MyGroup. This way, we accomplish what you want (keep a reference of the group) we don't have 2 different URLs for the same view, and we can eventually lose the query param and the view still works.
Does this make sense?

@illume
Copy link
Collaborator Author

illume commented Nov 8, 2024

All other links would then need to special case where /c/<cluster> means something different?

I don't think your proposal makes sense. Because why would we change the URL to '/c/<clusterGroup>' to just a single cluster just for this?

Edit:

With that proposal clicking on a detail view would update all the links in the navigation. With this way none of the other components need to rerender.

Unless I’m misunderstanding something?

This way, we accomplish what you want (keep a reference of the group) we don't have 2 different URLs for the same view, and we can eventually lose the query param and the view still works.
Does this make sense?

But they are two different views. There are other things being displayed than just the resource details. Every thing else related to the clusters is different.

*
* @returns the cluster name from the URL. If no cluster is defined in the URL, undefined is returned.
*/
export function useClusterFromURLVar(): string | undefined {
Copy link
Contributor

@sniok sniok Nov 8, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think we should be very explicit about what this means, because we already have a cluster 'variable' in the url /c/cluster/. To disambiguate I think this should be named something like useClusterFromQueryParam

of course if the approach of storing single cluster in query params stays, I only just saw discussion above

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What do you mean, never mind?

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I was thinking “query” is maybe overloaded with react query stuff. But maybe it’s ok.

useClusterFromSearchParam is also not quite right making it sound like it’s from a search.

useClusterFromURLQuery?
useURLQueryCluster?

Copy link
Contributor

@sniok sniok Nov 8, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

well there's a separate discussion about the url format, so this comment may not be relevant, let me rephrase it better

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

useURLQueryCluster sounds good
hm or maybe an approach of naming it for what it is instead of where it's stored, something like useDetailsSingleCluster?

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yeah maybe useDetailsSingleCluster is the least misdirecting/confusing.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

well there's a separate discussion about the url format, so this comment may not be relevant, let me rephrase it better

Can you please let us know which proposal you’d prefer and why?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

posted it in a separate comment

@sniok
Copy link
Contributor

sniok commented Nov 8, 2024

URL is supposed to be a unique resource identifier
if we think in terms of purely displaying details of a resource then /c/SINGLE_CLUSTER/resource-kind/my-resource makes sense
but the app also has selected clusters in the sidebar for example, so url has to represent that too

with the previous multi cluster changes we already changed the meaning of the /c/cluster/ param, it now represents all the selected clusters and not the cluster of a given resource.

so now we need to store information about a given resource cluster:

we could repurpose the /c/cluster/ param for it, but now it means different thing depending where we are in the app (selected clusters or cluster of a resource when showing details) and IMHO it's a bit confusing

we could put it in the query params /c/clusetA+clusterB/pods/my-pod?cluster=clusterA but query parameters are not supposed to be used for unique identification of a resource

a logical solution would be to introduce a new param in the url, like
/clusterB+clusterA/details/clusterA/pods/my-pod where /{selectedclusters}/details/{resourceCluster}/{resourceKind}/{resourceName}
(details can be ommited, variable order can be changed, it doesn't matter)

but this kind of solution seems like a big breaking change. so I think doing ?cluster=clusterA is the simplest solution here?

@illume
Copy link
Collaborator Author

illume commented Nov 8, 2024

a logical solution would be to introduce a new param in the url, like
/clusterB+clusterA/details/clusterA/pods/my-pod where /{selectedclusters}/details/{resourceCluster}/{resourceKind}/{resourceName}
(details can be ommited, variable order can be changed, it doesn't matter)

but this kind of solution seems like a big breaking change. so I think doing ?cluster=clusterA is the simplest solution here?

Adding {resourceCluster} into the URL could work too... I feel like it might even be the more correct choice?

How is it a breaking change though?

Edit:
Maybe adding it after the clusters?: /{selectedclusters}/{resourceCluster}/details/{resourceKind}/{resourceName}.

  • ?cluster pros simplest, and don't need to change routes
  • /{selectedclusters}/{resourceCluster}/details/{resourceKind}/{resourceName} is maybe more pure and correct. The con is having to change some routes as well... and also change the links in the navigation.

Considering that.. I'm leaning towards ?cluster... but if we can't come to a consensus, and someone asks I can try to implement one of the other ways. eg. /{selectedclusters}/{resourceCluster}/details/{resourceKind}/{resourceName} and see how it turns out?

@sniok
Copy link
Contributor

sniok commented Nov 8, 2024

How is it a breaking change though?

Detail links from current version wouldn't work in new version (if that is something we're concerned about)

@illume
Copy link
Collaborator Author

illume commented Nov 8, 2024

Detail links from current version wouldn't work in new version (if that is something we're concerned about)

I guess we can keep the previous route? So it will keep working as well.

  • new /{selectedclusters}/{resourceCluster}/details/{resourceKind}/{resourceName}
  • prev /{selectedclusters}/details/{resourceKind}/{resourceName}

One other con against ?cluster is that if you remove it the URL is broken.

  • if you have /{selectedclusters}/details/{resourceKind}/{resourceName}?cluster={resourceCluster}
  • then remove ?cluster the URL is broken: /{selectedclusters}/details/{resourceKind}/{resourceName}

So yeah... for these reasons I think it's worth trying out:

  • new /{selectedclusters}/{resourceCluster}/details/{resourceKind}/{resourceName}
  • prev /{selectedclusters}/details/{resourceKind}/{resourceName}

What do you think? If you both agree I'll try it. cc @joaquimrocha

@illume
Copy link
Collaborator Author

illume commented Nov 18, 2024

@joaquimrocha can you please respond to this comment? #2520 (comment)

@joaquimrocha
Copy link
Collaborator

So yeah... for these reasons I think it's worth trying out:

  • new /{selectedclusters}/{resourceCluster}/details/{resourceKind}/{resourceName}
  • prev /{selectedclusters}/details/{resourceKind}/{resourceName}

What do you think? If you both agree I'll try it. cc @joaquimrocha

I think having c/GROUP/CLUSTER/details/KIND/NAME and also having c/CLUSTER/details/KIND/NAME is confusing. Does that mean that you will also have c/GROUP/CLUSTER? What will be displayed in this case?

The point from my initial comment was that you do not need a group to display the details view, this is not a details view of a group, it's of a a resource. So what's missing in what we already have is the context of the group, so e.g. the user to go back to. And for that reason, IMO a query param works fine.

Unless I misunderstood your reply to my initial comment. Let me try to address it below:

All other links would then need to special case where /c/<cluster> means something different?

What does this mean?

I don't think your proposal makes sense. Because why would we change the URL to '/c/<clusterGroup>' to just a single cluster just for this?

Because the details view is single cluster only. In my mind, this is like going to the settings of a cluster: this would be single cluster only, no reason to go there in the context of a group.
So the view is the same whether you reach it from a group or single cluster related list, the only difference is that when coming from a group, you might have info that it came from a group, and that works fine with a query param.

With that proposal clicking on a detail view would update all the links in the navigation. With this way none of the other components need to rerender.

I don't understand. We can easily use the cluster member we got in each resource instance to compute the single cluster link + group query param, right?

This way, we accomplish what you want (keep a reference of the group) we don't have 2 different URLs for the same view, and we can eventually lose the query param and the view still works.
Does this make sense?

But they are two different views. There are other things being displayed than just the resource details. Every thing else related to the clusters is different.

What are the other things being displayed when you are viewing a resource so that you would need the group info without it being in a query param?

This is because in multi cluster mode the "cluster" that is used
is not the correct one (it is all of them).

Signed-off-by: René Dudfield <[email protected]>
Also add some documentation and a return type for the function.

Signed-off-by: René Dudfield <[email protected]>
This allows links to Details views to have the cluster from where
the resource lives in when in multi cluster mode. This allows
the URL to contain the multiple clusters and for the URL to still
know which of the multiple clusters to look.

Signed-off-by: René Dudfield <[email protected]>
From the ?cluster= in a URL search paramater.

Signed-off-by: René Dudfield <[email protected]>
This is so that in multi cluster mode the URL can keep the group
of clusters in the URL, but the details still know which cluster
to use for fetching details.

Signed-off-by: René Dudfield <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request frontend Issues related to the frontend multi Multi cluster aggregated view size:M This PR changes 30-99 lines, ignoring generated files.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants