impeditmaiores 1.0.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.
- package/.prettierignore +2 -0
- package/.travis.yml +35 -0
- package/.vscode/launch.json +24 -0
- package/.vscode/settings.json +3 -0
- package/codecov.yml +7 -0
- package/demos/ago-node-cli/README.md +29 -0
- package/demos/ago-node-cli/ago.js +33 -0
- package/demos/ago-node-cli/index.js +11 -0
- package/demos/ago-node-cli/lib/item-export-command.js +48 -0
- package/demos/ago-node-cli/lib/item-search-command.js +35 -0
- package/demos/ago-node-cli/package-lock.json +152 -0
- package/demos/ago-node-cli/package.json +30 -0
- package/demos/attachments/README.md +5 -0
- package/demos/attachments/index.html +165 -0
- package/demos/attachments/package-lock.json +182 -0
- package/demos/attachments/package.json +18 -0
- package/demos/batch-geocoder-node/NYC_Restaurant_Inspection_Results.csv +100 -0
- package/demos/batch-geocoder-node/README.md +15 -0
- package/demos/batch-geocoder-node/batch-geocode.js +115 -0
- package/demos/batch-geocoder-node/config-template.js +18 -0
- package/demos/batch-geocoder-node/package-lock.json +81 -0
- package/demos/batch-geocoder-node/package.json +37 -0
- package/demos/express/README.md +15 -0
- package/demos/express/config.json.template +3 -0
- package/demos/express/package-lock.json +413 -0
- package/demos/express/package.json +18 -0
- package/demos/express/server.js +33 -0
- package/demos/feature-service-browser/README.md +6 -0
- package/demos/feature-service-browser/index.html +122 -0
- package/demos/feature-service-browser/package-lock.json +182 -0
- package/demos/feature-service-browser/package.json +18 -0
- package/demos/geocoder-browser/README.md +10 -0
- package/demos/geocoder-browser/config.js.template +1 -0
- package/demos/geocoder-browser/index.html +131 -0
- package/demos/geocoder-browser/package-lock.json +182 -0
- package/demos/geocoder-browser/package.json +19 -0
- package/demos/geocoder-browser/post-sign-in.html +25 -0
- package/demos/jsapi-integration/README.md +25 -0
- package/demos/jsapi-integration/config.js +6 -0
- package/demos/jsapi-integration/index.html +89 -0
- package/demos/jsapi-integration/package-lock.json +184 -0
- package/demos/jsapi-integration/package.json +19 -0
- package/demos/node-cli-item-management/README.md +10 -0
- package/demos/node-cli-item-management/index.js +238 -0
- package/demos/node-cli-item-management/package-lock.json +152 -0
- package/demos/node-cli-item-management/package.json +27 -0
- package/demos/node-cli-item-management/screenshot.png +0 -0
- package/demos/oauth2-browser/README.md +14 -0
- package/demos/oauth2-browser/authenticate.html +30 -0
- package/demos/oauth2-browser/config.js.template +6 -0
- package/demos/oauth2-browser/index.html +211 -0
- package/demos/oauth2-browser/logo.svg +4 -0
- package/demos/oauth2-browser/package-lock.json +224 -0
- package/demos/oauth2-browser/package.json +18 -0
- package/demos/oauth2-browser/style.css +36 -0
- package/demos/oauth2-browser-retry/README.md +25 -0
- package/demos/oauth2-browser-retry/authenticate.html +22 -0
- package/demos/oauth2-browser-retry/index.html +116 -0
- package/demos/oauth2-browser-retry/logo.svg +4 -0
- package/demos/stream-response-to-file/README.md +7 -0
- package/demos/stream-response-to-file/index.js +36 -0
- package/demos/stream-response-to-file/output/.gitkeep +0 -0
- package/demos/stream-response-to-file/package-lock.json +60 -0
- package/demos/stream-response-to-file/package.json +33 -0
- package/demos/tree-shaking-rollup/.babelrc +3 -0
- package/demos/tree-shaking-rollup/README.md +9 -0
- package/demos/tree-shaking-rollup/index.html +11 -0
- package/demos/tree-shaking-rollup/package-lock.json +2225 -0
- package/demos/tree-shaking-rollup/package.json +25 -0
- package/demos/tree-shaking-rollup/rollup.config.js +17 -0
- package/demos/tree-shaking-rollup/src/index.js +8 -0
- package/demos/tree-shaking-webpack/README.md +8 -0
- package/demos/tree-shaking-webpack/index.html +11 -0
- package/demos/tree-shaking-webpack/package-lock.json +4614 -0
- package/demos/tree-shaking-webpack/package.json +24 -0
- package/demos/tree-shaking-webpack/src/index.js +10 -0
- package/demos/tree-shaking-webpack/webpack.config.js +27 -0
- package/demos/vue/.env.example +11 -0
- package/demos/vue/.eslintrc.js +17 -0
- package/demos/vue/.postcssrc.js +5 -0
- package/demos/vue/README.md +17 -0
- package/demos/vue/babel.config.js +3 -0
- package/demos/vue/package-lock.json +11342 -0
- package/demos/vue/package.json +33 -0
- package/demos/vue/public/favicon.ico +0 -0
- package/demos/vue/public/index.html +24 -0
- package/demos/vue/src/assets/logo.svg +29 -0
- package/demos/vue/src/components/App.vue +305 -0
- package/demos/vue/src/components/Authenticate.vue +65 -0
- package/demos/vue/src/components/Loader.vue +230 -0
- package/demos/vue/src/main.js +92 -0
- package/demos/webmap-checker-sapper/.env.example +5 -0
- package/demos/webmap-checker-sapper/README.md +123 -0
- package/demos/webmap-checker-sapper/appveyor.yml +18 -0
- package/demos/webmap-checker-sapper/cypress/fixtures/example.json +5 -0
- package/demos/webmap-checker-sapper/cypress/integration/spec.js +19 -0
- package/demos/webmap-checker-sapper/cypress/plugins/index.js +17 -0
- package/demos/webmap-checker-sapper/cypress/support/commands.js +25 -0
- package/demos/webmap-checker-sapper/cypress/support/index.js +20 -0
- package/demos/webmap-checker-sapper/cypress.json +4 -0
- package/demos/webmap-checker-sapper/package-lock.json +3870 -0
- package/demos/webmap-checker-sapper/package.json +50 -0
- package/demos/webmap-checker-sapper/rollup.config.js +87 -0
- package/demos/webmap-checker-sapper/src/client.js +20 -0
- package/demos/webmap-checker-sapper/src/components/LayerStatus.html +108 -0
- package/demos/webmap-checker-sapper/src/components/Nav.html +21 -0
- package/demos/webmap-checker-sapper/src/components/WebMap.html +62 -0
- package/demos/webmap-checker-sapper/src/routes/_error.html +41 -0
- package/demos/webmap-checker-sapper/src/routes/_layout.html +21 -0
- package/demos/webmap-checker-sapper/src/routes/auth/authorize.js +18 -0
- package/demos/webmap-checker-sapper/src/routes/auth/exchange-token.js +20 -0
- package/demos/webmap-checker-sapper/src/routes/auth/post-sign-in.js +24 -0
- package/demos/webmap-checker-sapper/src/routes/auth/sign-out.js +10 -0
- package/demos/webmap-checker-sapper/src/routes/index.html +20 -0
- package/demos/webmap-checker-sapper/src/routes/webmaps/[webmapId].html +83 -0
- package/demos/webmap-checker-sapper/src/routes/webmaps/index.html +59 -0
- package/demos/webmap-checker-sapper/src/server.js +101 -0
- package/demos/webmap-checker-sapper/src/service-worker.js +82 -0
- package/demos/webmap-checker-sapper/src/template.html +33 -0
- package/demos/webmap-checker-sapper/src/userInfoMiddleware.js +21 -0
- package/demos/webmap-checker-sapper/src/utils.js +33 -0
- package/demos/webmap-checker-sapper/static/favicon.png +0 -0
- package/demos/webmap-checker-sapper/static/global.css +36 -0
- package/demos/webmap-checker-sapper/static/manifest.json +20 -0
- package/demos/webmap-checker-sapper/static/svelte-logo-192.png +0 -0
- package/demos/webmap-checker-sapper/static/svelte-logo-512.png +0 -0
- package/docs/FAQ.md +48 -0
- package/docs/HISTORY.md +62 -0
- package/docs/acetate.config.js +262 -0
- package/docs/build-typedoc.js +434 -0
- package/docs/generate-srihashes.js +53 -0
- package/docs/src/_layout.html +86 -0
- package/docs/src/api/_declaration.html +600 -0
- package/docs/src/api/_layout.html +204 -0
- package/docs/src/api/_package.html +38 -0
- package/docs/src/api/index.html +16 -0
- package/docs/src/guides/_layout.html +24 -0
- package/docs/src/guides/amd-requirejs-dojo.md +40 -0
- package/docs/src/guides/browser-authentication.md +41 -0
- package/docs/src/guides/bundlers.md +52 -0
- package/docs/src/guides/cli-authentication.md +9 -0
- package/docs/src/guides/client-server-authentication.md +9 -0
- package/docs/src/guides/embedded-apps.md +93 -0
- package/docs/src/guides/from-a-cdn.md +38 -0
- package/docs/src/guides/index.md +59 -0
- package/docs/src/guides/node.md +87 -0
- package/docs/src/guides/package-overview.md +111 -0
- package/docs/src/guides/server-authentication.md +9 -0
- package/docs/src/guides/whats-new-v2-0.md +305 -0
- package/docs/src/img/icons.png +0 -0
- package/docs/src/img/icons@2x.png +0 -0
- package/docs/src/index.html +12 -0
- package/docs/src/js/api-search.js +112 -0
- package/docs/src/js/nav-toggle.js +41 -0
- package/docs/src/sass/_highlight.scss +96 -0
- package/docs/src/sass/_icons.scss +157 -0
- package/docs/src/sass/style.scss +242 -0
- package/docs/src/srihashes.json +12 -0
- package/jasmine.json +7 -0
- package/karma.conf.js +106 -0
- package/lerna.json +8 -0
- package/notes/README.md +68 -0
- package/package.json +87 -0
- package/packages/arcgis-rest-auth/README.md +71 -0
- package/packages/arcgis-rest-auth/package-lock.json +11 -0
- package/packages/arcgis-rest-auth/package.json +69 -0
- package/packages/arcgis-rest-auth/src/ApplicationSession.ts +122 -0
- package/packages/arcgis-rest-auth/src/UserSession.ts +1206 -0
- package/packages/arcgis-rest-auth/src/app-tokens.ts +91 -0
- package/packages/arcgis-rest-auth/src/authenticated-request-options.ts +24 -0
- package/packages/arcgis-rest-auth/src/federation-utils.ts +85 -0
- package/packages/arcgis-rest-auth/src/fetch-token.ts +50 -0
- package/packages/arcgis-rest-auth/src/generate-token.ts +35 -0
- package/packages/arcgis-rest-auth/src/index.ts +9 -0
- package/packages/arcgis-rest-auth/src/validate-app-access.ts +68 -0
- package/packages/arcgis-rest-auth/test/ApplicationSession.test.ts +124 -0
- package/packages/arcgis-rest-auth/test/UserSession.test.ts +1807 -0
- package/packages/arcgis-rest-auth/test/app-tokens.test.ts +91 -0
- package/packages/arcgis-rest-auth/test/federation-utils.test.ts +323 -0
- package/packages/arcgis-rest-auth/test/fetchToken.test.ts +112 -0
- package/packages/arcgis-rest-auth/test/generateToken.test.ts +102 -0
- package/packages/arcgis-rest-auth/test/utils.ts +14 -0
- package/packages/arcgis-rest-auth/test/validate-app-access.test.ts +46 -0
- package/packages/arcgis-rest-auth/tsconfig.json +6 -0
- package/packages/arcgis-rest-feature-layer/README.md +77 -0
- package/packages/arcgis-rest-feature-layer/package-lock.json +11 -0
- package/packages/arcgis-rest-feature-layer/package.json +64 -0
- package/packages/arcgis-rest-feature-layer/src/add.ts +56 -0
- package/packages/arcgis-rest-feature-layer/src/addAttachment.ts +53 -0
- package/packages/arcgis-rest-feature-layer/src/applyEdits.ts +90 -0
- package/packages/arcgis-rest-feature-layer/src/decodeValues.ts +124 -0
- package/packages/arcgis-rest-feature-layer/src/delete.ts +61 -0
- package/packages/arcgis-rest-feature-layer/src/deleteAttachments.ts +52 -0
- package/packages/arcgis-rest-feature-layer/src/getAttachments.ts +55 -0
- package/packages/arcgis-rest-feature-layer/src/getLayer.ts +24 -0
- package/packages/arcgis-rest-feature-layer/src/getService.ts +26 -0
- package/packages/arcgis-rest-feature-layer/src/helpers.ts +79 -0
- package/packages/arcgis-rest-feature-layer/src/index.ts +31 -0
- package/packages/arcgis-rest-feature-layer/src/query.ts +204 -0
- package/packages/arcgis-rest-feature-layer/src/queryRelated.ts +89 -0
- package/packages/arcgis-rest-feature-layer/src/update.ts +56 -0
- package/packages/arcgis-rest-feature-layer/src/updateAttachment.ts +59 -0
- package/packages/arcgis-rest-feature-layer/test/attachments.test.ts +200 -0
- package/packages/arcgis-rest-feature-layer/test/crud.test.ts +195 -0
- package/packages/arcgis-rest-feature-layer/test/decodeValues.test.ts +67 -0
- package/packages/arcgis-rest-feature-layer/test/getLayer.test.ts +31 -0
- package/packages/arcgis-rest-feature-layer/test/getService.test.ts +31 -0
- package/packages/arcgis-rest-feature-layer/test/mocks/cvdQueryResponse.ts +225 -0
- package/packages/arcgis-rest-feature-layer/test/mocks/feature.ts +302 -0
- package/packages/arcgis-rest-feature-layer/test/mocks/fields.ts +779 -0
- package/packages/arcgis-rest-feature-layer/test/mocks/foo.txt +1 -0
- package/packages/arcgis-rest-feature-layer/test/mocks/service.ts +398 -0
- package/packages/arcgis-rest-feature-layer/test/query.test.ts +167 -0
- package/packages/arcgis-rest-feature-layer/tsconfig.json +6 -0
- package/packages/arcgis-rest-geocoding/README.md +86 -0
- package/packages/arcgis-rest-geocoding/package-lock.json +11 -0
- package/packages/arcgis-rest-geocoding/package.json +64 -0
- package/packages/arcgis-rest-geocoding/src/bulk.ts +104 -0
- package/packages/arcgis-rest-geocoding/src/geocode.ts +133 -0
- package/packages/arcgis-rest-geocoding/src/helpers.ts +54 -0
- package/packages/arcgis-rest-geocoding/src/index.ts +15 -0
- package/packages/arcgis-rest-geocoding/src/reverse.ts +84 -0
- package/packages/arcgis-rest-geocoding/src/suggest.ts +45 -0
- package/packages/arcgis-rest-geocoding/test/bulk.test.ts +194 -0
- package/packages/arcgis-rest-geocoding/test/geocode.test.ts +249 -0
- package/packages/arcgis-rest-geocoding/test/helpers.test.ts +85 -0
- package/packages/arcgis-rest-geocoding/test/mocks/responses.ts +637 -0
- package/packages/arcgis-rest-geocoding/test/reverse.test.ts +126 -0
- package/packages/arcgis-rest-geocoding/test/suggest.test.ts +53 -0
- package/packages/arcgis-rest-geocoding/tsconfig.json +6 -0
- package/packages/arcgis-rest-portal/README.md +73 -0
- package/packages/arcgis-rest-portal/package-lock.json +11 -0
- package/packages/arcgis-rest-portal/package.json +64 -0
- package/packages/arcgis-rest-portal/src/groups/add-users.ts +140 -0
- package/packages/arcgis-rest-portal/src/groups/create.ts +43 -0
- package/packages/arcgis-rest-portal/src/groups/get.ts +184 -0
- package/packages/arcgis-rest-portal/src/groups/helpers.ts +14 -0
- package/packages/arcgis-rest-portal/src/groups/invite-users.ts +127 -0
- package/packages/arcgis-rest-portal/src/groups/join.ts +57 -0
- package/packages/arcgis-rest-portal/src/groups/notification.ts +77 -0
- package/packages/arcgis-rest-portal/src/groups/protect.ts +56 -0
- package/packages/arcgis-rest-portal/src/groups/remove-users.ts +76 -0
- package/packages/arcgis-rest-portal/src/groups/remove.ts +32 -0
- package/packages/arcgis-rest-portal/src/groups/search.ts +47 -0
- package/packages/arcgis-rest-portal/src/groups/update-user-membership.ts +63 -0
- package/packages/arcgis-rest-portal/src/groups/update.ts +39 -0
- package/packages/arcgis-rest-portal/src/index.ts +66 -0
- package/packages/arcgis-rest-portal/src/items/add.ts +138 -0
- package/packages/arcgis-rest-portal/src/items/content.ts +67 -0
- package/packages/arcgis-rest-portal/src/items/create.ts +150 -0
- package/packages/arcgis-rest-portal/src/items/export.ts +80 -0
- package/packages/arcgis-rest-portal/src/items/get.ts +437 -0
- package/packages/arcgis-rest-portal/src/items/helpers.ts +275 -0
- package/packages/arcgis-rest-portal/src/items/protect.ts +41 -0
- package/packages/arcgis-rest-portal/src/items/reassign.ts +61 -0
- package/packages/arcgis-rest-portal/src/items/remove.ts +135 -0
- package/packages/arcgis-rest-portal/src/items/search.ts +25 -0
- package/packages/arcgis-rest-portal/src/items/update.ts +184 -0
- package/packages/arcgis-rest-portal/src/items/upload.ts +125 -0
- package/packages/arcgis-rest-portal/src/orgs/notification.ts +131 -0
- package/packages/arcgis-rest-portal/src/sharing/access.ts +84 -0
- package/packages/arcgis-rest-portal/src/sharing/helpers.ts +81 -0
- package/packages/arcgis-rest-portal/src/sharing/is-item-shared-with-group.ts +42 -0
- package/packages/arcgis-rest-portal/src/sharing/share-item-with-group.ts +319 -0
- package/packages/arcgis-rest-portal/src/sharing/unshare-item-with-group.ts +105 -0
- package/packages/arcgis-rest-portal/src/users/get-user-tags.ts +52 -0
- package/packages/arcgis-rest-portal/src/users/get-user-url.ts +18 -0
- package/packages/arcgis-rest-portal/src/users/get-user.ts +58 -0
- package/packages/arcgis-rest-portal/src/users/invitation.ts +156 -0
- package/packages/arcgis-rest-portal/src/users/notification.ts +68 -0
- package/packages/arcgis-rest-portal/src/users/search-users.ts +37 -0
- package/packages/arcgis-rest-portal/src/users/update.ts +66 -0
- package/packages/arcgis-rest-portal/src/util/SearchQueryBuilder.ts +374 -0
- package/packages/arcgis-rest-portal/src/util/array.ts +16 -0
- package/packages/arcgis-rest-portal/src/util/generic-search.ts +99 -0
- package/packages/arcgis-rest-portal/src/util/get-portal-settings.ts +45 -0
- package/packages/arcgis-rest-portal/src/util/get-portal-url.ts +27 -0
- package/packages/arcgis-rest-portal/src/util/get-portal.ts +52 -0
- package/packages/arcgis-rest-portal/src/util/get-subscription-info.ts +43 -0
- package/packages/arcgis-rest-portal/src/util/scrub-control-chars.ts +12 -0
- package/packages/arcgis-rest-portal/src/util/search.ts +42 -0
- package/packages/arcgis-rest-portal/test/groups/add-users.test.ts +239 -0
- package/packages/arcgis-rest-portal/test/groups/crud.test.ts +180 -0
- package/packages/arcgis-rest-portal/test/groups/get.test.ts +176 -0
- package/packages/arcgis-rest-portal/test/groups/invite-users.test.ts +149 -0
- package/packages/arcgis-rest-portal/test/groups/join.test.ts +72 -0
- package/packages/arcgis-rest-portal/test/groups/notification.test.ts +112 -0
- package/packages/arcgis-rest-portal/test/groups/protect.test.ts +72 -0
- package/packages/arcgis-rest-portal/test/groups/remove-users.test.ts +140 -0
- package/packages/arcgis-rest-portal/test/groups/search.test.ts +151 -0
- package/packages/arcgis-rest-portal/test/groups/update-user-membership.test.ts +62 -0
- package/packages/arcgis-rest-portal/test/items/add.test.ts +323 -0
- package/packages/arcgis-rest-portal/test/items/content.test.ts +156 -0
- package/packages/arcgis-rest-portal/test/items/create.test.ts +399 -0
- package/packages/arcgis-rest-portal/test/items/export.test.ts +122 -0
- package/packages/arcgis-rest-portal/test/items/get.test.ts +583 -0
- package/packages/arcgis-rest-portal/test/items/helpers.test.ts +60 -0
- package/packages/arcgis-rest-portal/test/items/protect.test.ts +122 -0
- package/packages/arcgis-rest-portal/test/items/reassign.test.ts +131 -0
- package/packages/arcgis-rest-portal/test/items/remove.test.ts +238 -0
- package/packages/arcgis-rest-portal/test/items/search.test.ts +272 -0
- package/packages/arcgis-rest-portal/test/items/update.test.ts +554 -0
- package/packages/arcgis-rest-portal/test/items/upload.test.ts +282 -0
- package/packages/arcgis-rest-portal/test/mocks/groups/responses.ts +208 -0
- package/packages/arcgis-rest-portal/test/mocks/items/foo.zip +0 -0
- package/packages/arcgis-rest-portal/test/mocks/items/item.ts +526 -0
- package/packages/arcgis-rest-portal/test/mocks/items/resources.ts +38 -0
- package/packages/arcgis-rest-portal/test/mocks/items/search.ts +121 -0
- package/packages/arcgis-rest-portal/test/mocks/portal/response.ts +126 -0
- package/packages/arcgis-rest-portal/test/mocks/portal/settings-response.ts +56 -0
- package/packages/arcgis-rest-portal/test/mocks/sharing/sharing.ts +18 -0
- package/packages/arcgis-rest-portal/test/mocks/users/invitation.ts +70 -0
- package/packages/arcgis-rest-portal/test/mocks/users/notification.ts +34 -0
- package/packages/arcgis-rest-portal/test/mocks/users/user-search.ts +388 -0
- package/packages/arcgis-rest-portal/test/mocks/users/user-tags.ts +5 -0
- package/packages/arcgis-rest-portal/test/mocks/users/user.ts +174 -0
- package/packages/arcgis-rest-portal/test/orgs/notification.test.ts +142 -0
- package/packages/arcgis-rest-portal/test/sharing/access.test.ts +162 -0
- package/packages/arcgis-rest-portal/test/sharing/helpers.test.ts +55 -0
- package/packages/arcgis-rest-portal/test/sharing/share-item-with-group.test.ts +1325 -0
- package/packages/arcgis-rest-portal/test/sharing/unshare-item-with-group.test.ts +288 -0
- package/packages/arcgis-rest-portal/test/users/get-user-tags.test.ts +71 -0
- package/packages/arcgis-rest-portal/test/users/get-user-url.test.ts +40 -0
- package/packages/arcgis-rest-portal/test/users/get-user.test.ts +90 -0
- package/packages/arcgis-rest-portal/test/users/invitation.test.ts +127 -0
- package/packages/arcgis-rest-portal/test/users/notification.test.ts +77 -0
- package/packages/arcgis-rest-portal/test/users/search.test.ts +42 -0
- package/packages/arcgis-rest-portal/test/users/update.test.ts +151 -0
- package/packages/arcgis-rest-portal/test/util/SearchQueryBuilder.test.ts +340 -0
- package/packages/arcgis-rest-portal/test/util/array.test.ts +30 -0
- package/packages/arcgis-rest-portal/test/util/get-portal-settings.test.ts +68 -0
- package/packages/arcgis-rest-portal/test/util/get-portal-url.test.ts +37 -0
- package/packages/arcgis-rest-portal/test/util/portal.test.ts +148 -0
- package/packages/arcgis-rest-portal/test/util/scrub-control-chars.test.ts +22 -0
- package/packages/arcgis-rest-portal/tsconfig.json +6 -0
- package/packages/arcgis-rest-request/README.md +72 -0
- package/packages/arcgis-rest-request/package-lock.json +11 -0
- package/packages/arcgis-rest-request/package.json +60 -0
- package/packages/arcgis-rest-request/src/index.ts +25 -0
- package/packages/arcgis-rest-request/src/request.ts +413 -0
- package/packages/arcgis-rest-request/src/utils/ArcGISRequestError.ts +76 -0
- package/packages/arcgis-rest-request/src/utils/ErrorTypes.ts +29 -0
- package/packages/arcgis-rest-request/src/utils/GrantTypes.ts +5 -0
- package/packages/arcgis-rest-request/src/utils/HTTPMethods.ts +6 -0
- package/packages/arcgis-rest-request/src/utils/IAuthenticationManager.ts +21 -0
- package/packages/arcgis-rest-request/src/utils/IFetchTokenParams.ts +11 -0
- package/packages/arcgis-rest-request/src/utils/IGenerateTokenParams.ts +9 -0
- package/packages/arcgis-rest-request/src/utils/IParamBuilder.ts +3 -0
- package/packages/arcgis-rest-request/src/utils/IParams.ts +6 -0
- package/packages/arcgis-rest-request/src/utils/IParamsBuilder.ts +5 -0
- package/packages/arcgis-rest-request/src/utils/IRequestOptions.ts +49 -0
- package/packages/arcgis-rest-request/src/utils/ITokenRequestOptions.ts +9 -0
- package/packages/arcgis-rest-request/src/utils/ResponseFormats.ts +10 -0
- package/packages/arcgis-rest-request/src/utils/append-custom-params.ts +49 -0
- package/packages/arcgis-rest-request/src/utils/clean-url.ts +20 -0
- package/packages/arcgis-rest-request/src/utils/decode-query-string.ts +27 -0
- package/packages/arcgis-rest-request/src/utils/encode-form-data.ts +38 -0
- package/packages/arcgis-rest-request/src/utils/encode-query-string.ts +35 -0
- package/packages/arcgis-rest-request/src/utils/process-params.ts +108 -0
- package/packages/arcgis-rest-request/src/utils/retryAuthError.ts +10 -0
- package/packages/arcgis-rest-request/src/utils/warn.ts +11 -0
- package/packages/arcgis-rest-request/src/utils/with-options.ts +48 -0
- package/packages/arcgis-rest-request/test/mocks/errors.ts +76 -0
- package/packages/arcgis-rest-request/test/mocks/geojson-feature-collection.ts +13 -0
- package/packages/arcgis-rest-request/test/mocks/param-builder.ts +7 -0
- package/packages/arcgis-rest-request/test/mocks/sharing-rest-info.ts +41 -0
- package/packages/arcgis-rest-request/test/mocks/webmap.ts +41 -0
- package/packages/arcgis-rest-request/test/request.test.ts +571 -0
- package/packages/arcgis-rest-request/test/utils/ArcGISAuthError.test.ts +191 -0
- package/packages/arcgis-rest-request/test/utils/ArcGISRequestError.test.ts +51 -0
- package/packages/arcgis-rest-request/test/utils/check-for-errors.test.ts +111 -0
- package/packages/arcgis-rest-request/test/utils/clean-url.test.ts +50 -0
- package/packages/arcgis-rest-request/test/utils/encode-form-data.test.ts +133 -0
- package/packages/arcgis-rest-request/test/utils/encode-query-string.test.ts +18 -0
- package/packages/arcgis-rest-request/test/utils/process-params.test.ts +205 -0
- package/packages/arcgis-rest-request/test/utils/with-options.test.ts +133 -0
- package/packages/arcgis-rest-request/tsconfig.json +4 -0
- package/packages/arcgis-rest-routing/README.md +75 -0
- package/packages/arcgis-rest-routing/package-lock.json +11 -0
- package/packages/arcgis-rest-routing/package.json +63 -0
- package/packages/arcgis-rest-routing/src/helpers.ts +16 -0
- package/packages/arcgis-rest-routing/src/index.ts +11 -0
- package/packages/arcgis-rest-routing/src/solveRoute.ts +124 -0
- package/packages/arcgis-rest-routing/test/mocks/responses.ts +825 -0
- package/packages/arcgis-rest-routing/test/solveRoute.test.ts +509 -0
- package/packages/arcgis-rest-routing/tsconfig.json +6 -0
- package/packages/arcgis-rest-service-admin/README.md +73 -0
- package/packages/arcgis-rest-service-admin/package-lock.json +11 -0
- package/packages/arcgis-rest-service-admin/package.json +65 -0
- package/packages/arcgis-rest-service-admin/src/addTo.ts +70 -0
- package/packages/arcgis-rest-service-admin/src/create.ts +189 -0
- package/packages/arcgis-rest-service-admin/src/index.ts +11 -0
- package/packages/arcgis-rest-service-admin/src/update.ts +50 -0
- package/packages/arcgis-rest-service-admin/test/addTo.test.ts +350 -0
- package/packages/arcgis-rest-service-admin/test/create.test.ts +294 -0
- package/packages/arcgis-rest-service-admin/test/mocks/layerDefinition.ts +79 -0
- package/packages/arcgis-rest-service-admin/test/mocks/service.ts +81 -0
- package/packages/arcgis-rest-service-admin/test/update.test.ts +115 -0
- package/packages/arcgis-rest-service-admin/tsconfig.json +6 -0
- package/packages/arcgis-rest-types/README.md +66 -0
- package/packages/arcgis-rest-types/package.json +54 -0
- package/packages/arcgis-rest-types/src/feature.ts +39 -0
- package/packages/arcgis-rest-types/src/geometry.ts +272 -0
- package/packages/arcgis-rest-types/src/group.ts +72 -0
- package/packages/arcgis-rest-types/src/index.ts +9 -0
- package/packages/arcgis-rest-types/src/item.ts +81 -0
- package/packages/arcgis-rest-types/src/service.ts +114 -0
- package/packages/arcgis-rest-types/src/statisticDefinition.ts +33 -0
- package/packages/arcgis-rest-types/src/symbol.ts +170 -0
- package/packages/arcgis-rest-types/src/user.ts +49 -0
- package/packages/arcgis-rest-types/src/webmap.ts +1367 -0
- package/packages/arcgis-rest-types/tsconfig.json +10 -0
- package/support/changelog.js +393 -0
- package/support/deploy-doc-site.js +16 -0
- package/support/dev.sh +6 -0
- package/support/publish.sh +47 -0
- package/support/test-helpers.js +9 -0
- package/tsconfig.json +63 -0
- package/tslint.json +16 -0
- package/umd-base-profile.js +81 -0
- package/umd-production-profile.js +13 -0
@@ -0,0 +1,374 @@
|
|
1
|
+
import { IParamBuilder, warn } from "@esri/arcgis-rest-request";
|
2
|
+
/**
|
3
|
+
* `SearchQueryBuilder` can be used to construct the `q` param for [`searchItems`](/arcgis-rest-js/api/portal/searchItems#searchItems-search) or [`searchGroups`](/arcgis-rest-js/api/portal/searchGroups#searchGroups-search). By chaining methods, it helps build complex search queries.
|
4
|
+
*
|
5
|
+
* ```js
|
6
|
+
* const query = new SearchQueryBuilder()
|
7
|
+
* .match("Patrick")
|
8
|
+
* .in("owner")
|
9
|
+
* .and()
|
10
|
+
* .startGroup()
|
11
|
+
* .match("Web Mapping Application")
|
12
|
+
* .in("type")
|
13
|
+
* .or()
|
14
|
+
* .match("Mobile Application")
|
15
|
+
* .in("type")
|
16
|
+
* .or()
|
17
|
+
* .match("Application")
|
18
|
+
* .in("type")
|
19
|
+
* .endGroup()
|
20
|
+
* .and()
|
21
|
+
* .match("Demo App");
|
22
|
+
*
|
23
|
+
* searchItems(query).then((res) => {
|
24
|
+
* console.log(res.results);
|
25
|
+
* });
|
26
|
+
* ```
|
27
|
+
*
|
28
|
+
* Will search for items matching
|
29
|
+
* ```
|
30
|
+
* "owner: Patrick AND (type:"Web Mapping Application" OR type:"Mobile Application" OR type:Application) AND Demo App"
|
31
|
+
* ```
|
32
|
+
*/
|
33
|
+
export class SearchQueryBuilder implements IParamBuilder {
|
34
|
+
private termStack: any[] = [];
|
35
|
+
private rangeStack: any[] = [];
|
36
|
+
private q: string;
|
37
|
+
private openGroups = 0;
|
38
|
+
private currentModifer: string;
|
39
|
+
|
40
|
+
/**
|
41
|
+
* @param q An existing query string to start building from.
|
42
|
+
*/
|
43
|
+
constructor(q: string = "") {
|
44
|
+
this.q = q;
|
45
|
+
}
|
46
|
+
|
47
|
+
/**
|
48
|
+
* Defines strings to search for.
|
49
|
+
*
|
50
|
+
* ```js
|
51
|
+
* const query = new SearchQueryBuilder()
|
52
|
+
* .match("My Layer")
|
53
|
+
* ```
|
54
|
+
*
|
55
|
+
* @param terms strings to search for.
|
56
|
+
*/
|
57
|
+
public match(this: SearchQueryBuilder, ...terms: string[]) {
|
58
|
+
this.termStack = this.termStack.concat(terms);
|
59
|
+
return this;
|
60
|
+
}
|
61
|
+
|
62
|
+
/**
|
63
|
+
* Defines fields to search in. You can pass `"*"` or call this method without arguments to search a default set of fields
|
64
|
+
*
|
65
|
+
* ```js
|
66
|
+
* const query = new SearchQueryBuilder()
|
67
|
+
* .match("My Layer")
|
68
|
+
* .in("title")
|
69
|
+
* ```
|
70
|
+
*
|
71
|
+
* @param field The field to search for the previous match in.
|
72
|
+
*/
|
73
|
+
public in(this: SearchQueryBuilder, field?: string) {
|
74
|
+
const fn = `\`in(${field ? `"${field}"` : ""})\``;
|
75
|
+
|
76
|
+
if (!this.hasRange && !this.hasTerms) {
|
77
|
+
warn(
|
78
|
+
// prettier-ignore
|
79
|
+
`${fn} was called with no call to \`match(...)\` or \`from(...)\`/\`to(...)\`. Your query was not modified.`
|
80
|
+
);
|
81
|
+
return this;
|
82
|
+
}
|
83
|
+
|
84
|
+
if (field && field !== "*") {
|
85
|
+
this.q += `${field}:`;
|
86
|
+
}
|
87
|
+
|
88
|
+
return this.commit();
|
89
|
+
}
|
90
|
+
|
91
|
+
/**
|
92
|
+
* Starts a new search group.
|
93
|
+
*
|
94
|
+
* ```js
|
95
|
+
* const query = new SearchQueryBuilder()
|
96
|
+
* .startGroup()
|
97
|
+
* .match("Lakes")
|
98
|
+
* .in("title")
|
99
|
+
* .endGroup()
|
100
|
+
* .or()
|
101
|
+
* .startGroup()
|
102
|
+
* .match("Rivers")
|
103
|
+
* .in("title")
|
104
|
+
* .endGroup()
|
105
|
+
* ```
|
106
|
+
*/
|
107
|
+
public startGroup(this: SearchQueryBuilder) {
|
108
|
+
this.commit();
|
109
|
+
if (this.openGroups > 0) {
|
110
|
+
this.q += " ";
|
111
|
+
}
|
112
|
+
this.openGroups++;
|
113
|
+
this.q += "(";
|
114
|
+
return this;
|
115
|
+
}
|
116
|
+
|
117
|
+
/**
|
118
|
+
* Ends a search group.
|
119
|
+
*
|
120
|
+
* ```js
|
121
|
+
* const query = new SearchQueryBuilder()
|
122
|
+
* .startGroup()
|
123
|
+
* .match("Lakes")
|
124
|
+
* .in("title")
|
125
|
+
* .endGroup()
|
126
|
+
* .or()
|
127
|
+
* .startGroup()
|
128
|
+
* .match("Rivers")
|
129
|
+
* .in("title")
|
130
|
+
* .endGroup()
|
131
|
+
* ```
|
132
|
+
*/
|
133
|
+
public endGroup(this: SearchQueryBuilder) {
|
134
|
+
if (this.openGroups <= 0) {
|
135
|
+
warn(
|
136
|
+
`\`endGroup(...)\` was called without calling \`startGroup(...)\` first. Your query was not modified.`
|
137
|
+
);
|
138
|
+
return this;
|
139
|
+
}
|
140
|
+
this.commit();
|
141
|
+
this.openGroups--;
|
142
|
+
this.q += ")";
|
143
|
+
return this;
|
144
|
+
}
|
145
|
+
|
146
|
+
/**
|
147
|
+
* Joins two sets of queries with an `AND` clause.
|
148
|
+
*
|
149
|
+
* ```js
|
150
|
+
* const query = new SearchQueryBuilder()
|
151
|
+
* .match("Lakes")
|
152
|
+
* .in("title")
|
153
|
+
* .and()
|
154
|
+
* .match("Rivers")
|
155
|
+
* .in("title")
|
156
|
+
* ```
|
157
|
+
*/
|
158
|
+
public and(this: SearchQueryBuilder) {
|
159
|
+
return this.addModifier("and");
|
160
|
+
}
|
161
|
+
|
162
|
+
/**
|
163
|
+
* Joins two sets of queries with an `OR` clause.
|
164
|
+
*
|
165
|
+
* ```js
|
166
|
+
* const query = new SearchQueryBuilder()
|
167
|
+
* .match("Lakes")
|
168
|
+
* .in("title")
|
169
|
+
* .or()
|
170
|
+
* .match("Rivers")
|
171
|
+
* .in("title")
|
172
|
+
* ```
|
173
|
+
*/
|
174
|
+
public or(this: SearchQueryBuilder) {
|
175
|
+
return this.addModifier("or");
|
176
|
+
}
|
177
|
+
|
178
|
+
/**
|
179
|
+
* Joins two sets of queries with a `NOT` clause. Another option for filtering results is the [prohibit operator '-'](https://developers.arcgis.com/rest/users-groups-and-items/search-reference.htm#ESRI_SECTION1_5C6C35DB9E4A4F4492C5B937BDA2BF67).
|
180
|
+
*
|
181
|
+
* ```js
|
182
|
+
* // omit results with "Rivers" in their title
|
183
|
+
* const query = new SearchQueryBuilder()
|
184
|
+
* .not()
|
185
|
+
* .match("Rivers")
|
186
|
+
* .in("title")
|
187
|
+
*
|
188
|
+
* // equivalent
|
189
|
+
* const query = new SearchQueryBuilder()
|
190
|
+
* .match("Rivers")
|
191
|
+
* .in("-title")
|
192
|
+
* ```
|
193
|
+
*/
|
194
|
+
public not(this: SearchQueryBuilder) {
|
195
|
+
return this.addModifier("not");
|
196
|
+
}
|
197
|
+
|
198
|
+
/**
|
199
|
+
* Begins a new range query.
|
200
|
+
*
|
201
|
+
* ```js
|
202
|
+
* const query = new SearchQueryBuilder()
|
203
|
+
* .from(yesterdaysDate)
|
204
|
+
* .to(todaysDate)
|
205
|
+
* .in("created")
|
206
|
+
* ```
|
207
|
+
*/
|
208
|
+
public from(this: SearchQueryBuilder, term: number | string | Date) {
|
209
|
+
if (this.hasTerms) {
|
210
|
+
warn(
|
211
|
+
// prettier-ignore
|
212
|
+
`\`from(...)\` is not allowed after \`match(...)\` try using \`.from(...).to(...).in(...)\`. Your query was not modified.`
|
213
|
+
);
|
214
|
+
return this;
|
215
|
+
}
|
216
|
+
this.rangeStack[0] = term;
|
217
|
+
return this;
|
218
|
+
}
|
219
|
+
|
220
|
+
/**
|
221
|
+
* Ends a range query.
|
222
|
+
*
|
223
|
+
* ```js
|
224
|
+
* const query = new SearchQueryBuilder()
|
225
|
+
* .from(yesterdaysDate)
|
226
|
+
* .to(todaysDate)
|
227
|
+
* .in("created")
|
228
|
+
* ```
|
229
|
+
*/
|
230
|
+
public to(this: SearchQueryBuilder, term: any) {
|
231
|
+
if (this.hasTerms) {
|
232
|
+
warn(
|
233
|
+
// prettier-ignore
|
234
|
+
`\`to(...)\` is not allowed after \`match(...)\` try using \`.from(...).to(...).in(...)\`. Your query was not modified.`
|
235
|
+
);
|
236
|
+
return this;
|
237
|
+
}
|
238
|
+
this.rangeStack[1] = term;
|
239
|
+
return this;
|
240
|
+
}
|
241
|
+
|
242
|
+
/**
|
243
|
+
* Boosts the previous term to increase its rank in the results.
|
244
|
+
*
|
245
|
+
* ```js
|
246
|
+
* const query = new SearchQueryBuilder()
|
247
|
+
* .match("Lakes")
|
248
|
+
* .in("title")
|
249
|
+
* .or()
|
250
|
+
* .match("Rivers")
|
251
|
+
* .in("title")
|
252
|
+
* .boost(3)
|
253
|
+
* ```
|
254
|
+
*/
|
255
|
+
public boost(this: SearchQueryBuilder, num: number) {
|
256
|
+
this.commit();
|
257
|
+
this.q += `^${num}`;
|
258
|
+
return this;
|
259
|
+
}
|
260
|
+
|
261
|
+
/**
|
262
|
+
* Returns the current query string. Called internally when the request is made.
|
263
|
+
*/
|
264
|
+
public toParam() {
|
265
|
+
this.commit();
|
266
|
+
this.cleanup();
|
267
|
+
return this.q;
|
268
|
+
}
|
269
|
+
|
270
|
+
/**
|
271
|
+
* Returns a new instance of `SearchQueryBuilder` based on the current instance.
|
272
|
+
*/
|
273
|
+
public clone() {
|
274
|
+
this.commit();
|
275
|
+
this.cleanup();
|
276
|
+
return new SearchQueryBuilder(this.q + "");
|
277
|
+
}
|
278
|
+
|
279
|
+
private addModifier(modifier: string) {
|
280
|
+
if (this.currentModifer) {
|
281
|
+
warn(
|
282
|
+
// prettier-ignore
|
283
|
+
`You have called \`${this.currentModifer}()\` after \`${modifier}()\`. Your current query was not modified.`
|
284
|
+
);
|
285
|
+
return this;
|
286
|
+
}
|
287
|
+
|
288
|
+
this.commit();
|
289
|
+
|
290
|
+
if (this.q === "" && modifier !== "not") {
|
291
|
+
warn(
|
292
|
+
`You have called \`${modifier}()\` without calling another method to modify your query first. Try calling \`match()\` first.`
|
293
|
+
);
|
294
|
+
return this;
|
295
|
+
}
|
296
|
+
|
297
|
+
this.currentModifer = modifier;
|
298
|
+
this.q += this.q === "" ? "" : " ";
|
299
|
+
this.q += `${modifier.toUpperCase()} `;
|
300
|
+
return this;
|
301
|
+
}
|
302
|
+
|
303
|
+
private hasWhiteSpace(s: string) {
|
304
|
+
return /\s/g.test(s);
|
305
|
+
}
|
306
|
+
|
307
|
+
private formatTerm(term: any) {
|
308
|
+
if (term instanceof Date) {
|
309
|
+
return term.getTime();
|
310
|
+
}
|
311
|
+
|
312
|
+
if (typeof term === "string" && this.hasWhiteSpace(term)) {
|
313
|
+
return `"${term}"`;
|
314
|
+
}
|
315
|
+
|
316
|
+
return term;
|
317
|
+
}
|
318
|
+
|
319
|
+
private commit() {
|
320
|
+
this.currentModifer = undefined;
|
321
|
+
if (this.hasRange) {
|
322
|
+
this.q += `[${this.formatTerm(this.rangeStack[0])} TO ${this.formatTerm(
|
323
|
+
this.rangeStack[1]
|
324
|
+
)}]`;
|
325
|
+
this.rangeStack = [undefined, undefined];
|
326
|
+
}
|
327
|
+
|
328
|
+
if (this.hasTerms) {
|
329
|
+
this.q += this.termStack
|
330
|
+
.map(term => {
|
331
|
+
return this.formatTerm(term);
|
332
|
+
})
|
333
|
+
.join(" ");
|
334
|
+
this.termStack = [];
|
335
|
+
}
|
336
|
+
|
337
|
+
return this;
|
338
|
+
}
|
339
|
+
|
340
|
+
private get hasTerms() {
|
341
|
+
return this.termStack.length > 0;
|
342
|
+
}
|
343
|
+
|
344
|
+
private get hasRange() {
|
345
|
+
return this.rangeStack.length && this.rangeStack[0] && this.rangeStack[1];
|
346
|
+
}
|
347
|
+
|
348
|
+
private cleanup() {
|
349
|
+
// end a group if we have started one
|
350
|
+
if (this.openGroups > 0) {
|
351
|
+
warn(
|
352
|
+
// prettier-ignore
|
353
|
+
`Automatically closing ${this.openGroups} group(s). You can use \`endGroup(...)\` to remove this warning.`
|
354
|
+
);
|
355
|
+
|
356
|
+
while (this.openGroups > 0) {
|
357
|
+
this.q += ")";
|
358
|
+
this.openGroups--;
|
359
|
+
}
|
360
|
+
}
|
361
|
+
|
362
|
+
const oldQ = this.q;
|
363
|
+
this.q = oldQ.replace(/( AND ?| NOT ?| OR ?)*$/, "");
|
364
|
+
|
365
|
+
if (oldQ !== this.q) {
|
366
|
+
warn(
|
367
|
+
`\`startGroup(...)\` was called without calling \`endGroup(...)\` first. Your query was not modified.`
|
368
|
+
);
|
369
|
+
}
|
370
|
+
|
371
|
+
// clear empty groups
|
372
|
+
this.q = this.q.replace(/(\(\))*/, "");
|
373
|
+
}
|
374
|
+
}
|
@@ -0,0 +1,16 @@
|
|
1
|
+
/* Copyright (c) 2019 Environmental Systems Research Institute, Inc.
|
2
|
+
* Apache-2.0 */
|
3
|
+
|
4
|
+
export function chunk<T>(array: T[], size: number) {
|
5
|
+
if (array.length === 0) {
|
6
|
+
return [];
|
7
|
+
}
|
8
|
+
|
9
|
+
const chunks = [];
|
10
|
+
|
11
|
+
for (let i = 0; i < array.length; i += size) {
|
12
|
+
chunks.push(array.slice(i, i + size));
|
13
|
+
}
|
14
|
+
|
15
|
+
return chunks;
|
16
|
+
}
|
@@ -0,0 +1,99 @@
|
|
1
|
+
/* Copyright (c) 2018 Environmental Systems Research Institute, Inc.
|
2
|
+
* Apache-2.0 */
|
3
|
+
|
4
|
+
import {
|
5
|
+
request,
|
6
|
+
IRequestOptions,
|
7
|
+
appendCustomParams
|
8
|
+
} from "@esri/arcgis-rest-request";
|
9
|
+
import { IItem, IGroup, IUser } from "@esri/arcgis-rest-types";
|
10
|
+
|
11
|
+
import { SearchQueryBuilder } from "./SearchQueryBuilder";
|
12
|
+
import { getPortalUrl } from "../util/get-portal-url";
|
13
|
+
import {
|
14
|
+
ISearchOptions,
|
15
|
+
ISearchGroupContentOptions,
|
16
|
+
ISearchResult
|
17
|
+
} from "../util/search";
|
18
|
+
|
19
|
+
export function genericSearch<T extends IItem | IGroup | IUser>(
|
20
|
+
search:
|
21
|
+
| string
|
22
|
+
| ISearchOptions
|
23
|
+
| ISearchGroupContentOptions
|
24
|
+
| SearchQueryBuilder,
|
25
|
+
searchType: "item" | "group" | "groupContent" | "user"
|
26
|
+
): Promise<ISearchResult<T>> {
|
27
|
+
let url: string;
|
28
|
+
let options: IRequestOptions;
|
29
|
+
if (typeof search === "string" || search instanceof SearchQueryBuilder) {
|
30
|
+
options = {
|
31
|
+
httpMethod: "GET",
|
32
|
+
params: {
|
33
|
+
q: search
|
34
|
+
}
|
35
|
+
};
|
36
|
+
} else {
|
37
|
+
options = appendCustomParams<ISearchOptions>(
|
38
|
+
search,
|
39
|
+
["q", "num", "start", "sortField", "sortOrder"],
|
40
|
+
{
|
41
|
+
httpMethod: "GET"
|
42
|
+
}
|
43
|
+
);
|
44
|
+
}
|
45
|
+
|
46
|
+
let path;
|
47
|
+
switch (searchType) {
|
48
|
+
case "item":
|
49
|
+
path = "/search";
|
50
|
+
break;
|
51
|
+
case "group":
|
52
|
+
path = "/community/groups";
|
53
|
+
break;
|
54
|
+
case "groupContent":
|
55
|
+
// Need to have groupId property to do group contents search,
|
56
|
+
// cso filter out all but ISearchGroupContentOptions
|
57
|
+
if (
|
58
|
+
typeof search !== "string" &&
|
59
|
+
!(search instanceof SearchQueryBuilder) &&
|
60
|
+
search.groupId
|
61
|
+
) {
|
62
|
+
path = `/content/groups/${search.groupId}/search`;
|
63
|
+
} else {
|
64
|
+
return Promise.reject(new Error("you must pass a `groupId` option to `searchGroupContent`"));
|
65
|
+
}
|
66
|
+
break;
|
67
|
+
default:
|
68
|
+
// "users"
|
69
|
+
path = "/portals/self/users/search";
|
70
|
+
break;
|
71
|
+
}
|
72
|
+
url = getPortalUrl(options) + path;
|
73
|
+
|
74
|
+
// send the request
|
75
|
+
return request(url, options).then(r => {
|
76
|
+
if (r.nextStart && r.nextStart !== -1) {
|
77
|
+
r.nextPage = function() {
|
78
|
+
let newOptions: ISearchOptions;
|
79
|
+
|
80
|
+
if (
|
81
|
+
typeof search === "string" ||
|
82
|
+
search instanceof SearchQueryBuilder
|
83
|
+
) {
|
84
|
+
newOptions = {
|
85
|
+
q: search,
|
86
|
+
start: r.nextStart
|
87
|
+
};
|
88
|
+
} else {
|
89
|
+
newOptions = search;
|
90
|
+
newOptions.start = r.nextStart;
|
91
|
+
}
|
92
|
+
|
93
|
+
return genericSearch<T>(newOptions, searchType);
|
94
|
+
};
|
95
|
+
}
|
96
|
+
|
97
|
+
return r;
|
98
|
+
});
|
99
|
+
}
|
@@ -0,0 +1,45 @@
|
|
1
|
+
/* Copyright (c) 2017-2019 Environmental Systems Research Institute, Inc.
|
2
|
+
* Apache-2.0 */
|
3
|
+
|
4
|
+
import { IExtent } from "@esri/arcgis-rest-types";
|
5
|
+
import { request, IRequestOptions } from "@esri/arcgis-rest-request";
|
6
|
+
|
7
|
+
import { getPortalUrl } from "./get-portal-url";
|
8
|
+
|
9
|
+
export interface IPortalSettings {
|
10
|
+
allowedRedirectUris: string[];
|
11
|
+
defaultExtent: IExtent;
|
12
|
+
helperServices: { [key: string]: any };
|
13
|
+
informationalBanner: { [key: string]: any };
|
14
|
+
[key: string]: any;
|
15
|
+
}
|
16
|
+
|
17
|
+
/**
|
18
|
+
* ```js
|
19
|
+
* import { getPortalSettings } from "@esri/arcgis-rest-portal";
|
20
|
+
* //
|
21
|
+
* getPortalSettings()
|
22
|
+
* getPortalSettings("fe8")
|
23
|
+
* getPortalSettings(null, { portal: "https://custom.maps.arcgis.com/sharing/rest/" })
|
24
|
+
* ```
|
25
|
+
* Fetch the settings for the current portal by id. If no id is passed, portals/self/settings will be called
|
26
|
+
* @param id
|
27
|
+
* @param requestOptions
|
28
|
+
*/
|
29
|
+
export function getPortalSettings(
|
30
|
+
id?: string,
|
31
|
+
requestOptions?: IRequestOptions
|
32
|
+
): Promise<IPortalSettings> {
|
33
|
+
// construct the search url
|
34
|
+
const idOrSelf = id ? id : "self";
|
35
|
+
const url = `${getPortalUrl(requestOptions)}/portals/${idOrSelf}/settings`;
|
36
|
+
|
37
|
+
// default to a GET request
|
38
|
+
const options: IRequestOptions = {
|
39
|
+
...{ httpMethod: "GET" },
|
40
|
+
...requestOptions
|
41
|
+
};
|
42
|
+
|
43
|
+
// send the request
|
44
|
+
return request(url, options);
|
45
|
+
}
|
@@ -0,0 +1,27 @@
|
|
1
|
+
/* Copyright (c) 2017 Environmental Systems Research Institute, Inc.
|
2
|
+
* Apache-2.0 */
|
3
|
+
|
4
|
+
import { IRequestOptions, cleanUrl } from "@esri/arcgis-rest-request";
|
5
|
+
|
6
|
+
/**
|
7
|
+
* Helper that returns the appropriate portal url for a given request. `requestOptions.portal` is given
|
8
|
+
* precedence over `authentication.portal`. If neither are present, `www.arcgis.com/sharing/rest` is returned.
|
9
|
+
*
|
10
|
+
* @param requestOptions - Request options that may have authentication manager
|
11
|
+
* @returns Portal url to be used in API requests
|
12
|
+
*/
|
13
|
+
export function getPortalUrl(requestOptions: IRequestOptions = {}): string {
|
14
|
+
// use portal in options if specified
|
15
|
+
if (requestOptions.portal) {
|
16
|
+
return cleanUrl(requestOptions.portal);
|
17
|
+
}
|
18
|
+
|
19
|
+
// if auth was passed, use that portal
|
20
|
+
if (requestOptions.authentication) {
|
21
|
+
// the portal url is already scrubbed in the auth package
|
22
|
+
return requestOptions.authentication.portal;
|
23
|
+
}
|
24
|
+
|
25
|
+
// default to arcgis.com
|
26
|
+
return "https://www.arcgis.com/sharing/rest";
|
27
|
+
}
|
@@ -0,0 +1,52 @@
|
|
1
|
+
/* Copyright (c) 2017-2019 Environmental Systems Research Institute, Inc.
|
2
|
+
* Apache-2.0 */
|
3
|
+
|
4
|
+
import { request, IRequestOptions } from "@esri/arcgis-rest-request";
|
5
|
+
|
6
|
+
import { getPortalUrl } from "./get-portal-url";
|
7
|
+
|
8
|
+
export interface IPortal {
|
9
|
+
id: string;
|
10
|
+
isPortal: boolean;
|
11
|
+
name: string;
|
12
|
+
[key: string]: any;
|
13
|
+
}
|
14
|
+
|
15
|
+
/**
|
16
|
+
* Get the portal
|
17
|
+
* @param requestOptions
|
18
|
+
*/
|
19
|
+
export function getSelf(requestOptions?: IRequestOptions): Promise<IPortal> {
|
20
|
+
// just delegate to getPortal w/o an id
|
21
|
+
return getPortal(null, requestOptions);
|
22
|
+
}
|
23
|
+
|
24
|
+
/**
|
25
|
+
* ```js
|
26
|
+
* import { getPortal } from "@esri/arcgis-rest-request";
|
27
|
+
* //
|
28
|
+
* getPortal()
|
29
|
+
* getPortal("fe8")
|
30
|
+
* getPortal(null, { portal: "https://custom.maps.arcgis.com/sharing/rest/" })
|
31
|
+
* ```
|
32
|
+
* Fetch information about the current portal by id. If no id is passed, portals/self will be called
|
33
|
+
* @param id
|
34
|
+
* @param requestOptions
|
35
|
+
*/
|
36
|
+
export function getPortal(
|
37
|
+
id?: string,
|
38
|
+
requestOptions?: IRequestOptions
|
39
|
+
): Promise<IPortal> {
|
40
|
+
// construct the search url
|
41
|
+
const idOrSelf = id ? id : "self";
|
42
|
+
const url = `${getPortalUrl(requestOptions)}/portals/${idOrSelf}`;
|
43
|
+
|
44
|
+
// default to a GET request
|
45
|
+
const options: IRequestOptions = {
|
46
|
+
...{ httpMethod: "GET" },
|
47
|
+
...requestOptions
|
48
|
+
};
|
49
|
+
|
50
|
+
// send the request
|
51
|
+
return request(url, options);
|
52
|
+
}
|
@@ -0,0 +1,43 @@
|
|
1
|
+
/* Copyright (c) 2017-2019 Environmental Systems Research Institute, Inc.
|
2
|
+
* Apache-2.0 */
|
3
|
+
|
4
|
+
import { request, IRequestOptions } from "@esri/arcgis-rest-request";
|
5
|
+
|
6
|
+
import { getPortalUrl } from "./get-portal-url";
|
7
|
+
|
8
|
+
export interface ISubscriptionInfo {
|
9
|
+
id: string;
|
10
|
+
[key: string]: any;
|
11
|
+
}
|
12
|
+
|
13
|
+
/**
|
14
|
+
* ```js
|
15
|
+
* import { getSubscriptionInfo } from "@esri/arcgis-rest-request";
|
16
|
+
* //
|
17
|
+
* getSubscriptionInfo()
|
18
|
+
* getSubscriptionInfo("fe8")
|
19
|
+
* getSubscriptionInfo(null, { portal: "https://custom.maps.arcgis.com/sharing/rest/" })
|
20
|
+
* ```
|
21
|
+
* Fetch subscription information about the current portal by id. If no id is passed, portals/self/subscriptionInfo will be called
|
22
|
+
* @param id
|
23
|
+
* @param requestOptions
|
24
|
+
*/
|
25
|
+
export function getSubscriptionInfo(
|
26
|
+
id?: string,
|
27
|
+
requestOptions?: IRequestOptions
|
28
|
+
): Promise<ISubscriptionInfo> {
|
29
|
+
// construct the search url
|
30
|
+
const idOrSelf = id ? id : "self";
|
31
|
+
const url = `${getPortalUrl(
|
32
|
+
requestOptions
|
33
|
+
)}/portals/${idOrSelf}/subscriptionInfo`;
|
34
|
+
|
35
|
+
// default to a GET request
|
36
|
+
const options: IRequestOptions = {
|
37
|
+
...{ httpMethod: "GET" },
|
38
|
+
...requestOptions
|
39
|
+
};
|
40
|
+
|
41
|
+
// send the request
|
42
|
+
return request(url, options);
|
43
|
+
}
|
@@ -0,0 +1,12 @@
|
|
1
|
+
const CONTROL_CHAR_MATCHER = /[\x00-\x1F\x7F-\x9F\xA0]/g;
|
2
|
+
|
3
|
+
/**
|
4
|
+
* Returns a new string with all control characters removed.
|
5
|
+
*
|
6
|
+
* Doesn't remove characters from input string.
|
7
|
+
*
|
8
|
+
* @param str - the string to scrub
|
9
|
+
*/
|
10
|
+
export function scrubControlChars (str: string) {
|
11
|
+
return str.replace(CONTROL_CHAR_MATCHER, "");
|
12
|
+
}
|