awsiotfleetwise

package
v1.182.0-devpreview Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Dec 7, 2022 License: Apache-2.0 Imports: 7 Imported by: 0

README

AWS::IoTFleetWise Construct Library

This module is part of the AWS Cloud Development Kit project.

import iotfleetwise "github.com/aws/aws-cdk-go/awscdk"

There are no official hand-written (L2) constructs for this service yet. Here are some suggestions on how to proceed:

There are no hand-written (L2) constructs for this service yet. However, you can still use the automatically generated L1 constructs, and use this service exactly as you would using CloudFormation directly.

For more information on the resources and properties available for this service, see the CloudFormation documentation for AWS::IoTFleetWise.

(Read the CDK Contributing Guide and submit an RFC if you are interested in contributing to this construct library.)

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func CfnCampaign_CFN_RESOURCE_TYPE_NAME

func CfnCampaign_CFN_RESOURCE_TYPE_NAME() *string

func CfnCampaign_IsCfnElement

func CfnCampaign_IsCfnElement(x interface{}) *bool

Returns `true` if a construct is a stack element (i.e. part of the synthesized cloudformation template).

Uses duck-typing instead of `instanceof` to allow stack elements from different versions of this library to be included in the same stack.

Returns: The construct as a stack element or undefined if it is not a stack element. Experimental.

func CfnCampaign_IsCfnResource

func CfnCampaign_IsCfnResource(construct constructs.IConstruct) *bool

Check whether the given construct is a CfnResource. Experimental.

func CfnCampaign_IsConstruct

func CfnCampaign_IsConstruct(x interface{}) *bool

Return whether the given object is a Construct. Experimental.

func CfnDecoderManifest_CFN_RESOURCE_TYPE_NAME

func CfnDecoderManifest_CFN_RESOURCE_TYPE_NAME() *string

func CfnDecoderManifest_IsCfnElement

func CfnDecoderManifest_IsCfnElement(x interface{}) *bool

Returns `true` if a construct is a stack element (i.e. part of the synthesized cloudformation template).

Uses duck-typing instead of `instanceof` to allow stack elements from different versions of this library to be included in the same stack.

Returns: The construct as a stack element or undefined if it is not a stack element. Experimental.

func CfnDecoderManifest_IsCfnResource

func CfnDecoderManifest_IsCfnResource(construct constructs.IConstruct) *bool

Check whether the given construct is a CfnResource. Experimental.

func CfnDecoderManifest_IsConstruct

func CfnDecoderManifest_IsConstruct(x interface{}) *bool

Return whether the given object is a Construct. Experimental.

func CfnFleet_CFN_RESOURCE_TYPE_NAME

func CfnFleet_CFN_RESOURCE_TYPE_NAME() *string

func CfnFleet_IsCfnElement

func CfnFleet_IsCfnElement(x interface{}) *bool

Returns `true` if a construct is a stack element (i.e. part of the synthesized cloudformation template).

Uses duck-typing instead of `instanceof` to allow stack elements from different versions of this library to be included in the same stack.

Returns: The construct as a stack element or undefined if it is not a stack element. Experimental.

func CfnFleet_IsCfnResource

func CfnFleet_IsCfnResource(construct constructs.IConstruct) *bool

Check whether the given construct is a CfnResource. Experimental.

func CfnFleet_IsConstruct

func CfnFleet_IsConstruct(x interface{}) *bool

Return whether the given object is a Construct. Experimental.

func CfnModelManifest_CFN_RESOURCE_TYPE_NAME

func CfnModelManifest_CFN_RESOURCE_TYPE_NAME() *string

func CfnModelManifest_IsCfnElement

func CfnModelManifest_IsCfnElement(x interface{}) *bool

Returns `true` if a construct is a stack element (i.e. part of the synthesized cloudformation template).

Uses duck-typing instead of `instanceof` to allow stack elements from different versions of this library to be included in the same stack.

Returns: The construct as a stack element or undefined if it is not a stack element. Experimental.

func CfnModelManifest_IsCfnResource

func CfnModelManifest_IsCfnResource(construct constructs.IConstruct) *bool

Check whether the given construct is a CfnResource. Experimental.

func CfnModelManifest_IsConstruct

func CfnModelManifest_IsConstruct(x interface{}) *bool

Return whether the given object is a Construct. Experimental.

func CfnSignalCatalog_CFN_RESOURCE_TYPE_NAME

func CfnSignalCatalog_CFN_RESOURCE_TYPE_NAME() *string

func CfnSignalCatalog_IsCfnElement

func CfnSignalCatalog_IsCfnElement(x interface{}) *bool

Returns `true` if a construct is a stack element (i.e. part of the synthesized cloudformation template).

Uses duck-typing instead of `instanceof` to allow stack elements from different versions of this library to be included in the same stack.

Returns: The construct as a stack element or undefined if it is not a stack element. Experimental.

func CfnSignalCatalog_IsCfnResource

func CfnSignalCatalog_IsCfnResource(construct constructs.IConstruct) *bool

Check whether the given construct is a CfnResource. Experimental.

func CfnSignalCatalog_IsConstruct

func CfnSignalCatalog_IsConstruct(x interface{}) *bool

Return whether the given object is a Construct. Experimental.

func CfnVehicle_CFN_RESOURCE_TYPE_NAME

func CfnVehicle_CFN_RESOURCE_TYPE_NAME() *string

func CfnVehicle_IsCfnElement

func CfnVehicle_IsCfnElement(x interface{}) *bool

Returns `true` if a construct is a stack element (i.e. part of the synthesized cloudformation template).

Uses duck-typing instead of `instanceof` to allow stack elements from different versions of this library to be included in the same stack.

Returns: The construct as a stack element or undefined if it is not a stack element. Experimental.

func CfnVehicle_IsCfnResource

func CfnVehicle_IsCfnResource(construct constructs.IConstruct) *bool

Check whether the given construct is a CfnResource. Experimental.

func CfnVehicle_IsConstruct

func CfnVehicle_IsConstruct(x interface{}) *bool

Return whether the given object is a Construct. Experimental.

func NewCfnCampaign_Override

func NewCfnCampaign_Override(c CfnCampaign, scope awscdk.Construct, id *string, props *CfnCampaignProps)

Create a new `AWS::IoTFleetWise::Campaign`.

func NewCfnDecoderManifest_Override

func NewCfnDecoderManifest_Override(c CfnDecoderManifest, scope awscdk.Construct, id *string, props *CfnDecoderManifestProps)

Create a new `AWS::IoTFleetWise::DecoderManifest`.

func NewCfnFleet_Override

func NewCfnFleet_Override(c CfnFleet, scope awscdk.Construct, id *string, props *CfnFleetProps)

Create a new `AWS::IoTFleetWise::Fleet`.

func NewCfnModelManifest_Override

func NewCfnModelManifest_Override(c CfnModelManifest, scope awscdk.Construct, id *string, props *CfnModelManifestProps)

Create a new `AWS::IoTFleetWise::ModelManifest`.

func NewCfnSignalCatalog_Override

func NewCfnSignalCatalog_Override(c CfnSignalCatalog, scope awscdk.Construct, id *string, props *CfnSignalCatalogProps)

Create a new `AWS::IoTFleetWise::SignalCatalog`.

func NewCfnVehicle_Override

func NewCfnVehicle_Override(c CfnVehicle, scope awscdk.Construct, id *string, props *CfnVehicleProps)

Create a new `AWS::IoTFleetWise::Vehicle`.

Types

type CfnCampaign

type CfnCampaign interface {
	awscdk.CfnResource
	awscdk.IInspectable
	// `AWS::IoTFleetWise::Campaign.Action`.
	Action() *string
	SetAction(val *string)
	AttrArn() *string
	AttrCreationTime() *string
	AttrLastModificationTime() *string
	AttrStatus() *string
	// Options for this resource, such as condition, update policy etc.
	// Experimental.
	CfnOptions() awscdk.ICfnResourceOptions
	CfnProperties() *map[string]interface{}
	// AWS resource type.
	// Experimental.
	CfnResourceType() *string
	// `AWS::IoTFleetWise::Campaign.CollectionScheme`.
	CollectionScheme() interface{}
	SetCollectionScheme(val interface{})
	// `AWS::IoTFleetWise::Campaign.Compression`.
	Compression() *string
	SetCompression(val *string)
	// Returns: the stack trace of the point where this Resource was created from, sourced
	// from the +metadata+ entry typed +aws:cdk:logicalId+, and with the bottom-most
	// node +internal+ entries filtered.
	// Experimental.
	CreationStack() *[]*string
	// `AWS::IoTFleetWise::Campaign.DataExtraDimensions`.
	DataExtraDimensions() *[]*string
	SetDataExtraDimensions(val *[]*string)
	// The description of the campaign.
	Description() *string
	SetDescription(val *string)
	// `AWS::IoTFleetWise::Campaign.DiagnosticsMode`.
	DiagnosticsMode() *string
	SetDiagnosticsMode(val *string)
	// `AWS::IoTFleetWise::Campaign.ExpiryTime`.
	ExpiryTime() *string
	SetExpiryTime(val *string)
	// The logical ID for this CloudFormation stack element.
	//
	// The logical ID of the element
	// is calculated from the path of the resource node in the construct tree.
	//
	// To override this value, use `overrideLogicalId(newLogicalId)`.
	//
	// Returns: the logical ID as a stringified token. This value will only get
	// resolved during synthesis.
	// Experimental.
	LogicalId() *string
	// The name of a campaign.
	Name() *string
	SetName(val *string)
	// The construct tree node associated with this construct.
	// Experimental.
	Node() awscdk.ConstructNode
	// `AWS::IoTFleetWise::Campaign.PostTriggerCollectionDuration`.
	PostTriggerCollectionDuration() *float64
	SetPostTriggerCollectionDuration(val *float64)
	// `AWS::IoTFleetWise::Campaign.Priority`.
	Priority() *float64
	SetPriority(val *float64)
	// Return a string that will be resolved to a CloudFormation `{ Ref }` for this element.
	//
	// If, by any chance, the intrinsic reference of a resource is not a string, you could
	// coerce it to an IResolvable through `Lazy.any({ produce: resource.ref })`.
	// Experimental.
	Ref() *string
	// The ARN of the signal catalog associated with the campaign.
	SignalCatalogArn() *string
	SetSignalCatalogArn(val *string)
	// `AWS::IoTFleetWise::Campaign.SignalsToCollect`.
	SignalsToCollect() interface{}
	SetSignalsToCollect(val interface{})
	// `AWS::IoTFleetWise::Campaign.SpoolingMode`.
	SpoolingMode() *string
	SetSpoolingMode(val *string)
	// The stack in which this element is defined.
	//
	// CfnElements must be defined within a stack scope (directly or indirectly).
	// Experimental.
	Stack() awscdk.Stack
	// `AWS::IoTFleetWise::Campaign.StartTime`.
	StartTime() *string
	SetStartTime(val *string)
	// `AWS::IoTFleetWise::Campaign.Tags`.
	Tags() awscdk.TagManager
	// The ARN of a vehicle or fleet to which the campaign is deployed.
	TargetArn() *string
	SetTargetArn(val *string)
	// Return properties modified after initiation.
	//
	// Resources that expose mutable properties should override this function to
	// collect and return the properties object for this resource.
	// Experimental.
	UpdatedProperites() *map[string]interface{}
	// Syntactic sugar for `addOverride(path, undefined)`.
	// Experimental.
	AddDeletionOverride(path *string)
	// Indicates that this resource depends on another resource and cannot be provisioned unless the other resource has been successfully provisioned.
	//
	// This can be used for resources across stacks (or nested stack) boundaries
	// and the dependency will automatically be transferred to the relevant scope.
	// Experimental.
	AddDependsOn(target awscdk.CfnResource)
	// Add a value to the CloudFormation Resource Metadata.
	// See: https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/metadata-section-structure.html
	//
	// Note that this is a different set of metadata from CDK node metadata; this
	// metadata ends up in the stack template under the resource, whereas CDK
	// node metadata ends up in the Cloud Assembly.
	//
	// Experimental.
	AddMetadata(key *string, value interface{})
	// Adds an override to the synthesized CloudFormation resource.
	//
	// To add a
	// property override, either use `addPropertyOverride` or prefix `path` with
	// "Properties." (i.e. `Properties.TopicName`).
	//
	// If the override is nested, separate each nested level using a dot (.) in the path parameter.
	// If there is an array as part of the nesting, specify the index in the path.
	//
	// To include a literal `.` in the property name, prefix with a `\`. In most
	// programming languages you will need to write this as `"\\."` because the
	// `\` itself will need to be escaped.
	//
	// For example,
	// “`typescript
	// cfnResource.addOverride('Properties.GlobalSecondaryIndexes.0.Projection.NonKeyAttributes', ['myattribute']);
	// cfnResource.addOverride('Properties.GlobalSecondaryIndexes.1.ProjectionType', 'INCLUDE');
	// “`
	// would add the overrides
	// “`json
	// "Properties": {
	//    "GlobalSecondaryIndexes": [
	//      {
	//        "Projection": {
	//          "NonKeyAttributes": [ "myattribute" ]
	//          ...
	//        }
	//        ...
	//      },
	//      {
	//        "ProjectionType": "INCLUDE"
	//        ...
	//      },
	//    ]
	//    ...
	// }
	// “`
	//
	// The `value` argument to `addOverride` will not be processed or translated
	// in any way. Pass raw JSON values in here with the correct capitalization
	// for CloudFormation. If you pass CDK classes or structs, they will be
	// rendered with lowercased key names, and CloudFormation will reject the
	// template.
	// Experimental.
	AddOverride(path *string, value interface{})
	// Adds an override that deletes the value of a property from the resource definition.
	// Experimental.
	AddPropertyDeletionOverride(propertyPath *string)
	// Adds an override to a resource property.
	//
	// Syntactic sugar for `addOverride("Properties.<...>", value)`.
	// Experimental.
	AddPropertyOverride(propertyPath *string, value interface{})
	// Sets the deletion policy of the resource based on the removal policy specified.
	//
	// The Removal Policy controls what happens to this resource when it stops
	// being managed by CloudFormation, either because you've removed it from the
	// CDK application or because you've made a change that requires the resource
	// to be replaced.
	//
	// The resource can be deleted (`RemovalPolicy.DESTROY`), or left in your AWS
	// account for data recovery and cleanup later (`RemovalPolicy.RETAIN`).
	// Experimental.
	ApplyRemovalPolicy(policy awscdk.RemovalPolicy, options *awscdk.RemovalPolicyOptions)
	// Returns a token for an runtime attribute of this resource.
	//
	// Ideally, use generated attribute accessors (e.g. `resource.arn`), but this can be used for future compatibility
	// in case there is no generated attribute.
	// Experimental.
	GetAtt(attributeName *string) awscdk.Reference
	// Retrieve a value value from the CloudFormation Resource Metadata.
	// See: https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/metadata-section-structure.html
	//
	// Note that this is a different set of metadata from CDK node metadata; this
	// metadata ends up in the stack template under the resource, whereas CDK
	// node metadata ends up in the Cloud Assembly.
	//
	// Experimental.
	GetMetadata(key *string) interface{}
	// Examines the CloudFormation resource and discloses attributes.
	Inspect(inspector awscdk.TreeInspector)
	// Perform final modifications before synthesis.
	//
	// This method can be implemented by derived constructs in order to perform
	// final changes before synthesis. prepare() will be called after child
	// constructs have been prepared.
	//
	// This is an advanced framework feature. Only use this if you
	// understand the implications.
	// Experimental.
	OnPrepare()
	// Allows this construct to emit artifacts into the cloud assembly during synthesis.
	//
	// This method is usually implemented by framework-level constructs such as `Stack` and `Asset`
	// as they participate in synthesizing the cloud assembly.
	// Experimental.
	OnSynthesize(session constructs.ISynthesisSession)
	// Validate the current construct.
	//
	// This method can be implemented by derived constructs in order to perform
	// validation logic. It is called on all constructs before synthesis.
	//
	// Returns: An array of validation error messages, or an empty array if the construct is valid.
	// Experimental.
	OnValidate() *[]*string
	// Overrides the auto-generated logical ID with a specific ID.
	// Experimental.
	OverrideLogicalId(newLogicalId *string)
	// Perform final modifications before synthesis.
	//
	// This method can be implemented by derived constructs in order to perform
	// final changes before synthesis. prepare() will be called after child
	// constructs have been prepared.
	//
	// This is an advanced framework feature. Only use this if you
	// understand the implications.
	// Experimental.
	Prepare()
	RenderProperties(props *map[string]interface{}) *map[string]interface{}
	// Can be overridden by subclasses to determine if this resource will be rendered into the cloudformation template.
	//
	// Returns: `true` if the resource should be included or `false` is the resource
	// should be omitted.
	// Experimental.
	ShouldSynthesize() *bool
	// Allows this construct to emit artifacts into the cloud assembly during synthesis.
	//
	// This method is usually implemented by framework-level constructs such as `Stack` and `Asset`
	// as they participate in synthesizing the cloud assembly.
	// Experimental.
	Synthesize(session awscdk.ISynthesisSession)
	// Returns a string representation of this construct.
	//
	// Returns: a string representation of this resource.
	// Experimental.
	ToString() *string
	// Validate the current construct.
	//
	// This method can be implemented by derived constructs in order to perform
	// validation logic. It is called on all constructs before synthesis.
	//
	// Returns: An array of validation error messages, or an empty array if the construct is valid.
	// Experimental.
	Validate() *[]*string
	// Experimental.
	ValidateProperties(_properties interface{})
}

