sintfacilis 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/.env.example +2 -0
- package/.eslintrc.js +20 -0
- package/.github/workflows/deploy-docs.yml +27 -0
- package/.github/workflows/pre-release-tests.yml +45 -0
- package/.github/workflows/pull-request-tests.yml +45 -0
- package/.prettierignore +2 -0
- package/.prettierrc +19 -0
- package/.vscode/launch.json +24 -0
- package/.vscode/settings.json +3 -0
- package/codecov.yml +7 -0
- package/demos/.eslintrc.js +13 -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 +430 -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 +543 -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 +336 -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 +1008 -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 +543 -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 +610 -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 +93 -0
- package/demos/jsapi-integration/package-lock.json +247 -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 +432 -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 +474 -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 +227 -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 +5646 -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 +11455 -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 +28044 -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 +9622 -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/.eslintrc.js +12 -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 +39 -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 +106 -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 +104 -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/img/oauth-browser.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/jasmine.live.json +7 -0
- package/karma.conf.js +107 -0
- package/lerna.json +8 -0
- package/notes/README.md +68 -0
- package/package.json +141 -0
- package/packages/arcgis-rest-auth/README.md +71 -0
- package/packages/arcgis-rest-auth/package.json +69 -0
- package/packages/arcgis-rest-auth/post-message-auth-spec.md +70 -0
- package/packages/arcgis-rest-auth/src/ApiKey.ts +41 -0
- package/packages/arcgis-rest-auth/src/ApplicationSession.ts +122 -0
- package/packages/arcgis-rest-auth/src/UserSession.ts +1355 -0
- package/packages/arcgis-rest-auth/src/app-tokens.ts +131 -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 +13 -0
- package/packages/arcgis-rest-auth/src/validate-app-access.ts +68 -0
- package/packages/arcgis-rest-auth/test/ApiKey.test.ts +35 -0
- package/packages/arcgis-rest-auth/test/ApplicationSession.test.ts +124 -0
- package/packages/arcgis-rest-auth/test/UserSession.test.ts +2377 -0
- package/packages/arcgis-rest-auth/test/app-tokens.test.ts +95 -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-demographics/README.md +75 -0
- package/packages/arcgis-rest-demographics/package.json +69 -0
- package/packages/arcgis-rest-demographics/src/getAvailableCountries.ts +113 -0
- package/packages/arcgis-rest-demographics/src/getAvailableDataCollections.ts +166 -0
- package/packages/arcgis-rest-demographics/src/getAvailableGeographyLevels.ts +88 -0
- package/packages/arcgis-rest-demographics/src/getGeography.ts +152 -0
- package/packages/arcgis-rest-demographics/src/helpers.ts +28 -0
- package/packages/arcgis-rest-demographics/src/index.ts +8 -0
- package/packages/arcgis-rest-demographics/src/queryDemographicData.ts +106 -0
- package/packages/arcgis-rest-demographics/test/getAvailableCountries.test.ts +92 -0
- package/packages/arcgis-rest-demographics/test/getAvailableDataCollections.test.ts +115 -0
- package/packages/arcgis-rest-demographics/test/getAvailableGeographyLevels.test.ts +72 -0
- package/packages/arcgis-rest-demographics/test/getGeography.test.ts +141 -0
- package/packages/arcgis-rest-demographics/test/mocks/responses.ts +4 -0
- package/packages/arcgis-rest-demographics/test/queryDemographicData.test.live.ts +42 -0
- package/packages/arcgis-rest-demographics/test/queryDemographicData.test.ts +113 -0
- package/packages/arcgis-rest-demographics/tsconfig.json +6 -0
- package/packages/arcgis-rest-feature-layer/README.md +77 -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 +95 -0
- package/packages/arcgis-rest-feature-layer/src/decodeValues.ts +122 -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/getAllLayersAndTables.ts +30 -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 +97 -0
- package/packages/arcgis-rest-feature-layer/src/index.ts +32 -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 +60 -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 +197 -0
- package/packages/arcgis-rest-feature-layer/test/decodeValues.test.ts +67 -0
- package/packages/arcgis-rest-feature-layer/test/getAllLayersAndTables.test.ts +28 -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/helpers.test.ts +25 -0
- package/packages/arcgis-rest-feature-layer/test/mocks/allLayersAndTablesResponse.ts +906 -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.json +66 -0
- package/packages/arcgis-rest-geocoding/src/bulk.ts +104 -0
- package/packages/arcgis-rest-geocoding/src/geocode.ts +166 -0
- package/packages/arcgis-rest-geocoding/src/helpers.ts +56 -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 +253 -0
- package/packages/arcgis-rest-geocoding/test/helpers.test.ts +85 -0
- package/packages/arcgis-rest-geocoding/test/mocks/responses.ts +591 -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.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 +69 -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 +292 -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 +141 -0
- package/packages/arcgis-rest-portal/src/items/search.ts +25 -0
- package/packages/arcgis-rest-portal/src/items/update.ts +185 -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/services/get-unique-service-name.ts +35 -0
- package/packages/arcgis-rest-portal/src/services/is-service-name-available.ts +30 -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 +336 -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 +391 -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 +28 -0
- package/packages/arcgis-rest-portal/src/util/get-portal.ts +53 -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 +13 -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 +146 -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 +400 -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 +261 -0
- package/packages/arcgis-rest-portal/test/items/search.test.ts +275 -0
- package/packages/arcgis-rest-portal/test/items/update.test.ts +556 -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 +144 -0
- package/packages/arcgis-rest-portal/test/services/get-unique-service-name.test.ts +59 -0
- package/packages/arcgis-rest-portal/test/services/is-service-name-available.test.ts +46 -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 +1328 -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.json +60 -0
- package/packages/arcgis-rest-request/src/index.ts +25 -0
- package/packages/arcgis-rest-request/src/request.ts +433 -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 +22 -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 +54 -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 +109 -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 +621 -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.json +65 -0
- package/packages/arcgis-rest-routing/src/closestFacility.ts +225 -0
- package/packages/arcgis-rest-routing/src/helpers.ts +104 -0
- package/packages/arcgis-rest-routing/src/index.ts +14 -0
- package/packages/arcgis-rest-routing/src/originDestinationMatrix.ts +223 -0
- package/packages/arcgis-rest-routing/src/serviceArea.ts +173 -0
- package/packages/arcgis-rest-routing/src/solveRoute.ts +180 -0
- package/packages/arcgis-rest-routing/test/closestFacility.test.ts +683 -0
- package/packages/arcgis-rest-routing/test/mocks/inputs.ts +132 -0
- package/packages/arcgis-rest-routing/test/mocks/responses.ts +13316 -0
- package/packages/arcgis-rest-routing/test/originDestinationMatrix.test.ts +795 -0
- package/packages/arcgis-rest-routing/test/serviceArea.test.ts +601 -0
- package/packages/arcgis-rest-routing/test/solveRoute.test.ts +677 -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.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/get-service-admin-info.ts +34 -0
- package/packages/arcgis-rest-service-admin/src/get-view-sources.ts +20 -0
- package/packages/arcgis-rest-service-admin/src/index.ts +14 -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/get-service-admin-info.test.ts +37 -0
- package/packages/arcgis-rest-service-admin/test/get-view-sources.test.ts +40 -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 +5 -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 +42 -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 +156 -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 +1405 -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/umd-base-profile.js +81 -0
- package/umd-production-profile.js +13 -0
@@ -0,0 +1,126 @@
|
|
1
|
+
/* Copyright (c) 2018 Environmental Systems Research Institute, Inc.
|
2
|
+
* Apache-2.0 */
|
3
|
+
|
4
|
+
import { reverseGeocode } from "../src/reverse";
|
5
|
+
|
6
|
+
import * as fetchMock from "fetch-mock";
|
7
|
+
|
8
|
+
import { ReverseGeocode } from "./mocks/responses";
|
9
|
+
|
10
|
+
describe("geocode", () => {
|
11
|
+
afterEach(fetchMock.restore);
|
12
|
+
|
13
|
+
it("should make a reverse geocoding request", done => {
|
14
|
+
fetchMock.once("*", ReverseGeocode);
|
15
|
+
|
16
|
+
reverseGeocode({ x: -118.409, y: 33.9425 })
|
17
|
+
.then(response => {
|
18
|
+
expect(fetchMock.called()).toEqual(true);
|
19
|
+
const [url, options]: [string, RequestInit] = fetchMock.lastCall("*");
|
20
|
+
expect(url).toEqual(
|
21
|
+
"https://geocode-api.arcgis.com/arcgis/rest/services/World/GeocodeServer/reverseGeocode"
|
22
|
+
);
|
23
|
+
expect(options.method).toBe("POST");
|
24
|
+
expect(options.body).toContain("f=json");
|
25
|
+
expect(options.body).toContain(
|
26
|
+
`location=${encodeURIComponent('{"x":-118.409,"y":33.9425}')}`
|
27
|
+
);
|
28
|
+
expect(response).toEqual(ReverseGeocode); // introspect the entire response
|
29
|
+
done();
|
30
|
+
})
|
31
|
+
.catch(e => {
|
32
|
+
fail(e);
|
33
|
+
});
|
34
|
+
});
|
35
|
+
|
36
|
+
it("should make a reverse geocoding GET request and pass through a spatial reference", done => {
|
37
|
+
fetchMock.once("*", ReverseGeocode);
|
38
|
+
|
39
|
+
reverseGeocode(
|
40
|
+
{ x: -118.409, y: 33.9425, spatialReference: { wkid: 4326 } },
|
41
|
+
{ httpMethod: "GET" }
|
42
|
+
)
|
43
|
+
.then(response => {
|
44
|
+
expect(fetchMock.called()).toEqual(true);
|
45
|
+
const [url, options]: [string, RequestInit] = fetchMock.lastCall("*");
|
46
|
+
expect(url).toEqual(
|
47
|
+
"https://geocode-api.arcgis.com/arcgis/rest/services/World/GeocodeServer/reverseGeocode?f=json&location=%7B%22x%22%3A-118.409%2C%22y%22%3A33.9425%2C%22spatialReference%22%3A%7B%22wkid%22%3A4326%7D%7D"
|
48
|
+
);
|
49
|
+
expect(options.method).toBe("GET");
|
50
|
+
expect(response).toEqual(ReverseGeocode); // this introspects the entire response
|
51
|
+
done();
|
52
|
+
})
|
53
|
+
.catch(e => {
|
54
|
+
fail(e);
|
55
|
+
});
|
56
|
+
});
|
57
|
+
|
58
|
+
it("should make a reverse geocoding request and translate lat/long JSON objects", done => {
|
59
|
+
fetchMock.once("*", ReverseGeocode);
|
60
|
+
|
61
|
+
reverseGeocode({ longitude: -118.409, latitude: 33.9425 })
|
62
|
+
.then(response => {
|
63
|
+
expect(fetchMock.called()).toEqual(true);
|
64
|
+
const [url, options]: [string, RequestInit] = fetchMock.lastCall("*");
|
65
|
+
expect(url).toEqual(
|
66
|
+
"https://geocode-api.arcgis.com/arcgis/rest/services/World/GeocodeServer/reverseGeocode"
|
67
|
+
);
|
68
|
+
expect(options.method).toBe("POST");
|
69
|
+
expect(options.body).toContain("f=json");
|
70
|
+
expect(options.body).toContain(
|
71
|
+
`location=${encodeURIComponent("-118.409,33.9425")}`
|
72
|
+
);
|
73
|
+
expect(response).toEqual(ReverseGeocode); // this introspects the entire response
|
74
|
+
done();
|
75
|
+
})
|
76
|
+
.catch(e => {
|
77
|
+
fail(e);
|
78
|
+
});
|
79
|
+
});
|
80
|
+
|
81
|
+
it("should make a reverse geocoding request and translate lat/long JSON abbreviated objects", done => {
|
82
|
+
fetchMock.once("*", ReverseGeocode);
|
83
|
+
|
84
|
+
reverseGeocode({ lat: 33.9425, long: -118.409 })
|
85
|
+
.then(response => {
|
86
|
+
expect(fetchMock.called()).toEqual(true);
|
87
|
+
const [url, options]: [string, RequestInit] = fetchMock.lastCall("*");
|
88
|
+
expect(url).toEqual(
|
89
|
+
"https://geocode-api.arcgis.com/arcgis/rest/services/World/GeocodeServer/reverseGeocode"
|
90
|
+
);
|
91
|
+
expect(options.method).toBe("POST");
|
92
|
+
expect(options.body).toContain("f=json");
|
93
|
+
expect(options.body).toContain(
|
94
|
+
`location=${encodeURIComponent("-118.409,33.9425")}`
|
95
|
+
);
|
96
|
+
expect(response).toEqual(ReverseGeocode); // this introspects the entire response
|
97
|
+
done();
|
98
|
+
})
|
99
|
+
.catch(e => {
|
100
|
+
fail(e);
|
101
|
+
});
|
102
|
+
});
|
103
|
+
|
104
|
+
it("should make a reverse geocoding request and translate a raw long,lat array", done => {
|
105
|
+
fetchMock.once("*", ReverseGeocode);
|
106
|
+
|
107
|
+
reverseGeocode([-118, 34])
|
108
|
+
.then(response => {
|
109
|
+
expect(fetchMock.called()).toEqual(true);
|
110
|
+
const [url, options]: [string, RequestInit] = fetchMock.lastCall("*");
|
111
|
+
expect(url).toEqual(
|
112
|
+
"https://geocode-api.arcgis.com/arcgis/rest/services/World/GeocodeServer/reverseGeocode"
|
113
|
+
);
|
114
|
+
expect(options.method).toBe("POST");
|
115
|
+
expect(options.body).toContain("f=json");
|
116
|
+
expect(options.body).toContain(
|
117
|
+
`location=${encodeURIComponent("-118,34")}`
|
118
|
+
);
|
119
|
+
expect(response).toEqual(ReverseGeocode); // this introspects the entire response
|
120
|
+
done();
|
121
|
+
})
|
122
|
+
.catch(e => {
|
123
|
+
fail(e);
|
124
|
+
});
|
125
|
+
});
|
126
|
+
});
|
@@ -0,0 +1,53 @@
|
|
1
|
+
/* Copyright (c) 2018 Environmental Systems Research Institute, Inc.
|
2
|
+
* Apache-2.0 */
|
3
|
+
|
4
|
+
import { suggest } from "../src/suggest";
|
5
|
+
import * as fetchMock from "fetch-mock";
|
6
|
+
import { Suggest } from "./mocks/responses";
|
7
|
+
|
8
|
+
describe("geocode", () => {
|
9
|
+
afterEach(fetchMock.restore);
|
10
|
+
|
11
|
+
it("should make a request for suggestions", done => {
|
12
|
+
fetchMock.once("*", Suggest);
|
13
|
+
|
14
|
+
suggest("LAX")
|
15
|
+
.then(response => {
|
16
|
+
expect(fetchMock.called()).toEqual(true);
|
17
|
+
const [url, options]: [string, RequestInit] = fetchMock.lastCall("*");
|
18
|
+
expect(url).toEqual(
|
19
|
+
"https://geocode-api.arcgis.com/arcgis/rest/services/World/GeocodeServer/suggest"
|
20
|
+
);
|
21
|
+
expect(options.method).toBe("POST");
|
22
|
+
expect(options.body).toContain("f=json");
|
23
|
+
expect(options.body).toContain("text=LAX");
|
24
|
+
expect(response).toEqual(Suggest); // this introspects the entire response
|
25
|
+
done();
|
26
|
+
})
|
27
|
+
.catch(e => {
|
28
|
+
fail(e);
|
29
|
+
});
|
30
|
+
});
|
31
|
+
|
32
|
+
it("should make a request for suggestions with other parameters", done => {
|
33
|
+
fetchMock.once("*", Suggest);
|
34
|
+
|
35
|
+
suggest("LAX", { params: { category: "Address,Postal" } })
|
36
|
+
.then(response => {
|
37
|
+
expect(fetchMock.called()).toEqual(true);
|
38
|
+
const [url, options]: [string, RequestInit] = fetchMock.lastCall("*");
|
39
|
+
expect(url).toEqual(
|
40
|
+
"https://geocode-api.arcgis.com/arcgis/rest/services/World/GeocodeServer/suggest"
|
41
|
+
);
|
42
|
+
expect(options.method).toBe("POST");
|
43
|
+
expect(options.body).toContain("f=json");
|
44
|
+
expect(options.body).toContain("text=LAX");
|
45
|
+
expect(options.body).toContain("category=Address%2CPostal");
|
46
|
+
expect(response).toEqual(Suggest); // this introspects the entire response
|
47
|
+
done();
|
48
|
+
})
|
49
|
+
.catch(e => {
|
50
|
+
fail(e);
|
51
|
+
});
|
52
|
+
});
|
53
|
+
});
|
@@ -0,0 +1,73 @@
|
|
1
|
+
[![npm version][npm-img]][npm-url]
|
2
|
+
[![build status][travis-img]][travis-url]
|
3
|
+
[![gzip bundle size][gzip-image]][npm-url]
|
4
|
+
[![Coverage Status][coverage-img]][coverage-url]
|
5
|
+
[](https://raw.githubusercontent.com/Esri/arcgis-rest-js/master/LICENSE)
|
6
|
+
|
7
|
+
[npm-img]: https://img.shields.io/npm/v/@esri/arcgis-rest-portal.svg?style=flat-square
|
8
|
+
[npm-url]: https://www.npmjs.com/package/@esri/arcgis-rest-portal
|
9
|
+
[travis-img]: https://img.shields.io/travis/Esri/arcgis-rest-js/master.svg?style=flat-square
|
10
|
+
[travis-url]: https://travis-ci.org/Esri/arcgis-rest-js
|
11
|
+
[gzip-image]: https://img.badgesize.io/https://unpkg.com/@esri/arcgis-rest-portal/dist/umd/portal.umd.min.js?compression=gzip
|
12
|
+
[coverage-img]: https://codecov.io/gh/Esri/arcgis-rest-js/branch/master/graph/badge.svg
|
13
|
+
[coverage-url]: https://codecov.io/gh/Esri/arcgis-rest-js
|
14
|
+
|
15
|
+
# @esri/arcgis-rest-portal
|
16
|
+
|
17
|
+
> A module for working with ArcGIS Online and Enterprise content via the REST API that runs in Node.js and modern browsers.
|
18
|
+
|
19
|
+
### Example
|
20
|
+
|
21
|
+
```bash
|
22
|
+
npm install @esri/arcgis-rest-request
|
23
|
+
npm install @esri/arcgis-rest-portal
|
24
|
+
```
|
25
|
+
|
26
|
+
```js
|
27
|
+
import { getItem } from '@esri/arcgis-rest-portal';
|
28
|
+
|
29
|
+
const itemId = "30e5fe3149c34df1ba922e6f5bbf808f";
|
30
|
+
|
31
|
+
getItem(itemId)
|
32
|
+
.then(response => {
|
33
|
+
console.log(response.title) // World Topographic Map
|
34
|
+
});
|
35
|
+
```
|
36
|
+
|
37
|
+
### [API Reference](https://esri.github.io/arcgis-rest-js/api/portal/)
|
38
|
+
|
39
|
+
### Issues
|
40
|
+
|
41
|
+
If something isn't working the way you expected, please take a look at [previously logged issues](https://github.com/Esri/arcgis-rest-js/issues) first. Have you found a new bug? Want to request a new feature? We'd [**love**](https://github.com/Esri/arcgis-rest-js/issues/new) to hear from you.
|
42
|
+
|
43
|
+
If you're looking for help you can also post issues on [GIS Stackexchange](http://gis.stackexchange.com/questions/ask?tags=esri-oss).
|
44
|
+
|
45
|
+
### Versioning
|
46
|
+
|
47
|
+
For transparency into the release cycle and in striving to maintain backward compatibility, @esri/arcgis-rest-js is maintained under Semantic Versioning guidelines and will adhere to these rules whenever possible.
|
48
|
+
|
49
|
+
For more information on SemVer, please visit <http://semver.org/>.
|
50
|
+
|
51
|
+
### Contributing
|
52
|
+
|
53
|
+
Esri welcomes contributions from anyone and everyone. Please see our [guidelines for contributing](CONTRIBUTING.md).
|
54
|
+
|
55
|
+
### [Changelog](https://github.com/Esri/arcgis-rest-js/blob/master/CHANGELOG.md)
|
56
|
+
|
57
|
+
### License
|
58
|
+
|
59
|
+
Copyright © 2017-2019 Esri
|
60
|
+
|
61
|
+
Licensed under the Apache License, Version 2.0 (the "License");
|
62
|
+
you may not use this file except in compliance with the License.
|
63
|
+
You may obtain a copy of the License at
|
64
|
+
|
65
|
+
> http://www.apache.org/licenses/LICENSE-2.0
|
66
|
+
|
67
|
+
Unless required by applicable law or agreed to in writing, software
|
68
|
+
distributed under the License is distributed on an "AS IS" BASIS,
|
69
|
+
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
70
|
+
See the License for the specific language governing permissions and
|
71
|
+
limitations under the License.
|
72
|
+
|
73
|
+
A copy of the license is available in the repository's [LICENSE](../../LICENSE) file.
|
@@ -0,0 +1,64 @@
|
|
1
|
+
{
|
2
|
+
"name": "@esri/arcgis-rest-portal",
|
3
|
+
"version": "3.3.0",
|
4
|
+
"description": "ArcGIS Online and Enterprise content and user helpers for @esri/arcgis-rest-request",
|
5
|
+
"main": "dist/node/index.js",
|
6
|
+
"unpkg": "dist/umd/portal.umd.js",
|
7
|
+
"module": "dist/esm/index.js",
|
8
|
+
"js:next": "dist/esm/index.js",
|
9
|
+
"sideEffects": false,
|
10
|
+
"types": "dist/esm/index.d.ts",
|
11
|
+
"license": "Apache-2.0",
|
12
|
+
"files": [
|
13
|
+
"dist/**"
|
14
|
+
],
|
15
|
+
"dependencies": {
|
16
|
+
"@esri/arcgis-rest-types": "^3.3.0",
|
17
|
+
"tslib": "^1.13.0"
|
18
|
+
},
|
19
|
+
"devDependencies": {
|
20
|
+
"@esri/arcgis-rest-auth": "^3.3.0",
|
21
|
+
"@esri/arcgis-rest-request": "^3.3.0"
|
22
|
+
},
|
23
|
+
"peerDependencies": {
|
24
|
+
"@esri/arcgis-rest-auth": "^3.0.0",
|
25
|
+
"@esri/arcgis-rest-request": "^3.0.0"
|
26
|
+
},
|
27
|
+
"scripts": {
|
28
|
+
"prepare": "npm run build",
|
29
|
+
"build": "npm run build:node && npm run build:umd && npm run build:esm",
|
30
|
+
"build:esm": "tsc --module es2015 --outDir ./dist/esm --declaration",
|
31
|
+
"build:umd": "rollup -c ../../umd-base-profile.js && rollup -c ../../umd-production-profile.js",
|
32
|
+
"build:node": "tsc --module commonjs --outDir ./dist/node",
|
33
|
+
"dev:esm": "tsc -w --module es2015 --outDir ./dist/esm --declaration",
|
34
|
+
"dev:umd": "rollup -w -c ../../umd-base-profile.js",
|
35
|
+
"dev:node": "tsc -w --module commonjs --outDir ./dist/node"
|
36
|
+
},
|
37
|
+
"publishConfig": {
|
38
|
+
"access": "public"
|
39
|
+
},
|
40
|
+
"repository": {
|
41
|
+
"type": "git",
|
42
|
+
"url": "git+https://github.com/Esri/arcgis-rest-js.git",
|
43
|
+
"directory": "packages/arcgis-rest-portal"
|
44
|
+
},
|
45
|
+
"contributors": [
|
46
|
+
{
|
47
|
+
"name": "Dave Bouwman",
|
48
|
+
"email": "dbouwman@esri.com",
|
49
|
+
"url": "http://blog.davebouwman.com/"
|
50
|
+
}
|
51
|
+
],
|
52
|
+
"bugs": {
|
53
|
+
"url": "https://github.com/Esri/arcgis-rest-js/issues"
|
54
|
+
},
|
55
|
+
"homepage": "https://github.com/Esri/arcgis-rest-js#readme",
|
56
|
+
"keywords": [
|
57
|
+
"typescript",
|
58
|
+
"promise",
|
59
|
+
"fetch",
|
60
|
+
"arcgis",
|
61
|
+
"esri",
|
62
|
+
"ES6"
|
63
|
+
]
|
64
|
+
}
|
@@ -0,0 +1,140 @@
|
|
1
|
+
/* Copyright (c) 2017-2018 Environmental Systems Research Institute, Inc.
|
2
|
+
* Apache-2.0 */
|
3
|
+
|
4
|
+
import {
|
5
|
+
request,
|
6
|
+
IRequestOptions,
|
7
|
+
ArcGISRequestError
|
8
|
+
} from "@esri/arcgis-rest-request";
|
9
|
+
|
10
|
+
import { getPortalUrl } from "../util/get-portal-url";
|
11
|
+
import { chunk } from "../util/array";
|
12
|
+
|
13
|
+
export interface IAddGroupUsersOptions extends IRequestOptions {
|
14
|
+
/**
|
15
|
+
* Group ID
|
16
|
+
*/
|
17
|
+
id: string;
|
18
|
+
/**
|
19
|
+
* An array of usernames to be added to the group as group members
|
20
|
+
*/
|
21
|
+
users?: string[];
|
22
|
+
/**
|
23
|
+
* An array of usernames to be added to the group as group admins
|
24
|
+
*/
|
25
|
+
admins?: string[];
|
26
|
+
}
|
27
|
+
|
28
|
+
export interface IAddGroupUsersResult {
|
29
|
+
/**
|
30
|
+
* An array of usernames that were not added
|
31
|
+
*/
|
32
|
+
notAdded?: string[];
|
33
|
+
/**
|
34
|
+
* An array of request errors
|
35
|
+
*/
|
36
|
+
errors?: ArcGISRequestError[];
|
37
|
+
}
|
38
|
+
|
39
|
+
/**
|
40
|
+
* ```js
|
41
|
+
* import { addGroupUsers } from "@esri/arcgis-rest-portal";
|
42
|
+
* //
|
43
|
+
* addGroupUsers({
|
44
|
+
* id: groupId,
|
45
|
+
* users: ["username1", "username2"],
|
46
|
+
* admins: ["username3"],
|
47
|
+
* authentication
|
48
|
+
* })
|
49
|
+
* .then(response);
|
50
|
+
* ```
|
51
|
+
* Add users to a group. See the [REST Documentation](https://developers.arcgis.com/rest/users-groups-and-items/add-users-to-group.htm) for more information.
|
52
|
+
*
|
53
|
+
* @param requestOptions - Options for the request
|
54
|
+
* @returns A Promise
|
55
|
+
*/
|
56
|
+
export function addGroupUsers(
|
57
|
+
requestOptions: IAddGroupUsersOptions
|
58
|
+
): Promise<IAddGroupUsersResult> {
|
59
|
+
const id = requestOptions.id;
|
60
|
+
const url = `${getPortalUrl(requestOptions)}/community/groups/${id}/addUsers`;
|
61
|
+
const baseOptions = Object.assign({}, requestOptions, {
|
62
|
+
admins: undefined,
|
63
|
+
users: undefined
|
64
|
+
});
|
65
|
+
|
66
|
+
const batchRequestOptions = [
|
67
|
+
..._prepareRequests("users", requestOptions.users, baseOptions),
|
68
|
+
..._prepareRequests("admins", requestOptions.admins, baseOptions)
|
69
|
+
];
|
70
|
+
|
71
|
+
const promises = batchRequestOptions.map(options =>
|
72
|
+
_sendSafeRequest(url, options)
|
73
|
+
);
|
74
|
+
|
75
|
+
return Promise.all(promises).then(_consolidateRequestResults);
|
76
|
+
}
|
77
|
+
|
78
|
+
function _prepareRequests(
|
79
|
+
type: "admins" | "users",
|
80
|
+
usernames: string[],
|
81
|
+
baseOptions: IAddGroupUsersOptions
|
82
|
+
): IAddGroupUsersOptions[] {
|
83
|
+
if (!usernames || usernames.length < 1) {
|
84
|
+
return [];
|
85
|
+
}
|
86
|
+
|
87
|
+
// the ArcGIS REST API only allows to add no more than 25 users per request,
|
88
|
+
// see https://developers.arcgis.com/rest/users-groups-and-items/add-users-to-group.htm
|
89
|
+
const userChunks: string[][] = chunk<string>(usernames, 25);
|
90
|
+
|
91
|
+
return userChunks.map(users =>
|
92
|
+
_generateRequestOptions(type, users, baseOptions)
|
93
|
+
);
|
94
|
+
}
|
95
|
+
|
96
|
+
function _generateRequestOptions(
|
97
|
+
type: "admins" | "users",
|
98
|
+
usernames: string[],
|
99
|
+
baseOptions: IAddGroupUsersOptions
|
100
|
+
) {
|
101
|
+
return Object.assign({}, baseOptions, {
|
102
|
+
[type]: usernames,
|
103
|
+
params: {
|
104
|
+
...baseOptions.params,
|
105
|
+
[type]: usernames
|
106
|
+
}
|
107
|
+
});
|
108
|
+
}
|
109
|
+
|
110
|
+
// this request is safe since the request error will be handled
|
111
|
+
function _sendSafeRequest(
|
112
|
+
url: string,
|
113
|
+
requestOptions: IAddGroupUsersOptions
|
114
|
+
): Promise<IAddGroupUsersResult> {
|
115
|
+
return request(url, requestOptions).catch(error => {
|
116
|
+
return {
|
117
|
+
errors: [error]
|
118
|
+
};
|
119
|
+
});
|
120
|
+
}
|
121
|
+
|
122
|
+
function _consolidateRequestResults(
|
123
|
+
results: IAddGroupUsersResult[]
|
124
|
+
): IAddGroupUsersResult {
|
125
|
+
const notAdded = results
|
126
|
+
.filter(result => result.notAdded)
|
127
|
+
.reduce((collection, result) => collection.concat(result.notAdded), []);
|
128
|
+
|
129
|
+
const errors = results
|
130
|
+
.filter(result => result.errors)
|
131
|
+
.reduce((collection, result) => collection.concat(result.errors), []);
|
132
|
+
|
133
|
+
const consolidated: IAddGroupUsersResult = { notAdded };
|
134
|
+
|
135
|
+
if (errors.length > 0) {
|
136
|
+
consolidated.errors = errors;
|
137
|
+
}
|
138
|
+
|
139
|
+
return consolidated;
|
140
|
+
}
|
@@ -0,0 +1,43 @@
|
|
1
|
+
/* Copyright (c) 2017-2018 Environmental Systems Research Institute, Inc.
|
2
|
+
* Apache-2.0 */
|
3
|
+
|
4
|
+
import { request, IRequestOptions } from "@esri/arcgis-rest-request";
|
5
|
+
import { IGroupAdd, IGroup } from "@esri/arcgis-rest-types";
|
6
|
+
|
7
|
+
import { getPortalUrl } from "../util/get-portal-url";
|
8
|
+
|
9
|
+
export interface ICreateGroupOptions extends IRequestOptions {
|
10
|
+
group: IGroupAdd;
|
11
|
+
}
|
12
|
+
|
13
|
+
/**
|
14
|
+
* ```js
|
15
|
+
* import { createGroup } from "@esri/arcgis-rest-portal";
|
16
|
+
* //
|
17
|
+
* createGroup({
|
18
|
+
* group: {
|
19
|
+
* title: "No Homers",
|
20
|
+
* access: "public"
|
21
|
+
* },
|
22
|
+
* authentication
|
23
|
+
* })
|
24
|
+
* .then(response)
|
25
|
+
* ```
|
26
|
+
* Create a new Group. See the [REST Documentation](https://developers.arcgis.com/rest/users-groups-and-items/create-group.htm) for more information.
|
27
|
+
*
|
28
|
+
* Note: The group name must be unique within the user's organization.
|
29
|
+
* @param requestOptions - Options for the request, including a group object
|
30
|
+
* @returns A Promise that will resolve with the success/failure status of the request
|
31
|
+
*/
|
32
|
+
export function createGroup(
|
33
|
+
requestOptions: ICreateGroupOptions
|
34
|
+
): Promise<{ success: boolean; group: IGroup }> {
|
35
|
+
const url = `${getPortalUrl(requestOptions)}/community/createGroup`;
|
36
|
+
|
37
|
+
requestOptions.params = {
|
38
|
+
...requestOptions.params,
|
39
|
+
...requestOptions.group
|
40
|
+
};
|
41
|
+
|
42
|
+
return request(url, requestOptions);
|
43
|
+
}
|
@@ -0,0 +1,184 @@
|
|
1
|
+
/* Copyright (c) 2017-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 { IPagingParams, IGroup, IItem, IUser } from "@esri/arcgis-rest-types";
|
10
|
+
import { getPortalUrl } from "../util/get-portal-url";
|
11
|
+
|
12
|
+
export interface IGroupCategorySchema {
|
13
|
+
categorySchema: IGroupCategory[];
|
14
|
+
}
|
15
|
+
|
16
|
+
export interface IGroupCategory {
|
17
|
+
title: string;
|
18
|
+
description?: string;
|
19
|
+
categories?: IGroupCategory[];
|
20
|
+
}
|
21
|
+
|
22
|
+
export interface IGetGroupContentOptions extends IRequestOptions {
|
23
|
+
paging: IPagingParams;
|
24
|
+
}
|
25
|
+
|
26
|
+
export interface IGroupContentResult {
|
27
|
+
total: number;
|
28
|
+
start: number;
|
29
|
+
num: number;
|
30
|
+
nextStart: number;
|
31
|
+
items: IItem[];
|
32
|
+
}
|
33
|
+
|
34
|
+
export interface IGroupUsersResult {
|
35
|
+
owner: string;
|
36
|
+
admins: string[];
|
37
|
+
users: string[];
|
38
|
+
}
|
39
|
+
|
40
|
+
/**
|
41
|
+
* ```js
|
42
|
+
* import { getGroup } from "@esri/arcgis-rest-portal";
|
43
|
+
* //
|
44
|
+
* getGroup("fxb988") // id
|
45
|
+
* .then(response)
|
46
|
+
* ```
|
47
|
+
* Fetch a group using its id. See the [REST Documentation](https://developers.arcgis.com/rest/users-groups-and-items/group.htm) for more information.
|
48
|
+
*
|
49
|
+
* @param id - Group Id
|
50
|
+
* @param requestOptions - Options for the request
|
51
|
+
* @returns A Promise that will resolve with the data from the response.
|
52
|
+
*/
|
53
|
+
export function getGroup(
|
54
|
+
id: string,
|
55
|
+
requestOptions?: IRequestOptions
|
56
|
+
): Promise<IGroup> {
|
57
|
+
const url = `${getPortalUrl(requestOptions)}/community/groups/${id}`;
|
58
|
+
// default to a GET request
|
59
|
+
const options: IRequestOptions = {
|
60
|
+
...{ httpMethod: "GET" },
|
61
|
+
...requestOptions
|
62
|
+
};
|
63
|
+
return request(url, options);
|
64
|
+
}
|
65
|
+
|
66
|
+
/**
|
67
|
+
* Gets the category schema set on a group
|
68
|
+
*
|
69
|
+
* @param id - Group Id
|
70
|
+
* @param requestOptions - Options for the request
|
71
|
+
* @returns A promise that will resolve with JSON of group's category schema
|
72
|
+
* @see https://developers.arcgis.com/rest/users-groups-and-items/group-category-schema.htm
|
73
|
+
*/
|
74
|
+
export function getGroupCategorySchema(
|
75
|
+
id: string,
|
76
|
+
requestOptions?: IRequestOptions
|
77
|
+
): Promise<IGroupCategorySchema> {
|
78
|
+
const url = `${getPortalUrl(
|
79
|
+
requestOptions
|
80
|
+
)}/community/groups/${id}/categorySchema`;
|
81
|
+
|
82
|
+
// default to a GET request
|
83
|
+
const options: IRequestOptions = {
|
84
|
+
...{ httpMethod: "GET" },
|
85
|
+
...requestOptions
|
86
|
+
};
|
87
|
+
return request(url, options);
|
88
|
+
}
|
89
|
+
|
90
|
+
/**
|
91
|
+
* Returns the content of a Group. Since the group may contain 1000s of items
|
92
|
+
* the requestParams allow for paging.
|
93
|
+
* @param id - Group Id
|
94
|
+
* @param requestOptions - Options for the request, including paging parameters.
|
95
|
+
* @returns A Promise that will resolve with the content of the group.
|
96
|
+
*/
|
97
|
+
export function getGroupContent(
|
98
|
+
id: string,
|
99
|
+
requestOptions?: IGetGroupContentOptions
|
100
|
+
): Promise<IGroupContentResult> {
|
101
|
+
const url = `${getPortalUrl(requestOptions)}/content/groups/${id}`;
|
102
|
+
|
103
|
+
// default to a GET request
|
104
|
+
const options: IRequestOptions = {
|
105
|
+
...{ httpMethod: "GET" },
|
106
|
+
params: { start: 1, num: 100 },
|
107
|
+
...requestOptions
|
108
|
+
} as IGetGroupContentOptions;
|
109
|
+
|
110
|
+
// is this the most concise way to mixin with the defaults above?
|
111
|
+
if (requestOptions && requestOptions.paging) {
|
112
|
+
options.params = { ...requestOptions.paging };
|
113
|
+
}
|
114
|
+
|
115
|
+
return request(url, options);
|
116
|
+
}
|
117
|
+
|
118
|
+
/**
|
119
|
+
* Get the usernames of the admins and members. Does not return actual 'User' objects. Those must be
|
120
|
+
* retrieved via separate calls to the User's API.
|
121
|
+
* @param id - Group Id
|
122
|
+
* @param requestOptions - Options for the request
|
123
|
+
* @returns A Promise that will resolve with arrays of the group admin usernames and the member usernames
|
124
|
+
*/
|
125
|
+
export function getGroupUsers(
|
126
|
+
id: string,
|
127
|
+
requestOptions?: IRequestOptions
|
128
|
+
): Promise<IGroupUsersResult> {
|
129
|
+
const url = `${getPortalUrl(requestOptions)}/community/groups/${id}/users`;
|
130
|
+
// default to a GET request
|
131
|
+
const options: IRequestOptions = {
|
132
|
+
...{ httpMethod: "GET" },
|
133
|
+
...requestOptions
|
134
|
+
};
|
135
|
+
return request(url, options);
|
136
|
+
}
|
137
|
+
|
138
|
+
export interface ISearchGroupUsersOptions
|
139
|
+
extends IRequestOptions,
|
140
|
+
IPagingParams {
|
141
|
+
name?: string;
|
142
|
+
sortField?: string;
|
143
|
+
sortOrder?: string;
|
144
|
+
joined?: number | number[];
|
145
|
+
memberType?: string;
|
146
|
+
[key: string]: any;
|
147
|
+
}
|
148
|
+
|
149
|
+
export interface ISearchGroupUsersResult {
|
150
|
+
total: number;
|
151
|
+
start: number;
|
152
|
+
num: number;
|
153
|
+
nextStart: number;
|
154
|
+
owner: IUser;
|
155
|
+
users: any[];
|
156
|
+
}
|
157
|
+
|
158
|
+
/**
|
159
|
+
* ```js
|
160
|
+
* import { searchGroupUsers } from "@esri/arcgis-rest-portal";
|
161
|
+
* //
|
162
|
+
* searchGroupUsers('abc123')
|
163
|
+
* .then(response)
|
164
|
+
* ```
|
165
|
+
* Search the users in a group. See the [REST Documentation](https://developers.arcgis.com/rest/users-groups-and-items/group-users-list.htm) for more information.
|
166
|
+
*
|
167
|
+
* @param id - The group id
|
168
|
+
* @param searchOptions - Options for the request, including paging parameters.
|
169
|
+
* @returns A Promise that will resolve with the data from the response.
|
170
|
+
*/
|
171
|
+
export function searchGroupUsers(
|
172
|
+
id: string,
|
173
|
+
searchOptions?: ISearchGroupUsersOptions
|
174
|
+
): Promise<ISearchGroupUsersResult> {
|
175
|
+
const url = `${getPortalUrl(searchOptions)}/community/groups/${id}/userlist`;
|
176
|
+
const options = appendCustomParams<ISearchGroupUsersOptions>(
|
177
|
+
searchOptions || {},
|
178
|
+
["name", "num", "start", "sortField", "sortOrder", "joined", "memberType"],
|
179
|
+
{
|
180
|
+
httpMethod: "GET"
|
181
|
+
}
|
182
|
+
);
|
183
|
+
return request(url, options);
|
184
|
+
}
|