@basemaps/cli 6.27.0 → 6.29.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (90) hide show
  1. package/CHANGELOG.md +40 -0
  2. package/README.md +46 -13
  3. package/build/cli/base.cli.d.ts +0 -18
  4. package/build/cli/base.cli.d.ts.map +1 -1
  5. package/build/cli/base.cli.js +1 -60
  6. package/build/cli/bin.d.ts +2 -0
  7. package/build/cli/bin.d.ts.map +1 -0
  8. package/build/cli/bin.js +3 -0
  9. package/build/cli/cogify/{__test__ → __tests__}/batch.job.test.d.ts +0 -0
  10. package/build/cli/cogify/__tests__/batch.job.test.d.ts.map +1 -0
  11. package/build/cli/cogify/{__test__ → __tests__}/batch.job.test.js +48 -22
  12. package/build/cli/cogify/{__test__ → __tests__}/semver.test.d.ts +0 -0
  13. package/build/cli/cogify/__tests__/semver.test.d.ts.map +1 -0
  14. package/build/cli/cogify/{__test__ → __tests__}/semver.test.js +0 -0
  15. package/build/cli/cogify/action.cog.d.ts +2 -1
  16. package/build/cli/cogify/action.cog.d.ts.map +1 -1
  17. package/build/cli/cogify/action.cog.js +50 -43
  18. package/build/cli/cogify/action.job.d.ts +1 -1
  19. package/build/cli/cogify/action.job.d.ts.map +1 -1
  20. package/build/cli/cogify/action.job.js +2 -2
  21. package/build/cli/cogify/batch.job.d.ts +6 -4
  22. package/build/cli/cogify/batch.job.d.ts.map +1 -1
  23. package/build/cli/cogify/batch.job.js +63 -49
  24. package/build/cli/cogify/imagery.config.d.ts.map +1 -1
  25. package/build/cli/cogify/imagery.config.js +0 -2
  26. package/build/cli/config/action.bundle.d.ts +11 -0
  27. package/build/cli/config/action.bundle.d.ts.map +1 -0
  28. package/build/cli/config/action.bundle.js +36 -0
  29. package/build/cli/config/action.import.d.ts +14 -0
  30. package/build/cli/config/action.import.d.ts.map +1 -0
  31. package/build/cli/config/action.import.js +80 -0
  32. package/build/cli/config/config.diff.d.ts +10 -0
  33. package/build/cli/config/config.diff.d.ts.map +1 -0
  34. package/build/cli/config/config.diff.js +47 -0
  35. package/build/cli/config/config.update.d.ts +23 -0
  36. package/build/cli/config/config.update.d.ts.map +1 -0
  37. package/build/cli/config/config.update.js +71 -0
  38. package/build/cli/index.d.ts +7 -0
  39. package/build/cli/index.d.ts.map +1 -0
  40. package/build/cli/index.js +21 -0
  41. package/build/cli/screenshot/action.screenshot.d.ts +61 -0
  42. package/build/cli/screenshot/action.screenshot.d.ts.map +1 -0
  43. package/build/cli/screenshot/action.screenshot.js +121 -0
  44. package/build/cli/util.js +1 -1
  45. package/build/cog/{__test__ → __tests__}/builder.test.d.ts +0 -0
  46. package/build/cog/__tests__/builder.test.d.ts.map +1 -0
  47. package/build/cog/{__test__ → __tests__}/builder.test.js +0 -0
  48. package/build/cog/{__test__ → __tests__}/cog.stac.job.test.d.ts +0 -0
  49. package/build/cog/__tests__/cog.stac.job.test.d.ts.map +1 -0
  50. package/build/cog/{__test__ → __tests__}/cog.stac.job.test.js +1 -1
  51. package/build/cog/{__test__ → __tests__}/cog.test.d.ts +0 -0
  52. package/build/cog/__tests__/cog.test.d.ts.map +1 -0
  53. package/build/cog/{__test__ → __tests__}/cog.test.js +0 -0
  54. package/build/cog/{__test__ → __tests__}/cog.vrt.test.d.ts +0 -0
  55. package/build/cog/__tests__/cog.vrt.test.d.ts.map +1 -0
  56. package/build/cog/{__test__ → __tests__}/cog.vrt.test.js +1 -1
  57. package/build/cog/{__test__ → __tests__}/cutline.test.d.ts +0 -0
  58. package/build/cog/__tests__/cutline.test.d.ts.map +1 -0
  59. package/build/cog/{__test__ → __tests__}/cutline.test.js +2 -1
  60. package/build/cog/{__test__ → __tests__}/projection.loader.test.d.ts +0 -0
  61. package/build/cog/__tests__/projection.loader.test.d.ts.map +1 -0
  62. package/build/cog/{__test__ → __tests__}/projection.loader.test.js +0 -0
  63. package/build/cog/{__test__ → __tests__}/source.tiff.testhelper.d.ts +0 -0
  64. package/build/cog/__tests__/source.tiff.testhelper.d.ts.map +1 -0
  65. package/build/cog/{__test__ → __tests__}/source.tiff.testhelper.js +0 -0
  66. package/build/cog/cog.stac.job.js +1 -1
  67. package/build/cog/job.factory.d.ts.map +1 -1
  68. package/build/cog/job.factory.js +12 -4
  69. package/build/gdal/{__test__ → __tests__}/gdal.progress.test.d.ts +0 -0
  70. package/build/gdal/__tests__/gdal.progress.test.d.ts.map +1 -0
  71. package/build/gdal/{__test__ → __tests__}/gdal.progress.test.js +0 -0
  72. package/build/gdal/{__test__ → __tests__}/gdal.test.d.ts +0 -0
  73. package/build/gdal/__tests__/gdal.test.d.ts.map +1 -0
  74. package/build/gdal/{__test__ → __tests__}/gdal.test.js +0 -0
  75. package/package.json +17 -11
  76. package/build/cli/cogify/__test__/batch.job.test.d.ts.map +0 -1
  77. package/build/cli/cogify/__test__/semver.test.d.ts.map +0 -1
  78. package/build/cli/cogify/index.d.ts +0 -7
  79. package/build/cli/cogify/index.d.ts.map +0 -1
  80. package/build/cli/cogify/index.js +0 -16
  81. package/build/cog/__test__/builder.test.d.ts.map +0 -1
  82. package/build/cog/__test__/cog.stac.job.test.d.ts.map +0 -1
  83. package/build/cog/__test__/cog.test.d.ts.map +0 -1
  84. package/build/cog/__test__/cog.vrt.test.d.ts.map +0 -1
  85. package/build/cog/__test__/cutline.test.d.ts.map +0 -1
  86. package/build/cog/__test__/projection.loader.test.d.ts.map +0 -1
  87. package/build/cog/__test__/source.tiff.testhelper.d.ts.map +0 -1
  88. package/build/gdal/__test__/gdal.progress.test.d.ts.map +0 -1
  89. package/build/gdal/__test__/gdal.test.d.ts.map +0 -1
  90. package/cogify.js +0 -3
