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

Add DynamicWindowsDesktop to proto #46984

Merged
merged 10 commits into from
Oct 14, 2024

Conversation

probakowski
Copy link
Contributor

This PR adds new resource to proto files: DynamicWindowsDesktop.
It will be used for dynamic registration of windows desktops (#37103)

This is part of splitting #46738 into smaller, easier to review, PRs

Copy link

The PR changelog entry failed validation: Changelog entry not found in the PR body. Please add a "no-changelog" label to the PR, or changelog lines starting with changelog: followed by the changelog entries for the PR.

@probakowski probakowski added the no-changelog Indicates that a PR does not require a changelog entry label Sep 30, 2024
Copy link
Contributor

@rosstimothy rosstimothy 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 we should follow most of the guidance defined in RFD 153 for this new resource. The only deviation that might be warranted here is to define the dynamic desktop resource type in the legacy types package so that it can still have gogo tags and be added to List[Unified]Resources.

However, I think the rest of the CRUD service would be better off defined in it's own service and follow the API semantics laid out in RFD 153 for consistency and to reduce the footprint of the auth service proto.

api/proto/teleport/legacy/client/proto/authservice.proto Outdated Show resolved Hide resolved
api/proto/teleport/legacy/client/proto/authservice.proto Outdated Show resolved Hide resolved
@probakowski
Copy link
Contributor Author

@zmb3 @rosstimothy friendly ping

api/proto/teleport/legacy/types/types.proto Outdated Show resolved Hide resolved
Comment on lines +5480 to +5481
// DynamicWindowsDesktopV1 represents a dynamic windows host for desktop access.
message DynamicWindowsDesktopV1 {
Copy link
Contributor

Choose a reason for hiding this comment

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

Do we intend for this type to be added to any existing legacy APIs(Inventory Control Stream, List Resources, List Unified Resources, etc.)?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

We don't need it in List Resources and such because they are only used to create WindowsDesktops that will show up in those APIs already. We do want to add it to terraform provider and operator, though.

Copy link
Contributor

Choose a reason for hiding this comment

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

What about heartbeats via the Inventory Control Stream? I'm asking because if it will not be heartbeated via the ICS or added to one of the ListResources variants, then this type should likely be defined outside of legacy/types/types and follow the guidance in RFD 153 with respect to resource naming and definition.

@hugoShaka has recently made changes so that RFD 153 resources are available in the TF provider, though I'm not sure if the operator supports them yet.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

For the operator there's open issue that prevents us from using 153-style resources there. That's one of the reasons to put this into legacy package.

Copy link
Contributor

Choose a reason for hiding this comment

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

Do we need support for the operator immediately? Can it wait until we can properly support RFD 153 resources?

Copy link
Collaborator

Choose a reason for hiding this comment

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

We'd like to support Terraform and the Kube operator, but if I had to pick one then Terraform is probably more important.

I think it makes sense to keep dynamic registration as similar as we can across all resources. If Dynamic registration for apps and databases doesn't use 153-style resources then we might as well be consistent.

Copy link
Contributor

Choose a reason for hiding this comment

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

IMO the only reason not to switch to a pure 153 resource is if the resource needs to be used in a legacy API. I'm fairly certain we'll want to heartbeat these via ICS so that we can support more than 998 of them, but I've not gotten an answer about that yet.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

I don't think that we will heartbeat on them TBH, they are meant to be created/managed by user (or terraform but still) not by our service so they probably don't need heartbeat unless I miss something

Copy link
Contributor

Choose a reason for hiding this comment

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

In that case I'd vote for this to not be a legacy type but will yield if you all feel strongly it should belong here to not hold up progress.

@public-teleport-github-review-bot public-teleport-github-review-bot bot removed the request for review from atburke October 14, 2024 17:58
@probakowski probakowski enabled auto-merge October 14, 2024 18:17
@probakowski probakowski added this pull request to the merge queue Oct 14, 2024
Merged via the queue into master with commit 4c7fa50 Oct 14, 2024
42 checks passed
@probakowski probakowski deleted the probakowski/register-resources-proto branch October 14, 2024 18:39
mvbrock pushed a commit that referenced this pull request Oct 16, 2024
* Add DynamicWindowsDesktop to proto

* move rpc to separate server

* e

* remove dynamic windows from paginated resource

* Update api/proto/teleport/legacy/types/types.proto

Co-authored-by: rosstimothy <[email protected]>

---------

Co-authored-by: rosstimothy <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
desktop-access no-changelog Indicates that a PR does not require a changelog entry size/sm
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants