A plugin for the Serverless framework which configures ApiGateway access adn execution log retention.
npm install serverless-apigateway-log-retentionControl the retention of your ApiGateway access logs and execution logs.
npm install serverless-apigateway-log-retention
Add the plugin to your serverless.yml:
``yml`
plugins:
- serverless-apigateway-log-retention
.The plugin uses AWS profile configured under
provider.profile or defaults to AWS credentials set in the environment.If you can't directly connect to the internet, the plugin supports proxy which you can set via any of the following environment variables:
`
- HTTP_PROXY
- HTTPS_PROXY
- FTP_PROXY
- WSS_PROXY
- WS_PROXY
` By default the plugin assumes the API name format to be
[STAGE]-[SERVICE_NAME]. If your API name format is [SERVICE_NAME]-[STAGE], set provider.apiGateway.shouldStartNameWithService to true like so:
`yml
provider:
name: aws
apigateway:
shouldStartNameWithService: true
`If you want to use a custom API name, set it via
provider.apiName like so:
`yml
provider:
name: aws
apiName: 'my-custom-api-name'
`PLEASE NOTE THAT THE PLUGIN REQUIRES THE FOLLOWING AWS PERMISSIONS:
CloudWatch Logs
* putRetentionPolicy
* deleteRetentionPolicy
ApiGateway
* getRestApis
* getStage
Plugin Options
accessLogging.enabled (optional) - Whether or not to update access logging retention policy. Set to false by default.accessLogging.days (required) - Possible values are: 1, 3, 5, 7, 14, 30, 60, 90, 120, 150, 180, 365, 400, 545, 731, 1827, 3653 and 'never expire'.executionLogging.enabled (optional) - Whether or not to update execution logging retention policy. Set to false by default.executionLogging.days (required) - Possible values are: 1, 3, 5, 7, 14, 30, 60, 90, 120, 150, 180, 365, 400, 545, 731, 1827, 3653 and 'never expire'.Examples
serverless.yml - Enabled for execution logging and disabled for access logging:
`yml
service: sampleplugins:
- serverless-apigateway-log-retention
provider:
name: aws
custom:
apigatewayLogRetention:
executionLogging:
enabled: true
days: 'never expire'
`
serverless.yml - Enabled for access logging and execution logging:
`yml
service: sampleplugins:
- serverless-apigateway-log-retention
provider:
name: aws
custom:
apigatewayLogRetention:
executionLogging:
enabled: true
days: 14
accessLogging:
enabled: true
days: 7
``