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

src: use itty-router for routing requests #125

Merged
merged 1 commit into from
Aug 27, 2024
Merged

Conversation

flakey5
Copy link
Member

@flakey5 flakey5 commented Jun 21, 2024

Closes #122
Closes #106
Closes #111

Fixes dates past April/May on directory listings

TODO

  • r2 middleware
  • origin middleware
  • caching middleware
  • tests
  • commenting
  • custom request type (contains parsed url so we only do it once)

@flakey5
Copy link
Member Author

flakey5 commented Jun 21, 2024

cc @ovflowd

@flakey5 flakey5 force-pushed the flakey5/20240606/routing branch 4 times, most recently from 468abd1 to 6073527 Compare June 30, 2024 21:46
Copy link
Member

@ovflowd ovflowd left a comment

Choose a reason for hiding this comment

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

Partial review! Going to review more later :)

src/middleware/originMiddleware.ts Outdated Show resolved Hide resolved
src/middleware/r2Middleware.ts Outdated Show resolved Hide resolved
src/middleware/r2Middleware.ts Outdated Show resolved Hide resolved
src/middleware/r2Middleware.ts Outdated Show resolved Hide resolved
});
}

function getR2Path({
Copy link
Member

Choose a reason for hiding this comment

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

Shouldnt these be handled by itty router why path regular expressions? Ie:

/some/path/{something}/some/other/matcher

Copy link
Member Author

Choose a reason for hiding this comment

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

We are handling parts of the path with itty router here, but that just pulls out some info from the path so that we can use it later.

We still need to take the relevant parts and make the path in the r2 bucket, which is what this function does

Copy link
Member

Choose a reason for hiding this comment

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

Can't we use itty router again for that? Like a layered strategy?

So an in-router router? Because that is the part I really wish to become "easy to handle" by just using itty-router

Copy link
Member Author

Choose a reason for hiding this comment

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

Maybe? I'm not really sure what that would look like

I think with this approach we're still better off though. It's still a tiny bit messy but a lot more understandable than what we have now and would probably be simpler than having an in-router router imo

I also debated doing something like

router.get('/:rootPath/?:path+', [cached(r2Middleware), originMiddleware]);

that way we can just use a switch statement in getR2Path, which might help with cleaning it up. Performance wise it should be about the same. Might cause some annoyances if we want to add other GET paths to the worker later down the road though

Copy link
Member

Choose a reason for hiding this comment

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

I'm still a -1 with this approach, we doing too much logic, and I believe using an inner router (even if it's not really routing but just path matching feels better.

So we remove the wrangle of if/elses to simply having callback statements;

Hence this function itself instead of returning a value, has callbacks... At least for me it becomes easier to read than all these conditions 😅

And also easier to maintain as path matchers/globs are easier to maintain imo

Copy link
Member

@ovflowd ovflowd Aug 24, 2024

Choose a reason for hiding this comment

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

Let me know, @flakey5 what you decide to do here :) -- Since I would really appreciate some abstraction here.

Copy link
Member Author

Choose a reason for hiding this comment

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

How about we make an issue and take a look at this later on, just to limit this pr from growing any larger 😅 ?

I think I know an approach that would work for this though

@flakey5 flakey5 force-pushed the flakey5/20240606/routing branch 2 times, most recently from 9536911 to 7feed9d Compare July 4, 2024 18:30
@flakey5 flakey5 marked this pull request as ready for review July 4, 2024 18:30
@flakey5 flakey5 requested review from a team as code owners July 4, 2024 18:30
src/constants/r2Prefixes.ts Outdated Show resolved Hide resolved
@flakey5 flakey5 force-pushed the flakey5/20240606/routing branch 3 times, most recently from 16c0b7b to 7f20585 Compare July 4, 2024 20:19
@flakey5 flakey5 requested a review from ovflowd July 11, 2024 18:49
@ovflowd
Copy link
Member

ovflowd commented Jul 12, 2024

Sorry for the delayed review. Gonna do it tomorrow! I was swamped with work

@flakey5
Copy link
Member Author

flakey5 commented Jul 12, 2024

Sorry for the delayed review. Gonna do it tomorrow! I was swamped with work

No worries, thank you!

Copy link
Member

Choose a reason for hiding this comment

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

Isn't this auto-generated? If yes, shouldn't it be on the gitignore?

Copy link
Member Author

Choose a reason for hiding this comment

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

It is but with the way it's generated it needs to be committed. The update-latest-versions.js utilizes the s3 api, which requires an access key & secret for the dist-prod bucket.

Copy link
Member

Choose a reason for hiding this comment

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

Can't this be generated during the CI that deploys the Worker?

Copy link
Member Author

Choose a reason for hiding this comment

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

We could if we replaced the file with a placeholder, but imo committing a placeholder vs what's going to be deployed, I'd prefer the later since it'd be easier to debug if any issues pop up.

Or unless you're suggesting we move the update redirect links action into the deployment one (i.e. as a step we update & commit the file)? I'd be in favor of this tbh

Regardless we'd need something for the file in git or else we couldn't import it in the code, I also think this might be out of the scope of this pr since this is already the way it's been done and this pr is already fairly big

Copy link
Member

Choose a reason for hiding this comment

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

I feel that the CI could be responsible for generating the file and ensuring when deployed it is correct.

Instead of committing this within the repo; This sounds like the sort of file that shouldn't be committed.

Copy link
Member Author

Choose a reason for hiding this comment

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

This sounds like the sort of file that shouldn't be committed.

How would local testing work then, do we just want a placeholder file? It would throw if we omitted it entirely, https://github.com/nodejs/release-cloudflare-worker/pull/125/files#diff-d62c9ceba913680e28434574c470caed6e5539f9afd659b538f45840e1ad20caR7

src/utils/request.ts Outdated Show resolved Hide resolved
src/utils/memo.ts Outdated Show resolved Hide resolved
src/routes/router.ts Outdated Show resolved Hide resolved
Copy link
Member

@ovflowd ovflowd left a comment

Choose a reason for hiding this comment

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

LGTM! Apologies for taking so long to finish reviewing this. Please address my comments first before proceeding to merge this. Here are some caveats:

  • Please add more inline docs whenever possible, some logic might not be understood by newcomers and some insider' context of why a said piece of code was done in a certain way is done this way might be not easy to follow.
  • Update empty lines to be consistent
  • Ensure you are properly using import type
  • Avoid using + operator with strings
  • Separate logic from return statements, assign dedicated constants for the values of the keys of return statements that have complex objects
  • Ensure everything is properly typed
  • Make constants for things that should be constants
  • Ensure you are covering edge scenarios of your logic, cover things with test suites, in doubt ask Copilot.

@flakey5 flakey5 force-pushed the flakey5/20240606/routing branch 4 times, most recently from baa81d4 to d25e05c Compare August 24, 2024 23:20
@flakey5 flakey5 force-pushed the flakey5/20240606/routing branch from d25e05c to f642247 Compare August 25, 2024 18:25
@flakey5 flakey5 merged commit 39f5e0e into main Aug 27, 2024
3 checks passed
@flakey5 flakey5 deleted the flakey5/20240606/routing branch August 28, 2024 02:03
flakey5 added a commit that referenced this pull request Sep 5, 2024
Investigating why staging always falls back to the origin for directory
listings after #125, this will _hopefully_ fix things

Sentry ref: https://nodejs-org.sentry.io/issues/5799625624/

Signed-off-by: flakey5 <[email protected]>
flakey5 added a commit that referenced this pull request Sep 5, 2024
Investigating why staging always falls back to the origin for directory
listings after #125, this will _hopefully_ fix things

Sentry ref: https://nodejs-org.sentry.io/issues/5799625624/

Signed-off-by: flakey5 <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
force ci Force tests & linting to be ran on a PR
Projects
None yet
3 participants