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 way for package maintainers to specify their own overrides #8

Open
jdalton opened this issue Oct 17, 2024 · 14 comments
Open

Add a way for package maintainers to specify their own overrides #8

jdalton opened this issue Oct 17, 2024 · 14 comments
Assignees
Labels
enhancement New feature or request

Comments

@jdalton
Copy link
Collaborator

jdalton commented Oct 17, 2024

In developing Socket Registry I have been noodling on giving package maintainers the ability to specify their own overrides. So we can include them where it makes sense (in our registry/manifest.json). \cc @ljharb

I'd like the data to be accessible via the npm registry. We query the registry to create the manifest per package looking for things like "deprecated". Let's keep it simple. If a version is released with a prerelease of "override" we can defer to it for some category of overrides, like "cleanup".

@jdalton jdalton added the enhancement New feature or request label Oct 17, 2024
@jdalton
Copy link
Collaborator Author

jdalton commented Oct 17, 2024

@ljharb do you want to test the waters with this? Maybe pick an easier/simple package and try it out.

@jdalton jdalton self-assigned this Oct 17, 2024
@ljharb
Copy link

ljharb commented Oct 17, 2024

The use cases I think are good to handle are:

  • a different version of the same package is the replacement (either a prerelease range, or a major range, or a dist-tag)
  • an entirely different package is the replacement (replace foo with bar@^1 eg)
  • a scope is the replacement (replace foo with @ljharb-cleanups/foo, or something, same version numbers)

The third one is a bit too complex but I thought it was worth mentioning anyways.

A possible approach that could handle the first two is a new top-level key, say "variants". The LHS of this object is a category, like "cleanup", or an arbitrary string. The RHS is the same as the RHS of an overrides object.

So, for a concrete scenario:

  • I have call-bind v1, which by default uses function-bind, grabs a bunch of intrinsics, and is CJS.
  • I could create an ESM version that assumes bind and Object.defineProperty and Reflect.apply exist, and publish it as a prerelease of v2, like v2.0.0-cleanup.0
  • then on v1, i publish package.json with variants: { cleanup: '^2.0.0-cleanup' } or similar, and this tool can automatically pick that up

Alternatively:

  • I have call-bind v1, which by default uses function-bind, grabs a bunch of intrinsics, and is CJS.
  • I could create an ESM version that assumes bind and Object.defineProperty and Reflect.apply exist, and publish it as call-bind-modern
  • then on v1 of call-bind, i publish package.json with variants: { cleanup: 'call-bind-modern@^1' } or similar, and this tool can automatically pick that up

Thoughts?

@jdalton
Copy link
Collaborator Author

jdalton commented Oct 17, 2024

So the key is metadata in your package.json. Our socket overrides have a socket field in their package.json so I can dig that. I like storing it there so we can query and spot it. Enter bikeshed of what to call it. Let's say "variants" for now. A tag used for the name of the variant and a reference. I believe npm does it like npm:call-bind-modern@^1. That could work! Then any tool looking for a variant and a tag can do what they want with the info. We have a thing (cleanup) and a replacement (npm:call-bind-modern@^1).

@ljharb
Copy link

ljharb commented Oct 17, 2024

exactly - and i can make up my own variants if i want, and tools can choose to adopt them if they want.

@jdalton
Copy link
Collaborator Author

jdalton commented Oct 17, 2024

Okay. Let's roll with "variants". ChatGPT could not come up with a better name 🙃 🤣

@jdalton
Copy link
Collaborator Author

jdalton commented Nov 1, 2024

@ljharb This is next on my plate to take on. There's an easy way and a less easy way to detect this. One is looking at the packages already in the node_modules folder and the other is querying the registry to get the latest version and extract the package.json to inspect.

Update: We’ll try going the packument route

@ljharb

This comment was marked as resolved.

@jdalton

This comment was marked as resolved.

@ljharb

This comment was marked as resolved.

@jdalton

This comment was marked as resolved.

@ljharb

This comment was marked as resolved.

@jdalton

This comment was marked as resolved.

@jdalton
Copy link
Collaborator Author

jdalton commented Jan 23, 2025

@ljharb Touching base on this, have you added the variants field to any packages?

@ljharb
Copy link

ljharb commented Jan 23, 2025

no, not quite yet - the latest package i've published tho using multiple conceptual variants is https://npmjs.com/async-function, that might be a great one to experiment with.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
None yet
Development

No branches or pull requests

2 participants