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 a resource reference generator #50515

Open
wants to merge 4 commits into
base: master
Choose a base branch
from

Conversation

ptgott
Copy link
Contributor

@ptgott ptgott commented Dec 20, 2024

Closes #16948
Closes #9949
Closes #39564

Implements RFD 130.

See the included README for information about how the generator works.

This implementation breaks from RFD 130 in the following ways:

  • The reference includes separate pages for dynamic resources in order to make it easier to read.
  • The generator specifies the kind and version of each dynamic resource. To do this, the generator looks up a method called for each resource type to assign the type's version and kind.
  • The generator uses a YAML configuration file. This is because the config ended up including more fields than specified in the RFD, so separating the config from the source made sense to give users less noise to deal with.
  • In the example YAML blocks and type table values, leave types empty if we can't process them.

Edit the RFD:

  • Be less specific about the output template so this isn't wedded to implementation details.
  • Remove the description of example YAML delimiters. These are no longer viable, as we maintain several documentation generators that extract comments from the source.

@public-teleport-github-review-bot

@ptgott - this PR will require admin approval to merge due to its size. Consider breaking it up into a series smaller changes.

Copy link

🤖 Vercel preview here: https://docs-771hg03b4-goteleport.vercel.app/docs

@ptgott
Copy link
Contributor Author

ptgott commented Dec 20, 2024

Reviewer note: this PR doesn't include generated docs, since that would make the diff even larger than it is now.

@ptgott ptgott force-pushed the paul.gottschling/2024-12-9949-resources branch from 145bf35 to 04d814b Compare December 24, 2024 13:58
Copy link

github-actions bot commented Dec 24, 2024

Amplify deployment status

Branch Commit Job ID Status Preview Updated (UTC)
paul.gottschling/2024-12-9949-resources 5ae21e5 7 ✅SUCCEED paul-gottschling-2024-12-9949-resources 2025-01-17 19:36:00

Copy link
Collaborator

@zmb3 zmb3 left a comment

Choose a reason for hiding this comment

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

Seems reasonable, I'll have to test it out soon!

Copy link
Contributor

@strideynet strideynet left a comment

Choose a reason for hiding this comment

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

First pass looks generally good - glad to see this being worked on!

I think my major concern is there may be parts of this generator that expect/rely on the resource being an old-style resource prior to RFD153 that is generated by GoGo Protobuf. I'd recommend possibly including a new RFD153-compliant resource in your testdata to ensure it'll work with the newest stuff (e.g the Bot resource is one of these)

@ptgott
Copy link
Contributor Author

ptgott commented Jan 8, 2025

First pass looks generally good - glad to see this being worked on!

I think my major concern is there may be parts of this generator that expect/rely on the resource being an old-style resource prior to RFD153 that is generated by GoGo Protobuf. I'd recommend possibly including a new RFD153-compliant resource in your testdata to ensure it'll work with the newest stuff (e.g the Bot resource is one of these)

Thanks for the feedback! I've pushed a change in e8b2609 to support RFD153-compliant resources. The biggest issue I had here was that there doesn't seem to be a consistent way to assign the kind and version fields for these resources, so we may need to figure out a way to do this manually in a separate change.

@ptgott ptgott requested a review from strideynet January 8, 2025 15:29
@ptgott ptgott requested review from EdwardDowling and zmb3 January 9, 2025 15:18
@ptgott ptgott force-pushed the paul.gottschling/2024-12-9949-resources branch from 8802f44 to 04ab4e4 Compare January 9, 2025 16:14
Closes #16948
Closes #9949

Implements RFD 130.

See the included README for information about how the generator works.

This implementation breaks from RFD 130 in the following ways:

- The reference includes separate pages for dynamic resources in order
  to make it easier to read.
- The generator specifies the kind and version of each dynamic resource.
  To do this, the generator looks up a method called for each resource
  type to assign the type's version and kind.
- The generator uses a YAML configuration file. This is because the
  config ended up including more fields than specified in the RFD, so
  separating the config from the source made sense to give users less
  noise to deal with.
- In the example YAML blocks and type table values, leave types empty if
  we can't process them.

Edit the RFD:

- Be less specific about the output template so this isn't wedded to
  implementation details.
- Remove the description of example YAML delimiters. These are no longer
  viable, as we maintain several documentation generators that extract
  comments from the source.
RFD 153 resource types include unexported fields and include a
`Metadata` field from a different package than legacy resources types.
They also include the `Metadata` field with a pointer.

Accommodating the different `Metadata` field only requires adding
another entry to `required_field_types` in the config. This change also
adjusts the generator to ignore unexported fields in struct
declarations, and to treat pointer field types the same way as value
field types.

Finally, this change removes some unnecessary spacing from the reference
template.
- Embed the reference page template
- Fix comments
- Fix config path in main
- Use filepath.Join instead of path.Join
- Organize go.mod properly
- Move template parsing into an init function
- Change a var declaration to a const
- Update copyright year.
- Wrap errors properly in `fmt.Errorf`.
@ptgott ptgott force-pushed the paul.gottschling/2024-12-9949-resources branch from 04ab4e4 to 5ae21e5 Compare January 17, 2025 19:32
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
documentation rfd Request for Discussion size/xl
Projects
None yet
4 participants