package/CHANGELOG.md CHANGED
@@ -3,6 +3,46 @@
3
3
  All notable changes to this project will be documented in this file.
4
4
  See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
5
5
 
6
+ # [6.29.0](https://github.com/linz/basemaps/compare/v6.28.1...v6.29.0) (2022-06-27)
7
+
8
+
9
+ ### Bug Fixes
10
+
11
+ * **cli:** ensure cli can run inside of docker ([#2273](https://github.com/linz/basemaps/issues/2273)) ([8184167](https://github.com/linz/basemaps/commit/81841674efba2f86d9a39d01af62fccb1fe6f70f))
12
+ * **cli:** ensure errors are thrown ([#2248](https://github.com/linz/basemaps/issues/2248)) ([c0923fe](https://github.com/linz/basemaps/commit/c0923fe137ce36c610c6e13332292d5c7f573c16))
13
+ * **cli:** give each internal job a fresh copy of all data ([#2250](https://github.com/linz/basemaps/issues/2250)) ([52d59de](https://github.com/linz/basemaps/commit/52d59def25358e5a0f1fae5506edee6d8b17dbad))
14
+ * **cli:** look into batch to get exact list of tiffs being processed ([#2249](https://github.com/linz/basemaps/issues/2249)) ([69b722e](https://github.com/linz/basemaps/commit/69b722ea3190488231baf3b7023ce83e60e432c1))
15
+ * **config:** include missing zod dependency ([#2245](https://github.com/linz/basemaps/issues/2245)) ([94914dc](https://github.com/linz/basemaps/commit/94914dc728b60c51d6382c4460a1bd4e233f00c5))
16
+
17
+
18
+ ### Features
19
+
20
+ * **cli:** merge all cli from config-cli package and server package into cli package. ([#2260](https://github.com/linz/basemaps/issues/2260)) ([73afd61](https://github.com/linz/basemaps/commit/73afd610740f69e67504a0610c94a407a6ba4091))
21
+ * **config:** create a hash of config bundles and use bundle created timestamp for records ([#2274](https://github.com/linz/basemaps/issues/2274)) ([bd9c7bb](https://github.com/linz/basemaps/commit/bd9c7bbf3f651417b60ba6ad2ca655f89f1f5cd9))
22
+
23
+
24
+
25
+
26
+
27
+ ## [6.28.1](https://github.com/linz/basemaps/compare/v6.28.0...v6.28.1) (2022-06-07)
28
+
29
+ **Note:** Version bump only for package @basemaps/cli
30
+
31
+
32
+
33
+
34
+
35
+ # [6.28.0](https://github.com/linz/basemaps/compare/v6.27.0...v6.28.0) (2022-06-06)
36
+
37
+
38
+ ### Features
39
+
40
+ * **server:** bundle basemaps-server cli so its easier to install ([#2218](https://github.com/linz/basemaps/issues/2218)) ([8457b66](https://github.com/linz/basemaps/commit/8457b66be6d0f54decf43b515bb78853cefbc8ed))
41
+
42
+
43
+
44
+
45
+
6
46
  # [6.27.0](https://github.com/linz/basemaps/compare/v6.26.0...v6.27.0) (2022-05-29)
7
47
 
8
48
 
package/README.md CHANGED
@@ -1,35 +1,69 @@
1
- # @basemaps/cog
1
+ # @basemaps/cli
2
2
 
3
- Create a collection of cloud optimized geotiff's from a collection of geotiff, that is optimized to be used in `@basemaps/tiler`
3
+ CreateThis package is to control the configuration in the LINZ basemaps product.
4
4
 
5
5
  ## Install
6
6
 
7
7
  This script requires docker to be installed
8
8
 
9
- To install cogify
9
+ To install
10
10
 
11
11
  ```bash
12
- npm i @basemaps/cog
12
+ npm i @basemaps/cli
13
13
  ```
14
14
 
15
- ## Usage
15
+ ## Usage -- Bundle
16
16
 
17
- Create a list of COG's to create
17
+ Bundle config files into config bundle json from a given config path.
18
18
 
19
19
  ```bash
20
- cogify -V job --source ./source_folder/ --output ./source_folder/cogify/
20
+ ./bin/bmc.js bundle --config config/ --output config.json
21
21
  ```
22
22
 
23
- Build a specific COG
23
+ ## Usage -- Import
24
+
25
+ Import all configs from a bundled config.json into dynamo db from a given config path
24
26
 
25
27
  ```bash
26
- cogify -V cog --job ./cogs/01DYREBEEFFXEPBAYBED2TMAFJ/job.json --name 1-2-3 --commit
28
+ ./bin/bmc.js import --config config.json --commit
27
29
  ```
28
30
 
29
- Build all the COGs using aws BATCH
31
+ ## Usage -- Screenshots
32
+
33
+ Dump the screenshots from basemaps production
30
34
 
31
35
  ```bash
32
- cogify -V batch --job ./cogs/01DYREBEEFFXEPBAYBED2TMAFJ/job.json --commit
36
+ ./bin/bmc.js screenshot
37
+ ```
38
+
39
+ Dump the screenshots from different host
40
+
41
+ ```bash
42
+ ./bin/bmc.js screenshot --host HOST
43
+
44
+ ```
45
+
46
+ Dump the screenshots with config file
47
+
48
+ ```bash
49
+ ./bin/bmc.js screenshot --config s3://..../config.json.gz
50
+
51
+ ```
52
+
53
+ ## Usage -- cogify
54
+
55
+ Create a collection of cloud optimized geotiff's from a collection of geotiff, that is optimized to be used in `@basemaps/tiler`
56
+
57
+ Create a list of COG's to create
58
+
59
+ ```bash
60
+ ./bin/bmc.js -V job --source ./source_folder/ --output ./source_folder/cogify/
61
+ ```
62
+
63
+ Build a specific COG
64
+
65
+ ```bash
66
+ ./bin/bmc.js -V cog --job ./cogs/01DYREBEEFFXEPBAYBED2TMAFJ/job.json --name 1-2-3 --commit
33
67
  ```
34
68
 
35
69
  ## Advanced Job creation
@@ -39,7 +73,7 @@ Useful configuration options for `cogify job`
39
73
  ### Min Tile zoom `--min-zoom :number`
40
74
 
41
75
  using the argument `--min-zoom` will configure the highest COG tile that can be created
42
- for example, `--min-zoom 10` means tiles of zoom `0 - 10` can be created but `11` cannot.
76
+ for example, `--min-zoom 10` means tiles of zoom `0 - 10` can be created but `11` cannot.
43
77
 
44
78
  This is useful to control the size of COGS across varying imagery sets World level z0-5 vs region z12-15 vs specific area 20+
45
79
 
@@ -59,7 +93,6 @@ Outputs two GeoJSON files to provide a representation of the source and target i
59
93
 
60
94
  The best way to build a cog collection is to create multiple JOBS with `--geojson` enabled while adjusting `--max-cogs` and `--min-zoom` when a good covering is found the job can then be submitted to AWS for processing.
61
95
 
62
-
63
96
  Using a large area of interest as shown in the imagery set below and is showing three different sets of parameters, The shaded green area is the original source imagery
64
97
 
65
98
  ![Example Covering](./static/example-covering.png)
@@ -1,19 +1 @@
1
- #!/usr/bin/env node
2
- import { CommandLineParser } from '@rushstack/ts-command-line';
3
- import 'source-map-support/register.js';
4
- /** Useful traceability information */
5
- export declare const CliInfo: {
6
- package: string;
7
- version: string;
8
- hash: string;
9
- };
10
- /** Unique Id for this instance of the cli being run */
11
- export declare const CliId: string;
12
- export declare abstract class BaseCommandLine extends CommandLineParser {
13
- verbose: import("@rushstack/ts-command-line").CommandLineFlagParameter;
14
- extraVerbose: import("@rushstack/ts-command-line").CommandLineFlagParameter;
15
- protected onExecute(): Promise<void>;
16
- protected onDefineParameters(): void;
17
- run(): void;
18
- }
19
1
  //# sourceMappingURL=base.cli.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"base.cli.d.ts","sourceRoot":"","sources":["../../src/cli/base.cli.ts"],"names":[],"mappings":";AAGA,OAAO,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AAC/D,OAAO,gCAAgC,CAAC;AAGxC,uCAAuC;AACvC,eAAO,MAAM,OAAO,EAAE;IAAE,OAAO,EAAE,MAAM,CAAC;IAAC,OAAO,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAA;CAKrE,CAAC;AAEF,uDAAuD;AACvD,eAAO,MAAM,KAAK,QAAc,CAAC;AAEjC,8BAAsB,eAAgB,SAAQ,iBAAiB;IAC7D,OAAO,gEAIJ;IACH,YAAY,gEAIT;IAEH,SAAS,CAAC,SAAS,IAAI,OAAO,CAAC,IAAI,CAAC;IAepC,SAAS,CAAC,kBAAkB,IAAI,IAAI;IAI7B,GAAG,IAAI,IAAI;CAUnB"}
1
+ {"version":3,"file":"base.cli.d.ts","sourceRoot":"","sources":["../../src/cli/base.cli.ts"],"names":[],"mappings":""}
@@ -1,60 +1 @@
1
- #!/usr/bin/env node
2
- var _a, _b;
3
- import { LogConfig, LoggerFatalError } from '@basemaps/shared';
4
- import { GitTag } from '@basemaps/shared/build/cli/git.tag.js';
5
- import { CommandLineParser } from '@rushstack/ts-command-line';
6
- import 'source-map-support/register.js';
7
- import * as ulid from 'ulid';
8
- /** Useful traceability information */
9
- export const CliInfo = {
10
- // Detect unlinked packages looks for this string since its a package name, slightly work around it
11
- package: '@' + 'basemaps/cli',
12
- version: (_a = process.env.GIT_VERSION) !== null && _a !== void 0 ? _a : GitTag().version,
13
- hash: (_b = process.env.GIT_HASH) !== null && _b !== void 0 ? _b : GitTag().hash,
14
- };
15
- /** Unique Id for this instance of the cli being run */
16
- export const CliId = ulid.ulid();
17
- export class BaseCommandLine extends CommandLineParser {
18
- constructor() {
19
- super(...arguments);
20
- this.verbose = this.defineFlagParameter({
21
- parameterLongName: '--verbose',
22
- parameterShortName: '-v',
23
- description: 'Show extra logging detail',
24
- });
25
- this.extraVerbose = this.defineFlagParameter({
26
- parameterLongName: '--vv',
27
- parameterShortName: '-V',
28
- description: 'Show extra extra logging detail',
29
- });
30
- }
31
- onExecute() {
32
- if (this.verbose.value) {
33
- LogConfig.get().level = 'debug';
34
- }
35
- else if (this.extraVerbose.value) {
36
- LogConfig.get().level = 'trace';
37
- }
38
- else {
39
- LogConfig.get().level = 'info';
40
- }
41
- const logger = LogConfig.get().child({ id: CliId });
42
- logger.info(CliInfo, 'CliStart');
43
- LogConfig.set(logger);
44
- return super.onExecute();
45
- }
46
- onDefineParameters() {
47
- // Nothing
48
- }
49
- run() {
50
- this.executeWithoutErrorHandling().catch((err) => {
51
- if (err instanceof LoggerFatalError) {
52
- LogConfig.get().fatal(err.obj, err.message);
53
- }
54
- else {
55
- LogConfig.get().fatal({ err }, 'Failed to run command');
56
- }
57
- process.exit(1);
58
- });
59
- }
60
- }
1
+ "use strict";
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=bin.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bin.d.ts","sourceRoot":"","sources":["../../src/cli/bin.ts"],"names":[],"mappings":""}
@@ -0,0 +1,3 @@
1
+ Error.stackTraceLimit = 100;
2
+ import { BasemapsConfigCommandLine } from './index.js';
3
+ new BasemapsConfigCommandLine().run();
@@ -0,0 +1 @@
1
+ {"version":3,"file":"batch.job.test.d.ts","sourceRoot":"","sources":["../../../../src/cli/cogify/__tests__/batch.job.test.ts"],"names":[],"mappings":""}
@@ -1,3 +1,4 @@
1
+ import { LogConfig } from '@basemaps/shared';
1
2
  import o from 'ospec';
2
3
  import { BatchJob, extractResolutionFromName } from '../batch.job.js';
3
4
  o.spec('action.batch', () => {
@@ -12,9 +13,10 @@ o.spec('action.batch', () => {
12
13
  });
13
14
  o('should create valid jobNames', () => {
14
15
  const fakeJob = { id: '01FHRPYJ5FV1XAARZAC4T4K6MC', name: 'geographx_nz_texture_shade_2012_8-0m' };
15
- o(BatchJob.id(fakeJob, ['0'])).equals('01FHRPYJ5FV1XAARZAC4T4K6MC-9af5e139bbb3e502-0');
16
+ o(BatchJob.id(fakeJob, ['0'])).equals('01FHRPYJ5FV1XAARZAC4T4K6MC-9af5e139bbb3e502-1x-0');
16
17
  fakeJob.name = 'ōtorohanga_urban_2021_0.1m_RGB';
17
- o(BatchJob.id(fakeJob, ['0'])).equals('01FHRPYJ5FV1XAARZAC4T4K6MC-5294acface81c107-0');
18
+ o(BatchJob.id(fakeJob, ['0'])).equals('01FHRPYJ5FV1XAARZAC4T4K6MC-5294acface81c107-1x-0');
19
+ o(BatchJob.id(fakeJob)).equals('01FHRPYJ5FV1XAARZAC4T4K6MC-5294acface81c107-');
18
20
  });
19
21
  o('should truncate job names to 128 characters', () => {
20
22
  const fakeJob = { id: '01FHRPYJ5FV1XAARZAC4T4K6MC', name: 'geographx_nz_texture_shade_2012_8-0m' };
@@ -22,9 +24,9 @@ o.spec('action.batch', () => {
22
24
  'this is a really long file name',
23
25
  'it should over flow 128 characters',
24
26
  'so it should be truncated at some point.tiff',
25
- ])).equals('01FHRPYJ5FV1XAARZAC4T4K6MC-9af5e139bbb3e502-it should over flow 128 characters_so it should be truncated at some point.tiff_this');
27
+ ])).equals('01FHRPYJ5FV1XAARZAC4T4K6MC-9af5e139bbb3e502-3x-it should over flow 128 characters_so it should be truncated at some point.tiff_t');
26
28
  });
27
- o('should prepare valid chunk jobs', async () => {
29
+ o.spec('ChunkJobs', () => {
28
30
  const fakeGsd = 0.9;
29
31
  const ChunkJobSmall = 4097;
30
32
  const ChunkJobMiddle = 8193;
@@ -47,23 +49,47 @@ o.spec('action.batch', () => {
47
49
  { name: '1-2-14', width: ChunkJobMiddle * fakeGsd - 1 }, // Middle Job 70
48
50
  ];
49
51
  const fakeJob = { id: '01FHRPYJ5FV1XAARZAC4T4K6MC', output: { files: fakeFiles, gsd: fakeGsd } };
50
- o(await BatchJob.getJobs(fakeJob)).deepEquals([
51
- [fakeFiles[2].name],
52
- [fakeFiles[5].name],
53
- [
54
- fakeFiles[0].name,
55
- fakeFiles[1].name,
56
- fakeFiles[3].name,
57
- fakeFiles[4].name,
58
- fakeFiles[6].name,
59
- fakeFiles[7].name,
60
- fakeFiles[8].name,
61
- fakeFiles[9].name,
62
- fakeFiles[10].name,
63
- fakeFiles[11].name,
64
- ],
65
- [fakeFiles[13].name],
66
- [fakeFiles[12].name, fakeFiles[14].name], // Second Chunk
67
- ]);
52
+ o('should prepare valid chunk jobs', async () => {
53
+ o(BatchJob.getJobs(fakeJob, new Set(), LogConfig.get())).deepEquals([
54
+ [fakeFiles[2].name],
55
+ [fakeFiles[5].name],
56
+ [
57
+ fakeFiles[0].name,
58
+ fakeFiles[1].name,
59
+ fakeFiles[3].name,
60
+ fakeFiles[4].name,
61
+ fakeFiles[6].name,
62
+ fakeFiles[7].name,
63
+ fakeFiles[8].name,
64
+ fakeFiles[9].name,
65
+ fakeFiles[10].name,
66
+ fakeFiles[11].name,
67
+ ],
68
+ [fakeFiles[13].name],
69
+ [fakeFiles[12].name, fakeFiles[14].name], // Second Chunk
70
+ ]);
71
+ });
72
+ o('should skip tiffs that exist', () => {
73
+ const existing = new Set([
74
+ `${fakeFiles[0].name}.tiff`,
75
+ `${fakeFiles[1].name}.tiff`,
76
+ `${fakeFiles[13].name}.tiff`,
77
+ ]);
78
+ o(BatchJob.getJobs(fakeJob, existing, LogConfig.get())).deepEquals([
79
+ [fakeFiles[2].name],
80
+ [fakeFiles[5].name],
81
+ [
82
+ fakeFiles[3].name,
83
+ fakeFiles[4].name,
84
+ fakeFiles[6].name,
85
+ fakeFiles[7].name,
86
+ fakeFiles[8].name,
87
+ fakeFiles[9].name,
88
+ fakeFiles[10].name,
89
+ fakeFiles[11].name,
90
+ ],
91
+ [fakeFiles[12].name, fakeFiles[14].name], // Second Chunk
92
+ ]);
93
+ });
68
94
  });
69
95
  });
@@ -0,0 +1 @@
1
+ {"version":3,"file":"semver.test.d.ts","sourceRoot":"","sources":["../../../../src/cli/cogify/__tests__/semver.test.ts"],"names":[],"mappings":""}
@@ -2,7 +2,7 @@ import { LogType } from '@basemaps/shared';
2
2
  import { CommandLineAction } from '@rushstack/ts-command-line';
3
3
  import { CogStacJob } from '../../cog/cog.stac.job.js';
4
4
  import { CogJob } from '../../cog/types.js';
5
- export declare class ActionCogCreate extends CommandLineAction {
5
+ export declare class CommandCogCreate extends CommandLineAction {
6
6
  private job?;
7
7
  private name?;
8
8
  private commit?;
@@ -10,6 +10,7 @@ export declare class ActionCogCreate extends CommandLineAction {
10
10
  constructor();
11
11
  getNames(job: CogJob): Set<string> | null;
12
12
  onExecute(): Promise<void>;
13
+ processTiff(job: CogStacJob, tiffName: string, tmpFolder: string, isCommit: boolean, logger: LogType): Promise<void>;
13
14
  /** Check to see how many tiffs are remaining in the job */
14
15
  checkJobStatus(job: CogStacJob, logger: LogType): Promise<void>;
15
16
  protected onDefineParameters(): void;
@@ -1 +1 @@
1
- {"version":3,"file":"action.cog.d.ts","sourceRoot":"","sources":["../../../src/cli/cogify/action.cog.ts"],"names":[],"mappings":"AAAA,OAAO,EAAiD,OAAO,EAAE,MAAM,kBAAkB,CAAC;AAC1F,OAAO,EACL,iBAAiB,EAKlB,MAAM,4BAA4B,CAAC;AAIpC,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AAGvD,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAS5C,qBAAa,eAAgB,SAAQ,iBAAiB;IACpD,OAAO,CAAC,GAAG,CAAC,CAA6B;IACzC,OAAO,CAAC,IAAI,CAAC,CAAiC;IAC9C,OAAO,CAAC,MAAM,CAAC,CAA2B;IAC1C,OAAO,CAAC,QAAQ,CAAC,CAAkC;;IAUnD,QAAQ,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC,GAAG,IAAI;IA0CnC,SAAS,IAAI,OAAO,CAAC,IAAI,CAAC;IAqFhC,2DAA2D;IACrD,cAAc,CAAC,GAAG,EAAE,UAAU,EAAE,MAAM,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAqCrE,SAAS,CAAC,kBAAkB,IAAI,IAAI;CA4BrC"}
1
+ {"version":3,"file":"action.cog.d.ts","sourceRoot":"","sources":["../../../src/cli/cogify/action.cog.ts"],"names":[],"mappings":"AAAA,OAAO,EAAiD,OAAO,EAAE,MAAM,kBAAkB,CAAC;AAE1F,OAAO,EACL,iBAAiB,EAKlB,MAAM,4BAA4B,CAAC;AAIpC,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AAGvD,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAQ5C,qBAAa,gBAAiB,SAAQ,iBAAiB;IACrD,OAAO,CAAC,GAAG,CAAC,CAA6B;IACzC,OAAO,CAAC,IAAI,CAAC,CAAiC;IAC9C,OAAO,CAAC,MAAM,CAAC,CAA2B;IAC1C,OAAO,CAAC,QAAQ,CAAC,CAAkC;;IAUnD,QAAQ,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC,GAAG,IAAI;IA0CnC,SAAS,IAAI,OAAO,CAAC,IAAI,CAAC;IAkD1B,WAAW,CACf,GAAG,EAAE,UAAU,EACf,QAAQ,EAAE,MAAM,EAChB,SAAS,EAAE,MAAM,EACjB,QAAQ,EAAE,OAAO,EACjB,MAAM,EAAE,OAAO,GACd,OAAO,CAAC,IAAI,CAAC;IA2ChB,2DAA2D;IACrD,cAAc,CAAC,GAAG,EAAE,UAAU,EAAE,MAAM,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAqCrE,SAAS,CAAC,kBAAkB,IAAI,IAAI;CA4BrC"}
@@ -1,4 +1,5 @@
1
1
  import { Config, Env, fsa, LogConfig, LoggerFatalError } from '@basemaps/shared';
2
+ import { CliId } from '@basemaps/shared/build/cli/base.js';
2
3
  import { CommandLineAction, } from '@rushstack/ts-command-line';
3
4
  import { createReadStream, promises as fs } from 'fs';
4
5
  import { buildCogForName } from '../../cog/cog.js';
@@ -6,13 +7,12 @@ import { CogStacJob } from '../../cog/cog.stac.job.js';
6
7
  import { CogVrt } from '../../cog/cog.vrt.js';
7
8
  import { Cutline } from '../../cog/cutline.js';
8
9
  import { Gdal } from '../../gdal/gdal.js';
9
- import { CliId } from '../base.cli.js';
10
10
  import { makeTempFolder, makeTiffFolder } from '../folder.js';
11
11
  import path from 'path';
12
12
  import { insertConfigImagery, insertConfigTileSet } from './imagery.config.js';
13
13
  import { JobStatus } from '@basemaps/config';
14
14
  import { prepareUrl } from '../util.js';
15
- export class ActionCogCreate extends CommandLineAction {
15
+ export class CommandCogCreate extends CommandLineAction {
16
16
  constructor() {
17
17
  super({
18
18
  actionName: 'cog',
@@ -55,12 +55,12 @@ export class ActionCogCreate extends CommandLineAction {
55
55
  return output;
56
56
  }
57
57
  async onExecute() {
58
- var _a, _b, _c, _d;
59
- const jobFn = (_a = this.job) === null || _a === void 0 ? void 0 : _a.value;
60
- if (jobFn == null)
58
+ var _a, _b, _c;
59
+ const jobLocation = (_a = this.job) === null || _a === void 0 ? void 0 : _a.value;
60
+ if (jobLocation == null)
61
61
  throw new Error('Missing job name');
62
- const job = await CogStacJob.load(jobFn);
63
62
  const isCommit = (_c = (_b = this.commit) === null || _b === void 0 ? void 0 : _b.value) !== null && _c !== void 0 ? _c : false;
63
+ const job = await CogStacJob.load(jobLocation);
64
64
  const logger = LogConfig.get().child({
65
65
  correlationId: job.id,
66
66
  imageryName: job.name,
@@ -69,49 +69,15 @@ export class ActionCogCreate extends CommandLineAction {
69
69
  LogConfig.set(logger);
70
70
  logger.info('CogCreate:Start');
71
71
  const gdalVersion = await Gdal.version(logger);
72
- logger.info({ version: gdalVersion }, 'CogCreate:GdalVersion');
72
+ logger.info({ gdalVersion }, 'CogCreate:GdalVersion');
73
73
  const names = this.getNames(job);
74
74
  if (names == null || names.size === 0)
75
75
  return;
76
76
  const tmpFolder = await makeTempFolder(`basemaps-${job.id}-${CliId}`);
77
77
  try {
78
78
  for (const name of names) {
79
- const tiffFolder = await makeTiffFolder(tmpFolder, name);
80
- const targetPath = job.getJobPath(`${name}.tiff`);
81
- fsa.configure(job.output.location);
82
- const outputExists = await fsa.exists(targetPath);
83
- logger.info({ targetPath, outputExists }, 'CogCreate:CheckExists');
84
- // Output file exists don't try and overwrite it
85
- if (outputExists) {
86
- logger.warn({ targetPath }, 'CogCreate:OutputExists');
87
- await this.checkJobStatus(job, logger);
88
- continue;
89
- }
90
- let cutlineJson;
91
- if (job.output.cutline != null) {
92
- const cutlinePath = job.getJobPath('cutline.geojson.gz');
93
- logger.info({ path: cutlinePath }, 'CogCreate:UsingCutLine');
94
- cutlineJson = await Cutline.loadCutline(cutlinePath);
95
- }
96
- else {
97
- logger.warn('NoCutLine');
98
- }
99
- const cutline = new Cutline(job.tileMatrix, cutlineJson, (_d = job.output.cutline) === null || _d === void 0 ? void 0 : _d.blend, job.output.oneCogCovering);
100
- const tmpVrtPath = await CogVrt.buildVrt(tiffFolder, job, cutline, name, logger);
101
- if (tmpVrtPath == null) {
102
- logger.warn({ name }, 'CogCreate:NoMatchingSourceImagery');
103
- return;
104
- }
105
- const tmpTiff = fsa.join(tiffFolder, `${name}.tiff`);
106
- await buildCogForName(job, name, tmpVrtPath, tmpTiff, logger, isCommit);
107
- logger.info({ target: targetPath }, 'CogCreate:StoreTiff');
108
- if (isCommit) {
109
- await fsa.write(targetPath, createReadStream(tmpTiff));
110
- await this.checkJobStatus(job, logger);
111
- }
112
- else {
113
- logger.warn({ name }, 'DryRun:Done');
114
- }
79
+ const tiffJob = await CogStacJob.load(jobLocation);
80
+ await this.processTiff(tiffJob, name, tmpFolder, isCommit, logger.child({ tiffName: name }));
115
81
  }
116
82
  }
117
83
  catch (e) {
@@ -129,12 +95,53 @@ export class ActionCogCreate extends CommandLineAction {
129
95
  else
130
96
  throw new Error('Unable update the Processing Job status:' + jobFailed.id);
131
97
  }
98
+ // Ensure the error is thrown
99
+ throw e;
132
100
  }
133
101
  finally {
134
102
  // Cleanup!
135
103
  await fs.rm(tmpFolder, { recursive: true });
136
104
  }
137
105
  }
106
+ async processTiff(job, tiffName, tmpFolder, isCommit, logger) {
107
+ var _a;
108
+ const tiffFolder = await makeTiffFolder(tmpFolder, tiffName);
109
+ const targetPath = job.getJobPath(`${tiffName}.tiff`);
110
+ fsa.configure(job.output.location);
111
+ const outputExists = await fsa.exists(targetPath);
112
+ logger.info({ targetPath, outputExists }, 'CogCreate:CheckExists');
113
+ // Output file exists don't try and overwrite it
114
+ if (outputExists) {
115
+ logger.warn({ targetPath }, 'CogCreate:OutputExists');
116
+ await this.checkJobStatus(job, logger);
117
+ return;
118
+ }
119
+ let cutlineJson;
120
+ if (job.output.cutline != null) {
121
+ const cutlinePath = job.getJobPath('cutline.geojson.gz');
122
+ logger.info({ path: cutlinePath }, 'CogCreate:UsingCutLine');
123
+ cutlineJson = await Cutline.loadCutline(cutlinePath);
124
+ }
125
+ else {
126
+ logger.warn('CutLine:Skip');
127
+ }
128
+ const cutline = new Cutline(job.tileMatrix, cutlineJson, (_a = job.output.cutline) === null || _a === void 0 ? void 0 : _a.blend, job.output.oneCogCovering);
129
+ const tmpVrtPath = await CogVrt.buildVrt(tiffFolder, job, cutline, tiffName, logger);
130
+ if (tmpVrtPath == null) {
131
+ logger.warn('CogCreate:NoMatchingSourceImagery');
132
+ return;
133
+ }
134
+ const tmpTiff = fsa.join(tiffFolder, `${tiffName}.tiff`);
135
+ await buildCogForName(job, tiffName, tmpVrtPath, tmpTiff, logger, isCommit);
136
+ logger.info({ target: targetPath }, 'CogCreate:StoreTiff');
137
+ if (isCommit) {
138
+ await fsa.write(targetPath, createReadStream(tmpTiff));
139
+ await this.checkJobStatus(job, logger);
140
+ }
141
+ else {
142
+ logger.warn('DryRun:Done');
143
+ }
144
+ }
138
145
  /** Check to see how many tiffs are remaining in the job */
139
146
  async checkJobStatus(job, logger) {
140
147
  const basePath = job.getJobPath();
@@ -6,7 +6,7 @@ export declare class CLiInputData {
6
6
  externalId: CommandLineStringParameter;
7
7
  constructor(parent: CommandLineAction, prefix: string);
8
8
  }
9
- export declare class ActionJobCreate extends CommandLineAction {
9
+ export declare class CommandJobCreate extends CommandLineAction {
10
10
  private source;
11
11
  private output;
12
12
  private maxConcurrency;
@@ -1 +1 @@
1
- {"version":3,"file":"action.job.d.ts","sourceRoot":"","sources":["../../../src/cli/cogify/action.job.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAuB,MAAM,kBAAkB,CAAC;AACnE,OAAO,EACL,iBAAiB,EAGjB,0BAA0B,EAC3B,MAAM,4BAA4B,CAAC;AAMpC,qBAAa,YAAY;IACvB,IAAI,EAAE,0BAA0B,CAAC;IACjC,OAAO,EAAE,0BAA0B,CAAC;IACpC,UAAU,EAAE,0BAA0B,CAAC;gBAE3B,MAAM,EAAE,iBAAiB,EAAE,MAAM,EAAE,MAAM;CAsBtD;AAED,qBAAa,eAAgB,SAAQ,iBAAiB;IACpD,OAAO,CAAC,MAAM,CAAe;IAC7B,OAAO,CAAC,MAAM,CAAe;IAC7B,OAAO,CAAC,cAAc,CAA8B;IACpD,OAAO,CAAC,OAAO,CAA6B;IAC5C,OAAO,CAAC,YAAY,CAA8B;IAClD,OAAO,CAAC,UAAU,CAA6B;IAC/C,OAAO,CAAC,mBAAmB,CAA6B;IACxD,OAAO,CAAC,WAAW,CAA2B;IAC9C,OAAO,CAAC,OAAO,CAA8B;IAC7C,OAAO,CAAC,gBAAgB,CAA8B;IACtD,OAAO,CAAC,UAAU,CAA6B;IAC/C,OAAO,CAAC,MAAM,CAA2B;IACzC,OAAO,CAAC,QAAQ,CAA6B;IAC7C,OAAO,CAAC,YAAY,CAA6B;;IAUjD,QAAQ,CAAC,MAAM,EAAE,YAAY,GAAG,UAAU;IAkBpC,SAAS,IAAI,OAAO,CAAC,IAAI,CAAC;IA0DhC,SAAS,CAAC,kBAAkB,IAAI,IAAI;CAyFrC"}
1
+ {"version":3,"file":"action.job.d.ts","sourceRoot":"","sources":["../../../src/cli/cogify/action.job.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAuB,MAAM,kBAAkB,CAAC;AACnE,OAAO,EACL,iBAAiB,EAGjB,0BAA0B,EAC3B,MAAM,4BAA4B,CAAC;AAMpC,qBAAa,YAAY;IACvB,IAAI,EAAE,0BAA0B,CAAC;IACjC,OAAO,EAAE,0BAA0B,CAAC;IACpC,UAAU,EAAE,0BAA0B,CAAC;gBAE3B,MAAM,EAAE,iBAAiB,EAAE,MAAM,EAAE,MAAM;CAsBtD;AAED,qBAAa,gBAAiB,SAAQ,iBAAiB;IACrD,OAAO,CAAC,MAAM,CAAe;IAC7B,OAAO,CAAC,MAAM,CAAe;IAC7B,OAAO,CAAC,cAAc,CAA8B;IACpD,OAAO,CAAC,OAAO,CAA6B;IAC5C,OAAO,CAAC,YAAY,CAA8B;IAClD,OAAO,CAAC,UAAU,CAA6B;IAC/C,OAAO,CAAC,mBAAmB,CAA6B;IACxD,OAAO,CAAC,WAAW,CAA2B;IAC9C,OAAO,CAAC,OAAO,CAA8B;IAC7C,OAAO,CAAC,gBAAgB,CAA8B;IACtD,OAAO,CAAC,UAAU,CAA6B;IAC/C,OAAO,CAAC,MAAM,CAA2B;IACzC,OAAO,CAAC,QAAQ,CAA6B;IAC7C,OAAO,CAAC,YAAY,CAA6B;;IAUjD,QAAQ,CAAC,MAAM,EAAE,YAAY,GAAG,UAAU;IAkBpC,SAAS,IAAI,OAAO,CAAC,IAAI,CAAC;IA0DhC,SAAS,CAAC,kBAAkB,IAAI,IAAI;CAyFrC"}
@@ -3,7 +3,7 @@ import { fsa } from '@basemaps/shared';
3
3
  import { CommandLineAction, } from '@rushstack/ts-command-line';
4
4
  import { CogJobFactory, MaxConcurrencyDefault } from '../../cog/job.factory.js';
5
5
  import { GdalCogBuilderDefaults, GdalResamplingOptions } from '../../gdal/gdal.config.js';
6
- import { CliId } from '../base.cli.js';
6
+ import { CliId } from '@basemaps/shared/build/cli/base.js';
7
7
  export class CLiInputData {
8
8
  constructor(parent, prefix) {
9
9
  this.path = parent.defineStringParameter({
@@ -26,7 +26,7 @@ export class CLiInputData {
26
26
  });
27
27
  }
28
28
  }
29
- export class ActionJobCreate extends CommandLineAction {
29
+ export class CommandJobCreate extends CommandLineAction {
30
30
  constructor() {
31
31
  super({
32
32
  actionName: 'job',
@@ -9,6 +9,8 @@ import { CogJob } from '../../cog/types.js';
9
9
  */
10
10
  export declare function extractResolutionFromName(name: string): number;
11
11
  export declare class BatchJob {
12
+ static _batch: Batch;
13
+ static get batch(): Batch;
12
14
  /**
13
15
  * Create a id for a job
14
16
  *
@@ -17,8 +19,8 @@ export declare class BatchJob {
17
19
  * @param fileNames output filename
18
20
  * @returns job id
19
21
  */
20
- static id(job: CogJob, fileNames: string[]): string;
21
- static batchOne(jobPath: string, job: CogJob, batch: Batch, names: string[], isCommit: boolean): Promise<{
22
+ static id(job: CogJob, fileNames?: string[]): string;
23
+ static batchOne(jobPath: string, job: CogJob, names: string[], isCommit: boolean): Promise<{
22
24
  jobName: string;
23
25
  jobId: string;
24
26
  memory: number;
@@ -27,12 +29,12 @@ export declare class BatchJob {
27
29
  * List all the current jobs in batch and their statuses
28
30
  * @returns a map of JobName to if their status is "ok" (not failed)
29
31
  */
30
- static getCurrentJobList(batch: Batch): Promise<Map<string, boolean>>;
32
+ static getCurrentJobList(job: CogJob, logger: LogType): Promise<Set<string>>;
31
33
  static batchJob(job: CogJob, commit: boolean | undefined, logger: LogType): Promise<void>;
32
34
  /**
33
35
  * Prepare the jobs from job files, and chunk the small images into single
34
36
  * @returns List of jobs including single job and chunk jobs.
35
37
  */
36
- static getJobs(job: CogJob): Promise<string[][]>;
38
+ static getJobs(job: CogJob, existing: Set<string>, log: LogType): string[][];
37
39
  }
38
40
  //# sourceMappingURL=batch.job.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"batch.job.d.ts","sourceRoot":"","sources":["../../../src/cli/cogify/batch.job.ts"],"names":[],"mappings":"AACA,OAAO,EAAuB,OAAO,EAAc,MAAM,kBAAkB,CAAC;AAC5E,OAAO,KAAK,MAAM,0BAA0B,CAAC;AAE7C,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAa5C;;;;;GAKG;AACH,wBAAgB,yBAAyB,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAI9D;AAED,qBAAa,QAAQ;IACnB;;;;;;;OAOG;IACH,MAAM,CAAC,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,GAAG,MAAM;WAOtC,QAAQ,CACnB,OAAO,EAAE,MAAM,EACf,GAAG,EAAE,MAAM,EACX,KAAK,EAAE,KAAK,EACZ,KAAK,EAAE,MAAM,EAAE,EACf,QAAQ,EAAE,OAAO,GAChB,OAAO,CAAC;QAAE,OAAO,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,CAAC;IAmC9D;;;OAGG;WACU,iBAAiB,CAAC,KAAK,EAAE,KAAK,GAAG,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;WAqB9D,QAAQ,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,qBAAQ,EAAE,MAAM,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAyElF;;;OAGG;WACU,OAAO,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC;CA4BvD"}
1
+ {"version":3,"file":"batch.job.d.ts","sourceRoot":"","sources":["../../../src/cli/cogify/batch.job.ts"],"names":[],"mappings":"AACA,OAAO,EAAuB,OAAO,EAAc,MAAM,kBAAkB,CAAC;AAC5E,OAAO,KAAK,MAAM,0BAA0B,CAAC;AAG7C,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAa5C;;;;;GAKG;AACH,wBAAgB,yBAAyB,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAI9D;AAED,qBAAa,QAAQ;IACnB,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC;IACrB,MAAM,KAAK,KAAK,IAAI,KAAK,CAKxB;IACD;;;;;;;OAOG;IACH,MAAM,CAAC,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,MAAM,EAAE,GAAG,MAAM;WAQvC,QAAQ,CACnB,OAAO,EAAE,MAAM,EACf,GAAG,EAAE,MAAM,EACX,KAAK,EAAE,MAAM,EAAE,EACf,QAAQ,EAAE,OAAO,GAChB,OAAO,CAAC;QAAE,OAAO,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,CAAC;IAmC9D;;;OAGG;WACU,iBAAiB,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;WA0CrE,QAAQ,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,qBAAQ,EAAE,MAAM,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IA+ClF;;;OAGG;IACH,MAAM,CAAC,OAAO,CAAC,GAAG,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,CAAC,MAAM,CAAC,EAAE,GAAG,EAAE,OAAO,GAAG,MAAM,EAAE,EAAE;CAkC7E"}