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

Publish grammY to JSR respository #559

Open
Tracked by #675
fwqaaq opened this issue Apr 10, 2024 · 35 comments
Open
Tracked by #675

Publish grammY to JSR respository #559

fwqaaq opened this issue Apr 10, 2024 · 35 comments

Comments

@fwqaaq
Copy link
Contributor

fwqaaq commented Apr 10, 2024

  1. GitHub Action: https://jsr.io/docs/publishing-packages#publishing-from-github-actions
  2. Migrating Deno modules from /x to JSR: https://jsr.io/docs/migrate-x-to-jsr

You can use npm or deno to get packages from JSR.

@KnorpelSenf
Copy link
Member

This will be done with the entire ecosystem, not just the core library. We have to make sure that things stay consistent and compatible.

This requires a new build infrastructure. We still want to publish everything to npm because as of 2024, that is still the go-to place for Node.js users.

It is currently unclear whether or not we are going to leverage the existing tools we built. We may also want to write a service called jsr2npm that

  • takes a module from JSR,
  • downlaods its npm tarball,
  • rewrites the package name,
  • repackages the tarball,
  • consumes a publish token from npm, and
  • publishes the package to npm.

There are a lot of things to consider here, since people should be able to import grammY

  • from Deno (in one way or another)
  • from npm for Node.js
  • from npm for Vercel, Cloudflare Workers, and others
  • from npm for Browsers
  • from GitHub with Deno
  • from GitHub with npm for Node.js
  • from GitHub with npm for Vercel, Cloudflare Workers, and others
  • from GitHub with npm for Browsers
  • via a URL (JS-only, no types)

and it should all just work with no further setup.

We might have to make the difficult decision to drop support for CJS, but since this commit we might just ship ESM without TLA and require CJS users to pass a flag until it is stable.

@rojvv
Copy link
Member

rojvv commented Apr 10, 2024

I advocate for writing a custom script that replaces imports with JSR ones, and vendors whatever cannot be replaced.

@KnorpelSenf
Copy link
Member

Which imports? Do you mean @std?

@fwqaaq
Copy link
Contributor Author

fwqaaq commented Apr 10, 2024

This will be done with the entire ecosystem, not just the core library. We have to make sure that things stay consistent and compatible.

Yeah, the support of grammy for ESM is excellent, and JSR provides a very simple way to migrate: https://jsr.io/docs/migrate-x-to-jsr

@rojvv
Copy link
Member

rojvv commented Apr 10, 2024

Which imports? Do you mean @std?

@KnorpelSenf Yes, and grammY imports, of course.

@rojvv
Copy link
Member

rojvv commented Apr 10, 2024

I’m also unsure how JSR handles peer dependencies for Node.js, so I don’t think it’d be good to recommend it for Node.js users (maybe?).

@shevernitskiy
Copy link
Contributor

shevernitskiy commented May 11, 2024

It's pretty simple to download npm-ready tarball from jsr.
There is a special endpoint . For example:https://npm.jsr.io/@jsr/shevernitskiy__amooutputs:

{
  "name": "@jsr/shevernitskiy__amo",
  "description": "This is a simple wrapper client for the amoCRM REST API. It covers almost all API modules and endpoints. Also, it manages to token refreshing and webhook handling.",
  "dist-tags": {
    "latest": "0.2.5"
  },
  "versions": {
    "0.2.5": {
      "name": "@jsr/shevernitskiy__amo",
      "version": "0.2.5",
      "description": "This is a simple wrapper client for the amoCRM REST API. It covers almost all API modules and endpoints. Also, it manages to token refreshing and webhook handling.",
      "dist": {
        "tarball": "https://npm.jsr.io/~/11/@jsr/shevernitskiy__amo/0.2.5.tgz",
        "shasum": "04C2380FC1C556A52FA0A40FD3865A881550537D",
        "integrity": "sha512-k/HilfYJb+hbTRfbdtZy2G//nOLSmk1VCfNrXDHjnyWyeq06KS5LzUns0zAghmVSMoPQJYTOSW0nIA6Y7hiYkg=="
      },
      "dependencies": {
        
      }
    },
    "0.2.4": {
      "name": "@jsr/shevernitskiy__amo",
      "version": "0.2.4",
      "description": "This is a simple wrapper client for the amoCRM REST API. It covers almost all API modules and endpoints. Also, it manages to token refreshing and webhook handling.",
      "dist": {
        "tarball": "https://npm.jsr.io/~/11/@jsr/shevernitskiy__amo/0.2.4.tgz",
        "shasum": "39C6C73D454DE23A06E693F5A8E6308AB4084C01",
        "integrity": "sha512-J1Vx1QduYjUXKe2vVcK7luL8znCOfo1DA+Tv1VG6CVRGfOUx3Z2/Yk7SBHV8HNTs/q77dSxxglIJWL40grEFIA=="
      },
      "dependencies": {
        
      }
    }
  },
  "time": {
    "created": "2024-03-02T05:37:01.088Z",
    "modified": "2024-03-03T05:14:15.443Z",
    "0.2.5": "2024-04-11T05:02:50.177Z",
    "0.2.4": "2024-03-02T05:37:10.149Z"
  }
}

It contains all npm needs including package.json:
image

_dist contains d.ts files

@KnorpelSenf
Copy link
Member

Yep we're aware how JSR works, the pending question is just if we

a) download npm tarballs from JSR and upload them to npm, or
b) build our own tool, potentially leveraging the build functionality of JSR, and package stuff in CI and upload it ourselves.

a) is much easier, but we depend on an API during build.

b) is harder but naturally more reliable.

