Security News
PyPI’s New Archival Feature Closes a Major Security Gap
PyPI now allows maintainers to archive projects, improving security and helping users make informed decisions about their dependencies.
cdk-rest-api-integrations
Advanced tools
This CDK constructs library integrates AWS RestApi (a.k.a ApiGateway) with other AWS Services
This CDK constructs library integrates AWS RestApi (a.k.a ApiGateway) with other AWS Services directly (without the need for a lambda function or any other application).
By integrating a service in this way we can easily, reliably and securely (using RestApi features) expose an AWS Service functionality via HTTP.
A common use case is integrating SNS to receive messages via HTTP.
$ npm install cdk-rest-api-integrations --save
Add an SNS Topic and a RestApi to your stack, integrate them using a SnsRestApiIntegration construct:
// add the RestApi and Topic to be integrated with each other
const restApi = new apigateway.RestApi(this, 'myRestApi')
const myResource = restApi.root.addResource('myResource');
const topic = new sns.Topic(this, "myTopic")
// add the integration
new SnsRestApiIntegration(this, 'mySnsIntegration', {
topic: topic,
restApiResource: myResource
})
After deploying your CDK stack you can publish messages to the SNS Topic via HTTP:
$ curl -X POST https://xxxxxxxx.execute-api.eu-central-1.amazonaws.com/prod/myResource \
--header 'Content-Type: application/json' \
--data-raw '{"cdk":"rocks"}'
Add an SQS Queue and a RestApi to your stack, integrate them using a SqsRestApiIntegration construct:
// add the RestApi and Queue to be integrated with each other
const restApi = new apigateway.RestApi(this, 'myRestApi')
const myResource = restApi.root.addResource('myResource');
const queue = new sqs.Queue(this, "myQueue")
// add the integration
new SqsRestApiIntegration(this, 'mySqsIntegration', {
queue: queue,
restApiResource: myResource
})
After deploying your CDK stack you can publish messages to the SQS Queue via HTTP:
$ curl -X POST https://xxxxxxxx.execute-api.eu-central-1.amazonaws.com/prod/myResource \
--header 'Content-Type: application/json' \
--data-raw '{"cdk":"rocks"}'
Add a Kinesis Stream and a RestApi to your stack, integrate them using a KinesisRestApiIntegration construct:
// add the RestApi and Queue to be integrated with each other
const restApi = new apigateway.RestApi(this, 'myRestApi')
const myResource = restApi.root.addResource('myResource')
const stream = new kinesis.Stream(this, "myStream");
// add the integration
new SqsRestApiIntegration(this, 'mySqsIntegration', {
stream: stream,
restApiResource: myResource
})
After deploying your CDK stack you can publish messages to the SQS Queue via HTTP:
$ curl -X POST https://xxxxxxxx.execute-api.eu-central-1.amazonaws.com/prod/myResource \
--header 'Content-Type: application/json' \
--data-raw '{"cdk":"rocks"}'
Add a Step Functions StateMachine and a RestApi to your stack, integrate them using a KinesisRestApiIntegration construct:
// add the RestApi
const restApi = new apigateway.RestApi(this, 'myRestApi')
const myResource = restApi.root.addResource('myResource')
// add a Step Functions StateMachine
const stateMachine = new sfn.StateMachine(this, 'StateMachine', {
definition: new sfn.Wait(this, 'Wait X Seconds', {
time: sfn.WaitTime.secondsPath('$.waitSeconds'),
}),
timeout: Duration.minutes(5)
})
//add the integration
new StepFunctionsRestApiIntegration(this, 'myStepFunctionsIntegration', {
stateMachine : stateMachine,
restApiResource: myResource
})
After deploying your CDK stack you can start an execution via HTTP:
$ curl -X POST https://xxxxxxxx.execute-api.eu-central-1.amazonaws.com/prod/myResource \
--header 'Content-Type: application/json' \
--data-raw '{"waitSeconds": 4}'
FAQs
This CDK constructs library integrates AWS RestApi (a.k.a ApiGateway) with other AWS Services
The npm package cdk-rest-api-integrations receives a total of 26 weekly downloads. As such, cdk-rest-api-integrations popularity was classified as not popular.
We found that cdk-rest-api-integrations demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
PyPI now allows maintainers to archive projects, improving security and helping users make informed decisions about their dependencies.
Research
Security News
Malicious npm package postcss-optimizer delivers BeaverTail malware, targeting developer systems; similarities to past campaigns suggest a North Korean connection.
Security News
CISA's KEV data is now on GitHub, offering easier access, API integration, commit history tracking, and automated updates for security teams and researchers.