Skip to content

Lambda@Edge origin response event errors out with 502 error because read-only header was deleted #369

Open
@rdsedmundo

Description

@rdsedmundo

The Cloudfront request responds with:
The Lambda function result failed validation: The function tried to add, delete, or change a read-only header. We can't connect to the server for this app or website at this time. There might be too much traffic or a configuration error. Try again later, or contact the app or website owner.

From CloudWatch logs:
ERROR Validation error: Lambda function result failed validation, the function tried to delete read-only header, headerName : Transfer-Encoding.

I've figured out a workaround that is to just copy the header manually, but I wonder if the library should've taken care of that itself?

import { getCurrentInvoke } from '@vendia/serverless-express';

router.get('/*', (req, res) => {
  const { event } = getCurrentInvoke();

  if (event.Records[0].cf.response.headers['transfer-encoding']) {
    res.setHeader(
      'Transfer-Encoding',
      event.Records[0].cf.response.headers['transfer-encoding'][0].value,
    );
  }

Metadata

Metadata

Assignees

No one assigned

    Labels

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions