Я использую 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
В чем проблема?