@shevernitskiy
Copy link
Contributor

shevernitskiy commented May 12, 2024

I think it could be a for start and then replaced for b without any issues (if it will be needed). In CI it cloud be 1 or several steps.

@shevernitskiy
Copy link
Contributor

shevernitskiy commented May 12, 2024

I've noticed, that hono dev doing some work on this too:) honojs/hono#2662

@shevernitskiy
Copy link
Contributor

shevernitskiy commented May 15, 2024

Btw, https://github.com/denoland/dnt allows to download a package and make it local in case of it can't be resolved as npm packcage. Also it supports shims and mappings like *.deno.ts/ *.node.ts as well as deno2node and handles with jsr specifiers (denoland/dnt#398).
So, we could prepare npm build with this tool and move to JSR imports in deno source code.

@KnorpelSenf
Copy link
Member

d2n already does this for us. You're describing our current build setup, just with /x swapped out for jsr.

@shevernitskiy
Copy link
Contributor

As I understand, d2n can't download packages and make it local when it can't be resolved as npm package.

@KnorpelSenf
Copy link
Member

It can do this, but I don't think we use that feature anyway.

If we can't get rid of custom build tooling, then we can switch to JSR immediately and close this issue. Moving to dnt is not an option, this has been discussed extensively on numerous occasions. The only reason why we'd need to touch our tooling is if we can maybe drop everything and let JSR handle it, and all that's left for us to do is to download and re-upload.

@KnorpelSenf
Copy link
Member

KnorpelSenf commented May 16, 2024

I think I would like to go with the following approach:

  1. Check if we can rely on JSR to build our own npm tarball in GH actions, such as by importing the api crate from https://github.com/jsr-io/jsr/tree/main/api and then calling https://github.com/jsr-io/jsr/blob/4389058b3e80b647e3126fd84c005272d66e5348/api/src/tasks.rs#L71
  2. If this can be done with a reasonable amount of effort, publish dually to JSR and npm, both using the same transform logic (once running on JSR and once running inside GH actions)
  3. If step 1 fails, we instead build a tool to download tarballs from JSR, repackage them, and upload them to npm again
  4. Step 3 has the downside of relying on a third-party service during build, which is not ideal. If this ever breaks down or starts being unacceptable, we can go back to step 1 and put in more effort to use JSR, or build our own tool, or find a different solution so that CI is self-contained again

@shevernitskiy
Copy link
Contributor

Do you want to spin up whole api and use endpoint or just get the tarball build code?
Seems like the actual build code is here https://github.com/jsr-io/jsr/blob/main/api/src/analysis.rs#L434

@shevernitskiy
Copy link
Contributor

Well, at least i want to try:D
jsr-io/jsr#525

@KnorpelSenf
Copy link
Member

Nice! I'd fork JSR and extract the things myself so that we can work with it. If they accept a contribution upstream, that's great, but I would not want to wait for that.

The best way to do this is to isolate the transpilation up to the point that we just need to provide a scope, a name, and a version, and receive a tarball.

@kamikazechaser

This comment was marked as off-topic.

@KnorpelSenf

This comment was marked as off-topic.

@kamikazechaser

This comment was marked as off-topic.

@KnorpelSenf
Copy link
Member

@kamikazechaser have you read the above issue?

@kamikazechaser

This comment was marked as off-topic.

@KnorpelSenf

This comment was marked as off-topic.

@kamikazechaser
Copy link

kamikazechaser commented Oct 12, 2024

what you're saying related to this issue, or grammY in general?

The title is Publish grammY to JSR respository

What I am trying to say is that there is no downside to re-publishing this repo to JSR. It is going to go mainstream with Deno heavily investing into it. If you don;t want, I understand and that is fine.

@KnorpelSenf
Copy link
Member

I think you just have not read this issue 😁

@kamikazechaser
Copy link

I think this is going nowhere. I'll leave it at this. I understand that you want to be consistent with all ecosystems and that is fine.

@KnorpelSenf
Copy link
Member

@wojpawlik @niusia-ua I think we should not wait for jsr2npm to become a reality. We can start working on v2 before that, and publish beta releases to JSR for the time being. There will be enough time before a major release to figure out how to solve npm compat, so the tool can be written at a later point.

In contrast to JSR, npm can actually install things from GH, so we won't even leave npm users behind.

@wojpawlik
Copy link
Contributor

Issue: pushing a v2 tag will create a release on /x. It has no right to work there, since /x doesn't support import maps.

@KnorpelSenf
Copy link
Member

Not an issue. We are not going to tag beta releases. We are simply going to push them to JSR without tagging. When 2.0 is released (that will be a big day), we are going to remove the webhook integration with /x and start tagging again.

@wojpawlik
Copy link
Contributor

1.x releases after 2.0 won't be on /x. Is that ok?

@wojpawlik wojpawlik mentioned this issue Dec 30, 2024
51 tasks
@KnorpelSenf
Copy link
Member

I'm afraid there's no other way with how /x is designed.

Unless we want to temporarily re-add the webhook integration manually for a few seconds while adding a new 1.x tag. That could be an escape hatch if we want to provide further Bot API compatibility releases for 1.x

@wojpawlik
Copy link
Contributor

s/re-add/re-enable/

@KnorpelSenf
Copy link
Member

True, we should disable it instead of removing it. At least as long as we want to support 1.x releases.

@KnorpelSenf
Copy link
Member

KnorpelSenf commented Dec 31, 2024

I am currently working on #720 which unblocks #681 which in turn unblocks this issue. Getting out a first 2.0 beta version on JSR is a priority.

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

Successfully merging a pull request may close this issue.

6 participants