Skip to main content

L2 CDK construct to provision AWS IoT Fleetwise

Project description

NPM version PyPI version release

cdk-aws-iotfleetwise

L2 CDK construct to provision AWS IoT Fleetwise

Install

Typescript

npm install cdk-aws-iotfleetwise

API Reference

Python

pip install cdk-aws-iotfleetwise

API Reference

Sample

import { SignalCatalog,
         VehicleModel,
         Vehicle,
         Campaign,
         CanVehicleInterface,
         CanVehicleSignal,
         SignalCatalogBranch,
         TimeBasedCollectionScheme
         } from 'cdk-aws-iotfleetwise';

const signalCatalog = new SignalCatalog(stack, 'SignalCatalog', {
  database,
  table,
  role,
  nodes: [
    new SignalCatalogBranch('Vehicle', 'Vehicle'),
    new SignalCatalogSensor('EngineTorque', 'Vehicle.EngineTorque', 'DOUBLE'),
  ],
});

const model_a = new VehicleModel(stack, 'ModelA', {
  signalCatalog,
  name: 'modelA',
  description: 'Model A vehicle',
  networkInterfaces: [new CanVehicleInterface('1', 'vcan0')],
  signals: [
    new CanVehicleSignal('EngineTorque', 'Vehicle.EngineTorque', '1',
      401, // messageId
      1.0, // factor
      true, // isBigEndian
      false, // isSigned
      8, // lenght
      0.0, // offset
      9), // startBit
  ],
});

const vin100 = new Vehicle(stack, 'vin100', {
  vehicleId: 'vin100',
  vehicleModel: model_a,
  createIotThing: true
});

new Campaign(stack, 'Campaign', {
  name: 'TimeBasedCampaign',
  target: vin100,
  collectionScheme: new TimeBasedCollectionScheme(cdk.Duration.seconds(10)),
  signals: [
    new CampaignSignal('Vehicle.EngineTorque'),
  ],
});

Getting started

To deploy a simple end-to-end example you can use the following commands

yarn install
projen && projen build
npx cdk -a lib/integ.full.js deploy

The deploy takes about 15 mins mostly due to compilation of the IoT FleetWise agent in the EC2 instance that simulate the vehicle. Once deploy is finshed, approve the campaign with the command:

aws iotfleetwise update-campaign --campaign-name FwTimeBasedCampaign --action APPROVE

and data will start to show up in the Timestream table.

TODO

Warning: this construct should be considered at alpha stage and is not feature complete.

  • Reduce Lambda log retention to 1d
  • Apply the least priviledge principle to roles
  • Implement updates for all the custom resources
  • Conditional campaigns

Security

See CONTRIBUTING for more information.

License

This code is licensed under the MIT-0 License. See the LICENSE file.

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-aws-iotfleetwise-0.2.3.tar.gz (16.8 MB view details)

Uploaded Source

Built Distribution

cdk_aws_iotfleetwise-0.2.3-py3-none-any.whl (16.8 MB view details)

Uploaded Python 3

File details

Details for the file cdk-aws-iotfleetwise-0.2.3.tar.gz.

File metadata

  • Download URL: cdk-aws-iotfleetwise-0.2.3.tar.gz
  • Upload date:
  • Size: 16.8 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.10.4

File hashes

Hashes for cdk-aws-iotfleetwise-0.2.3.tar.gz
Algorithm Hash digest
SHA256 d092e0527060abd99719c56f925682242205d3a6ee2b609d73e268b9fccfb511
MD5 b245c0523588349b966ac4cfcb7fd805
BLAKE2b-256 e331bf20b1af7825a2fa12638cd81ac64f2dd905728f75d2232c923d5c7747f2

See more details on using hashes here.

File details

Details for the file cdk_aws_iotfleetwise-0.2.3-py3-none-any.whl.

File metadata

File hashes

Hashes for cdk_aws_iotfleetwise-0.2.3-py3-none-any.whl
Algorithm Hash digest
SHA256 f723e280c26d21609e50e6a797c2c063cacb60322a80778856542720da859e01
MD5 3cb405454fd9a17ee954ae4932bec94f
BLAKE2b-256 360896f924a49b8670baba1c3e791d291164923965f30e3d22c3273ff44762b6

See more details on using hashes here.

Supported by

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