Неверно сформированный лямбда-прокси ответ при доступе к лямбда REST - PullRequest
0 голосов
/ 12 мая 2018

Я использую Javascript для создания простой функции, которая будет развернута на AWS Lambda и используется как REST.

Предполагается, что она генерирует случайные имена, но сейчас я использую жестко закодированное значение.

// NamingService.js
class NamingService {
    generateName() {
        return 'generated-name'
    }
}

module.exports = NamingService;

В этом файле я обрабатываю запросы

const NamingService = require('./NamingService');

const responses = {
    success: (data={}) => {
        return {
            "statusCode": 200,
            "headers": {
                "Access-Control-Allow-Origin" : "*",
                "Access-Control-Allow-Credentials" : true
            },
            "body": JSON.stringify(data)
        }
    },
    error: (error) => {
        return {
            "statusCode": error.code || 500,
            "headers": {
                "Access-Control-Allow-Origin" : "*",
                "Access-Control-Allow-Credentials" : true
            },
            "body": JSON.stringify(error)
        }
    }
};

module.exports = {
    generateName: (event, context, callback) => {
        context.callbackWaitsForEmptyEventLoop = false;
        const namingService = new NamingService();
        namingService.generateName()
            .then(name => {
                callback(null, responses.success(name))
            })
            .catch(error => {
                callback(null, responses.error(error))
            })
    }
};

Я использую serverless для развертывания лямбда-функции

service: naming-service

provider:
  name: aws
  runtime: nodejs8.10
  region: eu-west-1
  memorySize: 128
  timeout: 30

functions:
  generateName:
    handler: lambdaHandlers.generateName
    events:
      - http:
          path: jester/name/generate
          method: get
          cors:
            origins:
              - '*'

После serverless deploy он показывает мне ответ

region: eu-west-1
stack: naming-service-dev
api keys:
  None
endpoints:
  GET - https://endpoint/jester/name/generate
functions:
  generateName: naming-service-dev-generateName

Но когда я пытаюсь запустить его (используя тестирование на API-шлюзе), я получаю эту ошибку

Fri May 11 21:37:19 UTC 2018 : Endpoint response body before transformations: "generated-name"
Fri May 11 21:37:19 UTC 2018 : Endpoint response headers: {Content-Length=16, Date=Fri, 11 May 2018 21:37:19 GMT;sampled=0, Content-Type=application/json}
Fri May 11 21:37:19 UTC 2018 : Execution failed due to configuration error: Malformed Lambda proxy response
Fri May 11 21:37:19 UTC 2018 : Method completed with status: 502

В чем проблема?

1 Ответ

0 голосов
/ 12 мая 2018

Проблема была с обработчиком generateName.Я не должен был использовать then на методе generateName

generateName: (event, context, callback) => {
    context.callbackWaitsForEmptyEventLoop = false;
    const namingService = new NamingService();
    const generatedName = namingService.generateName();
    callback(null, responses.success(generatedName));
}
...