-
Notifications
You must be signed in to change notification settings - Fork 485
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 doc for ReadmeUriTemplate #3382
base: main
Are you sure you want to change the base?
Conversation
# README Uri Template | ||
|
||
It is possible for a client to build a URL that can be used to download a README for a specific package. | ||
This will enable the clients to render the package's README without downloading the entire package. |
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.
isn't it also possible for the readme url to be provided in the package metadata (registration) blob? Or is that not yet implemented?
I think it should be made clear to server implementors that they implement one or the other, not both.
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.
Not implemented yet, we don't have any commitments from servers to implement that option.
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.
well, this makes me frustrated. Firstly, it imples that we talked to the dozens of 3rd party NuGet server implementors. Secondly, it means that the ReadmeFileUrl
public APIs in NuGet.Protocol are now leaky abstractions, since NuGet will never expect it in a search or registration response, which some people consider an anti-pattern and tech debt.
Considering these public APIs are in the unshipped txt, are you able to delete these public APIs before this version of Nuget ships?
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.
That's true I should say we didn't get a commitment from ADO to enable this feature. I unfortunately didn't see this response before the cutoff. That said the way I implemented this would have needed to change in a way that fixing it by Wednesday would have been too risky.
Regarding a leaky abstraction the ReadmeFileUrl is being populated by the protocol using the ReadmeUriTemplate. I did this intentionally so the client wouldn't need to concern itself with what implementation the feed has implemented.
|
||
@type value | Notes | ||
--------------------------------- | ----- | ||
ReadmeUriTemplate/6.13.0 | The initial release |
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.
There's a "server implementor guide" doc that has a chronological list of changes to the NuGet protocol, so it's easy for server implementors to check if they're "up to date" with all client features, and find what's new since the last time they checked. This should be documented on that page.
If you have any suggestions on how to make sure other people who make changes to the protocol know to update that page, without needing a human like me to remind them, please share your ideas.
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.
When do we decide to update that page? For instance, the report abuse resource wasn't added there.
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.
please add the report abuse resource as well
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.
Hmm, so I recall having a conversation about how we want to tell the servers that if they implement this new resource type that the client will be call it anytime we try to view a readme so they should expect calls for packages that do not have README and should return 404s...
NuGet Server Implementation Guide seems to have these sorts of considerations. Should we continue splitting these across the two documents? I don't feel like I know enough about how report abuse works to add anything meaningful to the guide.
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.
the two documents have different focuses. The resource doc has all the details. The server implementation guide helps people working on NuGet feeds figure out what has changed recently.
Pretend you work on a package repository, and notice that most of them (Azure Artifacts, Artifactory, GitHub Package Registry, etc) support multiple package managers (nuget, npm, cargo, pip, etc). The server implementation guide helps these people quickly figure out if there are any new features that they might be interested in implementing, without having to read every single resource docs page.
Hence the server implementation guide is best to have a summary or overview, with a link to the detailed resource docs. But the important part is that it's a kind of change log with dates, so the server implementors can quickly check oh, we implemented everything (we care about) in 2020, is there anything new we should implement now?
No description provided.