Skip to main content

CDK Construct for AWS IoT Core certificates and things

Project description

AWS IoT Core Thing with Certificate v3 construct

This is a CDK construct that creates an AWS IoT Core Thing with a certificate and policy using aws-sdk-js-v3.

elements

Cloudformation does not support creating a certificate for an IoT Thing, so this construct uses the AWS SDK to create a certificate and attach it to the Thing.

This construct is a modified version of this excellent construct (cdk-iot-core-certificate) to work with aws-sdk-js-v3.

View on Construct Hub Open in Visual Studio Code npm version Build Status Release Status License Downloads npm downloads

Installation

npm i cdk-iot-core-certificates-v3

Usage

import * as s3 from 'aws-cdk-lib/aws-s3';
import { ThingWithCert } from 'cdk-iot-core-certificates-v3';

declare const saveFileBucket: s3.IBucket;

const { thingArn, certId, certPem, privKey } = new ThingWithCert(this, 'MyThing', {
  // The name of the thing
  thingName: 'MyThing',
  // Whether to save the certificate and private key to the SSM Parameter Store
  saveToParamStore: true,
  // The prefix to use for the SSM Parameter Store parameters
  paramPrefix: 'test',
  // The bucket to save the certificate and private key to
  // Both files are saved at `{thingName}/{thingName}.private.key` and `{thingName}/{thingName}.cert.pem`
  // If not provided, the certificate and private key will not be saved
  saveFileBucket,
});

If you want to create multiple things and save certificates and private keys to the same bucket, you should not use saveFileBucket prop and save them at once by BucketDeployment construct.

This is because the each saveFileBucket prop will share a custom resource for each thing, which will cause the deployment to fail.

import * as s3 from 'aws-cdk-lib/aws-s3';
import * as s3deploy from 'aws-cdk-lib/aws-s3-deployment';
import { ThingWithCert } from 'cdk-iot-core-certificates-v3';

const thingNames = ['Thing1', 'Thing2', 'Thing3'];
const certBucket = new s3.Bucket(this, "CertBucket");
const sources: s3deploy.ISource[] = [];

thingNames.forEach((thingName, index) => {
  const { certPem, privKey } = new ThingWithCert(this, `Thing${index}`, {
    thingName,
    saveToParamStore: true,
  });
  sources.push(
    s3deploy.Source.data(`${thingName}/${thingName}.cert.pem`, certPem),
    s3deploy.Source.data(`${thingName}/${thingName}.private.key`, privKey)
  );
});

// Deploy the certificate and private key to the S3 bucket at once
new s3deploy.BucketDeployment(this, "DeployCerts", {
  sources,
  destinationBucket: certBucket,
});

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

cdk_iot_core_certificates_v3-0.1.2.tar.gz (34.2 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

cdk_iot_core_certificates_v3-0.1.2-py3-none-any.whl (34.2 MB view details)

Uploaded Python 3

File details

Details for the file cdk_iot_core_certificates_v3-0.1.2.tar.gz.

File metadata

File hashes

Hashes for cdk_iot_core_certificates_v3-0.1.2.tar.gz
Algorithm Hash digest
SHA256 7aedfa6959832e2d1d0472f4e53633782c1947df96aa4fdaa1affde5fc7776e8
MD5 98c22a80ccbff0aec5b2e69c43e2b6c9
BLAKE2b-256 1b4c0e9c1385cac41b917702f436de1f0ff00937bb7d4d7c303efa975789583b

See more details on using hashes here.

Provenance

The following attestation bundles were made for cdk_iot_core_certificates_v3-0.1.2.tar.gz:

Publisher: release.yml on badmintoncryer/cdk-iot-core-certificates-v3

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file cdk_iot_core_certificates_v3-0.1.2-py3-none-any.whl.

File metadata

File hashes

Hashes for cdk_iot_core_certificates_v3-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 812678de0dc6ab00b7bc2375a15fd53a83643d35ab96b970b9773635e4a4ea5a
MD5 84f8efe515ee9aec7218ae3f18bc0bd1
BLAKE2b-256 3a5f078c473cec84563791d2ba2cc9ebcdcf85c306050447419afdf9211505f8

See more details on using hashes here.

Provenance

The following attestation bundles were made for cdk_iot_core_certificates_v3-0.1.2-py3-none-any.whl:

Publisher: release.yml on badmintoncryer/cdk-iot-core-certificates-v3

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page