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

Allow compression to be disabled in self-hosted #231

Closed
rojosinalma opened this issue Mar 1, 2024 · 9 comments
Closed

Allow compression to be disabled in self-hosted #231

rojosinalma opened this issue Mar 1, 2024 · 9 comments
Labels

Comments

@rojosinalma
Copy link

rojosinalma commented Mar 1, 2024

Hello! I'm a dev using the gateway in a self-hosted environment (well actually in an EC2 machine in AWS), but I mean not running it as a service from Portkey.

Currently I'm having issues with the compression of requests, the gateway is basically using compression for every request unless its running on lagon or workerd. As per the code declares:

gateway/src/index.ts

Lines 35 to 38 in 8f60b16

const runtime = getRuntimeKey();
if (runtime !== "lagon" && runtime !== "workerd") {
return compress()(c, next)
}

I would prefer if compression is present only if there's a header in the request or alternatively provide an env var that allows to switch it off completely. I think the former would be a better option since it allows traffic control on a per-request basis.

@github-actions github-actions bot added the triage label Mar 1, 2024
@roh26it
Copy link
Collaborator

roh26it commented Mar 2, 2024

Hi @rojosinalma,

Thanks for reaching out!

The gateway respects the Accept-Encoding header in the request. You can try setting it to identity in your requests to disable compression.

Let me know if you need more help

@roh26it roh26it closed this as completed Mar 2, 2024
@rojosinalma
Copy link
Author

Thanks for explaining, but I still don't fully understand how is what you mentioned going to bypass what's hardcoded in the block I posted.

Could you give me more information please?

@VisargD
Copy link
Collaborator

VisargD commented Mar 3, 2024

Hey @rojosinalma - The compress middleware code that you have pointed out is written in a way that it will only do compress if the Accept-Encoding has a compression technique mentioned in it or if the code itself imposes a compress technique. In the case of gateway, we have not mentioned any compression technique, so it will rely on Accept-Encoding header. So if you send Accept-Encoding as identity, then it will not apply any compression on response. I hope this helps.

@rojosinalma
Copy link
Author

rojosinalma commented Mar 3, 2024 via email

@VisargD
Copy link
Collaborator

VisargD commented Mar 3, 2024

The same link that you have shared contains this info: https://hono.dev/middleware/builtin/compress#options

The compression scheme to allow for response compression. Either gzip or deflate. If not defined, both are allowed and will be used based on the Accept-Encoding header. gzip is prioritized if this option is not provided and the client provides both in the Accept-Encoding header.

Here it is mentioned that Accept-Encoding header is used to determine the type of response compression. So if you do not send it, then hono will not compress it.

Regarding the identity value for accept-encoding, its a HTTP standard that is also mentioned in MDN web docs. So you can either remove accept-encoding from request header or send it as identity to inform server to not apply the compression. Ref: https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Accept-Encoding#identity

When you send the header as identity, the code that is written inside hono compress middleware will not find any encoding and gateway also does not pass any default encoding method, so it will skip compressing the response. Here is the code for hono compress middleware: https://github.com/honojs/hono/blob/main/src/middleware/compress/index.ts

@rojosinalma
Copy link
Author

rojosinalma commented Mar 3, 2024 via email

@rojosinalma
Copy link
Author

rojosinalma commented Apr 29, 2024

This issue is still present when using Gemini, even when adding the header I was instructed to add Gemini is failing because of compression. If I bypass the previously mentioned condition, the Gateway works.

Can you please add an option or give some alternative to completely disable it?

cc @VisargD @roh26it

@vrushankportkey
Copy link
Collaborator

@rojosinalma we recently made some updates to fix this. Can you please try again?

@rojosinalma
Copy link
Author

At this point (4 months later) we already found a work around it on our own.
Could you describe what you changed?

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

No branches or pull requests

4 participants