Elastacloud.TwinMigration 0.0.0.1

There is a newer version of this package available.
See the version list below for details.
dotnet tool install --global Elastacloud.TwinMigration --version 0.0.0.1                
This package contains a .NET tool you can call from the shell/command line.
dotnet new tool-manifest # if you are setting up this repo
dotnet tool install --local Elastacloud.TwinMigration --version 0.0.0.1                
This package contains a .NET tool you can call from the shell/command line.
#tool dotnet:?package=Elastacloud.TwinMigration&version=0.0.0.1                
nuke :add-package Elastacloud.TwinMigration --version 0.0.0.1                

Introduction

An SDK wrapper around Azure Digital Twins SDK that provides additional best practices around versioning, query helpers, fluent access to creation.

Versioning

Digital Twin instances are typed. These types are described by DTDL models which can be versioned. You should keep your DTDL in JSON files, git control them and then target a deployment in an automated way.

The main challenges facing us with Versioning are:

  • How do we keep digital twin instance matching the desired version of the DTDL model?
    • We may want migrate digital twin instances to new versions of DTDL models over time or there may be a migration process, such as adding a value for a new property
  • When working with digital twin instances in client code (e.g. C#) how do we map the digital twin instance to the appropriate POCO? (Or, perhaps, is there one POCO that subsumes all versions?)

This repo provides a dotnet tool, a Global Tool to assist in the validation and deployment of Azure Digital Twin models. It has multiple modes, as described below.

Installation

dotnet tool install twinmigration

Validation

Purpose: To generate Markdown compatible tables of DTDL compliance between a source input path and a target ADT.

You can execute it in a number of ways:

  1. Source Input Files to Target ADT - allows you to ask "what is deployed that is different to my local DTML?"
  2. Source Input Files to Target Input Files - allows you to ask "what is different two sets of DTDL files held locally?"
  3. Source ADT to Target ADT - allows you to ask "what is deployed differently between these ADT instances?"
  4. Source ADT to Target Input Files - allows you to ask "what is different from the deployment to my local DTML?"

Usage

twinmigration validate --source-input-path C:\DTDL\Latest --target-twin-instance https://[myTwinInstance].api.weu.digitaltwins.azure.net

Example Output

ModelValidated Success Message
dtmi:digitaltwins:rec_3_3:core:Agent;2 False The model dtmi:digitaltwins:rec_3_3:core:Agent;2 isn't in the target environment
dtmi:digitaltwins:rec_3_3:core:Asset;1 False The model dtmi:digitaltwins:rec_3_3:core:Asset;1 isn't in the target environment
dtmi:digitaltwins:rec_3_3:core:BuildingComponent;1 False The model dtmi:digitaltwins:rec_3_3:core:BuildingComponent;1 isn't in the target environment

Deployment

twinmigration deploy --source-input-path C:\DTDL\Latest --target-twin-instance https://[myTwinInstance].api.weu.digitaltwins.azure.net

This will take all the Models defined in the --source-input-path and apply them to the target instance.

Available flags:

  • -f --force will skip local validation code and attempt the full deployment
  • -c --strict will cause local validation to fail if there is a version update that skips a version, for example from dtmi:elastacloud:code;1 to dtmi:elastacloud:code;3.

Decommission

twinmigration decommission --target-twin-instance https://[myTwinInstance].api.weu.digitaltwins.azure.net

This will take all the Models defined in the target Azure Digital Twin and will decommission it, if there is a later version of the model available. This means we can deploy new models, have runtime code still able to target old models while the runtime code is being updated, and then have the old models decommissioned when the runtime code has been replaced.

Available Flags:

  • -o --tolerance default 1, controls how many versions out of date a model must be before it is selected for decommissioning. For instance if dtmi:elastacloud:code;4 exists and running with tolerance of 2 will decommission dtmi:elastacloud:code;1 and dtmi:elastacloud:code;2

Query Helpers

This repo provides a dotnet package to assist in the runtime management of these versions, to provide a POCO for acting as a container for the instance data, and validating POCOs against deployed DTDL instances.

Product Compatible and additional computed target framework versions.
.NET net5.0 is compatible.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

This package has no dependencies.

Version Downloads Last updated
3.1.8 124 4/26/2024
3.1.7 205 2/5/2024
3.1.6 182 2/1/2024
3.1.5 198 1/31/2024
3.1.4 196 6/12/2023
3.1.2 347 11/22/2022
3.1.1 346 10/5/2022
3.0.12 443 7/28/2022
3.0.11 428 7/20/2022
3.0.10 458 6/10/2022
3.0.9 450 6/9/2022
3.0.8 454 4/28/2022
3.0.7 437 4/27/2022
3.0.6 446 4/26/2022
3.0.5 477 4/21/2022
3.0.4 435 4/14/2022
3.0.3 458 4/14/2022
3.0.2 453 4/14/2022
2.0.15 462 3/25/2022
2.0.14 447 3/21/2022
2.0.13 468 2/24/2022
2.0.12 454 2/14/2022
2.0.11 445 2/3/2022
2.0.1 298 1/5/2022
1.0.61 319 11/16/2021
1.0.60 403 11/9/2021
1.0.59 366 11/4/2021
1.0.58 356 10/29/2021
1.0.57 345 10/27/2021
1.0.56 461 9/27/2021
1.0.55 388 9/7/2021
1.0.54 399 7/29/2021
1.0.53 381 7/29/2021
1.0.52 372 7/28/2021
1.0.51 339 7/6/2021
1.0.50 434 7/1/2021
1.0.49 394 7/1/2021
1.0.48 374 6/28/2021
1.0.47 338 5/5/2021
1.0.46 347 5/5/2021
1.0.45 363 5/4/2021
1.0.44 350 5/4/2021
1.0.43 370 4/26/2021
1.0.42 391 4/23/2021
1.0.41 375 4/23/2021
1.0.40 368 4/23/2021
1.0.39 350 4/23/2021
1.0.38 343 4/23/2021
1.0.37 358 4/23/2021
1.0.36 373 4/23/2021
1.0.33 372 4/21/2021
1.0.32 335 4/21/2021
1.0.31 351 4/21/2021
1.0.30 403 4/19/2021
1.0.29 395 4/19/2021
1.0.28 378 4/16/2021
1.0.27 409 4/16/2021
1.0.25 379 4/15/2021
1.0.24 396 4/14/2021
1.0.23 401 4/14/2021
1.0.22 364 4/14/2021
1.0.21 352 4/14/2021
1.0.20 360 4/13/2021
1.0.17 357 4/12/2021
1.0.16 360 4/12/2021
1.0.15 402 4/10/2021
1.0.14 365 4/10/2021
1.0.13 390 4/9/2021
1.0.12 359 4/9/2021
0.0.1 432 4/9/2021
0.0.0.1 394 4/9/2021