@basemaps/lambda-tiler 6.18.0 → 6.21.1
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.
- package/CHANGELOG.md +66 -0
- package/LICENSE +2 -2
- package/build/__test__/tile.set.cache.test.js +4 -10
- package/build/__test__/tile.style.json.test.d.ts +2 -0
- package/build/__test__/tile.style.json.test.d.ts.map +1 -0
- package/build/__test__/tile.style.json.test.js +33 -0
- package/build/__test__/xyz.test.js +27 -26
- package/build/cli/dump.js +2 -2
- package/build/cli/validate.js +2 -1
- package/build/index.d.ts.map +1 -1
- package/build/index.js +18 -1
- package/build/routes/__test__/attribution.test.js +3 -13
- package/build/routes/attribution.d.ts.map +1 -1
- package/build/routes/attribution.js +7 -20
- package/build/routes/esri/rest.d.ts +10 -0
- package/build/routes/esri/rest.d.ts.map +1 -0
- package/build/routes/esri/rest.js +87 -0
- package/build/routes/imagery.d.ts +10 -0
- package/build/routes/imagery.d.ts.map +1 -0
- package/build/routes/imagery.js +50 -0
- package/build/routes/response.d.ts +4 -0
- package/build/routes/response.d.ts.map +1 -0
- package/build/routes/response.js +3 -0
- package/build/routes/tile.d.ts +0 -20
- package/build/routes/tile.d.ts.map +1 -1
- package/build/routes/tile.js +11 -164
- package/build/routes/tile.json.d.ts +10 -0
- package/build/routes/tile.json.d.ts.map +1 -0
- package/build/routes/tile.json.js +31 -0
- package/build/routes/tile.style.json.d.ts +10 -0
- package/build/routes/tile.style.json.d.ts.map +1 -0
- package/build/routes/tile.style.json.js +74 -0
- package/build/routes/tile.wmts.d.ts +9 -0
- package/build/routes/tile.wmts.d.ts.map +1 -0
- package/build/routes/tile.wmts.js +57 -0
- package/build/routes/tile.xyz.d.ts +13 -0
- package/build/routes/tile.xyz.d.ts.map +1 -0
- package/build/routes/tile.xyz.js +28 -0
- package/build/source.tracer.d.ts +17 -0
- package/build/source.tracer.d.ts.map +1 -0
- package/build/source.tracer.js +22 -0
- package/build/tile.set.cache.js +3 -3
- package/build/tile.set.d.ts +0 -16
- package/build/tile.set.d.ts.map +1 -1
- package/build/tile.set.js +1 -20
- package/build/tile.set.raster.d.ts +9 -4
- package/build/tile.set.raster.d.ts.map +1 -1
- package/build/tile.set.raster.js +17 -6
- package/build/tile.set.vector.d.ts +10 -4
- package/build/tile.set.vector.d.ts.map +1 -1
- package/build/tile.set.vector.js +18 -8
- package/bundle.sh +2 -2
- package/package.json +14 -14
- package/scripts/create.deployment.package.mjs +34 -0
- package/src/__test__/tile.set.cache.test.ts +4 -12
- package/src/__test__/tile.style.json.test.ts +40 -0
- package/src/__test__/xyz.test.ts +35 -33
- package/src/cli/dump.ts +2 -2
- package/src/cli/validate.ts +2 -1
- package/src/index.ts +21 -1
- package/src/routes/__test__/attribution.test.ts +3 -13
- package/src/routes/attribution.ts +6 -17
- package/src/routes/esri/rest.ts +90 -0
- package/src/routes/imagery.ts +52 -0
- package/src/routes/response.ts +4 -0
- package/src/routes/tile.json.ts +44 -0
- package/src/routes/tile.style.json.ts +77 -0
- package/src/routes/tile.ts +11 -186
- package/src/routes/tile.wmts.ts +59 -0
- package/src/routes/tile.xyz.ts +30 -0
- package/src/source.tracer.ts +34 -0
- package/src/tile.set.cache.ts +3 -3
- package/src/tile.set.raster.ts +32 -7
- package/src/tile.set.ts +0 -40
- package/src/tile.set.vector.ts +26 -7
- package/tsconfig.tsbuildinfo +1 -1
- package/dist/index.js +0 -29695
- package/dist/node_modules/ansi-regex/index.js +0 -4
- package/dist/node_modules/ansi-regex/license +0 -21
- package/dist/node_modules/ansi-regex/package.json +0 -108
- package/dist/node_modules/ansi-regex/readme.md +0 -39
- package/dist/node_modules/aproba/LICENSE +0 -14
- package/dist/node_modules/aproba/README.md +0 -94
- package/dist/node_modules/aproba/index.js +0 -105
- package/dist/node_modules/aproba/package.json +0 -62
- package/dist/node_modules/are-we-there-yet/CHANGES.md +0 -37
- package/dist/node_modules/are-we-there-yet/LICENSE +0 -5
- package/dist/node_modules/are-we-there-yet/README.md +0 -195
- package/dist/node_modules/are-we-there-yet/index.js +0 -4
- package/dist/node_modules/are-we-there-yet/package.json +0 -63
- package/dist/node_modules/are-we-there-yet/tracker-base.js +0 -11
- package/dist/node_modules/are-we-there-yet/tracker-group.js +0 -107
- package/dist/node_modules/are-we-there-yet/tracker-stream.js +0 -36
- package/dist/node_modules/are-we-there-yet/tracker.js +0 -30
- package/dist/node_modules/base64-js/LICENSE +0 -21
- package/dist/node_modules/base64-js/README.md +0 -34
- package/dist/node_modules/base64-js/base64js.min.js +0 -1
- package/dist/node_modules/base64-js/index.d.ts +0 -3
- package/dist/node_modules/base64-js/index.js +0 -150
- package/dist/node_modules/base64-js/package.json +0 -75
- package/dist/node_modules/bl/.travis.yml +0 -17
- package/dist/node_modules/bl/BufferList.js +0 -396
- package/dist/node_modules/bl/LICENSE.md +0 -13
- package/dist/node_modules/bl/README.md +0 -247
- package/dist/node_modules/bl/bl.js +0 -84
- package/dist/node_modules/bl/node_modules/readable-stream/CONTRIBUTING.md +0 -38
- package/dist/node_modules/bl/node_modules/readable-stream/GOVERNANCE.md +0 -136
- package/dist/node_modules/bl/node_modules/readable-stream/LICENSE +0 -47
- package/dist/node_modules/bl/node_modules/readable-stream/README.md +0 -106
- package/dist/node_modules/bl/node_modules/readable-stream/errors-browser.js +0 -127
- package/dist/node_modules/bl/node_modules/readable-stream/errors.js +0 -116
- package/dist/node_modules/bl/node_modules/readable-stream/experimentalWarning.js +0 -17
- package/dist/node_modules/bl/node_modules/readable-stream/lib/_stream_duplex.js +0 -139
- package/dist/node_modules/bl/node_modules/readable-stream/lib/_stream_passthrough.js +0 -39
- package/dist/node_modules/bl/node_modules/readable-stream/lib/_stream_readable.js +0 -1124
- package/dist/node_modules/bl/node_modules/readable-stream/lib/_stream_transform.js +0 -201
- package/dist/node_modules/bl/node_modules/readable-stream/lib/_stream_writable.js +0 -697
- package/dist/node_modules/bl/node_modules/readable-stream/lib/internal/streams/async_iterator.js +0 -207
- package/dist/node_modules/bl/node_modules/readable-stream/lib/internal/streams/buffer_list.js +0 -210
- package/dist/node_modules/bl/node_modules/readable-stream/lib/internal/streams/destroy.js +0 -105
- package/dist/node_modules/bl/node_modules/readable-stream/lib/internal/streams/end-of-stream.js +0 -104
- package/dist/node_modules/bl/node_modules/readable-stream/lib/internal/streams/from-browser.js +0 -3
- package/dist/node_modules/bl/node_modules/readable-stream/lib/internal/streams/from.js +0 -64
- package/dist/node_modules/bl/node_modules/readable-stream/lib/internal/streams/pipeline.js +0 -97
- package/dist/node_modules/bl/node_modules/readable-stream/lib/internal/streams/state.js +0 -27
- package/dist/node_modules/bl/node_modules/readable-stream/lib/internal/streams/stream-browser.js +0 -1
- package/dist/node_modules/bl/node_modules/readable-stream/lib/internal/streams/stream.js +0 -1
- package/dist/node_modules/bl/node_modules/readable-stream/package.json +0 -97
- package/dist/node_modules/bl/node_modules/readable-stream/readable-browser.js +0 -9
- package/dist/node_modules/bl/node_modules/readable-stream/readable.js +0 -16
- package/dist/node_modules/bl/package.json +0 -69
- package/dist/node_modules/bl/test/convert.js +0 -21
- package/dist/node_modules/bl/test/indexOf.js +0 -492
- package/dist/node_modules/bl/test/isBufferList.js +0 -32
- package/dist/node_modules/bl/test/test.js +0 -869
- package/dist/node_modules/buffer/AUTHORS.md +0 -70
- package/dist/node_modules/buffer/LICENSE +0 -21
- package/dist/node_modules/buffer/README.md +0 -410
- package/dist/node_modules/buffer/index.d.ts +0 -186
- package/dist/node_modules/buffer/index.js +0 -1817
- package/dist/node_modules/buffer/package.json +0 -127
- package/dist/node_modules/chownr/LICENSE +0 -15
- package/dist/node_modules/chownr/README.md +0 -3
- package/dist/node_modules/chownr/chownr.js +0 -167
- package/dist/node_modules/chownr/package.json +0 -62
- package/dist/node_modules/code-point-at/index.js +0 -32
- package/dist/node_modules/code-point-at/license +0 -21
- package/dist/node_modules/code-point-at/package.json +0 -70
- package/dist/node_modules/code-point-at/readme.md +0 -32
- package/dist/node_modules/color/LICENSE +0 -21
- package/dist/node_modules/color/README.md +0 -123
- package/dist/node_modules/color/index.js +0 -482
- package/dist/node_modules/color/package.json +0 -72
- package/dist/node_modules/color-convert/CHANGELOG.md +0 -54
- package/dist/node_modules/color-convert/LICENSE +0 -21
- package/dist/node_modules/color-convert/README.md +0 -68
- package/dist/node_modules/color-convert/conversions.js +0 -868
- package/dist/node_modules/color-convert/index.js +0 -78
- package/dist/node_modules/color-convert/package.json +0 -81
- package/dist/node_modules/color-convert/route.js +0 -97
- package/dist/node_modules/color-name/.eslintrc.json +0 -43
- package/dist/node_modules/color-name/LICENSE +0 -8
- package/dist/node_modules/color-name/README.md +0 -11
- package/dist/node_modules/color-name/index.js +0 -152
- package/dist/node_modules/color-name/package.json +0 -54
- package/dist/node_modules/color-name/test.js +0 -7
- package/dist/node_modules/color-string/LICENSE +0 -21
- package/dist/node_modules/color-string/README.md +0 -62
- package/dist/node_modules/color-string/index.js +0 -242
- package/dist/node_modules/color-string/package.json +0 -81
- package/dist/node_modules/console-control-strings/LICENSE +0 -13
- package/dist/node_modules/console-control-strings/README.md +0 -145
- package/dist/node_modules/console-control-strings/README.md~ +0 -140
- package/dist/node_modules/console-control-strings/index.js +0 -125
- package/dist/node_modules/console-control-strings/package.json +0 -61
- package/dist/node_modules/core-util-is/LICENSE +0 -19
- package/dist/node_modules/core-util-is/README.md +0 -3
- package/dist/node_modules/core-util-is/lib/util.js +0 -107
- package/dist/node_modules/core-util-is/package.json +0 -68
- package/dist/node_modules/decompress-response/index.d.ts +0 -29
- package/dist/node_modules/decompress-response/index.js +0 -40
- package/dist/node_modules/decompress-response/license +0 -9
- package/dist/node_modules/decompress-response/package.json +0 -82
- package/dist/node_modules/decompress-response/readme.md +0 -52
- package/dist/node_modules/deep-extend/CHANGELOG.md +0 -46
- package/dist/node_modules/deep-extend/LICENSE +0 -20
- package/dist/node_modules/deep-extend/README.md +0 -91
- package/dist/node_modules/deep-extend/index.js +0 -1
- package/dist/node_modules/deep-extend/lib/deep-extend.js +0 -150
- package/dist/node_modules/deep-extend/package.json +0 -92
- package/dist/node_modules/delegates/History.md +0 -22
- package/dist/node_modules/delegates/License +0 -20
- package/dist/node_modules/delegates/Makefile +0 -8
- package/dist/node_modules/delegates/Readme.md +0 -94
- package/dist/node_modules/delegates/index.js +0 -121
- package/dist/node_modules/delegates/package.json +0 -48
- package/dist/node_modules/delegates/test/index.js +0 -94
- package/dist/node_modules/detect-libc/LICENSE +0 -201
- package/dist/node_modules/detect-libc/README.md +0 -78
- package/dist/node_modules/detect-libc/bin/detect-libc.js +0 -18
- package/dist/node_modules/detect-libc/lib/detect-libc.js +0 -92
- package/dist/node_modules/detect-libc/package.json +0 -71
- package/dist/node_modules/end-of-stream/LICENSE +0 -21
- package/dist/node_modules/end-of-stream/README.md +0 -54
- package/dist/node_modules/end-of-stream/index.js +0 -94
- package/dist/node_modules/end-of-stream/package.json +0 -66
- package/dist/node_modules/expand-template/.travis.yml +0 -6
- package/dist/node_modules/expand-template/LICENSE +0 -21
- package/dist/node_modules/expand-template/README.md +0 -43
- package/dist/node_modules/expand-template/index.js +0 -26
- package/dist/node_modules/expand-template/package.json +0 -60
- package/dist/node_modules/expand-template/test.js +0 -67
- package/dist/node_modules/fs-constants/LICENSE +0 -21
- package/dist/node_modules/fs-constants/README.md +0 -26
- package/dist/node_modules/fs-constants/browser.js +0 -1
- package/dist/node_modules/fs-constants/index.js +0 -1
- package/dist/node_modules/fs-constants/package.json +0 -47
- package/dist/node_modules/gauge/CHANGELOG.md +0 -160
- package/dist/node_modules/gauge/LICENSE +0 -13
- package/dist/node_modules/gauge/README.md +0 -399
- package/dist/node_modules/gauge/base-theme.js +0 -14
- package/dist/node_modules/gauge/error.js +0 -24
- package/dist/node_modules/gauge/has-color.js +0 -12
- package/dist/node_modules/gauge/index.js +0 -233
- package/dist/node_modules/gauge/package.json +0 -91
- package/dist/node_modules/gauge/plumbing.js +0 -48
- package/dist/node_modules/gauge/process.js +0 -3
- package/dist/node_modules/gauge/progress-bar.js +0 -35
- package/dist/node_modules/gauge/render-template.js +0 -181
- package/dist/node_modules/gauge/set-immediate.js +0 -7
- package/dist/node_modules/gauge/set-interval.js +0 -3
- package/dist/node_modules/gauge/spin.js +0 -5
- package/dist/node_modules/gauge/template-item.js +0 -73
- package/dist/node_modules/gauge/theme-set.js +0 -115
- package/dist/node_modules/gauge/themes.js +0 -54
- package/dist/node_modules/gauge/wide-truncate.js +0 -25
- package/dist/node_modules/github-from-package/.travis.yml +0 -4
- package/dist/node_modules/github-from-package/LICENSE +0 -18
- package/dist/node_modules/github-from-package/example/package.json +0 -8
- package/dist/node_modules/github-from-package/example/url.js +0 -3
- package/dist/node_modules/github-from-package/index.js +0 -17
- package/dist/node_modules/github-from-package/package.json +0 -58
- package/dist/node_modules/github-from-package/readme.markdown +0 -53
- package/dist/node_modules/github-from-package/test/a.json +0 -8
- package/dist/node_modules/github-from-package/test/b.json +0 -5
- package/dist/node_modules/github-from-package/test/c.json +0 -5
- package/dist/node_modules/github-from-package/test/d.json +0 -7
- package/dist/node_modules/github-from-package/test/e.json +0 -5
- package/dist/node_modules/github-from-package/test/url.js +0 -19
- package/dist/node_modules/has-unicode/LICENSE +0 -14
- package/dist/node_modules/has-unicode/README.md +0 -43
- package/dist/node_modules/has-unicode/index.js +0 -16
- package/dist/node_modules/has-unicode/package.json +0 -58
- package/dist/node_modules/ieee754/LICENSE +0 -11
- package/dist/node_modules/ieee754/README.md +0 -51
- package/dist/node_modules/ieee754/index.d.ts +0 -10
- package/dist/node_modules/ieee754/index.js +0 -85
- package/dist/node_modules/ieee754/package.json +0 -84
- package/dist/node_modules/inherits/LICENSE +0 -16
- package/dist/node_modules/inherits/README.md +0 -42
- package/dist/node_modules/inherits/inherits.js +0 -9
- package/dist/node_modules/inherits/inherits_browser.js +0 -27
- package/dist/node_modules/inherits/package.json +0 -65
- package/dist/node_modules/ini/LICENSE +0 -15
- package/dist/node_modules/ini/README.md +0 -102
- package/dist/node_modules/ini/ini.js +0 -206
- package/dist/node_modules/ini/package.json +0 -66
- package/dist/node_modules/is-arrayish/LICENSE +0 -21
- package/dist/node_modules/is-arrayish/README.md +0 -16
- package/dist/node_modules/is-arrayish/index.js +0 -9
- package/dist/node_modules/is-arrayish/package.json +0 -77
- package/dist/node_modules/is-arrayish/yarn-error.log +0 -1443
- package/dist/node_modules/is-fullwidth-code-point/index.js +0 -46
- package/dist/node_modules/is-fullwidth-code-point/license +0 -21
- package/dist/node_modules/is-fullwidth-code-point/package.json +0 -77
- package/dist/node_modules/is-fullwidth-code-point/readme.md +0 -39
- package/dist/node_modules/isarray/.travis.yml +0 -4
- package/dist/node_modules/isarray/Makefile +0 -6
- package/dist/node_modules/isarray/README.md +0 -60
- package/dist/node_modules/isarray/component.json +0 -19
- package/dist/node_modules/isarray/index.js +0 -5
- package/dist/node_modules/isarray/package.json +0 -73
- package/dist/node_modules/isarray/test.js +0 -20
- package/dist/node_modules/lru-cache/LICENSE +0 -15
- package/dist/node_modules/lru-cache/README.md +0 -166
- package/dist/node_modules/lru-cache/index.js +0 -334
- package/dist/node_modules/lru-cache/package.json +0 -69
- package/dist/node_modules/mimic-response/index.d.ts +0 -17
- package/dist/node_modules/mimic-response/index.js +0 -38
- package/dist/node_modules/mimic-response/license +0 -9
- package/dist/node_modules/mimic-response/package.json +0 -74
- package/dist/node_modules/mimic-response/readme.md +0 -57
- package/dist/node_modules/minimist/.travis.yml +0 -8
- package/dist/node_modules/minimist/LICENSE +0 -18
- package/dist/node_modules/minimist/example/parse.js +0 -2
- package/dist/node_modules/minimist/index.js +0 -245
- package/dist/node_modules/minimist/package.json +0 -74
- package/dist/node_modules/minimist/readme.markdown +0 -95
- package/dist/node_modules/minimist/test/all_bool.js +0 -32
- package/dist/node_modules/minimist/test/bool.js +0 -178
- package/dist/node_modules/minimist/test/dash.js +0 -31
- package/dist/node_modules/minimist/test/default_bool.js +0 -35
- package/dist/node_modules/minimist/test/dotted.js +0 -22
- package/dist/node_modules/minimist/test/kv_short.js +0 -16
- package/dist/node_modules/minimist/test/long.js +0 -31
- package/dist/node_modules/minimist/test/num.js +0 -36
- package/dist/node_modules/minimist/test/parse.js +0 -197
- package/dist/node_modules/minimist/test/parse_modified.js +0 -9
- package/dist/node_modules/minimist/test/proto.js +0 -44
- package/dist/node_modules/minimist/test/short.js +0 -67
- package/dist/node_modules/minimist/test/stop_early.js +0 -15
- package/dist/node_modules/minimist/test/unknown.js +0 -102
- package/dist/node_modules/minimist/test/whitespace.js +0 -8
- package/dist/node_modules/mkdirp-classic/LICENSE +0 -21
- package/dist/node_modules/mkdirp-classic/README.md +0 -18
- package/dist/node_modules/mkdirp-classic/index.js +0 -98
- package/dist/node_modules/mkdirp-classic/package.json +0 -47
- package/dist/node_modules/napi-build-utils/LICENSE +0 -21
- package/dist/node_modules/napi-build-utils/README.md +0 -48
- package/dist/node_modules/napi-build-utils/index.js +0 -213
- package/dist/node_modules/napi-build-utils/index.md +0 -81
- package/dist/node_modules/napi-build-utils/package.json +0 -68
- package/dist/node_modules/node-abi/.github/workflows/update-abi.yml +0 -41
- package/dist/node_modules/node-abi/.travis.yml +0 -17
- package/dist/node_modules/node-abi/CODE_OF_CONDUCT.md +0 -73
- package/dist/node_modules/node-abi/CONTRIBUTING.md +0 -53
- package/dist/node_modules/node-abi/LICENSE +0 -21
- package/dist/node_modules/node-abi/README.md +0 -50
- package/dist/node_modules/node-abi/abi_registry.json +0 -144
- package/dist/node_modules/node-abi/index.js +0 -176
- package/dist/node_modules/node-abi/node_modules/semver/CHANGELOG.md +0 -39
- package/dist/node_modules/node-abi/node_modules/semver/LICENSE +0 -15
- package/dist/node_modules/node-abi/node_modules/semver/README.md +0 -412
- package/dist/node_modules/node-abi/node_modules/semver/bin/semver +0 -160
- package/dist/node_modules/node-abi/node_modules/semver/package.json +0 -60
- package/dist/node_modules/node-abi/node_modules/semver/range.bnf +0 -16
- package/dist/node_modules/node-abi/node_modules/semver/semver.js +0 -1483
- package/dist/node_modules/node-abi/package.json +0 -65
- package/dist/node_modules/node-abi/scripts/update-abi-registry.js +0 -119
- package/dist/node_modules/node-abi/test/index.js +0 -174
- package/dist/node_modules/node-addon-api/CHANGELOG.md +0 -722
- package/dist/node_modules/node-addon-api/LICENSE.md +0 -13
- package/dist/node_modules/node-addon-api/README.md +0 -293
- package/dist/node_modules/node-addon-api/common.gypi +0 -21
- package/dist/node_modules/node-addon-api/except.gypi +0 -16
- package/dist/node_modules/node-addon-api/index.js +0 -11
- package/dist/node_modules/node-addon-api/napi-inl.deprecated.h +0 -192
- package/dist/node_modules/node-addon-api/napi-inl.h +0 -5671
- package/dist/node_modules/node-addon-api/napi.h +0 -2727
- package/dist/node_modules/node-addon-api/node_api.gyp +0 -9
- package/dist/node_modules/node-addon-api/noexcept.gypi +0 -16
- package/dist/node_modules/node-addon-api/nothing.c +0 -0
- package/dist/node_modules/node-addon-api/package-support.json +0 -21
- package/dist/node_modules/node-addon-api/package.json +0 -393
- package/dist/node_modules/node-addon-api/tools/README.md +0 -73
- package/dist/node_modules/node-addon-api/tools/check-napi.js +0 -100
- package/dist/node_modules/node-addon-api/tools/clang-format.js +0 -67
- package/dist/node_modules/node-addon-api/tools/conversion.js +0 -309
- package/dist/node_modules/npmlog/CHANGELOG.md +0 -49
- package/dist/node_modules/npmlog/LICENSE +0 -15
- package/dist/node_modules/npmlog/README.md +0 -216
- package/dist/node_modules/npmlog/log.js +0 -309
- package/dist/node_modules/npmlog/package.json +0 -61
- package/dist/node_modules/number-is-nan/index.js +0 -4
- package/dist/node_modules/number-is-nan/license +0 -21
- package/dist/node_modules/number-is-nan/package.json +0 -67
- package/dist/node_modules/number-is-nan/readme.md +0 -28
- package/dist/node_modules/object-assign/index.js +0 -90
- package/dist/node_modules/object-assign/license +0 -21
- package/dist/node_modules/object-assign/package.json +0 -74
- package/dist/node_modules/object-assign/readme.md +0 -61
- package/dist/node_modules/once/LICENSE +0 -15
- package/dist/node_modules/once/README.md +0 -79
- package/dist/node_modules/once/once.js +0 -42
- package/dist/node_modules/once/package.json +0 -68
- package/dist/node_modules/prebuild-install/CHANGELOG.md +0 -81
- package/dist/node_modules/prebuild-install/CONTRIBUTING.md +0 -6
- package/dist/node_modules/prebuild-install/LICENSE +0 -21
- package/dist/node_modules/prebuild-install/README.md +0 -139
- package/dist/node_modules/prebuild-install/asset.js +0 -44
- package/dist/node_modules/prebuild-install/bin.js +0 -78
- package/dist/node_modules/prebuild-install/download.js +0 -142
- package/dist/node_modules/prebuild-install/error.js +0 -14
- package/dist/node_modules/prebuild-install/help.txt +0 -16
- package/dist/node_modules/prebuild-install/index.js +0 -1
- package/dist/node_modules/prebuild-install/log.js +0 -25
- package/dist/node_modules/prebuild-install/package.json +0 -127
- package/dist/node_modules/prebuild-install/proxy.js +0 -35
- package/dist/node_modules/prebuild-install/rc.js +0 -60
- package/dist/node_modules/prebuild-install/util.js +0 -143
- package/dist/node_modules/process-nextick-args/index.js +0 -45
- package/dist/node_modules/process-nextick-args/license.md +0 -19
- package/dist/node_modules/process-nextick-args/package.json +0 -50
- package/dist/node_modules/process-nextick-args/readme.md +0 -18
- package/dist/node_modules/pump/.travis.yml +0 -5
- package/dist/node_modules/pump/LICENSE +0 -21
- package/dist/node_modules/pump/README.md +0 -65
- package/dist/node_modules/pump/index.js +0 -82
- package/dist/node_modules/pump/package.json +0 -60
- package/dist/node_modules/pump/test-browser.js +0 -66
- package/dist/node_modules/pump/test-node.js +0 -53
- package/dist/node_modules/rc/LICENSE.APACHE2 +0 -15
- package/dist/node_modules/rc/LICENSE.BSD +0 -26
- package/dist/node_modules/rc/LICENSE.MIT +0 -24
- package/dist/node_modules/rc/README.md +0 -227
- package/dist/node_modules/rc/browser.js +0 -7
- package/dist/node_modules/rc/cli.js +0 -4
- package/dist/node_modules/rc/index.js +0 -53
- package/dist/node_modules/rc/lib/utils.js +0 -104
- package/dist/node_modules/rc/package.json +0 -64
- package/dist/node_modules/rc/test/ini.js +0 -16
- package/dist/node_modules/rc/test/nested-env-vars.js +0 -50
- package/dist/node_modules/rc/test/test.js +0 -59
- package/dist/node_modules/readable-stream/.travis.yml +0 -34
- package/dist/node_modules/readable-stream/CONTRIBUTING.md +0 -38
- package/dist/node_modules/readable-stream/GOVERNANCE.md +0 -136
- package/dist/node_modules/readable-stream/LICENSE +0 -47
- package/dist/node_modules/readable-stream/README.md +0 -58
- package/dist/node_modules/readable-stream/doc/wg-meetings/2015-01-30.md +0 -60
- package/dist/node_modules/readable-stream/duplex-browser.js +0 -1
- package/dist/node_modules/readable-stream/duplex.js +0 -1
- package/dist/node_modules/readable-stream/lib/_stream_duplex.js +0 -131
- package/dist/node_modules/readable-stream/lib/_stream_passthrough.js +0 -47
- package/dist/node_modules/readable-stream/lib/_stream_readable.js +0 -1019
- package/dist/node_modules/readable-stream/lib/_stream_transform.js +0 -214
- package/dist/node_modules/readable-stream/lib/_stream_writable.js +0 -687
- package/dist/node_modules/readable-stream/lib/internal/streams/BufferList.js +0 -79
- package/dist/node_modules/readable-stream/lib/internal/streams/destroy.js +0 -74
- package/dist/node_modules/readable-stream/lib/internal/streams/stream-browser.js +0 -1
- package/dist/node_modules/readable-stream/lib/internal/streams/stream.js +0 -1
- package/dist/node_modules/readable-stream/package.json +0 -81
- package/dist/node_modules/readable-stream/passthrough.js +0 -1
- package/dist/node_modules/readable-stream/readable-browser.js +0 -7
- package/dist/node_modules/readable-stream/readable.js +0 -19
- package/dist/node_modules/readable-stream/transform.js +0 -1
- package/dist/node_modules/readable-stream/writable-browser.js +0 -1
- package/dist/node_modules/readable-stream/writable.js +0 -8
- package/dist/node_modules/safe-buffer/LICENSE +0 -21
- package/dist/node_modules/safe-buffer/README.md +0 -584
- package/dist/node_modules/safe-buffer/index.d.ts +0 -187
- package/dist/node_modules/safe-buffer/index.js +0 -62
- package/dist/node_modules/safe-buffer/package.json +0 -64
- package/dist/node_modules/semver/CHANGELOG.md +0 -111
- package/dist/node_modules/semver/LICENSE +0 -15
- package/dist/node_modules/semver/README.md +0 -566
- package/dist/node_modules/semver/bin/semver.js +0 -173
- package/dist/node_modules/semver/classes/comparator.js +0 -135
- package/dist/node_modules/semver/classes/index.js +0 -5
- package/dist/node_modules/semver/classes/range.js +0 -510
- package/dist/node_modules/semver/classes/semver.js +0 -287
- package/dist/node_modules/semver/functions/clean.js +0 -6
- package/dist/node_modules/semver/functions/cmp.js +0 -48
- package/dist/node_modules/semver/functions/coerce.js +0 -51
- package/dist/node_modules/semver/functions/compare-build.js +0 -7
- package/dist/node_modules/semver/functions/compare-loose.js +0 -3
- package/dist/node_modules/semver/functions/compare.js +0 -5
- package/dist/node_modules/semver/functions/diff.js +0 -23
- package/dist/node_modules/semver/functions/eq.js +0 -3
- package/dist/node_modules/semver/functions/gt.js +0 -3
- package/dist/node_modules/semver/functions/gte.js +0 -3
- package/dist/node_modules/semver/functions/inc.js +0 -15
- package/dist/node_modules/semver/functions/lt.js +0 -3
- package/dist/node_modules/semver/functions/lte.js +0 -3
- package/dist/node_modules/semver/functions/major.js +0 -3
- package/dist/node_modules/semver/functions/minor.js +0 -3
- package/dist/node_modules/semver/functions/neq.js +0 -3
- package/dist/node_modules/semver/functions/parse.js +0 -33
- package/dist/node_modules/semver/functions/patch.js +0 -3
- package/dist/node_modules/semver/functions/prerelease.js +0 -6
- package/dist/node_modules/semver/functions/rcompare.js +0 -3
- package/dist/node_modules/semver/functions/rsort.js +0 -3
- package/dist/node_modules/semver/functions/satisfies.js +0 -10
- package/dist/node_modules/semver/functions/sort.js +0 -3
- package/dist/node_modules/semver/functions/valid.js +0 -6
- package/dist/node_modules/semver/index.js +0 -48
- package/dist/node_modules/semver/internal/constants.js +0 -17
- package/dist/node_modules/semver/internal/debug.js +0 -9
- package/dist/node_modules/semver/internal/identifiers.js +0 -23
- package/dist/node_modules/semver/internal/parse-options.js +0 -11
- package/dist/node_modules/semver/internal/re.js +0 -182
- package/dist/node_modules/semver/package.json +0 -73
- package/dist/node_modules/semver/preload.js +0 -2
- package/dist/node_modules/semver/range.bnf +0 -16
- package/dist/node_modules/semver/ranges/gtr.js +0 -4
- package/dist/node_modules/semver/ranges/intersects.js +0 -7
- package/dist/node_modules/semver/ranges/ltr.js +0 -4
- package/dist/node_modules/semver/ranges/max-satisfying.js +0 -25
- package/dist/node_modules/semver/ranges/min-satisfying.js +0 -24
- package/dist/node_modules/semver/ranges/min-version.js +0 -60
- package/dist/node_modules/semver/ranges/outside.js +0 -80
- package/dist/node_modules/semver/ranges/simplify.js +0 -44
- package/dist/node_modules/semver/ranges/subset.js +0 -222
- package/dist/node_modules/semver/ranges/to-comparators.js +0 -8
- package/dist/node_modules/semver/ranges/valid.js +0 -11
- package/dist/node_modules/set-blocking/CHANGELOG.md +0 -26
- package/dist/node_modules/set-blocking/LICENSE.txt +0 -14
- package/dist/node_modules/set-blocking/README.md +0 -31
- package/dist/node_modules/set-blocking/index.js +0 -7
- package/dist/node_modules/set-blocking/package.json +0 -70
- package/dist/node_modules/sharp/LICENSE +0 -191
- package/dist/node_modules/sharp/README.md +0 -117
- package/dist/node_modules/sharp/binding.gyp +0 -230
- package/dist/node_modules/sharp/build/Release/sharp.node +0 -0
- package/dist/node_modules/sharp/install/can-compile.js +0 -11
- package/dist/node_modules/sharp/install/dll-copy.js +0 -37
- package/dist/node_modules/sharp/install/libvips.js +0 -180
- package/dist/node_modules/sharp/lib/agent.js +0 -40
- package/dist/node_modules/sharp/lib/channel.js +0 -167
- package/dist/node_modules/sharp/lib/colour.js +0 -130
- package/dist/node_modules/sharp/lib/composite.js +0 -178
- package/dist/node_modules/sharp/lib/constructor.js +0 -392
- package/dist/node_modules/sharp/lib/index.js +0 -13
- package/dist/node_modules/sharp/lib/input.js +0 -429
- package/dist/node_modules/sharp/lib/is.js +0 -129
- package/dist/node_modules/sharp/lib/libvips.js +0 -123
- package/dist/node_modules/sharp/lib/operation.js +0 -648
- package/dist/node_modules/sharp/lib/output.js +0 -1035
- package/dist/node_modules/sharp/lib/platform.js +0 -25
- package/dist/node_modules/sharp/lib/resize.js +0 -454
- package/dist/node_modules/sharp/lib/utility.js +0 -179
- package/dist/node_modules/sharp/package.json +0 -427
- package/dist/node_modules/sharp/src/common.cc +0 -827
- package/dist/node_modules/sharp/src/common.h +0 -308
- package/dist/node_modules/sharp/src/libvips/cplusplus/VConnection.cpp +0 -178
- package/dist/node_modules/sharp/src/libvips/cplusplus/VError.cpp +0 -50
- package/dist/node_modules/sharp/src/libvips/cplusplus/VImage.cpp +0 -1467
- package/dist/node_modules/sharp/src/libvips/cplusplus/VInterpolate.cpp +0 -76
- package/dist/node_modules/sharp/src/libvips/cplusplus/vips-operators.cpp +0 -3526
- package/dist/node_modules/sharp/src/metadata.cc +0 -271
- package/dist/node_modules/sharp/src/metadata.h +0 -90
- package/dist/node_modules/sharp/src/operations.cc +0 -285
- package/dist/node_modules/sharp/src/operations.h +0 -102
- package/dist/node_modules/sharp/src/pipeline.cc +0 -1516
- package/dist/node_modules/sharp/src/pipeline.h +0 -325
- package/dist/node_modules/sharp/src/sharp.cc +0 -52
- package/dist/node_modules/sharp/src/stats.cc +0 -193
- package/dist/node_modules/sharp/src/stats.h +0 -70
- package/dist/node_modules/sharp/src/utilities.cc +0 -243
- package/dist/node_modules/sharp/src/utilities.h +0 -29
- package/dist/node_modules/sharp/vendor/8.10.6/THIRD-PARTY-NOTICES.md +0 -42
- package/dist/node_modules/sharp/vendor/8.10.6/lib/libvips-cpp.so.42 +0 -0
- package/dist/node_modules/sharp/vendor/8.10.6/platform.json +0 -1
- package/dist/node_modules/sharp/vendor/8.10.6/versions.json +0 -31
- package/dist/node_modules/signal-exit/LICENSE.txt +0 -16
- package/dist/node_modules/signal-exit/README.md +0 -39
- package/dist/node_modules/signal-exit/index.js +0 -200
- package/dist/node_modules/signal-exit/package.json +0 -66
- package/dist/node_modules/signal-exit/signals.js +0 -53
- package/dist/node_modules/simple-concat/.travis.yml +0 -3
- package/dist/node_modules/simple-concat/LICENSE +0 -20
- package/dist/node_modules/simple-concat/README.md +0 -44
- package/dist/node_modules/simple-concat/index.js +0 -15
- package/dist/node_modules/simple-concat/package.json +0 -72
- package/dist/node_modules/simple-concat/test/basic.js +0 -41
- package/dist/node_modules/simple-get/LICENSE +0 -20
- package/dist/node_modules/simple-get/README.md +0 -319
- package/dist/node_modules/simple-get/index.js +0 -99
- package/dist/node_modules/simple-get/package.json +0 -79
- package/dist/node_modules/simple-swizzle/LICENSE +0 -21
- package/dist/node_modules/simple-swizzle/README.md +0 -39
- package/dist/node_modules/simple-swizzle/index.js +0 -29
- package/dist/node_modules/simple-swizzle/package.json +0 -71
- package/dist/node_modules/string-width/index.js +0 -37
- package/dist/node_modules/string-width/license +0 -21
- package/dist/node_modules/string-width/package.json +0 -89
- package/dist/node_modules/string-width/readme.md +0 -42
- package/dist/node_modules/string_decoder/.travis.yml +0 -50
- package/dist/node_modules/string_decoder/LICENSE +0 -48
- package/dist/node_modules/string_decoder/README.md +0 -47
- package/dist/node_modules/string_decoder/lib/string_decoder.js +0 -296
- package/dist/node_modules/string_decoder/package.json +0 -61
- package/dist/node_modules/strip-ansi/index.js +0 -6
- package/dist/node_modules/strip-ansi/license +0 -21
- package/dist/node_modules/strip-ansi/package.json +0 -102
- package/dist/node_modules/strip-ansi/readme.md +0 -33
- package/dist/node_modules/strip-json-comments/index.js +0 -70
- package/dist/node_modules/strip-json-comments/license +0 -21
- package/dist/node_modules/strip-json-comments/package.json +0 -74
- package/dist/node_modules/strip-json-comments/readme.md +0 -64
- package/dist/node_modules/tar-fs/.travis.yml +0 -6
- package/dist/node_modules/tar-fs/LICENSE +0 -21
- package/dist/node_modules/tar-fs/README.md +0 -165
- package/dist/node_modules/tar-fs/index.js +0 -351
- package/dist/node_modules/tar-fs/package.json +0 -69
- package/dist/node_modules/tar-fs/test/fixtures/a/hello.txt +0 -1
- package/dist/node_modules/tar-fs/test/fixtures/b/a/test.txt +0 -1
- package/dist/node_modules/tar-fs/test/fixtures/d/file1 +0 -0
- package/dist/node_modules/tar-fs/test/fixtures/d/file2 +0 -0
- package/dist/node_modules/tar-fs/test/fixtures/d/sub-dir/file5 +0 -0
- package/dist/node_modules/tar-fs/test/fixtures/d/sub-files/file3 +0 -0
- package/dist/node_modules/tar-fs/test/fixtures/d/sub-files/file4 +0 -0
- package/dist/node_modules/tar-fs/test/fixtures/e/directory/.ignore +0 -0
- package/dist/node_modules/tar-fs/test/fixtures/e/file +0 -0
- package/dist/node_modules/tar-fs/test/fixtures/invalid.tar +0 -0
- package/dist/node_modules/tar-fs/test/index.js +0 -346
- package/dist/node_modules/tar-stream/LICENSE +0 -21
- package/dist/node_modules/tar-stream/README.md +0 -168
- package/dist/node_modules/tar-stream/extract.js +0 -257
- package/dist/node_modules/tar-stream/headers.js +0 -295
- package/dist/node_modules/tar-stream/index.js +0 -2
- package/dist/node_modules/tar-stream/node_modules/readable-stream/CONTRIBUTING.md +0 -38
- package/dist/node_modules/tar-stream/node_modules/readable-stream/GOVERNANCE.md +0 -136
- package/dist/node_modules/tar-stream/node_modules/readable-stream/LICENSE +0 -47
- package/dist/node_modules/tar-stream/node_modules/readable-stream/README.md +0 -106
- package/dist/node_modules/tar-stream/node_modules/readable-stream/errors-browser.js +0 -127
- package/dist/node_modules/tar-stream/node_modules/readable-stream/errors.js +0 -116
- package/dist/node_modules/tar-stream/node_modules/readable-stream/experimentalWarning.js +0 -17
- package/dist/node_modules/tar-stream/node_modules/readable-stream/lib/_stream_duplex.js +0 -139
- package/dist/node_modules/tar-stream/node_modules/readable-stream/lib/_stream_passthrough.js +0 -39
- package/dist/node_modules/tar-stream/node_modules/readable-stream/lib/_stream_readable.js +0 -1124
- package/dist/node_modules/tar-stream/node_modules/readable-stream/lib/_stream_transform.js +0 -201
- package/dist/node_modules/tar-stream/node_modules/readable-stream/lib/_stream_writable.js +0 -697
- package/dist/node_modules/tar-stream/node_modules/readable-stream/lib/internal/streams/async_iterator.js +0 -207
- package/dist/node_modules/tar-stream/node_modules/readable-stream/lib/internal/streams/buffer_list.js +0 -210
- package/dist/node_modules/tar-stream/node_modules/readable-stream/lib/internal/streams/destroy.js +0 -105
- package/dist/node_modules/tar-stream/node_modules/readable-stream/lib/internal/streams/end-of-stream.js +0 -104
- package/dist/node_modules/tar-stream/node_modules/readable-stream/lib/internal/streams/from-browser.js +0 -3
- package/dist/node_modules/tar-stream/node_modules/readable-stream/lib/internal/streams/from.js +0 -64
- package/dist/node_modules/tar-stream/node_modules/readable-stream/lib/internal/streams/pipeline.js +0 -97
- package/dist/node_modules/tar-stream/node_modules/readable-stream/lib/internal/streams/state.js +0 -27
- package/dist/node_modules/tar-stream/node_modules/readable-stream/lib/internal/streams/stream-browser.js +0 -1
- package/dist/node_modules/tar-stream/node_modules/readable-stream/lib/internal/streams/stream.js +0 -1
- package/dist/node_modules/tar-stream/node_modules/readable-stream/package.json +0 -97
- package/dist/node_modules/tar-stream/node_modules/readable-stream/readable-browser.js +0 -9
- package/dist/node_modules/tar-stream/node_modules/readable-stream/readable.js +0 -16
- package/dist/node_modules/tar-stream/pack.js +0 -255
- package/dist/node_modules/tar-stream/package.json +0 -90
- package/dist/node_modules/tar-stream/sandbox.js +0 -11
- package/dist/node_modules/tunnel-agent/LICENSE +0 -55
- package/dist/node_modules/tunnel-agent/README.md +0 -4
- package/dist/node_modules/tunnel-agent/index.js +0 -244
- package/dist/node_modules/tunnel-agent/package.json +0 -56
- package/dist/node_modules/util-deprecate/History.md +0 -16
- package/dist/node_modules/util-deprecate/LICENSE +0 -24
- package/dist/node_modules/util-deprecate/README.md +0 -53
- package/dist/node_modules/util-deprecate/browser.js +0 -67
- package/dist/node_modules/util-deprecate/node.js +0 -6
- package/dist/node_modules/util-deprecate/package.json +0 -58
- package/dist/node_modules/wide-align/LICENSE +0 -14
- package/dist/node_modules/wide-align/README.md +0 -47
- package/dist/node_modules/wide-align/align.js +0 -65
- package/dist/node_modules/wide-align/package.json +0 -66
- package/dist/node_modules/wrappy/LICENSE +0 -15
- package/dist/node_modules/wrappy/README.md +0 -36
- package/dist/node_modules/wrappy/package.json +0 -58
- package/dist/node_modules/wrappy/wrappy.js +0 -33
- package/dist/node_modules/yallist/LICENSE +0 -15
- package/dist/node_modules/yallist/README.md +0 -204
- package/dist/node_modules/yallist/iterator.js +0 -8
- package/dist/node_modules/yallist/package.json +0 -62
- package/dist/node_modules/yallist/yallist.js +0 -426
- package/dist/package-lock.json +0 -507
- package/dist/package.json +0 -63
- package/dist/static/expected_tile_2193_153_255_z7.png +0 -0
- package/dist/static/expected_tile_NZTM2000Quad_30_33_z6.png +0 -0
- package/dist/static/expected_tile_WebMercatorQuad_252_156_z8.png +0 -0
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { LambdaHttpRequest, LambdaHttpResponse } from '@linzjs/lambda';
|
|
2
|
+
/**
|
|
3
|
+
* Get metadata around the imagery such as the source bounding box or the bounding box of the COGS
|
|
4
|
+
*
|
|
5
|
+
* @example
|
|
6
|
+
* - /v1/imagery/:imageryId/source.geojson
|
|
7
|
+
* - /v1/imagery/:imageryId/covering.geojson
|
|
8
|
+
*/
|
|
9
|
+
export declare function Imagery(req: LambdaHttpRequest): Promise<LambdaHttpResponse>;
|
|
10
|
+
//# sourceMappingURL=imagery.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"imagery.d.ts","sourceRoot":"","sources":["../../src/routes/imagery.ts"],"names":[],"mappings":"AAEA,OAAO,EAAc,iBAAiB,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AAgBnF;;;;;;GAMG;AACH,wBAAsB,OAAO,CAAC,GAAG,EAAE,iBAAiB,GAAG,OAAO,CAAC,kBAAkB,CAAC,CA0BjF"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { Config } from '@basemaps/config';
|
|
2
|
+
import { fsa } from '@basemaps/shared';
|
|
3
|
+
import { HttpHeader, LambdaHttpResponse } from '@linzjs/lambda';
|
|
4
|
+
import { createHash } from 'crypto';
|
|
5
|
+
import { promisify } from 'util';
|
|
6
|
+
import { gzip } from 'zlib';
|
|
7
|
+
import { Router } from '../router.js';
|
|
8
|
+
import { NotModified } from './response.js';
|
|
9
|
+
import { TileEtag } from './tile.etag.js';
|
|
10
|
+
const gzipP = promisify(gzip);
|
|
11
|
+
function isAllowedFile(f) {
|
|
12
|
+
if (f.endsWith('.geojson'))
|
|
13
|
+
return true;
|
|
14
|
+
if (f.endsWith('.json'))
|
|
15
|
+
return true;
|
|
16
|
+
return false;
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Get metadata around the imagery such as the source bounding box or the bounding box of the COGS
|
|
20
|
+
*
|
|
21
|
+
* @example
|
|
22
|
+
* - /v1/imagery/:imageryId/source.geojson
|
|
23
|
+
* - /v1/imagery/:imageryId/covering.geojson
|
|
24
|
+
*/
|
|
25
|
+
export async function Imagery(req) {
|
|
26
|
+
const { rest } = Router.action(req);
|
|
27
|
+
const [imageryId, requestType] = rest;
|
|
28
|
+
if (!isAllowedFile(requestType))
|
|
29
|
+
return new LambdaHttpResponse(404, 'Not found');
|
|
30
|
+
const imagery = await Config.Imagery.get(imageryId);
|
|
31
|
+
if (imagery == null)
|
|
32
|
+
return new LambdaHttpResponse(404, 'Not found');
|
|
33
|
+
const targetPath = fsa.join(imagery.uri, requestType);
|
|
34
|
+
try {
|
|
35
|
+
const buf = await fsa.read(targetPath);
|
|
36
|
+
const cacheKey = createHash('sha256').update(buf).digest('base64');
|
|
37
|
+
if (TileEtag.isNotModified(req, cacheKey))
|
|
38
|
+
return NotModified;
|
|
39
|
+
const response = new LambdaHttpResponse(200, 'ok');
|
|
40
|
+
response.header(HttpHeader.ETag, cacheKey);
|
|
41
|
+
response.header(HttpHeader.ContentEncoding, 'gzip');
|
|
42
|
+
response.buffer(await gzipP(buf), 'application/json');
|
|
43
|
+
req.set('bytes', buf.byteLength);
|
|
44
|
+
return response;
|
|
45
|
+
}
|
|
46
|
+
catch (e) {
|
|
47
|
+
req.log.warn({ targetPath }, 'ImageryMetadata:Failed');
|
|
48
|
+
return new LambdaHttpResponse(404, 'Not found');
|
|
49
|
+
}
|
|
50
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"response.d.ts","sourceRoot":"","sources":["../../src/routes/response.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AAEpD,eAAO,MAAM,QAAQ,oBAA2C,CAAC;AACjE,eAAO,MAAM,WAAW,oBAA8C,CAAC"}
|
package/build/routes/tile.d.ts
CHANGED
|
@@ -1,23 +1,3 @@
|
|
|
1
|
-
import { TileMatrixSet } from '@basemaps/geo';
|
|
2
1
|
import { LambdaHttpRequest, LambdaHttpResponse } from '@linzjs/lambda';
|
|
3
|
-
import { TileMakerSharp } from '@basemaps/tiler-sharp';
|
|
4
|
-
import { TileSetRaster } from '../tile.set.raster.js';
|
|
5
|
-
export declare const TileComposer: TileMakerSharp;
|
|
6
|
-
export declare const NotFound: LambdaHttpResponse;
|
|
7
|
-
export declare const NotModified: LambdaHttpResponse;
|
|
8
|
-
export interface TileJson {
|
|
9
|
-
tiles: string[];
|
|
10
|
-
minzoom: number;
|
|
11
|
-
maxzoom: number;
|
|
12
|
-
format: string;
|
|
13
|
-
tilejson: string;
|
|
14
|
-
}
|
|
15
|
-
export declare const TileRoute: {
|
|
16
|
-
tile(req: LambdaHttpRequest): Promise<LambdaHttpResponse>;
|
|
17
|
-
wmtsLoadTileSets(name: string, tileMatrix: TileMatrixSet | null): Promise<TileSetRaster[]>;
|
|
18
|
-
wmts(req: LambdaHttpRequest): Promise<LambdaHttpResponse>;
|
|
19
|
-
tileJson(req: LambdaHttpRequest): Promise<LambdaHttpResponse>;
|
|
20
|
-
styleJson(req: LambdaHttpRequest, fileName: string): Promise<LambdaHttpResponse>;
|
|
21
|
-
};
|
|
22
2
|
export declare function Tiles(req: LambdaHttpRequest): Promise<LambdaHttpResponse>;
|
|
23
3
|
//# sourceMappingURL=tile.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tile.d.ts","sourceRoot":"","sources":["../../src/routes/tile.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"tile.d.ts","sourceRoot":"","sources":["../../src/routes/tile.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AAUvE,wBAAsB,KAAK,CAAC,GAAG,EAAE,iBAAiB,GAAG,OAAO,CAAC,kBAAkB,CAAC,CAY/E"}
|
package/build/routes/tile.js
CHANGED
|
@@ -1,180 +1,27 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { Config, Env, setNameAndProjection, TileSetName, tileWmtsFromPath, tileXyzFromPath } from '@basemaps/shared';
|
|
3
|
-
import { TileMakerSharp } from '@basemaps/tiler-sharp';
|
|
4
|
-
import { createHash } from 'crypto';
|
|
1
|
+
import { LambdaHttpResponse } from '@linzjs/lambda';
|
|
5
2
|
import { isValidApiKey } from '../api.key.js';
|
|
6
|
-
import { TileSets } from '../tile.set.cache.js';
|
|
7
|
-
import { WmtsCapabilities } from '../wmts.capability.js';
|
|
8
|
-
import { attribution } from './attribution.js';
|
|
9
|
-
import { TileEtag } from './tile.etag.js';
|
|
10
3
|
import { Router } from '../router.js';
|
|
11
|
-
import {
|
|
12
|
-
import {
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
async tile(req) {
|
|
18
|
-
const action = Router.action(req);
|
|
19
|
-
const xyzData = tileXyzFromPath(action.rest);
|
|
20
|
-
if (xyzData == null)
|
|
21
|
-
return NotFound;
|
|
22
|
-
ValidateTilePath.validate(req, xyzData);
|
|
23
|
-
req.timer.start('tileset:load');
|
|
24
|
-
const tileSet = await TileSets.get(xyzData.name, xyzData.tileMatrix);
|
|
25
|
-
req.timer.end('tileset:load');
|
|
26
|
-
if (tileSet == null)
|
|
27
|
-
return NotFound;
|
|
28
|
-
const res = await tileSet.tile(req, xyzData);
|
|
29
|
-
return res;
|
|
30
|
-
},
|
|
31
|
-
async wmtsLoadTileSets(name, tileMatrix) {
|
|
32
|
-
if (tileMatrix != null) {
|
|
33
|
-
const ts = await TileSets.get(name, tileMatrix);
|
|
34
|
-
if (ts == null || ts.isVector())
|
|
35
|
-
return [];
|
|
36
|
-
return [ts];
|
|
37
|
-
}
|
|
38
|
-
if (name === '')
|
|
39
|
-
name = TileSetName.aerial;
|
|
40
|
-
return (await TileSets.getAll(name, tileMatrix)).filter((f) => f.type === 'raster');
|
|
41
|
-
},
|
|
42
|
-
async wmts(req) {
|
|
43
|
-
var _a;
|
|
44
|
-
const action = Router.action(req);
|
|
45
|
-
const wmtsData = tileWmtsFromPath(action.rest);
|
|
46
|
-
if (wmtsData == null)
|
|
47
|
-
return NotFound;
|
|
48
|
-
setNameAndProjection(req, wmtsData);
|
|
49
|
-
const host = (_a = Env.get(Env.PublicUrlBase)) !== null && _a !== void 0 ? _a : '';
|
|
50
|
-
req.timer.start('tileset:load');
|
|
51
|
-
const tileSets = await TileRoute.wmtsLoadTileSets(wmtsData.name, wmtsData.tileMatrix);
|
|
52
|
-
req.timer.end('tileset:load');
|
|
53
|
-
if (tileSets.length === 0)
|
|
54
|
-
return NotFound;
|
|
55
|
-
const providerId = Config.Provider.id('linz');
|
|
56
|
-
const provider = await Config.Provider.get(providerId);
|
|
57
|
-
if (provider == null)
|
|
58
|
-
return NotFound;
|
|
59
|
-
const apiKey = Router.apiKey(req);
|
|
60
|
-
const xml = WmtsCapabilities.toXml(host, provider, tileSets, apiKey);
|
|
61
|
-
if (xml == null)
|
|
62
|
-
return NotFound;
|
|
63
|
-
const data = Buffer.from(xml);
|
|
64
|
-
const cacheKey = createHash('sha256').update(data).digest('base64');
|
|
65
|
-
if (TileEtag.isNotModified(req, cacheKey))
|
|
66
|
-
return NotModified;
|
|
67
|
-
const response = new LambdaHttpResponse(200, 'ok');
|
|
68
|
-
response.header(HttpHeader.ETag, cacheKey);
|
|
69
|
-
response.header(HttpHeader.CacheControl, 'max-age=0');
|
|
70
|
-
response.buffer(data, 'text/xml');
|
|
71
|
-
req.set('bytes', data.byteLength);
|
|
72
|
-
return response;
|
|
73
|
-
},
|
|
74
|
-
async tileJson(req) {
|
|
75
|
-
var _a;
|
|
76
|
-
const { version, rest, name } = Router.action(req);
|
|
77
|
-
const apiKey = Router.apiKey(req);
|
|
78
|
-
const host = (_a = Env.get(Env.PublicUrlBase)) !== null && _a !== void 0 ? _a : '';
|
|
79
|
-
const tileUrl = `${host}/${version}/${name}/${rest[0]}/${rest[1]}/{z}/{x}/{y}.pbf?api=${apiKey}`;
|
|
80
|
-
const tileJson = {
|
|
81
|
-
tiles: [tileUrl],
|
|
82
|
-
minzoom: 0,
|
|
83
|
-
maxzoom: 15,
|
|
84
|
-
format: 'pbf',
|
|
85
|
-
tilejson: '2.0.0',
|
|
86
|
-
};
|
|
87
|
-
const json = JSON.stringify(tileJson);
|
|
88
|
-
const data = Buffer.from(json);
|
|
89
|
-
const cacheKey = createHash('sha256').update(data).digest('base64');
|
|
90
|
-
if (TileEtag.isNotModified(req, cacheKey))
|
|
91
|
-
return NotModified;
|
|
92
|
-
const response = new LambdaHttpResponse(200, 'ok');
|
|
93
|
-
response.header(HttpHeader.ETag, cacheKey);
|
|
94
|
-
response.header(HttpHeader.CacheControl, 'max-age=120');
|
|
95
|
-
response.buffer(data, 'application/json');
|
|
96
|
-
req.set('bytes', data.byteLength);
|
|
97
|
-
return response;
|
|
98
|
-
},
|
|
99
|
-
async styleJson(req, fileName) {
|
|
100
|
-
var _a;
|
|
101
|
-
const apiKey = Router.apiKey(req);
|
|
102
|
-
if (apiKey == null)
|
|
103
|
-
return new LambdaHttpResponse(400, 'Invalid API Key.');
|
|
104
|
-
const styleName = fileName.split('.json')[0];
|
|
105
|
-
const host = (_a = Env.get(Env.PublicUrlBase)) !== null && _a !== void 0 ? _a : '';
|
|
106
|
-
// Get style Config from db
|
|
107
|
-
const dbId = Config.Style.id(styleName);
|
|
108
|
-
const styleConfig = await Config.Style.get(dbId);
|
|
109
|
-
if (styleConfig == null)
|
|
110
|
-
return NotFound;
|
|
111
|
-
// Prepare sources and add linz source
|
|
112
|
-
const style = styleConfig.style;
|
|
113
|
-
const sources = {};
|
|
114
|
-
for (const [key, value] of Object.entries(style.sources)) {
|
|
115
|
-
if (value.type === 'vector') {
|
|
116
|
-
if (value.url.includes(host)) {
|
|
117
|
-
const url = new URL(value.url);
|
|
118
|
-
url.searchParams.set('api', apiKey);
|
|
119
|
-
value.url = url.toString().replace(/%7B/g, '{').replace(/%7D/g, '}');
|
|
120
|
-
}
|
|
121
|
-
}
|
|
122
|
-
else if (value.type === 'raster' && Array.isArray(value.tiles)) {
|
|
123
|
-
for (let i = 0; i < value.tiles.length; i++) {
|
|
124
|
-
const tile = value.tiles[i];
|
|
125
|
-
if (tile.includes(host)) {
|
|
126
|
-
const url = new URL(tile);
|
|
127
|
-
url.searchParams.set('api', apiKey);
|
|
128
|
-
value.tiles[i] = url.toString().replace(/%7B/g, '{').replace(/%7D/g, '}');
|
|
129
|
-
}
|
|
130
|
-
}
|
|
131
|
-
}
|
|
132
|
-
sources[key] = value;
|
|
133
|
-
}
|
|
134
|
-
// prepare Style.json
|
|
135
|
-
const styleJson = {
|
|
136
|
-
/** Style.json version 8 */
|
|
137
|
-
version: 8,
|
|
138
|
-
id: style.id,
|
|
139
|
-
name: style.name,
|
|
140
|
-
sources,
|
|
141
|
-
layers: style.layers,
|
|
142
|
-
metadata: style.metadata || {},
|
|
143
|
-
glyphs: style.glyphs || '',
|
|
144
|
-
sprite: style.sprite || '',
|
|
145
|
-
};
|
|
146
|
-
const json = JSON.stringify(styleJson);
|
|
147
|
-
const data = Buffer.from(json);
|
|
148
|
-
const cacheKey = createHash('sha256').update(data).digest('base64');
|
|
149
|
-
if (TileEtag.isNotModified(req, cacheKey))
|
|
150
|
-
return NotModified;
|
|
151
|
-
const response = new LambdaHttpResponse(200, 'ok');
|
|
152
|
-
response.header(HttpHeader.ETag, cacheKey);
|
|
153
|
-
response.header(HttpHeader.CacheControl, 'no-store');
|
|
154
|
-
response.buffer(data, 'application/json');
|
|
155
|
-
req.set('bytes', data.byteLength);
|
|
156
|
-
return response;
|
|
157
|
-
},
|
|
158
|
-
};
|
|
4
|
+
import { attribution } from './attribution.js';
|
|
5
|
+
import { NotFound } from './response.js';
|
|
6
|
+
import { tileJson } from './tile.json.js';
|
|
7
|
+
import { styleJson } from './tile.style.json.js';
|
|
8
|
+
import { wmts } from './tile.wmts.js';
|
|
9
|
+
import { tileXyz } from './tile.xyz.js';
|
|
159
10
|
export async function Tiles(req) {
|
|
160
11
|
const { rest } = Router.action(req);
|
|
161
12
|
if (rest.length < 1)
|
|
162
13
|
return NotFound;
|
|
163
14
|
const apiKey = Router.apiKey(req);
|
|
164
|
-
const apiKeyHash = createHash('sha256')
|
|
165
|
-
.update(apiKey !== null && apiKey !== void 0 ? apiKey : '')
|
|
166
|
-
.digest('base64');
|
|
167
|
-
req.set('api', apiKeyHash);
|
|
168
15
|
if (!isValidApiKey(apiKey))
|
|
169
16
|
return new LambdaHttpResponse(400, 'Invalid API Key');
|
|
170
17
|
const fileName = rest[rest.length - 1].toLowerCase();
|
|
171
18
|
if (fileName === 'attribution.json')
|
|
172
19
|
return attribution(req);
|
|
173
20
|
if (fileName === 'wmtscapabilities.xml')
|
|
174
|
-
return
|
|
21
|
+
return wmts(req);
|
|
175
22
|
if (fileName === 'tile.json')
|
|
176
|
-
return
|
|
23
|
+
return tileJson(req);
|
|
177
24
|
if (fileName.endsWith('json') && rest[rest.length - 2] === 'style')
|
|
178
|
-
return
|
|
179
|
-
return
|
|
25
|
+
return styleJson(req, fileName);
|
|
26
|
+
return tileXyz(req);
|
|
180
27
|
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { LambdaHttpRequest, LambdaHttpResponse } from '@linzjs/lambda';
|
|
2
|
+
export interface TileJson {
|
|
3
|
+
tiles: string[];
|
|
4
|
+
minzoom: number;
|
|
5
|
+
maxzoom: number;
|
|
6
|
+
format: string;
|
|
7
|
+
tilejson: string;
|
|
8
|
+
}
|
|
9
|
+
export declare function tileJson(req: LambdaHttpRequest): Promise<LambdaHttpResponse>;
|
|
10
|
+
//# sourceMappingURL=tile.json.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tile.json.d.ts","sourceRoot":"","sources":["../../src/routes/tile.json.ts"],"names":[],"mappings":"AACA,OAAO,EAAc,iBAAiB,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AAMnF,MAAM,WAAW,QAAQ;IACvB,KAAK,EAAE,MAAM,EAAE,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED,wBAAsB,QAAQ,CAAC,GAAG,EAAE,iBAAiB,GAAG,OAAO,CAAC,kBAAkB,CAAC,CA4BlF"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { Env } from '@basemaps/shared';
|
|
2
|
+
import { HttpHeader, LambdaHttpResponse } from '@linzjs/lambda';
|
|
3
|
+
import { createHash } from 'crypto';
|
|
4
|
+
import { Router } from '../router.js';
|
|
5
|
+
import { NotModified } from './response.js';
|
|
6
|
+
import { TileEtag } from './tile.etag.js';
|
|
7
|
+
export async function tileJson(req) {
|
|
8
|
+
var _a;
|
|
9
|
+
const { version, rest, name } = Router.action(req);
|
|
10
|
+
const apiKey = Router.apiKey(req);
|
|
11
|
+
const host = (_a = Env.get(Env.PublicUrlBase)) !== null && _a !== void 0 ? _a : '';
|
|
12
|
+
const tileUrl = `${host}/${version}/${name}/${rest[0]}/${rest[1]}/{z}/{x}/{y}.pbf?api=${apiKey}`;
|
|
13
|
+
const tileJson = {
|
|
14
|
+
tiles: [tileUrl],
|
|
15
|
+
minzoom: 0,
|
|
16
|
+
maxzoom: 15,
|
|
17
|
+
format: 'pbf',
|
|
18
|
+
tilejson: '2.0.0',
|
|
19
|
+
};
|
|
20
|
+
const json = JSON.stringify(tileJson);
|
|
21
|
+
const data = Buffer.from(json);
|
|
22
|
+
const cacheKey = createHash('sha256').update(data).digest('base64');
|
|
23
|
+
if (TileEtag.isNotModified(req, cacheKey))
|
|
24
|
+
return NotModified;
|
|
25
|
+
const response = new LambdaHttpResponse(200, 'ok');
|
|
26
|
+
response.header(HttpHeader.ETag, cacheKey);
|
|
27
|
+
response.header(HttpHeader.CacheControl, 'max-age=120');
|
|
28
|
+
response.buffer(data, 'application/json');
|
|
29
|
+
req.set('bytes', data.byteLength);
|
|
30
|
+
return response;
|
|
31
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { LambdaHttpRequest, LambdaHttpResponse } from '@linzjs/lambda';
|
|
2
|
+
/**
|
|
3
|
+
* Convert relative URLS into a full hostname url
|
|
4
|
+
* @param url possible url to update
|
|
5
|
+
* @param apiKey ApiKey to append with ?api= if required
|
|
6
|
+
* @returns Updated Url or empty string if url is empty
|
|
7
|
+
*/
|
|
8
|
+
export declare function convertRelativeUrl(url?: string, apiKey?: string): string;
|
|
9
|
+
export declare function styleJson(req: LambdaHttpRequest, fileName: string): Promise<LambdaHttpResponse>;
|
|
10
|
+
//# sourceMappingURL=tile.style.json.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tile.style.json.d.ts","sourceRoot":"","sources":["../../src/routes/tile.style.json.ts"],"names":[],"mappings":"AAGA,OAAO,EAAc,iBAAiB,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AAOnF;;;;;GAKG;AACH,wBAAgB,kBAAkB,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,MAAM,CAOxE;AAED,wBAAsB,SAAS,CAAC,GAAG,EAAE,iBAAiB,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,kBAAkB,CAAC,CAmDrG"}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import { Config, Env } from '@basemaps/shared';
|
|
2
|
+
import { fsa } from '@chunkd/fs';
|
|
3
|
+
import { HttpHeader, LambdaHttpResponse } from '@linzjs/lambda';
|
|
4
|
+
import { createHash } from 'crypto';
|
|
5
|
+
import { URL } from 'url';
|
|
6
|
+
import { Router } from '../router.js';
|
|
7
|
+
import { NotFound, NotModified } from './response.js';
|
|
8
|
+
import { TileEtag } from './tile.etag.js';
|
|
9
|
+
/**
|
|
10
|
+
* Convert relative URLS into a full hostname url
|
|
11
|
+
* @param url possible url to update
|
|
12
|
+
* @param apiKey ApiKey to append with ?api= if required
|
|
13
|
+
* @returns Updated Url or empty string if url is empty
|
|
14
|
+
*/
|
|
15
|
+
export function convertRelativeUrl(url, apiKey) {
|
|
16
|
+
var _a;
|
|
17
|
+
if (url == null)
|
|
18
|
+
return '';
|
|
19
|
+
const host = (_a = Env.get(Env.PublicUrlBase)) !== null && _a !== void 0 ? _a : '';
|
|
20
|
+
if (!url.startsWith('/'))
|
|
21
|
+
return url; // Not relative ignore
|
|
22
|
+
const fullUrl = new URL(fsa.join(host, url));
|
|
23
|
+
if (apiKey)
|
|
24
|
+
fullUrl.searchParams.set('api', apiKey);
|
|
25
|
+
return fullUrl.toString().replace(/%7B/g, '{').replace(/%7D/g, '}');
|
|
26
|
+
}
|
|
27
|
+
export async function styleJson(req, fileName) {
|
|
28
|
+
const apiKey = Router.apiKey(req);
|
|
29
|
+
if (apiKey == null)
|
|
30
|
+
return new LambdaHttpResponse(400, 'Invalid API Key.');
|
|
31
|
+
const styleName = fileName.split('.json')[0];
|
|
32
|
+
// Get style Config from db
|
|
33
|
+
const dbId = Config.Style.id(styleName);
|
|
34
|
+
const styleConfig = await Config.Style.get(dbId);
|
|
35
|
+
if (styleConfig == null)
|
|
36
|
+
return NotFound;
|
|
37
|
+
// Prepare sources and add linz source
|
|
38
|
+
const style = styleConfig.style;
|
|
39
|
+
const sources = {};
|
|
40
|
+
for (const [key, value] of Object.entries(style.sources)) {
|
|
41
|
+
if (value.type === 'vector') {
|
|
42
|
+
value.url = convertRelativeUrl(value.url, apiKey);
|
|
43
|
+
}
|
|
44
|
+
else if (value.type === 'raster' && Array.isArray(value.tiles)) {
|
|
45
|
+
for (let i = 0; i < value.tiles.length; i++) {
|
|
46
|
+
value.tiles[i] = convertRelativeUrl(value.tiles[i], apiKey);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
sources[key] = value;
|
|
50
|
+
}
|
|
51
|
+
// prepare Style.json
|
|
52
|
+
const styleJson = {
|
|
53
|
+
/** Style.json version 8 */
|
|
54
|
+
version: 8,
|
|
55
|
+
id: style.id,
|
|
56
|
+
name: style.name,
|
|
57
|
+
sources,
|
|
58
|
+
layers: style.layers,
|
|
59
|
+
metadata: style.metadata || {},
|
|
60
|
+
glyphs: convertRelativeUrl(style.glyphs),
|
|
61
|
+
sprite: convertRelativeUrl(style.sprite),
|
|
62
|
+
};
|
|
63
|
+
const json = JSON.stringify(styleJson);
|
|
64
|
+
const data = Buffer.from(json);
|
|
65
|
+
const cacheKey = createHash('sha256').update(data).digest('base64');
|
|
66
|
+
if (TileEtag.isNotModified(req, cacheKey))
|
|
67
|
+
return NotModified;
|
|
68
|
+
const response = new LambdaHttpResponse(200, 'ok');
|
|
69
|
+
response.header(HttpHeader.ETag, cacheKey);
|
|
70
|
+
response.header(HttpHeader.CacheControl, 'no-store');
|
|
71
|
+
response.buffer(data, 'application/json');
|
|
72
|
+
req.set('bytes', data.byteLength);
|
|
73
|
+
return response;
|
|
74
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { LambdaHttpRequest, LambdaHttpResponse } from '@linzjs/lambda';
|
|
2
|
+
/**
|
|
3
|
+
* Serve a WMTS request
|
|
4
|
+
*
|
|
5
|
+
* /v1/tiles/:tileSet/:tileMatrixSet/WMTSCapabilities.xml
|
|
6
|
+
* @example `/v1/tiles/aerial/NZTM2000Quad/WMTSCapabilities.xml`
|
|
7
|
+
*/
|
|
8
|
+
export declare function wmts(req: LambdaHttpRequest): Promise<LambdaHttpResponse>;
|
|
9
|
+
//# sourceMappingURL=tile.wmts.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tile.wmts.d.ts","sourceRoot":"","sources":["../../src/routes/tile.wmts.ts"],"names":[],"mappings":"AAGA,OAAO,EAAc,iBAAiB,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AASnF;;;;;GAKG;AACH,wBAAsB,IAAI,CAAC,GAAG,EAAE,iBAAiB,GAAG,OAAO,CAAC,kBAAkB,CAAC,CA8B9E"}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { Config, TileSetType } from '@basemaps/config';
|
|
2
|
+
import { Env, TileSetName, tileWmtsFromPath } from '@basemaps/shared';
|
|
3
|
+
import { HttpHeader, LambdaHttpResponse } from '@linzjs/lambda';
|
|
4
|
+
import { createHash } from 'crypto';
|
|
5
|
+
import { Router } from '../router.js';
|
|
6
|
+
import { TileSets } from '../tile.set.cache.js';
|
|
7
|
+
import { WmtsCapabilities } from '../wmts.capability.js';
|
|
8
|
+
import { NotFound, NotModified } from './response.js';
|
|
9
|
+
import { TileEtag } from './tile.etag.js';
|
|
10
|
+
/**
|
|
11
|
+
* Serve a WMTS request
|
|
12
|
+
*
|
|
13
|
+
* /v1/tiles/:tileSet/:tileMatrixSet/WMTSCapabilities.xml
|
|
14
|
+
* @example `/v1/tiles/aerial/NZTM2000Quad/WMTSCapabilities.xml`
|
|
15
|
+
*/
|
|
16
|
+
export async function wmts(req) {
|
|
17
|
+
var _a;
|
|
18
|
+
const action = Router.action(req);
|
|
19
|
+
const wmtsData = tileWmtsFromPath(action.rest);
|
|
20
|
+
if (wmtsData == null)
|
|
21
|
+
return NotFound;
|
|
22
|
+
const host = (_a = Env.get(Env.PublicUrlBase)) !== null && _a !== void 0 ? _a : '';
|
|
23
|
+
req.timer.start('tileset:load');
|
|
24
|
+
const tileSets = await wmtsLoadTileSets(wmtsData.name, wmtsData.tileMatrix);
|
|
25
|
+
req.timer.end('tileset:load');
|
|
26
|
+
if (tileSets.length === 0)
|
|
27
|
+
return NotFound;
|
|
28
|
+
const providerId = Config.Provider.id('linz');
|
|
29
|
+
const provider = await Config.Provider.get(providerId);
|
|
30
|
+
if (provider == null)
|
|
31
|
+
return NotFound;
|
|
32
|
+
const apiKey = Router.apiKey(req);
|
|
33
|
+
const xml = WmtsCapabilities.toXml(host, provider, tileSets, apiKey);
|
|
34
|
+
if (xml == null)
|
|
35
|
+
return NotFound;
|
|
36
|
+
const data = Buffer.from(xml);
|
|
37
|
+
const cacheKey = createHash('sha256').update(data).digest('base64');
|
|
38
|
+
if (TileEtag.isNotModified(req, cacheKey))
|
|
39
|
+
return NotModified;
|
|
40
|
+
const response = new LambdaHttpResponse(200, 'ok');
|
|
41
|
+
response.header(HttpHeader.ETag, cacheKey);
|
|
42
|
+
response.header(HttpHeader.CacheControl, 'max-age=0');
|
|
43
|
+
response.buffer(data, 'text/xml');
|
|
44
|
+
req.set('bytes', data.byteLength);
|
|
45
|
+
return response;
|
|
46
|
+
}
|
|
47
|
+
async function wmtsLoadTileSets(name, tileMatrix) {
|
|
48
|
+
if (tileMatrix != null) {
|
|
49
|
+
const ts = await TileSets.get(name, tileMatrix);
|
|
50
|
+
if (ts == null || ts.type === TileSetType.Vector)
|
|
51
|
+
return [];
|
|
52
|
+
return [ts];
|
|
53
|
+
}
|
|
54
|
+
if (name === '')
|
|
55
|
+
name = TileSetName.aerial;
|
|
56
|
+
return (await TileSets.getAll(name, tileMatrix)).filter((f) => f.type === 'raster');
|
|
57
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { LambdaHttpRequest, LambdaHttpResponse } from '@linzjs/lambda';
|
|
2
|
+
/**
|
|
3
|
+
* Serve a tile
|
|
4
|
+
*
|
|
5
|
+
* /v1/tiles/:tileSet/:tileMatrixSet/:z/:x/:y.:tileType
|
|
6
|
+
*
|
|
7
|
+
* @example
|
|
8
|
+
* Vector Tile `/v1/tiles/topographic/EPSG:3857/2/1/1.pbf`
|
|
9
|
+
* Raster Tile `/v1/tiles/aerial/EPSG:3857/6/0/38.webp`
|
|
10
|
+
* @returns
|
|
11
|
+
*/
|
|
12
|
+
export declare function tileXyz(req: LambdaHttpRequest): Promise<LambdaHttpResponse>;
|
|
13
|
+
//# sourceMappingURL=tile.xyz.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tile.xyz.d.ts","sourceRoot":"","sources":["../../src/routes/tile.xyz.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,iBAAiB,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AAMvE;;;;;;;;;GASG;AACH,wBAAsB,OAAO,CAAC,GAAG,EAAE,iBAAiB,GAAG,OAAO,CAAC,kBAAkB,CAAC,CAYjF"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { tileXyzFromPath } from '@basemaps/shared';
|
|
2
|
+
import { Router } from '../router.js';
|
|
3
|
+
import { TileSets } from '../tile.set.cache.js';
|
|
4
|
+
import { ValidateTilePath } from '../validate.js';
|
|
5
|
+
import { NotFound } from './response.js';
|
|
6
|
+
/**
|
|
7
|
+
* Serve a tile
|
|
8
|
+
*
|
|
9
|
+
* /v1/tiles/:tileSet/:tileMatrixSet/:z/:x/:y.:tileType
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
* Vector Tile `/v1/tiles/topographic/EPSG:3857/2/1/1.pbf`
|
|
13
|
+
* Raster Tile `/v1/tiles/aerial/EPSG:3857/6/0/38.webp`
|
|
14
|
+
* @returns
|
|
15
|
+
*/
|
|
16
|
+
export async function tileXyz(req) {
|
|
17
|
+
const action = Router.action(req);
|
|
18
|
+
const xyzData = tileXyzFromPath(action.rest);
|
|
19
|
+
if (xyzData == null)
|
|
20
|
+
return NotFound;
|
|
21
|
+
ValidateTilePath.validate(req, xyzData);
|
|
22
|
+
req.timer.start('tileset:load');
|
|
23
|
+
const tileSet = await TileSets.get(xyzData.name, xyzData.tileMatrix);
|
|
24
|
+
req.timer.end('tileset:load');
|
|
25
|
+
if (tileSet == null)
|
|
26
|
+
return NotFound;
|
|
27
|
+
return await tileSet.tile(req, xyzData);
|
|
28
|
+
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { ChunkSource } from '@chunkd/core';
|
|
2
|
+
interface SourceRequest {
|
|
3
|
+
offset: number;
|
|
4
|
+
length?: number;
|
|
5
|
+
source: string;
|
|
6
|
+
duration?: number;
|
|
7
|
+
}
|
|
8
|
+
export declare class SourceTracer {
|
|
9
|
+
requests: SourceRequest[];
|
|
10
|
+
/** Reset the request tracer */
|
|
11
|
+
reset(): void;
|
|
12
|
+
/** Override the fetchByte function to trace all requests for this source */
|
|
13
|
+
trace(source: ChunkSource): void;
|
|
14
|
+
}
|
|
15
|
+
export declare const St: SourceTracer;
|
|
16
|
+
export {};
|
|
17
|
+
//# sourceMappingURL=source.tracer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"source.tracer.d.ts","sourceRoot":"","sources":["../src/source.tracer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAE3C,UAAU,aAAa;IACrB,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,qBAAa,YAAY;IACvB,QAAQ,EAAE,aAAa,EAAE,CAAM;IAE/B,+BAA+B;IAC/B,KAAK,IAAI,IAAI;IAIb,6EAA6E;IAC7E,KAAK,CAAC,MAAM,EAAE,WAAW,GAAG,IAAI;CAajC;AAED,eAAO,MAAM,EAAE,cAAqB,CAAC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
export class SourceTracer {
|
|
2
|
+
constructor() {
|
|
3
|
+
this.requests = [];
|
|
4
|
+
}
|
|
5
|
+
/** Reset the request tracer */
|
|
6
|
+
reset() {
|
|
7
|
+
this.requests = [];
|
|
8
|
+
}
|
|
9
|
+
/** Override the fetchByte function to trace all requests for this source */
|
|
10
|
+
trace(source) {
|
|
11
|
+
const originFetch = source.fetchBytes;
|
|
12
|
+
source.fetchBytes = async (offset, length) => {
|
|
13
|
+
const request = { source: source.uri, offset, length };
|
|
14
|
+
this.requests.push(request);
|
|
15
|
+
const startTime = Date.now();
|
|
16
|
+
const ret = await originFetch.apply(source, [offset, length]);
|
|
17
|
+
request.duration = Date.now() - startTime;
|
|
18
|
+
return ret;
|
|
19
|
+
};
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
export const St = new SourceTracer();
|
package/build/tile.set.cache.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { TileSetNameParser } from '@basemaps/config';
|
|
1
|
+
import { TileSetNameParser, TileSetType } from '@basemaps/config';
|
|
2
2
|
import { TileMatrixSets } from '@basemaps/geo';
|
|
3
3
|
import { Config } from '@basemaps/shared';
|
|
4
4
|
import { TileSetRaster } from './tile.set.raster.js';
|
|
@@ -42,7 +42,7 @@ export class TileSetCache {
|
|
|
42
42
|
if (nameComp.layer != null) {
|
|
43
43
|
const parentName = TileSetNameParser.componentsToName({ ...nameComp, layer: undefined });
|
|
44
44
|
const parent = await this.get(parentName, tileMatrix);
|
|
45
|
-
if (parent == null || parent.
|
|
45
|
+
if (parent == null || parent.type === TileSetType.Vector)
|
|
46
46
|
return null;
|
|
47
47
|
return parent.child(nameComp.layer);
|
|
48
48
|
}
|
|
@@ -79,7 +79,7 @@ export class TileSetCache {
|
|
|
79
79
|
for (const parent of tileMatrixSets) {
|
|
80
80
|
if (parent == null)
|
|
81
81
|
continue;
|
|
82
|
-
if (parent.
|
|
82
|
+
if (parent.type === TileSetType.Vector)
|
|
83
83
|
continue;
|
|
84
84
|
tileSets.push(parent);
|
|
85
85
|
if (nameComp.layer != null) {
|
package/build/tile.set.d.ts
CHANGED
|
@@ -1,20 +1,4 @@
|
|
|
1
|
-
import { ConfigTileSetRaster, ConfigTileSetVector, TileSetNameComponents, TileSetType } from '@basemaps/config';
|
|
2
|
-
import { TileMatrixSet } from '@basemaps/geo';
|
|
3
|
-
import { LambdaHttpRequest, LambdaHttpResponse } from '@linzjs/lambda';
|
|
4
|
-
import { TileDataXyz } from '@basemaps/shared';
|
|
5
1
|
import { TileSetRaster } from './tile.set.raster.js';
|
|
6
2
|
import { TileSetVector } from './tile.set.vector.js';
|
|
7
3
|
export declare type TileSet = TileSetVector | TileSetRaster;
|
|
8
|
-
export declare abstract class TileSetHandler<T extends ConfigTileSetRaster | ConfigTileSetVector> {
|
|
9
|
-
type: TileSetType;
|
|
10
|
-
components: TileSetNameComponents;
|
|
11
|
-
tileMatrix: TileMatrixSet;
|
|
12
|
-
tileSet: T;
|
|
13
|
-
constructor(name: string, tileMatrix: TileMatrixSet);
|
|
14
|
-
get id(): string;
|
|
15
|
-
get fullName(): string;
|
|
16
|
-
isVector(): this is TileSetVector;
|
|
17
|
-
isRaster(): this is TileSetRaster;
|
|
18
|
-
abstract tile(req: LambdaHttpRequest, xyz: TileDataXyz): Promise<LambdaHttpResponse>;
|
|
19
|
-
}
|
|
20
4
|
//# sourceMappingURL=tile.set.d.ts.map
|