Skip to content

A tool to migrate Items, Catalogs and Collections from old versions to the most recent one.

License

Notifications You must be signed in to change notification settings

stac-utils/stac-migrate

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

53 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

stac-migrate

A library to update STAC files to the latest version (1.1.0 at the moment of writing). Supports updating STAC versions 0.6.0 and later.

Version of this library: 2.0.1

Usage

JavaScript / Node

Add to your project with npm install @radiantearth/stac-migrate --save

Import the library: const Migrate = require('@radiantearth/stac-migrate');

  • Migrate (auto-detection): Migrate.stac(stac: object, updateVersionNumber: boolean = true) => object
    This method does not migrate the Commons extension - use Migrate.item if you have used the Commons extension.

  • Migrate a STAC Collection: Migrate.collection(collection: object, updateVersionNumber: boolean = true) => object

  • Migrate a STAC Catalog: Migrate.catalog(catalog: object, updateVersionNumber: boolean = true) => object

  • Migrate a STAC Item: Migrate.item(item: object, collection: object = null, updateVersionNumber: boolean = true) => object

    The collection parameter is only required to migrate the Commons extension. Otherwise, you don't need to pass this paramater.

  • Migrate a STAC CollectionCollection: Migrate.collectionCollection(apiCollections: object, updateVersionNumber: boolean = true) => object

  • Migrate a STAC ItemCollection: Migrate.itemCollection(apiItems: object, updateVersionNumber: boolean = true) => object

Note: All changes will be applied in-place! If you don't want the input object to change, make a deep clone before. If you don't have a library which supports this (e.g. lodash) you can simply use var clone = JSON.parse(JSON.stringify(object));.

CLI

You can also use the CLI to migrate a single file. The commands follow the different methods above and has the same "restrictions" as above.

  • Migrate (auto-detection, override): npx stac-migrate <source_path>
  • Migrate (auto-detection, save to a different file with 4 spaces indentation): npx stac-migrate <source_path> --dest <dest_path> --indent 4
  • Migrate a STAC Collection: npx stac-migrate <source_path> <dest_path> --collection
  • Migrate a STAC Catalog: npx stac-migrate <source_path> <dest_path> --catalog
  • Migrate a STAC Item: npx stac-migrate <source_path> <dest_path> --item --collection_path <collection_path>
  • Migrate a STAC Item Collection: npx stac-migrate <source_path> <dest_path> --item_collection
  • Migrate a STAC Collection Collection: npx stac-migrate <source_path> <dest_path> --collecions

Supported Extensions

  • Checksum (legacy, use Migrate.enableMultihash(require('multihashes')) to enable conversion from pre-0.9 checksums - disabled by default to keep the bundle size low)
  • Classification 2.0.0
  • Collection Assets (legacy)
  • Commons (legacy)
  • Data Cube 2.2.0
  • Datetime Range (legacy)
  • Electro-Optical 2.0.0
  • File 2.1.0 (and 1.0.0 for nodata)
  • Item Asset Definition 1.0.0 (legacy)
  • Label 1.0.1
  • Point Cloud 1.0.0
  • Processing 1.2.0
  • Projection 2.0.0
  • Raster 2.0.0
  • SAR 1.0.0
  • Satellite 1.0.0
  • Scientific Citation 1.0.0
  • Single Item
  • Table 1.2.0
  • Timestamps 1.1.0
  • Versioning Indicators 1.2.0
  • View Geometry 1.0.0

Development

Run the tests: npm test

About

A tool to migrate Items, Catalogs and Collections from old versions to the most recent one.

Resources

License

Stars

Watchers

Forks

Packages

No packages published