A CloudFormation `AWS::IoTFleetWise::Campaign`.

Creates an orchestration of data collection rules. The AWS IoT FleetWise Edge Agent software running in vehicles uses campaigns to decide how to collect and transfer data to the cloud. You create campaigns in the cloud. After you or your team approve campaigns, AWS IoT FleetWise automatically deploys them to vehicles.

For more information, see [Collect and transfer data with campaigns](https://docs.aws.amazon.com/iot-fleetwise/latest/developerguide/campaigns.html) in the *AWS IoT FleetWise Developer Guide* .

Example:

// The code below shows an example of how to instantiate this type.
// The values are placeholders you should change.
import "github.com/aws/aws-cdk-go/awscdk"

cfnCampaign := awscdk.Aws_iotfleetwise.NewCfnCampaign(this, jsii.String("MyCfnCampaign"), &cfnCampaignProps{
	action: jsii.String("action"),
	collectionScheme: &collectionSchemeProperty{
		conditionBasedCollectionScheme: &conditionBasedCollectionSchemeProperty{
			expression: jsii.String("expression"),

			// the properties below are optional
			conditionLanguageVersion: jsii.Number(123),
			minimumTriggerIntervalMs: jsii.Number(123),
			triggerMode: jsii.String("triggerMode"),
		},
		timeBasedCollectionScheme: &timeBasedCollectionSchemeProperty{
			periodMs: jsii.Number(123),
		},
	},
	name: jsii.String("name"),
	signalCatalogArn: jsii.String("signalCatalogArn"),
	targetArn: jsii.String("targetArn"),

	// the properties below are optional
	compression: jsii.String("compression"),
	dataExtraDimensions: []*string{
		jsii.String("dataExtraDimensions"),
	},
	description: jsii.String("description"),
	diagnosticsMode: jsii.String("diagnosticsMode"),
	expiryTime: jsii.String("expiryTime"),
	postTriggerCollectionDuration: jsii.Number(123),
	priority: jsii.Number(123),
	signalsToCollect: []interface{}{
		&signalInformationProperty{
			name: jsii.String("name"),

			// the properties below are optional
			maxSampleCount: jsii.Number(123),
			minimumSamplingIntervalMs: jsii.Number(123),
		},
	},
	spoolingMode: jsii.String("spoolingMode"),
	startTime: jsii.String("startTime"),
	tags: []cfnTag{
		&cfnTag{
			key: jsii.String("key"),
			value: jsii.String("value"),
		},
	},
})

func NewCfnCampaign

func NewCfnCampaign(scope awscdk.Construct, id *string, props *CfnCampaignProps) CfnCampaign

Create a new `AWS::IoTFleetWise::Campaign`.

type CfnCampaignProps

type CfnCampaignProps struct {
	// `AWS::IoTFleetWise::Campaign.Action`.
	Action *string `field:"required" json:"action" yaml:"action"`
	// `AWS::IoTFleetWise::Campaign.CollectionScheme`.
	CollectionScheme interface{} `field:"required" json:"collectionScheme" yaml:"collectionScheme"`
	// The name of a campaign.
	Name *string `field:"required" json:"name" yaml:"name"`
	// The ARN of the signal catalog associated with the campaign.
	SignalCatalogArn *string `field:"required" json:"signalCatalogArn" yaml:"signalCatalogArn"`
	// The ARN of a vehicle or fleet to which the campaign is deployed.
	TargetArn *string `field:"required" json:"targetArn" yaml:"targetArn"`
	// `AWS::IoTFleetWise::Campaign.Compression`.
	Compression *string `field:"optional" json:"compression" yaml:"compression"`
	// `AWS::IoTFleetWise::Campaign.DataExtraDimensions`.
	DataExtraDimensions *[]*string `field:"optional" json:"dataExtraDimensions" yaml:"dataExtraDimensions"`
	// The description of the campaign.
	Description *string `field:"optional" json:"description" yaml:"description"`
	// `AWS::IoTFleetWise::Campaign.DiagnosticsMode`.
	DiagnosticsMode *string `field:"optional" json:"diagnosticsMode" yaml:"diagnosticsMode"`
	// `AWS::IoTFleetWise::Campaign.ExpiryTime`.
	ExpiryTime *string `field:"optional" json:"expiryTime" yaml:"expiryTime"`
	// `AWS::IoTFleetWise::Campaign.PostTriggerCollectionDuration`.
	PostTriggerCollectionDuration *float64 `field:"optional" json:"postTriggerCollectionDuration" yaml:"postTriggerCollectionDuration"`
	// `AWS::IoTFleetWise::Campaign.Priority`.
	Priority *float64 `field:"optional" json:"priority" yaml:"priority"`
	// `AWS::IoTFleetWise::Campaign.SignalsToCollect`.
	SignalsToCollect interface{} `field:"optional" json:"signalsToCollect" yaml:"signalsToCollect"`
	// `AWS::IoTFleetWise::Campaign.SpoolingMode`.
	SpoolingMode *string `field:"optional" json:"spoolingMode" yaml:"spoolingMode"`
	// `AWS::IoTFleetWise::Campaign.StartTime`.
	StartTime *string `field:"optional" json:"startTime" yaml:"startTime"`
	// `AWS::IoTFleetWise::Campaign.Tags`.
	Tags *[]*awscdk.CfnTag `field:"optional" json:"tags" yaml:"tags"`
}

Properties for defining a `CfnCampaign`.

Example:

// The code below shows an example of how to instantiate this type.
// The values are placeholders you should change.
import "github.com/aws/aws-cdk-go/awscdk"

cfnCampaignProps := &cfnCampaignProps{
	action: jsii.String("action"),
	collectionScheme: &collectionSchemeProperty{
		conditionBasedCollectionScheme: &conditionBasedCollectionSchemeProperty{
			expression: jsii.String("expression"),

			// the properties below are optional
			conditionLanguageVersion: jsii.Number(123),
			minimumTriggerIntervalMs: jsii.Number(123),
			triggerMode: jsii.String("triggerMode"),
		},
		timeBasedCollectionScheme: &timeBasedCollectionSchemeProperty{
			periodMs: jsii.Number(123),
		},
	},
	name: jsii.String("name"),
	signalCatalogArn: jsii.String("signalCatalogArn"),
	targetArn: jsii.String("targetArn"),

	// the properties below are optional
	compression: jsii.String("compression"),
	dataExtraDimensions: []*string{
		jsii.String("dataExtraDimensions"),
	},
	description: jsii.String("description"),
	diagnosticsMode: jsii.String("diagnosticsMode"),
	expiryTime: jsii.String("expiryTime"),
	postTriggerCollectionDuration: jsii.Number(123),
	priority: jsii.Number(123),
	signalsToCollect: []interface{}{
		&signalInformationProperty{
			name: jsii.String("name"),

			// the properties below are optional
			maxSampleCount: jsii.Number(123),
			minimumSamplingIntervalMs: jsii.Number(123),
		},
	},
	spoolingMode: jsii.String("spoolingMode"),
	startTime: jsii.String("startTime"),
	tags: []cfnTag{
		&cfnTag{
			key: jsii.String("key"),
			value: jsii.String("value"),
		},
	},
}

type CfnCampaign_CollectionSchemeProperty

type CfnCampaign_CollectionSchemeProperty struct {
	// Information about a collection scheme that uses a simple logical expression to recognize what data to collect.
	ConditionBasedCollectionScheme interface{} `field:"optional" json:"conditionBasedCollectionScheme" yaml:"conditionBasedCollectionScheme"`
	// Information about a collection scheme that uses a time period to decide how often to collect data.
	TimeBasedCollectionScheme interface{} `field:"optional" json:"timeBasedCollectionScheme" yaml:"timeBasedCollectionScheme"`
}

Specifies what data to collect and how often or when to collect it.

Example:

// The code below shows an example of how to instantiate this type.
// The values are placeholders you should change.
import "github.com/aws/aws-cdk-go/awscdk"

collectionSchemeProperty := &collectionSchemeProperty{
	conditionBasedCollectionScheme: &conditionBasedCollectionSchemeProperty{
		expression: jsii.String("expression"),

		// the properties below are optional
		conditionLanguageVersion: jsii.Number(123),
		minimumTriggerIntervalMs: jsii.Number(123),
		triggerMode: jsii.String("triggerMode"),
	},
	timeBasedCollectionScheme: &timeBasedCollectionSchemeProperty{
		periodMs: jsii.Number(123),
	},
}

type CfnCampaign_ConditionBasedCollectionSchemeProperty

type CfnCampaign_ConditionBasedCollectionSchemeProperty struct {
	// The logical expression used to recognize what data to collect.
	//
	// For example, `$variable.Vehicle.OutsideAirTemperature >= 105.0` .
	Expression *string `field:"required" json:"expression" yaml:"expression"`
	// Specifies the version of the conditional expression language.
	ConditionLanguageVersion *float64 `field:"optional" json:"conditionLanguageVersion" yaml:"conditionLanguageVersion"`
	// The minimum duration of time between two triggering events to collect data, in milliseconds.
	//
	// > If a signal changes often, you might want to collect data at a slower rate.
	MinimumTriggerIntervalMs *float64 `field:"optional" json:"minimumTriggerIntervalMs" yaml:"minimumTriggerIntervalMs"`
	// Whether to collect data for all triggering events ( `ALWAYS` ).
	//
	// Specify ( `RISING_EDGE` ), or specify only when the condition first evaluates to false. For example, triggering on "AirbagDeployed"; Users aren't interested on triggering when the airbag is already exploded; they only care about the change from not deployed => deployed.
	TriggerMode *string `field:"optional" json:"triggerMode" yaml:"triggerMode"`
}

Information about a collection scheme that uses a simple logical expression to recognize what data to collect.

Example:

// The code below shows an example of how to instantiate this type.
// The values are placeholders you should change.
import "github.com/aws/aws-cdk-go/awscdk"

conditionBasedCollectionSchemeProperty := &conditionBasedCollectionSchemeProperty{
	expression: jsii.String("expression"),

	// the properties below are optional
	conditionLanguageVersion: jsii.Number(123),
	minimumTriggerIntervalMs: jsii.Number(123),
	triggerMode: jsii.String("triggerMode"),
}

type CfnCampaign_SignalInformationProperty

type CfnCampaign_SignalInformationProperty struct {
	// The name of the signal.
	Name *string `field:"required" json:"name" yaml:"name"`
	// The maximum number of samples to collect.
	MaxSampleCount *float64 `field:"optional" json:"maxSampleCount" yaml:"maxSampleCount"`
	// The minimum duration of time (in milliseconds) between two triggering events to collect data.
	//
	// > If a signal changes often, you might want to collect data at a slower rate.
	MinimumSamplingIntervalMs *float64 `field:"optional" json:"minimumSamplingIntervalMs" yaml:"minimumSamplingIntervalMs"`
}

Information about a signal.

Example:

// The code below shows an example of how to instantiate this type.
// The values are placeholders you should change.
import "github.com/aws/aws-cdk-go/awscdk"

signalInformationProperty := &signalInformationProperty{
	name: jsii.String("name"),

	// the properties below are optional
	maxSampleCount: jsii.Number(123),
	minimumSamplingIntervalMs: jsii.Number(123),
}

type CfnCampaign_TimeBasedCollectionSchemeProperty

type CfnCampaign_TimeBasedCollectionSchemeProperty struct {
	// The time period (in milliseconds) to decide how often to collect data.
	//
	// For example, if the time period is `60000` , the Edge Agent software collects data once every minute.
	PeriodMs *float64 `field:"required" json:"periodMs" yaml:"periodMs"`
}

Information about a collection scheme that uses a time period to decide how often to collect data.

Example:

// The code below shows an example of how to instantiate this type.
// The values are placeholders you should change.
import "github.com/aws/aws-cdk-go/awscdk"

timeBasedCollectionSchemeProperty := &timeBasedCollectionSchemeProperty{
	periodMs: jsii.Number(123),
}

type CfnDecoderManifest

type CfnDecoderManifest interface {
	awscdk.CfnResource
	awscdk.IInspectable
	AttrArn() *string
	AttrCreationTime() *string
	AttrLastModificationTime() *string
	// Options for this resource, such as condition, update policy etc.
	// Experimental.
	CfnOptions() awscdk.ICfnResourceOptions
	CfnProperties() *map[string]interface{}
	// AWS resource type.
	// Experimental.
	CfnResourceType() *string
	// Returns: the stack trace of the point where this Resource was created from, sourced
	// from the +metadata+ entry typed +aws:cdk:logicalId+, and with the bottom-most
	// node +internal+ entries filtered.
	// Experimental.
	CreationStack() *[]*string
	// A brief description of the decoder manifest.
	Description() *string
	SetDescription(val *string)
	// The logical ID for this CloudFormation stack element.
	//
	// The logical ID of the element
	// is calculated from the path of the resource node in the construct tree.
	//
	// To override this value, use `overrideLogicalId(newLogicalId)`.
	//
	// Returns: the logical ID as a stringified token. This value will only get
	// resolved during synthesis.
	// Experimental.
	LogicalId() *string
	// The ARN of a vehicle model (model manifest) associated with the decoder manifest.
	ModelManifestArn() *string
	SetModelManifestArn(val *string)
	// The name of the decoder manifest.
	Name() *string
	SetName(val *string)
	// `AWS::IoTFleetWise::DecoderManifest.NetworkInterfaces`.
	NetworkInterfaces() interface{}
	SetNetworkInterfaces(val interface{})
	// The construct tree node associated with this construct.
	// Experimental.
	Node() awscdk.ConstructNode
	// Return a string that will be resolved to a CloudFormation `{ Ref }` for this element.
	//
	// If, by any chance, the intrinsic reference of a resource is not a string, you could
	// coerce it to an IResolvable through `Lazy.any({ produce: resource.ref })`.
	// Experimental.
	Ref() *string
	// `AWS::IoTFleetWise::DecoderManifest.SignalDecoders`.
	SignalDecoders() interface{}
	SetSignalDecoders(val interface{})
	// The stack in which this element is defined.
	//
	// CfnElements must be defined within a stack scope (directly or indirectly).
	// Experimental.
	Stack() awscdk.Stack
	// The state of the decoder manifest.
	//
	// If the status is `ACTIVE` , the decoder manifest can't be edited. If the status is marked `DRAFT` , you can edit the decoder manifest.
	Status() *string
	SetStatus(val *string)
	// `AWS::IoTFleetWise::DecoderManifest.Tags`.
	Tags() awscdk.TagManager
	// Return properties modified after initiation.
	//
	// Resources that expose mutable properties should override this function to
	// collect and return the properties object for this resource.
	// Experimental.
	UpdatedProperites() *map[string]interface{}
	// Syntactic sugar for `addOverride(path, undefined)`.
	// Experimental.
	AddDeletionOverride(path *string)
	// Indicates that this resource depends on another resource and cannot be provisioned unless the other resource has been successfully provisioned.
	//
	// This can be used for resources across stacks (or nested stack) boundaries
	// and the dependency will automatically be transferred to the relevant scope.
	// Experimental.
	AddDependsOn(target awscdk.CfnResource)
	// Add a value to the CloudFormation Resource Metadata.
	// See: https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/metadata-section-structure.html
	//
	// Note that this is a different set of metadata from CDK node metadata; this
	// metadata ends up in the stack template under the resource, whereas CDK
	// node metadata ends up in the Cloud Assembly.
	//
	// Experimental.
	AddMetadata(key *string, value interface{})
	// Adds an override to the synthesized CloudFormation resource.
	//
	// To add a
	// property override, either use `addPropertyOverride` or prefix `path` with
	// "Properties." (i.e. `Properties.TopicName`).
	//
	// If the override is nested, separate each nested level using a dot (.) in the path parameter.
	// If there is an array as part of the nesting, specify the index in the path.
	//
	// To include a literal `.` in the property name, prefix with a `\`. In most
	// programming languages you will need to write this as `"\\."` because the
	// `\` itself will need to be escaped.
	//
	// For example,
	// “`typescript
	// cfnResource.addOverride('Properties.GlobalSecondaryIndexes.0.Projection.NonKeyAttributes', ['myattribute']);
	// cfnResource.addOverride('Properties.GlobalSecondaryIndexes.1.ProjectionType', 'INCLUDE');
	// “`
	// would add the overrides
	// “`json
	// "Properties": {
	//    "GlobalSecondaryIndexes": [
	//      {
	//        "Projection": {
	//          "NonKeyAttributes": [ "myattribute" ]
	//          ...
	//        }
	//        ...
	//      },
	//      {
	//        "ProjectionType": "INCLUDE"
	//        ...
	//      },
	//    ]
	//    ...
	// }
	// “`
	//
	// The `value` argument to `addOverride` will not be processed or translated
	// in any way. Pass raw JSON values in here with the correct capitalization
	// for CloudFormation. If you pass CDK classes or structs, they will be
	// rendered with lowercased key names, and CloudFormation will reject the
	// template.
	// Experimental.
	AddOverride(path *string, value interface{})
	// Adds an override that deletes the value of a property from the resource definition.
	// Experimental.
	AddPropertyDeletionOverride(propertyPath *string)
	// Adds an override to a resource property.
	//
	// Syntactic sugar for `addOverride("Properties.<...>", value)`.
	// Experimental.
	AddPropertyOverride(propertyPath *string, value interface{})
	// Sets the deletion policy of the resource based on the removal policy specified.
	//
	// The Removal Policy controls what happens to this resource when it stops
	// being managed by CloudFormation, either because you've removed it from the
	// CDK application or because you've made a change that requires the resource
	// to be replaced.
	//
	// The resource can be deleted (`RemovalPolicy.DESTROY`), or left in your AWS
	// account for data recovery and cleanup later (`RemovalPolicy.RETAIN`).
	// Experimental.
	ApplyRemovalPolicy(policy awscdk.RemovalPolicy, options *awscdk.RemovalPolicyOptions)
	// Returns a token for an runtime attribute of this resource.
	//
	// Ideally, use generated attribute accessors (e.g. `resource.arn`), but this can be used for future compatibility
	// in case there is no generated attribute.
	// Experimental.
	GetAtt(attributeName *string) awscdk.Reference
	// Retrieve a value value from the CloudFormation Resource Metadata.
	// See: https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/metadata-section-structure.html
	//
	// Note that this is a different set of metadata from CDK node metadata; this
	// metadata ends up in the stack template under the resource, whereas CDK
	// node metadata ends up in the Cloud Assembly.
	//
	// Experimental.
	GetMetadata(key *string) interface{}
	// Examines the CloudFormation resource and discloses attributes.
	Inspect(inspector awscdk.TreeInspector)
	// Perform final modifications before synthesis.
	//
	// This method can be implemented by derived constructs in order to perform
	// final changes before synthesis. prepare() will be called after child
	// constructs have been prepared.
	//
	// This is an advanced framework feature. Only use this if you
	// understand the implications.
	// Experimental.
	OnPrepare()
	// Allows this construct to emit artifacts into the cloud assembly during synthesis.
	//
	// This method is usually implemented by framework-level constructs such as `Stack` and `Asset`
	// as they participate in synthesizing the cloud assembly.
	// Experimental.
	OnSynthesize(session constructs.ISynthesisSession)
	// Validate the current construct.
	//
	// This method can be implemented by derived constructs in order to perform
	// validation logic. It is called on all constructs before synthesis.
	//
	// Returns: An array of validation error messages, or an empty array if the construct is valid.
	// Experimental.
	OnValidate() *[]*string
	// Overrides the auto-generated logical ID with a specific ID.
	// Experimental.
	OverrideLogicalId(newLogicalId *string)
	// Perform final modifications before synthesis.
	//
	// This method can be implemented by derived constructs in order to perform
	// final changes before synthesis. prepare() will be called after child
	// constructs have been prepared.
	//
	// This is an advanced framework feature. Only use this if you
	// understand the implications.
	// Experimental.
	Prepare()
	RenderProperties(props *map[string]interface{}) *map[string]interface{}
	// Can be overridden by subclasses to determine if this resource will be rendered into the cloudformation template.
	//
	// Returns: `true` if the resource should be included or `false` is the resource
	// should be omitted.
	// Experimental.
	ShouldSynthesize() *bool
	// Allows this construct to emit artifacts into the cloud assembly during synthesis.
	//
	// This method is usually implemented by framework-level constructs such as `Stack` and `Asset`
	// as they participate in synthesizing the cloud assembly.
	// Experimental.
	Synthesize(session awscdk.ISynthesisSession)
	// Returns a string representation of this construct.
	//
	// Returns: a string representation of this resource.
	// Experimental.
	ToString() *string
	// Validate the current construct.
	//
	// This method can be implemented by derived constructs in order to perform
	// validation logic. It is called on all constructs before synthesis.
	//
	// Returns: An array of validation error messages, or an empty array if the construct is valid.
	// Experimental.
	Validate() *[]*string
	// Experimental.
	ValidateProperties(_properties interface{})
}

A CloudFormation `AWS::IoTFleetWise::DecoderManifest`.

Creates the decoder manifest associated with a model manifest. To create a decoder manifest, the following must be true:

- Every signal decoder has a unique name. - Each signal decoder is associated with a network interface. - Each network interface has a unique ID. - The signal decoders are specified in the model manifest.

Example:

// The code below shows an example of how to instantiate this type.
// The values are placeholders you should change.
import "github.com/aws/aws-cdk-go/awscdk"

var networkInterfaces interface{}
var signalDecoders interface{}

cfnDecoderManifest := awscdk.Aws_iotfleetwise.NewCfnDecoderManifest(this, jsii.String("MyCfnDecoderManifest"), &cfnDecoderManifestProps{
	modelManifestArn: jsii.String("modelManifestArn"),
	name: jsii.String("name"),

	// the properties below are optional
	description: jsii.String("description"),
	networkInterfaces: []interface{}{
		networkInterfaces,
	},
	signalDecoders: []interface{}{
		signalDecoders,
	},
	status: jsii.String("status"),
	tags: []cfnTag{
		&cfnTag{
			key: jsii.String("key"),
			value: jsii.String("value"),
		},
	},
})

func NewCfnDecoderManifest

func NewCfnDecoderManifest(scope awscdk.Construct, id *string, props *CfnDecoderManifestProps) CfnDecoderManifest

Create a new `AWS::IoTFleetWise::DecoderManifest`.

type CfnDecoderManifestProps

type CfnDecoderManifestProps struct {
	// The ARN of a vehicle model (model manifest) associated with the decoder manifest.
	ModelManifestArn *string `field:"required" json:"modelManifestArn" yaml:"modelManifestArn"`
	// The name of the decoder manifest.
	Name *string `field:"required" json:"name" yaml:"name"`
	// A brief description of the decoder manifest.
	Description *string `field:"optional" json:"description" yaml:"description"`
	// `AWS::IoTFleetWise::DecoderManifest.NetworkInterfaces`.
	NetworkInterfaces interface{} `field:"optional" json:"networkInterfaces" yaml:"networkInterfaces"`
	// `AWS::IoTFleetWise::DecoderManifest.SignalDecoders`.
	SignalDecoders interface{} `field:"optional" json:"signalDecoders" yaml:"signalDecoders"`
	// The state of the decoder manifest.
	//
	// If the status is `ACTIVE` , the decoder manifest can't be edited. If the status is marked `DRAFT` , you can edit the decoder manifest.
	Status *string `field:"optional" json:"status" yaml:"status"`
	// `AWS::IoTFleetWise::DecoderManifest.Tags`.
	Tags *[]*awscdk.CfnTag `field:"optional" json:"tags" yaml:"tags"`
}

Properties for defining a `CfnDecoderManifest`.

Example:

// The code below shows an example of how to instantiate this type.
// The values are placeholders you should change.
import "github.com/aws/aws-cdk-go/awscdk"

var networkInterfaces interface{}
var signalDecoders interface{}

cfnDecoderManifestProps := &cfnDecoderManifestProps{
	modelManifestArn: jsii.String("modelManifestArn"),
	name: jsii.String("name"),

	// the properties below are optional
	description: jsii.String("description"),
	networkInterfaces: []interface{}{
		networkInterfaces,
	},
	signalDecoders: []interface{}{
		signalDecoders,
	},
	status: jsii.String("status"),
	tags: []cfnTag{
		&cfnTag{
			key: jsii.String("key"),
			value: jsii.String("value"),
		},
	},
}

type CfnDecoderManifest_CanInterfaceProperty

type CfnDecoderManifest_CanInterfaceProperty struct {
	// The unique name of the interface.
	Name *string `field:"required" json:"name" yaml:"name"`
	// The name of the communication protocol for the interface.
	ProtocolName *string `field:"optional" json:"protocolName" yaml:"protocolName"`
	// The version of the communication protocol for the interface.
	ProtocolVersion *string `field:"optional" json:"protocolVersion" yaml:"protocolVersion"`
}

A single controller area network (CAN) device interface.

Example:

// The code below shows an example of how to instantiate this type.
// The values are placeholders you should change.
import "github.com/aws/aws-cdk-go/awscdk"

canInterfaceProperty := &canInterfaceProperty{
	name: jsii.String("name"),

	// the properties below are optional
	protocolName: jsii.String("protocolName"),
	protocolVersion: jsii.String("protocolVersion"),
}

type CfnDecoderManifest_CanNetworkInterfaceProperty

type CfnDecoderManifest_CanNetworkInterfaceProperty struct {
	// `CfnDecoderManifest.CanNetworkInterfaceProperty.CanInterface`.
	CanInterface interface{} `field:"required" json:"canInterface" yaml:"canInterface"`
	// `CfnDecoderManifest.CanNetworkInterfaceProperty.InterfaceId`.
	InterfaceId *string `field:"required" json:"interfaceId" yaml:"interfaceId"`
	// `CfnDecoderManifest.CanNetworkInterfaceProperty.Type`.
	Type *string `field:"required" json:"type" yaml:"type"`
}

Example:

// The code below shows an example of how to instantiate this type.
// The values are placeholders you should change.
import "github.com/aws/aws-cdk-go/awscdk"

canNetworkInterfaceProperty := &canNetworkInterfaceProperty{
	canInterface: &canInterfaceProperty{
		name: jsii.String("name"),

		// the properties below are optional
		protocolName: jsii.String("protocolName"),
		protocolVersion: jsii.String("protocolVersion"),
	},
	interfaceId: jsii.String("interfaceId"),
	type: jsii.String("type"),
}

type CfnDecoderManifest_CanSignalDecoderProperty

type CfnDecoderManifest_CanSignalDecoderProperty struct {
	// `CfnDecoderManifest.CanSignalDecoderProperty.CanSignal`.
	CanSignal interface{} `field:"required" json:"canSignal" yaml:"canSignal"`
	// `CfnDecoderManifest.CanSignalDecoderProperty.FullyQualifiedName`.
	FullyQualifiedName *string `field:"required" json:"fullyQualifiedName" yaml:"fullyQualifiedName"`
	// `CfnDecoderManifest.CanSignalDecoderProperty.InterfaceId`.
	InterfaceId *string `field:"required" json:"interfaceId" yaml:"interfaceId"`
	// `CfnDecoderManifest.CanSignalDecoderProperty.Type`.
	Type *string `field:"required" json:"type" yaml:"type"`
}

Example:

// The code below shows an example of how to instantiate this type.
// The values are placeholders you should change.
import "github.com/aws/aws-cdk-go/awscdk"

var factor interface{}
var isBigEndian interface{}
var isSigned interface{}
var length interface{}
var messageId interface{}
var offset interface{}
var startBit interface{}

canSignalDecoderProperty := &canSignalDecoderProperty{
	canSignal: &canSignalProperty{
		factor: factor,
		isBigEndian: isBigEndian,
		isSigned: isSigned,
		length: length,
		messageId: messageId,
		offset: offset,
		startBit: startBit,

		// the properties below are optional
		name: jsii.String("name"),
	},
	fullyQualifiedName: jsii.String("fullyQualifiedName"),
	interfaceId: jsii.String("interfaceId"),
	type: jsii.String("type"),
}

type CfnDecoderManifest_CanSignalProperty

type CfnDecoderManifest_CanSignalProperty struct {
	// A multiplier used to decode the CAN message.
	Factor interface{} `field:"required" json:"factor" yaml:"factor"`
	// Whether the byte ordering of a CAN message is big-endian.
	IsBigEndian interface{} `field:"required" json:"isBigEndian" yaml:"isBigEndian"`
	// Whether the message data is specified as a signed value.
	IsSigned interface{} `field:"required" json:"isSigned" yaml:"isSigned"`
	// How many bytes of data are in the message.
	Length interface{} `field:"required" json:"length" yaml:"length"`
	// The ID of the message.
	MessageId interface{} `field:"required" json:"messageId" yaml:"messageId"`
	// Indicates where data appears in the CAN message.
	Offset interface{} `field:"required" json:"offset" yaml:"offset"`
	// Indicates the beginning of the CAN message.
	StartBit interface{} `field:"required" json:"startBit" yaml:"startBit"`
	// The name of the signal.
	Name *string `field:"optional" json:"name" yaml:"name"`
}

Information about a single controller area network (CAN) signal and the messages it receives and transmits.

Example:

// The code below shows an example of how to instantiate this type.
// The values are placeholders you should change.
import "github.com/aws/aws-cdk-go/awscdk"

var factor interface{}
var isBigEndian interface{}
var isSigned interface{}
var length interface{}
var messageId interface{}
var offset interface{}
var startBit interface{}

canSignalProperty := &canSignalProperty{
	factor: factor,
	isBigEndian: isBigEndian,
	isSigned: isSigned,
	length: length,
	messageId: messageId,
	offset: offset,
	startBit: startBit,

	// the properties below are optional
	name: jsii.String("name"),
}

type CfnDecoderManifest_ObdInterfaceProperty

type CfnDecoderManifest_ObdInterfaceProperty struct {
	// The name of the interface.
	Name *string `field:"required" json:"name" yaml:"name"`
	// The ID of the message requesting vehicle data.
	RequestMessageId interface{} `field:"required" json:"requestMessageId" yaml:"requestMessageId"`
	// The maximum number message requests per diagnostic trouble code per second.
	DtcRequestIntervalSeconds interface{} `field:"optional" json:"dtcRequestIntervalSeconds" yaml:"dtcRequestIntervalSeconds"`
	// Whether the vehicle has a transmission control module (TCM).
	HasTransmissionEcu interface{} `field:"optional" json:"hasTransmissionEcu" yaml:"hasTransmissionEcu"`
	// The standard OBD II PID.
	ObdStandard *string `field:"optional" json:"obdStandard" yaml:"obdStandard"`
	// The maximum number message requests per second.
	PidRequestIntervalSeconds interface{} `field:"optional" json:"pidRequestIntervalSeconds" yaml:"pidRequestIntervalSeconds"`
	// Whether to use extended IDs in the message.
	UseExtendedIds interface{} `field:"optional" json:"useExtendedIds" yaml:"useExtendedIds"`
}

A network interface that specifies the On-board diagnostic (OBD) II network protocol.

Example:

// The code below shows an example of how to instantiate this type.
// The values are placeholders you should change.
import "github.com/aws/aws-cdk-go/awscdk"

var dtcRequestIntervalSeconds interface{}
var hasTransmissionEcu interface{}
var pidRequestIntervalSeconds interface{}
var requestMessageId interface{}
var useExtendedIds interface{}

obdInterfaceProperty := &obdInterfaceProperty{
	name: jsii.String("name"),
	requestMessageId: requestMessageId,

	// the properties below are optional
	dtcRequestIntervalSeconds: dtcRequestIntervalSeconds,
	hasTransmissionEcu: hasTransmissionEcu,
	obdStandard: jsii.String("obdStandard"),
	pidRequestIntervalSeconds: pidRequestIntervalSeconds,
	useExtendedIds: useExtendedIds,
}

type CfnDecoderManifest_ObdNetworkInterfaceProperty

type CfnDecoderManifest_ObdNetworkInterfaceProperty struct {
	// `CfnDecoderManifest.ObdNetworkInterfaceProperty.InterfaceId`.
	InterfaceId *string `field:"required" json:"interfaceId" yaml:"interfaceId"`
	// `CfnDecoderManifest.ObdNetworkInterfaceProperty.ObdInterface`.
	ObdInterface interface{} `field:"required" json:"obdInterface" yaml:"obdInterface"`
	// `CfnDecoderManifest.ObdNetworkInterfaceProperty.Type`.
	Type *string `field:"required" json:"type" yaml:"type"`
}

Example:

// The code below shows an example of how to instantiate this type.
// The values are placeholders you should change.
import "github.com/aws/aws-cdk-go/awscdk"

var dtcRequestIntervalSeconds interface{}
var hasTransmissionEcu interface{}
var pidRequestIntervalSeconds interface{}
var requestMessageId interface{}
var useExtendedIds interface{}

obdNetworkInterfaceProperty := &obdNetworkInterfaceProperty{
	interfaceId: jsii.String("interfaceId"),
	obdInterface: &obdInterfaceProperty{
		name: jsii.String("name"),
		requestMessageId: requestMessageId,

		// the properties below are optional
		dtcRequestIntervalSeconds: dtcRequestIntervalSeconds,
		hasTransmissionEcu: hasTransmissionEcu,
		obdStandard: jsii.String("obdStandard"),
		pidRequestIntervalSeconds: pidRequestIntervalSeconds,
		useExtendedIds: useExtendedIds,
	},
	type: jsii.String("type"),
}

type CfnDecoderManifest_ObdSignalDecoderProperty

type CfnDecoderManifest_ObdSignalDecoderProperty struct {
	// `CfnDecoderManifest.ObdSignalDecoderProperty.FullyQualifiedName`.
	FullyQualifiedName *string `field:"required" json:"fullyQualifiedName" yaml:"fullyQualifiedName"`
	// `CfnDecoderManifest.ObdSignalDecoderProperty.InterfaceId`.
	InterfaceId *string `field:"required" json:"interfaceId" yaml:"interfaceId"`
	// `CfnDecoderManifest.ObdSignalDecoderProperty.ObdSignal`.
	ObdSignal interface{} `field:"required" json:"obdSignal" yaml:"obdSignal"`
	// `CfnDecoderManifest.ObdSignalDecoderProperty.Type`.
	Type *string `field:"required" json:"type" yaml:"type"`
}

Example:

// The code below shows an example of how to instantiate this type.
// The values are placeholders you should change.
import "github.com/aws/aws-cdk-go/awscdk"

var bitMaskLength interface{}
var bitRightShift interface{}
var byteLength interface{}
var offset interface{}
var pid interface{}
var pidResponseLength interface{}
var scaling interface{}
var serviceMode interface{}
var startByte interface{}

obdSignalDecoderProperty := &obdSignalDecoderProperty{
	fullyQualifiedName: jsii.String("fullyQualifiedName"),
	interfaceId: jsii.String("interfaceId"),
	obdSignal: &obdSignalProperty{
		byteLength: byteLength,
		offset: offset,
		pid: pid,
		pidResponseLength: pidResponseLength,
		scaling: scaling,
		serviceMode: serviceMode,
		startByte: startByte,

		// the properties below are optional
		bitMaskLength: bitMaskLength,
		bitRightShift: bitRightShift,
	},
	type: jsii.String("type"),
}

type CfnDecoderManifest_ObdSignalProperty

type CfnDecoderManifest_ObdSignalProperty struct {
	// The length of a message.
	ByteLength interface{} `field:"required" json:"byteLength" yaml:"byteLength"`
	// Indicates where data appears in the message.
	Offset interface{} `field:"required" json:"offset" yaml:"offset"`
	// The diagnostic code used to request data from a vehicle for this signal.
	Pid interface{} `field:"required" json:"pid" yaml:"pid"`
	// The length of the requested data.
	PidResponseLength interface{} `field:"required" json:"pidResponseLength" yaml:"pidResponseLength"`
	// A multiplier used to decode the message.
	Scaling interface{} `field:"required" json:"scaling" yaml:"scaling"`
	// The mode of operation (diagnostic service) in a message.
	ServiceMode interface{} `field:"required" json:"serviceMode" yaml:"serviceMode"`
	// Indicates the beginning of the message.
	StartByte interface{} `field:"required" json:"startByte" yaml:"startByte"`
	// The number of bits to mask in a message.
	BitMaskLength interface{} `field:"optional" json:"bitMaskLength" yaml:"bitMaskLength"`
	// The number of positions to shift bits in the message.
	BitRightShift interface{} `field:"optional" json:"bitRightShift" yaml:"bitRightShift"`
}

Information about signal messages using the on-board diagnostics (OBD) II protocol in a vehicle.

Example:

// The code below shows an example of how to instantiate this type.
// The values are placeholders you should change.
import "github.com/aws/aws-cdk-go/awscdk"

var bitMaskLength interface{}
var bitRightShift interface{}
var byteLength interface{}
var offset interface{}
var pid interface{}
var pidResponseLength interface{}
var scaling interface{}
var serviceMode interface{}
var startByte interface{}

obdSignalProperty := &obdSignalProperty{
	byteLength: byteLength,
	offset: offset,
	pid: pid,
	pidResponseLength: pidResponseLength,
	scaling: scaling,
	serviceMode: serviceMode,
	startByte: startByte,

	// the properties below are optional
	bitMaskLength: bitMaskLength,
	bitRightShift: bitRightShift,
}

type CfnFleet

type CfnFleet interface {
	awscdk.CfnResource
	awscdk.IInspectable
	AttrArn() *string
	AttrCreationTime() *string
	AttrLastModificationTime() *string
	// Options for this resource, such as condition, update policy etc.
	// Experimental.
	CfnOptions() awscdk.ICfnResourceOptions
	CfnProperties() *map[string]interface{}
	// AWS resource type.
	// Experimental.
	CfnResourceType() *string
	// Returns: the stack trace of the point where this Resource was created from, sourced
	// from the +metadata+ entry typed +aws:cdk:logicalId+, and with the bottom-most
	// node +internal+ entries filtered.
	// Experimental.
	CreationStack() *[]*string
	// A brief description of the fleet.
	Description() *string
	SetDescription(val *string)
	// The unique ID of the fleet.
	Id() *string
	SetId(val *string)
	// The logical ID for this CloudFormation stack element.
	//
	// The logical ID of the element
	// is calculated from the path of the resource node in the construct tree.
	//
	// To override this value, use `overrideLogicalId(newLogicalId)`.
	//
	// Returns: the logical ID as a stringified token. This value will only get
	// resolved during synthesis.
	// Experimental.
	LogicalId() *string
	// The construct tree node associated with this construct.
	// Experimental.
	Node() awscdk.ConstructNode
	// Return a string that will be resolved to a CloudFormation `{ Ref }` for this element.
	//
	// If, by any chance, the intrinsic reference of a resource is not a string, you could
	// coerce it to an IResolvable through `Lazy.any({ produce: resource.ref })`.
	// Experimental.
	Ref() *string
	// The ARN of the signal catalog associated with the fleet.
	SignalCatalogArn() *string
	SetSignalCatalogArn(val *string)
	// The stack in which this element is defined.
	//
	// CfnElements must be defined within a stack scope (directly or indirectly).
	// Experimental.
	Stack() awscdk.Stack
	// `AWS::IoTFleetWise::Fleet.Tags`.
	Tags() awscdk.TagManager
	// Return properties modified after initiation.
	//
	// Resources that expose mutable properties should override this function to
	// collect and return the properties object for this resource.
	// Experimental.
	UpdatedProperites() *map[string]interface{}
	// Syntactic sugar for `addOverride(path, undefined)`.
	// Experimental.
	AddDeletionOverride(path *string)
	// Indicates that this resource depends on another resource and cannot be provisioned unless the other resource has been successfully provisioned.
	//
	// This can be used for resources across stacks (or nested stack) boundaries
	// and the dependency will automatically be transferred to the relevant scope.
	// Experimental.
	AddDependsOn(target awscdk.CfnResource)
	// Add a value to the CloudFormation Resource Metadata.
	// See: https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/metadata-section-structure.html
	//
	// Note that this is a different set of metadata from CDK node metadata; this
	// metadata ends up in the stack template under the resource, whereas CDK
	// node metadata ends up in the Cloud Assembly.
	//
	// Experimental.
	AddMetadata(key *string, value interface{})
	// Adds an override to the synthesized CloudFormation resource.
	//
	// To add a
	// property override, either use `addPropertyOverride` or prefix `path` with
	// "Properties." (i.e. `Properties.TopicName`).
	//
	// If the override is nested, separate each nested level using a dot (.) in the path parameter.
	// If there is an array as part of the nesting, specify the index in the path.
	//
	// To include a literal `.` in the property name, prefix with a `\`. In most
	// programming languages you will need to write this as `"\\."` because the
	// `\` itself will need to be escaped.
	//
	// For example,
	// “`typescript
	// cfnResource.addOverride('Properties.GlobalSecondaryIndexes.0.Projection.NonKeyAttributes', ['myattribute']);
	// cfnResource.addOverride('Properties.GlobalSecondaryIndexes.1.ProjectionType', 'INCLUDE');
	// “`
	// would add the overrides
	// “`json
	// "Properties": {
	//    "GlobalSecondaryIndexes": [
	//      {
	//        "Projection": {
	//          "NonKeyAttributes": [ "myattribute" ]
	//          ...
	//        }
	//        ...
	//      },
	//      {
	//        "ProjectionType": "INCLUDE"
	//        ...
	//      },
	//    ]
	//    ...
	// }
	// “`
	//
	// The `value` argument to `addOverride` will not be processed or translated
	// in any way. Pass raw JSON values in here with the correct capitalization
	// for CloudFormation. If you pass CDK classes or structs, they will be
	// rendered with lowercased key names, and CloudFormation will reject the
	// template.
	// Experimental.
	AddOverride(path *string, value interface{})
	// Adds an override that deletes the value of a property from the resource definition.
	// Experimental.
	AddPropertyDeletionOverride(propertyPath *string)
	// Adds an override to a resource property.
	//
	// Syntactic sugar for `addOverride("Properties.<...>", value)`.
	// Experimental.
	AddPropertyOverride(propertyPath *string, value interface{})
	// Sets the deletion policy of the resource based on the removal policy specified.
	//
	// The Removal Policy controls what happens to this resource when it stops
	// being managed by CloudFormation, either because you've removed it from the
	// CDK application or because you've made a change that requires the resource
	// to be replaced.
	//
	// The resource can be deleted (`RemovalPolicy.DESTROY`), or left in your AWS
	// account for data recovery and cleanup later (`RemovalPolicy.RETAIN`).
	// Experimental.
	ApplyRemovalPolicy(policy awscdk.RemovalPolicy, options *awscdk.RemovalPolicyOptions)
	// Returns a token for an runtime attribute of this resource.
	//
	// Ideally, use generated attribute accessors (e.g. `resource.arn`), but this can be used for future compatibility
	// in case there is no generated attribute.
	// Experimental.
	GetAtt(attributeName *string) awscdk.Reference
	// Retrieve a value value from the CloudFormation Resource Metadata.
	// See: https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/metadata-section-structure.html
	//
	// Note that this is a different set of metadata from CDK node metadata; this
	// metadata ends up in the stack template under the resource, whereas CDK
	// node metadata ends up in the Cloud Assembly.
	//
	// Experimental.
	GetMetadata(key *string) interface{}
	// Examines the CloudFormation resource and discloses attributes.
	Inspect(inspector awscdk.TreeInspector)
	// Perform final modifications before synthesis.
	//
	// This method can be implemented by derived constructs in order to perform
	// final changes before synthesis. prepare() will be called after child
	// constructs have been prepared.
	//
	// This is an advanced framework feature. Only use this if you
	// understand the implications.
	// Experimental.
	OnPrepare()
	// Allows this construct to emit artifacts into the cloud assembly during synthesis.
	//
	// This method is usually implemented by framework-level constructs such as `Stack` and `Asset`
	// as they participate in synthesizing the cloud assembly.
	// Experimental.
	OnSynthesize(session constructs.ISynthesisSession)
	// Validate the current construct.
	//
	// This method can be implemented by derived constructs in order to perform
	// validation logic. It is called on all constructs before synthesis.
	//
	// Returns: An array of validation error messages, or an empty array if the construct is valid.
	// Experimental.
	OnValidate() *[]*string
	// Overrides the auto-generated logical ID with a specific ID.
	// Experimental.
	OverrideLogicalId(newLogicalId *string)
	// Perform final modifications before synthesis.
	//
	// This method can be implemented by derived constructs in order to perform
	// final changes before synthesis. prepare() will be called after child
	// constructs have been prepared.
	//
	// This is an advanced framework feature. Only use this if you
	// understand the implications.
	// Experimental.
	Prepare()
	RenderProperties(props *map[string]interface{}) *map[string]interface{}
	// Can be overridden by subclasses to determine if this resource will be rendered into the cloudformation template.
	//
	// Returns: `true` if the resource should be included or `false` is the resource
	// should be omitted.
	// Experimental.
	ShouldSynthesize() *bool
	// Allows this construct to emit artifacts into the cloud assembly during synthesis.
	//
	// This method is usually implemented by framework-level constructs such as `Stack` and `Asset`
	// as they participate in synthesizing the cloud assembly.
	// Experimental.
	Synthesize(session awscdk.ISynthesisSession)
	// Returns a string representation of this construct.
	//
	// Returns: a string representation of this resource.
	// Experimental.
	ToString() *string
	// Validate the current construct.
	//
	// This method can be implemented by derived constructs in order to perform
	// validation logic. It is called on all constructs before synthesis.
	//
	// Returns: An array of validation error messages, or an empty array if the construct is valid.
	// Experimental.
	Validate() *[]*string
	// Experimental.
	ValidateProperties(_properties interface{})
}

A CloudFormation `AWS::IoTFleetWise::Fleet`.

Creates a fleet that represents a group of vehicles.

> You must create both a signal catalog and vehicles before you can create a fleet.

For more information, see [Fleets](https://docs.aws.amazon.com/iot-fleetwise/latest/developerguide/fleets.html) in the *AWS IoT FleetWise Developer Guide* .

Example:

// The code below shows an example of how to instantiate this type.
// The values are placeholders you should change.
import "github.com/aws/aws-cdk-go/awscdk"

cfnFleet := awscdk.Aws_iotfleetwise.NewCfnFleet(this, jsii.String("MyCfnFleet"), &cfnFleetProps{
	id: jsii.String("id"),
	signalCatalogArn: jsii.String("signalCatalogArn"),

	// the properties below are optional
	description: jsii.String("description"),
	tags: []cfnTag{
		&cfnTag{
			key: jsii.String("key"),
			value: jsii.String("value"),
		},
	},
})

func NewCfnFleet

func NewCfnFleet(scope awscdk.Construct, id *string, props *CfnFleetProps) CfnFleet

Create a new `AWS::IoTFleetWise::Fleet`.

type CfnFleetProps

type CfnFleetProps struct {
	// The unique ID of the fleet.
	Id *string `field:"required" json:"id" yaml:"id"`
	// The ARN of the signal catalog associated with the fleet.
	SignalCatalogArn *string `field:"required" json:"signalCatalogArn" yaml:"signalCatalogArn"`
	// A brief description of the fleet.
	Description *string `field:"optional" json:"description" yaml:"description"`
	// `AWS::IoTFleetWise::Fleet.Tags`.
	Tags *[]*awscdk.CfnTag `field:"optional" json:"tags" yaml:"tags"`
}

Properties for defining a `CfnFleet`.

Example:

// The code below shows an example of how to instantiate this type.
// The values are placeholders you should change.
import "github.com/aws/aws-cdk-go/awscdk"

cfnFleetProps := &cfnFleetProps{
	id: jsii.String("id"),
	signalCatalogArn: jsii.String("signalCatalogArn"),

	// the properties below are optional
	description: jsii.String("description"),
	tags: []cfnTag{
		&cfnTag{
			key: jsii.String("key"),
			value: jsii.String("value"),
		},
	},
}

type CfnModelManifest

type CfnModelManifest interface {
	awscdk.CfnResource
	awscdk.IInspectable
	AttrArn() *string
	AttrCreationTime() *string
	AttrLastModificationTime() *string
	// Options for this resource, such as condition, update policy etc.
	// Experimental.
	CfnOptions() awscdk.ICfnResourceOptions
	CfnProperties() *map[string]interface{}
	// AWS resource type.
	// Experimental.
	CfnResourceType() *string
	// Returns: the stack trace of the point where this Resource was created from, sourced
	// from the +metadata+ entry typed +aws:cdk:logicalId+, and with the bottom-most
	// node +internal+ entries filtered.
	// Experimental.
	CreationStack() *[]*string
	// A brief description of the vehicle model.
	Description() *string
	SetDescription(val *string)
	// The logical ID for this CloudFormation stack element.
	//
	// The logical ID of the element
	// is calculated from the path of the resource node in the construct tree.
	//
	// To override this value, use `overrideLogicalId(newLogicalId)`.
	//
	// Returns: the logical ID as a stringified token. This value will only get
	// resolved during synthesis.
	// Experimental.
	LogicalId() *string
	// The name of the vehicle model.
	Name() *string
	SetName(val *string)
	// The construct tree node associated with this construct.
	// Experimental.
	Node() awscdk.ConstructNode
	// `AWS::IoTFleetWise::ModelManifest.Nodes`.
	Nodes() *[]*string
	SetNodes(val *[]*string)
	// Return a string that will be resolved to a CloudFormation `{ Ref }` for this element.
	//
	// If, by any chance, the intrinsic reference of a resource is not a string, you could
	// coerce it to an IResolvable through `Lazy.any({ produce: resource.ref })`.
	// Experimental.
	Ref() *string
	// The ARN of the signal catalog associated with the vehicle model.
	SignalCatalogArn() *string
	SetSignalCatalogArn(val *string)
	// The stack in which this element is defined.
	//
	// CfnElements must be defined within a stack scope (directly or indirectly).
	// Experimental.
	Stack() awscdk.Stack
	// The state of the vehicle model.
	//
	// If the status is `ACTIVE` , the vehicle model can't be edited. If the status is `DRAFT` , you can edit the vehicle model.
	Status() *string
	SetStatus(val *string)
	// `AWS::IoTFleetWise::ModelManifest.Tags`.
	Tags() awscdk.TagManager
	// Return properties modified after initiation.
	//
	// Resources that expose mutable properties should override this function to
	// collect and return the properties object for this resource.
	// Experimental.
	UpdatedProperites() *map[string]interface{}
	// Syntactic sugar for `addOverride(path, undefined)`.
	// Experimental.
	AddDeletionOverride(path *string)
	// Indicates that this resource depends on another resource and cannot be provisioned unless the other resource has been successfully provisioned.
	//
	// This can be used for resources across stacks (or nested stack) boundaries
	// and the dependency will automatically be transferred to the relevant scope.
	// Experimental.
	AddDependsOn(target awscdk.CfnResource)
	// Add a value to the CloudFormation Resource Metadata.
	// See: https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/metadata-section-structure.html
	//
	// Note that this is a different set of metadata from CDK node metadata; this
	// metadata ends up in the stack template under the resource, whereas CDK
	// node metadata ends up in the Cloud Assembly.
	//
	// Experimental.
	AddMetadata(key *string, value interface{})
	// Adds an override to the synthesized CloudFormation resource.
	//
	// To add a
	// property override, either use `addPropertyOverride` or prefix `path` with
	// "Properties." (i.e. `Properties.TopicName`).
	//
	// If the override is nested, separate each nested level using a dot (.) in the path parameter.
	// If there is an array as part of the nesting, specify the index in the path.
	//
	// To include a literal `.` in the property name, prefix with a `\`. In most
	// programming languages you will need to write this as `"\\."` because the
	// `\` itself will need to be escaped.
	//
	// For example,
	// “`typescript
	// cfnResource.addOverride('Properties.GlobalSecondaryIndexes.0.Projection.NonKeyAttributes', ['myattribute']);
	// cfnResource.addOverride('Properties.GlobalSecondaryIndexes.1.ProjectionType', 'INCLUDE');
	// “`
	// would add the overrides
	// “`json
	// "Properties": {
	//    "GlobalSecondaryIndexes": [
	//      {
	//        "Projection": {
	//          "NonKeyAttributes": [ "myattribute" ]
	//          ...
	//        }
	//        ...
	//      },
	//      {
	//        "ProjectionType": "INCLUDE"
	//        ...
	//      },
	//    ]
	//    ...
	// }
	// “`
	//
	// The `value` argument to `addOverride` will not be processed or translated
	// in any way. Pass raw JSON values in here with the correct capitalization
	// for CloudFormation. If you pass CDK classes or structs, they will be
	// rendered with lowercased key names, and CloudFormation will reject the
	// template.
	// Experimental.
	AddOverride(path *string, value interface{})
	// Adds an override that deletes the value of a property from the resource definition.
	// Experimental.
	AddPropertyDeletionOverride(propertyPath *string)
	// Adds an override to a resource property.
	//
	// Syntactic sugar for `addOverride("Properties.<...>", value)`.
	// Experimental.
	AddPropertyOverride(propertyPath *string, value interface{})
	// Sets the deletion policy of the resource based on the removal policy specified.
	//
	// The Removal Policy controls what happens to this resource when it stops
	// being managed by CloudFormation, either because you've removed it from the
	// CDK application or because you've made a change that requires the resource
	// to be replaced.
	//
	// The resource can be deleted (`RemovalPolicy.DESTROY`), or left in your AWS
	// account for data recovery and cleanup later (`RemovalPolicy.RETAIN`).
	// Experimental.
	ApplyRemovalPolicy(policy awscdk.RemovalPolicy, options *awscdk.RemovalPolicyOptions)
	// Returns a token for an runtime attribute of this resource.
	//
	// Ideally, use generated attribute accessors (e.g. `resource.arn`), but this can be used for future compatibility
	// in case there is no generated attribute.
	// Experimental.
	GetAtt(attributeName *string) awscdk.Reference
	// Retrieve a value value from the CloudFormation Resource Metadata.
	// See: https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/metadata-section-structure.html
	//
	// Note that this is a different set of metadata from CDK node metadata; this
	// metadata ends up in the stack template under the resource, whereas CDK
	// node metadata ends up in the Cloud Assembly.
	//
	// Experimental.
	GetMetadata(key *string) interface{}
	// Examines the CloudFormation resource and discloses attributes.
	Inspect(inspector awscdk.TreeInspector)
	// Perform final modifications before synthesis.
	//
	// This method can be implemented by derived constructs in order to perform
	// final changes before synthesis. prepare() will be called after child
	// constructs have been prepared.
	//
	// This is an advanced framework feature. Only use this if you
	// understand the implications.
	// Experimental.
	OnPrepare()
	// Allows this construct to emit artifacts into the cloud assembly during synthesis.
	//
	// This method is usually implemented by framework-level constructs such as `Stack` and `Asset`
	// as they participate in synthesizing the cloud assembly.
	// Experimental.
	OnSynthesize(session constructs.ISynthesisSession)
	// Validate the current construct.
	//
	// This method can be implemented by derived constructs in order to perform
	// validation logic. It is called on all constructs before synthesis.
	//
	// Returns: An array of validation error messages, or an empty array if the construct is valid.
	// Experimental.
	OnValidate() *[]*string
	// Overrides the auto-generated logical ID with a specific ID.
	// Experimental.
	OverrideLogicalId(newLogicalId *string)
	// Perform final modifications before synthesis.
	//
	// This method can be implemented by derived constructs in order to perform
	// final changes before synthesis. prepare() will be called after child
	// constructs have been prepared.
	//
	// This is an advanced framework feature. Only use this if you
	// understand the implications.
	// Experimental.
	Prepare()
	RenderProperties(props *map[string]interface{}) *map[string]interface{}
	// Can be overridden by subclasses to determine if this resource will be rendered into the cloudformation template.
	//
	// Returns: `true` if the resource should be included or `false` is the resource
	// should be omitted.
	// Experimental.
	ShouldSynthesize() *bool
	// Allows this construct to emit artifacts into the cloud assembly during synthesis.
	//
	// This method is usually implemented by framework-level constructs such as `Stack` and `Asset`
	// as they participate in synthesizing the cloud assembly.
	// Experimental.
	Synthesize(session awscdk.ISynthesisSession)
	// Returns a string representation of this construct.
	//
	// Returns: a string representation of this resource.
	// Experimental.
	ToString() *string
	// Validate the current construct.
	//
	// This method can be implemented by derived constructs in order to perform
	// validation logic. It is called on all constructs before synthesis.
	//
	// Returns: An array of validation error messages, or an empty array if the construct is valid.
	// Experimental.
	Validate() *[]*string
	// Experimental.
	ValidateProperties(_properties interface{})
}

A CloudFormation `AWS::IoTFleetWise::ModelManifest`.

Creates a vehicle model (model manifest) that specifies signals (attributes, branches, sensors, and actuators).

For more information, see [Vehicle models](https://docs.aws.amazon.com/iot-fleetwise/latest/developerguide/vehicle-models.html) in the *AWS IoT FleetWise Developer Guide* .

Example:

// The code below shows an example of how to instantiate this type.
// The values are placeholders you should change.
import "github.com/aws/aws-cdk-go/awscdk"

cfnModelManifest := awscdk.Aws_iotfleetwise.NewCfnModelManifest(this, jsii.String("MyCfnModelManifest"), &cfnModelManifestProps{
	name: jsii.String("name"),
	signalCatalogArn: jsii.String("signalCatalogArn"),

	// the properties below are optional
	description: jsii.String("description"),
	nodes: []*string{
		jsii.String("nodes"),
	},
	status: jsii.String("status"),
	tags: []cfnTag{
		&cfnTag{
			key: jsii.String("key"),
			value: jsii.String("value"),
		},
	},
})

func NewCfnModelManifest

func NewCfnModelManifest(scope awscdk.Construct, id *string, props *CfnModelManifestProps) CfnModelManifest

Create a new `AWS::IoTFleetWise::ModelManifest`.

type CfnModelManifestProps

type CfnModelManifestProps struct {
	// The name of the vehicle model.
	Name *string `field:"required" json:"name" yaml:"name"`
	// The ARN of the signal catalog associated with the vehicle model.
	SignalCatalogArn *string `field:"required" json:"signalCatalogArn" yaml:"signalCatalogArn"`
	// A brief description of the vehicle model.
	Description *string `field:"optional" json:"description" yaml:"description"`
	// `AWS::IoTFleetWise::ModelManifest.Nodes`.
	Nodes *[]*string `field:"optional" json:"nodes" yaml:"nodes"`
	// The state of the vehicle model.
	//
	// If the status is `ACTIVE` , the vehicle model can't be edited. If the status is `DRAFT` , you can edit the vehicle model.
	Status *string `field:"optional" json:"status" yaml:"status"`
	// `AWS::IoTFleetWise::ModelManifest.Tags`.
	Tags *[]*awscdk.CfnTag `field:"optional" json:"tags" yaml:"tags"`
}

Properties for defining a `CfnModelManifest`.

Example:

// The code below shows an example of how to instantiate this type.
// The values are placeholders you should change.
import "github.com/aws/aws-cdk-go/awscdk"

cfnModelManifestProps := &cfnModelManifestProps{
	name: jsii.String("name"),
	signalCatalogArn: jsii.String("signalCatalogArn"),

	// the properties below are optional
	description: jsii.String("description"),
	nodes: []*string{
		jsii.String("nodes"),
	},
	status: jsii.String("status"),
	tags: []cfnTag{
		&cfnTag{
			key: jsii.String("key"),
			value: jsii.String("value"),
		},
	},
}

type CfnSignalCatalog

type CfnSignalCatalog interface {
	awscdk.CfnResource
	awscdk.IInspectable
	AttrArn() *string
	AttrCreationTime() *string
	AttrLastModificationTime() *string
	AttrNodeCountsTotalActuators() awscdk.IResolvable
	AttrNodeCountsTotalAttributes() awscdk.IResolvable
	AttrNodeCountsTotalBranches() awscdk.IResolvable
	AttrNodeCountsTotalNodes() awscdk.IResolvable
	AttrNodeCountsTotalSensors() awscdk.IResolvable
	// Options for this resource, such as condition, update policy etc.
	// Experimental.
	CfnOptions() awscdk.ICfnResourceOptions
	CfnProperties() *map[string]interface{}
	// AWS resource type.
	// Experimental.
	CfnResourceType() *string
	// Returns: the stack trace of the point where this Resource was created from, sourced
	// from the +metadata+ entry typed +aws:cdk:logicalId+, and with the bottom-most
	// node +internal+ entries filtered.
	// Experimental.
	CreationStack() *[]*string
	// `AWS::IoTFleetWise::SignalCatalog.Description`.
	Description() *string
	SetDescription(val *string)
	// The logical ID for this CloudFormation stack element.
	//
	// The logical ID of the element
	// is calculated from the path of the resource node in the construct tree.
	//
	// To override this value, use `overrideLogicalId(newLogicalId)`.
	//
	// Returns: the logical ID as a stringified token. This value will only get
	// resolved during synthesis.
	// Experimental.
	LogicalId() *string
	// The name of the signal catalog.
	Name() *string
	SetName(val *string)
	// The construct tree node associated with this construct.
	// Experimental.
	Node() awscdk.ConstructNode
	// `AWS::IoTFleetWise::SignalCatalog.Nodes`.
	Nodes() interface{}
	SetNodes(val interface{})
	// Return a string that will be resolved to a CloudFormation `{ Ref }` for this element.
	//
	// If, by any chance, the intrinsic reference of a resource is not a string, you could
	// coerce it to an IResolvable through `Lazy.any({ produce: resource.ref })`.
	// Experimental.
	Ref() *string
	// The stack in which this element is defined.
	//
	// CfnElements must be defined within a stack scope (directly or indirectly).
	// Experimental.
	Stack() awscdk.Stack
	// `AWS::IoTFleetWise::SignalCatalog.Tags`.
	Tags() awscdk.TagManager
	// Return properties modified after initiation.
	//
	// Resources that expose mutable properties should override this function to
	// collect and return the properties object for this resource.
	// Experimental.
	UpdatedProperites() *map[string]interface{}
	// Syntactic sugar for `addOverride(path, undefined)`.
	// Experimental.
	AddDeletionOverride(path *string)
	// Indicates that this resource depends on another resource and cannot be provisioned unless the other resource has been successfully provisioned.
	//
	// This can be used for resources across stacks (or nested stack) boundaries
	// and the dependency will automatically be transferred to the relevant scope.
	// Experimental.
	AddDependsOn(target awscdk.CfnResource)
	// Add a value to the CloudFormation Resource Metadata.
	// See: https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/metadata-section-structure.html
	//
	// Note that this is a different set of metadata from CDK node metadata; this
	// metadata ends up in the stack template under the resource, whereas CDK
	// node metadata ends up in the Cloud Assembly.
	//
	// Experimental.
	AddMetadata(key *string, value interface{})
	// Adds an override to the synthesized CloudFormation resource.
	//
	// To add a
	// property override, either use `addPropertyOverride` or prefix `path` with
	// "Properties." (i.e. `Properties.TopicName`).
	//
	// If the override is nested, separate each nested level using a dot (.) in the path parameter.
	// If there is an array as part of the nesting, specify the index in the path.
	//
	// To include a literal `.` in the property name, prefix with a `\`. In most
	// programming languages you will need to write this as `"\\."` because the
	// `\` itself will need to be escaped.
	//
	// For example,
	// “`typescript
	// cfnResource.addOverride('Properties.GlobalSecondaryIndexes.0.Projection.NonKeyAttributes', ['myattribute']);
	// cfnResource.addOverride('Properties.GlobalSecondaryIndexes.1.ProjectionType', 'INCLUDE');
	// “`
	// would add the overrides
	// “`json
	// "Properties": {
	//    "GlobalSecondaryIndexes": [
	//      {
	//        "Projection": {
	//          "NonKeyAttributes": [ "myattribute" ]
	//          ...
	//        }
	//        ...
	//      },
	//      {
	//        "ProjectionType": "INCLUDE"
	//        ...
	//      },
	//    ]
	//    ...
	// }
	// “`
	//
	// The `value` argument to `addOverride` will not be processed or translated
	// in any way. Pass raw JSON values in here with the correct capitalization
	// for CloudFormation. If you pass CDK classes or structs, they will be
	// rendered with lowercased key names, and CloudFormation will reject the
	// template.
	// Experimental.
	AddOverride(path *string, value interface{})
	// Adds an override that deletes the value of a property from the resource definition.
	// Experimental.
	AddPropertyDeletionOverride(propertyPath *string)
	// Adds an override to a resource property.
	//
	// Syntactic sugar for `addOverride("Properties.<...>", value)`.
	// Experimental.
	AddPropertyOverride(propertyPath *string, value interface{})
	// Sets the deletion policy of the resource based on the removal policy specified.
	//
	// The Removal Policy controls what happens to this resource when it stops
	// being managed by CloudFormation, either because you've removed it from the
	// CDK application or because you've made a change that requires the resource
	// to be replaced.
	//
	// The resource can be deleted (`RemovalPolicy.DESTROY`), or left in your AWS
	// account for data recovery and cleanup later (`RemovalPolicy.RETAIN`).
	// Experimental.
	ApplyRemovalPolicy(policy awscdk.RemovalPolicy, options *awscdk.RemovalPolicyOptions)
	// Returns a token for an runtime attribute of this resource.
	//
	// Ideally, use generated attribute accessors (e.g. `resource.arn`), but this can be used for future compatibility
	// in case there is no generated attribute.
	// Experimental.
	GetAtt(attributeName *string) awscdk.Reference
	// Retrieve a value value from the CloudFormation Resource Metadata.
	// See: https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/metadata-section-structure.html
	//
	// Note that this is a different set of metadata from CDK node metadata; this
	// metadata ends up in the stack template under the resource, whereas CDK
	// node metadata ends up in the Cloud Assembly.
	//
	// Experimental.
	GetMetadata(key *string) interface{}
	// Examines the CloudFormation resource and discloses attributes.
	Inspect(inspector awscdk.TreeInspector)
	// Perform final modifications before synthesis.
	//
	// This method can be implemented by derived constructs in order to perform
	// final changes before synthesis. prepare() will be called after child
	// constructs have been prepared.
	//
	// This is an advanced framework feature. Only use this if you
	// understand the implications.
	// Experimental.
	OnPrepare()
	// Allows this construct to emit artifacts into the cloud assembly during synthesis.
	//
	// This method is usually implemented by framework-level constructs such as `Stack` and `Asset`
	// as they participate in synthesizing the cloud assembly.
	// Experimental.
	OnSynthesize(session constructs.ISynthesisSession)
	// Validate the current construct.
	//
	// This method can be implemented by derived constructs in order to perform
	// validation logic. It is called on all constructs before synthesis.
	//
	// Returns: An array of validation error messages, or an empty array if the construct is valid.
	// Experimental.
	OnValidate() *[]*string
	// Overrides the auto-generated logical ID with a specific ID.
	// Experimental.
	OverrideLogicalId(newLogicalId *string)
	// Perform final modifications before synthesis.
	//
	// This method can be implemented by derived constructs in order to perform
	// final changes before synthesis. prepare() will be called after child
	// constructs have been prepared.
	//
	// This is an advanced framework feature. Only use this if you
	// understand the implications.
	// Experimental.
	Prepare()
	RenderProperties(props *map[string]interface{}) *map[string]interface{}
	// Can be overridden by subclasses to determine if this resource will be rendered into the cloudformation template.
	//
	// Returns: `true` if the resource should be included or `false` is the resource
	// should be omitted.
	// Experimental.
	ShouldSynthesize() *bool
	// Allows this construct to emit artifacts into the cloud assembly during synthesis.
	//
	// This method is usually implemented by framework-level constructs such as `Stack` and `Asset`
	// as they participate in synthesizing the cloud assembly.
	// Experimental.
	Synthesize(session awscdk.ISynthesisSession)
	// Returns a string representation of this construct.
	//
	// Returns: a string representation of this resource.
	// Experimental.
	ToString() *string
	// Validate the current construct.
	//
	// This method can be implemented by derived constructs in order to perform
	// validation logic. It is called on all constructs before synthesis.
	//
	// Returns: An array of validation error messages, or an empty array if the construct is valid.
	// Experimental.
	Validate() *[]*string
	// Experimental.
	ValidateProperties(_properties interface{})
}

A CloudFormation `AWS::IoTFleetWise::SignalCatalog`.

Creates a collection of standardized signals that can be reused to create vehicle models.

Example:

// The code below shows an example of how to instantiate this type.
// The values are placeholders you should change.
import "github.com/aws/aws-cdk-go/awscdk"

cfnSignalCatalog := awscdk.Aws_iotfleetwise.NewCfnSignalCatalog(this, jsii.String("MyCfnSignalCatalog"), &cfnSignalCatalogProps{
	description: jsii.String("description"),
	name: jsii.String("name"),
	nodes: []interface{}{
		&nodeProperty{
			actuator: &actuatorProperty{
				dataType: jsii.String("dataType"),
				fullyQualifiedName: jsii.String("fullyQualifiedName"),

				// the properties below are optional
				allowedValues: []*string{
					jsii.String("allowedValues"),
				},
				assignedValue: jsii.String("assignedValue"),
				description: jsii.String("description"),
				max: jsii.Number(123),
				min: jsii.Number(123),
				unit: jsii.String("unit"),
			},
			attribute: &attributeProperty{
				dataType: jsii.String("dataType"),
				fullyQualifiedName: jsii.String("fullyQualifiedName"),

				// the properties below are optional
				allowedValues: []*string{
					jsii.String("allowedValues"),
				},
				assignedValue: jsii.String("assignedValue"),
				defaultValue: jsii.String("defaultValue"),
				description: jsii.String("description"),
				max: jsii.Number(123),
				min: jsii.Number(123),
				unit: jsii.String("unit"),
			},
			branch: &branchProperty{
				fullyQualifiedName: jsii.String("fullyQualifiedName"),

				// the properties below are optional
				description: jsii.String("description"),
			},
			sensor: &sensorProperty{
				dataType: jsii.String("dataType"),
				fullyQualifiedName: jsii.String("fullyQualifiedName"),

				// the properties below are optional
				allowedValues: []*string{
					jsii.String("allowedValues"),
				},
				description: jsii.String("description"),
				max: jsii.Number(123),
				min: jsii.Number(123),
				unit: jsii.String("unit"),
			},
		},
	},
	tags: []cfnTag{
		&cfnTag{
			key: jsii.String("key"),
			value: jsii.String("value"),
		},
	},
})

func NewCfnSignalCatalog

func NewCfnSignalCatalog(scope awscdk.Construct, id *string, props *CfnSignalCatalogProps) CfnSignalCatalog

Create a new `AWS::IoTFleetWise::SignalCatalog`.

type CfnSignalCatalogProps

type CfnSignalCatalogProps struct {
	// `AWS::IoTFleetWise::SignalCatalog.Description`.
	Description *string `field:"optional" json:"description" yaml:"description"`
	// The name of the signal catalog.
	Name *string `field:"optional" json:"name" yaml:"name"`
	// `AWS::IoTFleetWise::SignalCatalog.Nodes`.
	Nodes interface{} `field:"optional" json:"nodes" yaml:"nodes"`
	// `AWS::IoTFleetWise::SignalCatalog.Tags`.
	Tags *[]*awscdk.CfnTag `field:"optional" json:"tags" yaml:"tags"`
}

Properties for defining a `CfnSignalCatalog`.

Example:

// The code below shows an example of how to instantiate this type.
// The values are placeholders you should change.
import "github.com/aws/aws-cdk-go/awscdk"

cfnSignalCatalogProps := &cfnSignalCatalogProps{
	description: jsii.String("description"),
	name: jsii.String("name"),
	nodes: []interface{}{
		&nodeProperty{
			actuator: &actuatorProperty{
				dataType: jsii.String("dataType"),
				fullyQualifiedName: jsii.String("fullyQualifiedName"),

				// the properties below are optional
				allowedValues: []*string{
					jsii.String("allowedValues"),
				},
				assignedValue: jsii.String("assignedValue"),
				description: jsii.String("description"),
				max: jsii.Number(123),
				min: jsii.Number(123),
				unit: jsii.String("unit"),
			},
			attribute: &attributeProperty{
				dataType: jsii.String("dataType"),
				fullyQualifiedName: jsii.String("fullyQualifiedName"),

				// the properties below are optional
				allowedValues: []*string{
					jsii.String("allowedValues"),
				},
				assignedValue: jsii.String("assignedValue"),
				defaultValue: jsii.String("defaultValue"),
				description: jsii.String("description"),
				max: jsii.Number(123),
				min: jsii.Number(123),
				unit: jsii.String("unit"),
			},
			branch: &branchProperty{
				fullyQualifiedName: jsii.String("fullyQualifiedName"),

				// the properties below are optional
				description: jsii.String("description"),
			},
			sensor: &sensorProperty{
				dataType: jsii.String("dataType"),
				fullyQualifiedName: jsii.String("fullyQualifiedName"),

				// the properties below are optional
				allowedValues: []*string{
					jsii.String("allowedValues"),
				},
				description: jsii.String("description"),
				max: jsii.Number(123),
				min: jsii.Number(123),
				unit: jsii.String("unit"),
			},
		},
	},
	tags: []cfnTag{
		&cfnTag{
			key: jsii.String("key"),
			value: jsii.String("value"),
		},
	},
}

type CfnSignalCatalog_ActuatorProperty

type CfnSignalCatalog_ActuatorProperty struct {
	// The specified data type of the actuator.
	DataType *string `field:"required" json:"dataType" yaml:"dataType"`
	// The fully qualified name of the actuator.
	//
	// For example, the fully qualified name of an actuator might be `Vehicle.Front.Left.Door.Lock` .
	FullyQualifiedName *string `field:"required" json:"fullyQualifiedName" yaml:"fullyQualifiedName"`
	// A list of possible values an actuator can take.
	AllowedValues *[]*string `field:"optional" json:"allowedValues" yaml:"allowedValues"`
	// A specified value for the actuator.
	AssignedValue *string `field:"optional" json:"assignedValue" yaml:"assignedValue"`
	// A brief description of the actuator.
	Description *string `field:"optional" json:"description" yaml:"description"`
	// The specified possible maximum value of an actuator.
	Max *float64 `field:"optional" json:"max" yaml:"max"`
	// The specified possible minimum value of an actuator.
	Min *float64 `field:"optional" json:"min" yaml:"min"`
	// The scientific unit for the actuator.
	Unit *string `field:"optional" json:"unit" yaml:"unit"`
}

A signal that represents a vehicle device such as the engine, heater, and door locks.

Data from an actuator reports the state of a certain vehicle device.

> Updating actuator data can change the state of a device. For example, you can turn on or off the heater by updating its actuator data.

Example:

// The code below shows an example of how to instantiate this type.
// The values are placeholders you should change.
import "github.com/aws/aws-cdk-go/awscdk"

actuatorProperty := &actuatorProperty{
	dataType: jsii.String("dataType"),
	fullyQualifiedName: jsii.String("fullyQualifiedName"),

	// the properties below are optional
	allowedValues: []*string{
		jsii.String("allowedValues"),
	},
	assignedValue: jsii.String("assignedValue"),
	description: jsii.String("description"),
	max: jsii.Number(123),
	min: jsii.Number(123),
	unit: jsii.String("unit"),
}

type CfnSignalCatalog_AttributeProperty

type CfnSignalCatalog_AttributeProperty struct {
	// The specified data type of the attribute.
	DataType *string `field:"required" json:"dataType" yaml:"dataType"`
	// The fully qualified name of the attribute.
	//
	// For example, the fully qualified name of an attribute might be `Vehicle.Body.Engine.Type` .
	FullyQualifiedName *string `field:"required" json:"fullyQualifiedName" yaml:"fullyQualifiedName"`
	// A list of possible values an attribute can be assigned.
	AllowedValues *[]*string `field:"optional" json:"allowedValues" yaml:"allowedValues"`
	// A specified value for the attribute.
	AssignedValue *string `field:"optional" json:"assignedValue" yaml:"assignedValue"`
	// The default value of the attribute.
	DefaultValue *string `field:"optional" json:"defaultValue" yaml:"defaultValue"`
	// A brief description of the attribute.
	Description *string `field:"optional" json:"description" yaml:"description"`
	// The specified possible maximum value of the attribute.
	Max *float64 `field:"optional" json:"max" yaml:"max"`
	// The specified possible minimum value of the attribute.
	Min *float64 `field:"optional" json:"min" yaml:"min"`
	// The scientific unit for the attribute.
	Unit *string `field:"optional" json:"unit" yaml:"unit"`
}

A signal that represents static information about the vehicle, such as engine type or manufacturing date.

Example:

// The code below shows an example of how to instantiate this type.
// The values are placeholders you should change.
import "github.com/aws/aws-cdk-go/awscdk"

attributeProperty := &attributeProperty{
	dataType: jsii.String("dataType"),
	fullyQualifiedName: jsii.String("fullyQualifiedName"),

	// the properties below are optional
	allowedValues: []*string{
		jsii.String("allowedValues"),
	},
	assignedValue: jsii.String("assignedValue"),
	defaultValue: jsii.String("defaultValue"),
	description: jsii.String("description"),
	max: jsii.Number(123),
	min: jsii.Number(123),
	unit: jsii.String("unit"),
}

type CfnSignalCatalog_BranchProperty

type CfnSignalCatalog_BranchProperty struct {
	// The fully qualified name of the branch.
	//
	// For example, the fully qualified name of a branch might be `Vehicle.Body.Engine` .
	FullyQualifiedName *string `field:"required" json:"fullyQualifiedName" yaml:"fullyQualifiedName"`
	// A brief description of the branch.
	Description *string `field:"optional" json:"description" yaml:"description"`
}

A group of signals that are defined in a hierarchical structure.

Example:

// The code below shows an example of how to instantiate this type.
// The values are placeholders you should change.
import "github.com/aws/aws-cdk-go/awscdk"

branchProperty := &branchProperty{
	fullyQualifiedName: jsii.String("fullyQualifiedName"),

	// the properties below are optional
	description: jsii.String("description"),
}

type CfnSignalCatalog_NodeCountsProperty

type CfnSignalCatalog_NodeCountsProperty struct {
	// The total number of nodes in a vehicle network that represent actuators.
	TotalActuators *float64 `field:"optional" json:"totalActuators" yaml:"totalActuators"`
	// The total number of nodes in a vehicle network that represent attributes.
	TotalAttributes *float64 `field:"optional" json:"totalAttributes" yaml:"totalAttributes"`
	// The total number of nodes in a vehicle network that represent branches.
	TotalBranches *float64 `field:"optional" json:"totalBranches" yaml:"totalBranches"`
	// The total number of nodes in a vehicle network.
	TotalNodes *float64 `field:"optional" json:"totalNodes" yaml:"totalNodes"`
	// The total number of nodes in a vehicle network that represent sensors.
	TotalSensors *float64 `field:"optional" json:"totalSensors" yaml:"totalSensors"`
}

Information about the number of nodes and node types in a vehicle network.

Example:

// The code below shows an example of how to instantiate this type.
// The values are placeholders you should change.
import "github.com/aws/aws-cdk-go/awscdk"

nodeCountsProperty := &nodeCountsProperty{
	totalActuators: jsii.Number(123),
	totalAttributes: jsii.Number(123),
	totalBranches: jsii.Number(123),
	totalNodes: jsii.Number(123),
	totalSensors: jsii.Number(123),
}

type CfnSignalCatalog_NodeProperty

type CfnSignalCatalog_NodeProperty struct {
	// Information about a node specified as an actuator.
	//
	// > An actuator is a digital representation of a vehicle device.
	Actuator interface{} `field:"optional" json:"actuator" yaml:"actuator"`
	// Information about a node specified as an attribute.
	//
	// > An attribute represents static information about a vehicle.
	Attribute interface{} `field:"optional" json:"attribute" yaml:"attribute"`
	// Information about a node specified as a branch.
	//
	// > A group of signals that are defined in a hierarchical structure.
	Branch interface{} `field:"optional" json:"branch" yaml:"branch"`
	// `CfnSignalCatalog.NodeProperty.Sensor`.
	Sensor interface{} `field:"optional" json:"sensor" yaml:"sensor"`
}

A general abstraction of a signal.

A node can be specified as an actuator, attribute, branch, or sensor.

Example:

// The code below shows an example of how to instantiate this type.
// The values are placeholders you should change.
import "github.com/aws/aws-cdk-go/awscdk"

nodeProperty := &nodeProperty{
	actuator: &actuatorProperty{
		dataType: jsii.String("dataType"),
		fullyQualifiedName: jsii.String("fullyQualifiedName"),

		// the properties below are optional
		allowedValues: []*string{
			jsii.String("allowedValues"),
		},
		assignedValue: jsii.String("assignedValue"),
		description: jsii.String("description"),
		max: jsii.Number(123),
		min: jsii.Number(123),
		unit: jsii.String("unit"),
	},
	attribute: &attributeProperty{
		dataType: jsii.String("dataType"),
		fullyQualifiedName: jsii.String("fullyQualifiedName"),

		// the properties below are optional
		allowedValues: []*string{
			jsii.String("allowedValues"),
		},
		assignedValue: jsii.String("assignedValue"),
		defaultValue: jsii.String("defaultValue"),
		description: jsii.String("description"),
		max: jsii.Number(123),
		min: jsii.Number(123),
		unit: jsii.String("unit"),
	},
	branch: &branchProperty{
		fullyQualifiedName: jsii.String("fullyQualifiedName"),

		// the properties below are optional
		description: jsii.String("description"),
	},
	sensor: &sensorProperty{
		dataType: jsii.String("dataType"),
		fullyQualifiedName: jsii.String("fullyQualifiedName"),

		// the properties below are optional
		allowedValues: []*string{
			jsii.String("allowedValues"),
		},
		description: jsii.String("description"),
		max: jsii.Number(123),
		min: jsii.Number(123),
		unit: jsii.String("unit"),
	},
}

type CfnSignalCatalog_SensorProperty

type CfnSignalCatalog_SensorProperty struct {
	// The specified data type of the sensor.
	DataType *string `field:"required" json:"dataType" yaml:"dataType"`
	// The fully qualified name of the sensor.
	//
	// For example, the fully qualified name of a sensor might be `Vehicle.Body.Engine.Battery` .
	FullyQualifiedName *string `field:"required" json:"fullyQualifiedName" yaml:"fullyQualifiedName"`
	// A list of possible values a sensor can take.
	AllowedValues *[]*string `field:"optional" json:"allowedValues" yaml:"allowedValues"`
	// A brief description of a sensor.
	Description *string `field:"optional" json:"description" yaml:"description"`
	// The specified possible maximum value of the sensor.
	Max *float64 `field:"optional" json:"max" yaml:"max"`
	// The specified possible minimum value of the sensor.
	Min *float64 `field:"optional" json:"min" yaml:"min"`
	// The scientific unit of measurement for data collected by the sensor.
	Unit *string `field:"optional" json:"unit" yaml:"unit"`
}

An input component that reports the environmental condition of a vehicle.

> You can collect data about fluid levels, temperatures, vibrations, or battery voltage from sensors.

Example:

// The code below shows an example of how to instantiate this type.
// The values are placeholders you should change.
import "github.com/aws/aws-cdk-go/awscdk"

sensorProperty := &sensorProperty{
	dataType: jsii.String("dataType"),
	fullyQualifiedName: jsii.String("fullyQualifiedName"),

	// the properties below are optional
	allowedValues: []*string{
		jsii.String("allowedValues"),
	},
	description: jsii.String("description"),
	max: jsii.Number(123),
	min: jsii.Number(123),
	unit: jsii.String("unit"),
}

type CfnVehicle

type CfnVehicle interface {
	awscdk.CfnResource
	awscdk.IInspectable
	// An option to create a new AWS IoT thing when creating a vehicle, or to validate an existing thing as a vehicle.
	AssociationBehavior() *string
	SetAssociationBehavior(val *string)
	AttrArn() *string
	AttrCreationTime() *string
	// Static information about a vehicle in a key-value pair.
	//
	// For example: `"engine Type"` : `"v6"`.
	Attributes() interface{}
	SetAttributes(val interface{})
	AttrLastModificationTime() *string
	// Options for this resource, such as condition, update policy etc.
	// Experimental.
	CfnOptions() awscdk.ICfnResourceOptions
	CfnProperties() *map[string]interface{}
	// AWS resource type.
	// Experimental.
	CfnResourceType() *string
	// Returns: the stack trace of the point where this Resource was created from, sourced
	// from the +metadata+ entry typed +aws:cdk:logicalId+, and with the bottom-most
	// node +internal+ entries filtered.
	// Experimental.
	CreationStack() *[]*string
	// The Amazon Resource Name (ARN) of a decoder manifest associated with the vehicle to create.
	DecoderManifestArn() *string
	SetDecoderManifestArn(val *string)
	// The logical ID for this CloudFormation stack element.
	//
	// The logical ID of the element
	// is calculated from the path of the resource node in the construct tree.
	//
	// To override this value, use `overrideLogicalId(newLogicalId)`.
	//
	// Returns: the logical ID as a stringified token. This value will only get
	// resolved during synthesis.
	// Experimental.
	LogicalId() *string
	// The ARN of the vehicle model (model manifest) to create the vehicle from.
	ModelManifestArn() *string
	SetModelManifestArn(val *string)
	// `AWS::IoTFleetWise::Vehicle.Name`.
	Name() *string
	SetName(val *string)
	// The construct tree node associated with this construct.
	// Experimental.
	Node() awscdk.ConstructNode
	// Return a string that will be resolved to a CloudFormation `{ Ref }` for this element.
	//
	// If, by any chance, the intrinsic reference of a resource is not a string, you could
	// coerce it to an IResolvable through `Lazy.any({ produce: resource.ref })`.
	// Experimental.
	Ref() *string
	// The stack in which this element is defined.
	//
	// CfnElements must be defined within a stack scope (directly or indirectly).
	// Experimental.
	Stack() awscdk.Stack
	// Metadata which can be used to manage the vehicle.
	Tags() awscdk.TagManager
	// Return properties modified after initiation.
	//
	// Resources that expose mutable properties should override this function to
	// collect and return the properties object for this resource.
	// Experimental.
	UpdatedProperites() *map[string]interface{}
	// Syntactic sugar for `addOverride(path, undefined)`.
	// Experimental.
	AddDeletionOverride(path *string)
	// Indicates that this resource depends on another resource and cannot be provisioned unless the other resource has been successfully provisioned.
	//
	// This can be used for resources across stacks (or nested stack) boundaries
	// and the dependency will automatically be transferred to the relevant scope.
	// Experimental.
	AddDependsOn(target awscdk.CfnResource)
	// Add a value to the CloudFormation Resource Metadata.
	// See: https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/metadata-section-structure.html
	//
	// Note that this is a different set of metadata from CDK node metadata; this
	// metadata ends up in the stack template under the resource, whereas CDK
	// node metadata ends up in the Cloud Assembly.
	//
	// Experimental.
	AddMetadata(key *string, value interface{})
	// Adds an override to the synthesized CloudFormation resource.
	//
	// To add a
	// property override, either use `addPropertyOverride` or prefix `path` with
	// "Properties." (i.e. `Properties.TopicName`).
	//
	// If the override is nested, separate each nested level using a dot (.) in the path parameter.
	// If there is an array as part of the nesting, specify the index in the path.
	//
	// To include a literal `.` in the property name, prefix with a `\`. In most
	// programming languages you will need to write this as `"\\."` because the
	// `\` itself will need to be escaped.
	//
	// For example,
	// “`typescript
	// cfnResource.addOverride('Properties.GlobalSecondaryIndexes.0.Projection.NonKeyAttributes', ['myattribute']);
	// cfnResource.addOverride('Properties.GlobalSecondaryIndexes.1.ProjectionType', 'INCLUDE');
	// “`
	// would add the overrides
	// “`json
	// "Properties": {
	//    "GlobalSecondaryIndexes": [
	//      {
	//        "Projection": {
	//          "NonKeyAttributes": [ "myattribute" ]
	//          ...
	//        }
	//        ...
	//      },
	//      {
	//        "ProjectionType": "INCLUDE"
	//        ...
	//      },
	//    ]
	//    ...
	// }
	// “`
	//
	// The `value` argument to `addOverride` will not be processed or translated
	// in any way. Pass raw JSON values in here with the correct capitalization
	// for CloudFormation. If you pass CDK classes or structs, they will be
	// rendered with lowercased key names, and CloudFormation will reject the
	// template.
	// Experimental.
	AddOverride(path *string, value interface{})
	// Adds an override that deletes the value of a property from the resource definition.
	// Experimental.
	AddPropertyDeletionOverride(propertyPath *string)
	// Adds an override to a resource property.
	//
	// Syntactic sugar for `addOverride("Properties.<...>", value)`.
	// Experimental.
	AddPropertyOverride(propertyPath *string, value interface{})
	// Sets the deletion policy of the resource based on the removal policy specified.
	//
	// The Removal Policy controls what happens to this resource when it stops
	// being managed by CloudFormation, either because you've removed it from the
	// CDK application or because you've made a change that requires the resource
	// to be replaced.
	//
	// The resource can be deleted (`RemovalPolicy.DESTROY`), or left in your AWS
	// account for data recovery and cleanup later (`RemovalPolicy.RETAIN`).
	// Experimental.
	ApplyRemovalPolicy(policy awscdk.RemovalPolicy, options *awscdk.RemovalPolicyOptions)
	// Returns a token for an runtime attribute of this resource.
	//
	// Ideally, use generated attribute accessors (e.g. `resource.arn`), but this can be used for future compatibility
	// in case there is no generated attribute.
	// Experimental.
	GetAtt(attributeName *string) awscdk.Reference
	// Retrieve a value value from the CloudFormation Resource Metadata.
	// See: https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/metadata-section-structure.html
	//
	// Note that this is a different set of metadata from CDK node metadata; this
	// metadata ends up in the stack template under the resource, whereas CDK
	// node metadata ends up in the Cloud Assembly.
	//
	// Experimental.
	GetMetadata(key *string) interface{}
	// Examines the CloudFormation resource and discloses attributes.
	Inspect(inspector awscdk.TreeInspector)
	// Perform final modifications before synthesis.
	//
	// This method can be implemented by derived constructs in order to perform
	// final changes before synthesis. prepare() will be called after child
	// constructs have been prepared.
	//
	// This is an advanced framework feature. Only use this if you
	// understand the implications.
	// Experimental.
	OnPrepare()
	// Allows this construct to emit artifacts into the cloud assembly during synthesis.
	//
	// This method is usually implemented by framework-level constructs such as `Stack` and `Asset`
	// as they participate in synthesizing the cloud assembly.
	// Experimental.
	OnSynthesize(session constructs.ISynthesisSession)
	// Validate the current construct.
	//
	// This method can be implemented by derived constructs in order to perform
	// validation logic. It is called on all constructs before synthesis.
	//
	// Returns: An array of validation error messages, or an empty array if the construct is valid.
	// Experimental.
	OnValidate() *[]*string
	// Overrides the auto-generated logical ID with a specific ID.
	// Experimental.
	OverrideLogicalId(newLogicalId *string)
	// Perform final modifications before synthesis.
	//
	// This method can be implemented by derived constructs in order to perform
	// final changes before synthesis. prepare() will be called after child
	// constructs have been prepared.
	//
	// This is an advanced framework feature. Only use this if you
	// understand the implications.
	// Experimental.
	Prepare()
	RenderProperties(props *map[string]interface{}) *map[string]interface{}
	// Can be overridden by subclasses to determine if this resource will be rendered into the cloudformation template.
	//
	// Returns: `true` if the resource should be included or `false` is the resource
	// should be omitted.
	// Experimental.
	ShouldSynthesize() *bool
	// Allows this construct to emit artifacts into the cloud assembly during synthesis.
	//
	// This method is usually implemented by framework-level constructs such as `Stack` and `Asset`
	// as they participate in synthesizing the cloud assembly.
	// Experimental.
	Synthesize(session awscdk.ISynthesisSession)
	// Returns a string representation of this construct.
	//
	// Returns: a string representation of this resource.
	// Experimental.
	ToString() *string
	// Validate the current construct.
	//
	// This method can be implemented by derived constructs in order to perform
	// validation logic. It is called on all constructs before synthesis.
	//
	// Returns: An array of validation error messages, or an empty array if the construct is valid.
	// Experimental.
	Validate() *[]*string
	// Experimental.
	ValidateProperties(_properties interface{})
}

A CloudFormation `AWS::IoTFleetWise::Vehicle`.

Creates a vehicle, which is an instance of a vehicle model (model manifest). Vehicles created from the same vehicle model consist of the same signals inherited from the vehicle model.

> If you have an existing AWS IoT Thing, you can use AWS IoT FleetWise to create a vehicle and collect data from your thing.

For more information, see [Create a vehicle (CLI)](https://docs.aws.amazon.com/iot-fleetwise/latest/developerguide/create-vehicle-cli.html) in the *AWS IoT FleetWise Developer Guide* .

Example:

// The code below shows an example of how to instantiate this type.
// The values are placeholders you should change.
import "github.com/aws/aws-cdk-go/awscdk"

cfnVehicle := awscdk.Aws_iotfleetwise.NewCfnVehicle(this, jsii.String("MyCfnVehicle"), &cfnVehicleProps{
	decoderManifestArn: jsii.String("decoderManifestArn"),
	modelManifestArn: jsii.String("modelManifestArn"),
	name: jsii.String("name"),

	// the properties below are optional
	associationBehavior: jsii.String("associationBehavior"),
	attributes: map[string]*string{
		"attributesKey": jsii.String("attributes"),
	},
	tags: []cfnTag{
		&cfnTag{
			key: jsii.String("key"),
			value: jsii.String("value"),
		},
	},
})

func NewCfnVehicle

func NewCfnVehicle(scope awscdk.Construct, id *string, props *CfnVehicleProps) CfnVehicle

Create a new `AWS::IoTFleetWise::Vehicle`.

type CfnVehicleProps

type CfnVehicleProps struct {
	// The Amazon Resource Name (ARN) of a decoder manifest associated with the vehicle to create.
	DecoderManifestArn *string `field:"required" json:"decoderManifestArn" yaml:"decoderManifestArn"`
	// The ARN of the vehicle model (model manifest) to create the vehicle from.
	ModelManifestArn *string `field:"required" json:"modelManifestArn" yaml:"modelManifestArn"`
	// `AWS::IoTFleetWise::Vehicle.Name`.
	Name *string `field:"required" json:"name" yaml:"name"`
	// An option to create a new AWS IoT thing when creating a vehicle, or to validate an existing thing as a vehicle.
	AssociationBehavior *string `field:"optional" json:"associationBehavior" yaml:"associationBehavior"`
	// Static information about a vehicle in a key-value pair.
	//
	// For example: `"engine Type"` : `"v6"`.
	Attributes interface{} `field:"optional" json:"attributes" yaml:"attributes"`
	// Metadata which can be used to manage the vehicle.
	Tags *[]*awscdk.CfnTag `field:"optional" json:"tags" yaml:"tags"`
}

Properties for defining a `CfnVehicle`.

Example:

// The code below shows an example of how to instantiate this type.
// The values are placeholders you should change.
import "github.com/aws/aws-cdk-go/awscdk"

cfnVehicleProps := &cfnVehicleProps{
	decoderManifestArn: jsii.String("decoderManifestArn"),
	modelManifestArn: jsii.String("modelManifestArn"),
	name: jsii.String("name"),

	// the properties below are optional
	associationBehavior: jsii.String("associationBehavior"),
	attributes: map[string]*string{
		"attributesKey": jsii.String("attributes"),
	},
	tags: []cfnTag{
		&cfnTag{
			key: jsii.String("key"),
			value: jsii.String("value"),
		},
	},
}

Source Files

Directories

Path Synopsis

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL