aspernaturalias 1.0.0
Sign up to get free protection for your applications and to get access to all the features.
- package/.prettierignore +2 -0
- package/.travis.yml +31 -0
- package/.vscode/launch.json +24 -0
- package/.vscode/settings.json +3 -0
- package/codecov.yml +3 -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 +164 -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 +94 -0
- package/demos/batch-geocoder-node/package.json +38 -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 +85 -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 +202 -0
- package/demos/oauth2-browser/logo.svg +4 -0
- package/demos/oauth2-browser/package-lock.json +163 -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 +9 -0
- package/demos/tree-shaking-webpack/index.html +11 -0
- package/demos/tree-shaking-webpack/package-lock.json +4595 -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 +11323 -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 +3851 -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/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 +88 -0
- package/package.json +129 -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 +997 -0
- package/packages/arcgis-rest-auth/src/authenticated-request-options.ts +24 -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/test/ApplicationSession.test.ts +124 -0
- package/packages/arcgis-rest-auth/test/UserSession.test.ts +1315 -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/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/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/helpers.ts +55 -0
- package/packages/arcgis-rest-feature-layer/src/index.ts +28 -0
- package/packages/arcgis-rest-feature-layer/src/query.ts +203 -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 +202 -0
- package/packages/arcgis-rest-feature-layer/test/crud.test.ts +130 -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/mocks/cvdQueryResponse.ts +225 -0
- package/packages/arcgis-rest-feature-layer/test/mocks/feature.ts +281 -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 +259 -0
- package/packages/arcgis-rest-feature-layer/test/query.test.ts +168 -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 +105 -0
- package/packages/arcgis-rest-geocoding/src/geocode.ts +130 -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 +151 -0
- package/packages/arcgis-rest-geocoding/test/geocode.test.ts +212 -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/create.ts +43 -0
- package/packages/arcgis-rest-portal/src/groups/get.ts +99 -0
- package/packages/arcgis-rest-portal/src/groups/helpers.ts +14 -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.ts +32 -0
- package/packages/arcgis-rest-portal/src/groups/search.ts +25 -0
- package/packages/arcgis-rest-portal/src/groups/update.ts +39 -0
- package/packages/arcgis-rest-portal/src/index.ts +48 -0
- package/packages/arcgis-rest-portal/src/items/add.ts +137 -0
- package/packages/arcgis-rest-portal/src/items/create.ts +128 -0
- package/packages/arcgis-rest-portal/src/items/get.ts +177 -0
- package/packages/arcgis-rest-portal/src/items/helpers.ts +193 -0
- package/packages/arcgis-rest-portal/src/items/protect.ts +39 -0
- package/packages/arcgis-rest-portal/src/items/remove.ts +131 -0
- package/packages/arcgis-rest-portal/src/items/search.ts +25 -0
- package/packages/arcgis-rest-portal/src/items/update.ts +145 -0
- package/packages/arcgis-rest-portal/src/sharing/access.ts +84 -0
- package/packages/arcgis-rest-portal/src/sharing/group-sharing.ts +210 -0
- package/packages/arcgis-rest-portal/src/sharing/helpers.ts +84 -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 +162 -0
- package/packages/arcgis-rest-portal/src/users/notification.ts +70 -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/generic-search.ts +67 -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/search.ts +38 -0
- package/packages/arcgis-rest-portal/test/groups/crud.test.ts +180 -0
- package/packages/arcgis-rest-portal/test/groups/get.test.ts +101 -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/search.test.ts +110 -0
- package/packages/arcgis-rest-portal/test/items/add.test.ts +321 -0
- package/packages/arcgis-rest-portal/test/items/create.test.ts +375 -0
- package/packages/arcgis-rest-portal/test/items/get.test.ts +309 -0
- package/packages/arcgis-rest-portal/test/items/protect.test.ts +122 -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 +515 -0
- package/packages/arcgis-rest-portal/test/mocks/groups/responses.ts +144 -0
- package/packages/arcgis-rest-portal/test/mocks/items/foo.zip +0 -0
- package/packages/arcgis-rest-portal/test/mocks/items/item.ts +122 -0
- package/packages/arcgis-rest-portal/test/mocks/items/resources.ts +31 -0
- package/packages/arcgis-rest-portal/test/mocks/items/search.ts +121 -0
- package/packages/arcgis-rest-portal/test/mocks/portal/response.ts +112 -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.ts +173 -0
- package/packages/arcgis-rest-portal/test/sharing/access.test.ts +162 -0
- package/packages/arcgis-rest-portal/test/sharing/group-sharing.test.ts +650 -0
- package/packages/arcgis-rest-portal/test/sharing/helpers.test.ts +55 -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/update.test.ts +151 -0
- package/packages/arcgis-rest-portal/test/util/SearchQueryBuilder.test.ts +340 -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 +97 -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 +24 -0
- package/packages/arcgis-rest-request/src/request.ts +389 -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 +43 -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 +16 -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 +23 -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 +496 -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 +47 -0
- package/packages/arcgis-rest-request/test/utils/encode-form-data.test.ts +133 -0
- package/packages/arcgis-rest-request/test/utils/process-params.test.ts +193 -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 +213 -0
- package/packages/arcgis-rest-service-admin/src/index.ts +9 -0
- package/packages/arcgis-rest-service-admin/test/addTo.test.ts +350 -0
- package/packages/arcgis-rest-service-admin/test/create.test.ts +377 -0
- package/packages/arcgis-rest-service-admin/test/mocks/layerDefinition.ts +79 -0
- package/packages/arcgis-rest-service-admin/test/mocks/move.ts +11 -0
- package/packages/arcgis-rest-service-admin/test/mocks/service.ts +69 -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 +7 -0
- package/packages/arcgis-rest-types/src/item.ts +65 -0
- package/packages/arcgis-rest-types/src/symbol.ts +170 -0
- package/packages/arcgis-rest-types/src/user.ts +48 -0
- package/packages/arcgis-rest-types/src/webmap.ts +1345 -0
- package/packages/arcgis-rest-types/tsconfig.json +9 -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,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.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.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.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.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.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.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.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
|
+
[![apache licensed](https://img.shields.io/badge/license-Apache-green.svg?style=flat-square)](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,11 @@
|
|
1
|
+
{
|
2
|
+
"requires": true,
|
3
|
+
"lockfileVersion": 1,
|
4
|
+
"dependencies": {
|
5
|
+
"tslib": {
|
6
|
+
"version": "1.9.3",
|
7
|
+
"resolved": "https://registry.npmjs.org/tslib/-/tslib-1.9.3.tgz",
|
8
|
+
"integrity": "sha512-4krF8scpejhaOgqzBEcGM7yDIEfi0/8+8zDRZhNZZ2kjmHJ4hv3zCbQWxoJGz1iw5U0Jl0nma13xzHXcncMavQ=="
|
9
|
+
}
|
10
|
+
}
|
11
|
+
}
|
@@ -0,0 +1,64 @@
|
|
1
|
+
{
|
2
|
+
"name": "@esri/arcgis-rest-portal",
|
3
|
+
"version": "2.0.4",
|
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": "^2.0.4",
|
17
|
+
"tslib": "^1.9.3"
|
18
|
+
},
|
19
|
+
"devDependencies": {
|
20
|
+
"@esri/arcgis-rest-auth": "^2.0.4",
|
21
|
+
"@esri/arcgis-rest-request": "^2.0.4"
|
22
|
+
},
|
23
|
+
"peerDependencies": {
|
24
|
+
"@esri/arcgis-rest-auth": "^2.0.0",
|
25
|
+
"@esri/arcgis-rest-request": "^2.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,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,99 @@
|
|
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 { IPagingParams, IGroup, IItem } from "@esri/arcgis-rest-types";
|
6
|
+
|
7
|
+
import { getPortalUrl } from "../util/get-portal-url";
|
8
|
+
|
9
|
+
export interface IGetGroupContentOptions extends IRequestOptions {
|
10
|
+
paging: IPagingParams;
|
11
|
+
}
|
12
|
+
|
13
|
+
export interface IGroupContentResult {
|
14
|
+
total: number;
|
15
|
+
start: number;
|
16
|
+
num: number;
|
17
|
+
nextStart: number;
|
18
|
+
items: IItem[];
|
19
|
+
}
|
20
|
+
|
21
|
+
export interface IGroupUsersResult {
|
22
|
+
owner: string;
|
23
|
+
admins: string[];
|
24
|
+
users: string[];
|
25
|
+
}
|
26
|
+
|
27
|
+
/**
|
28
|
+
* ```js
|
29
|
+
* import { getGroup } from "@esri/arcgis-rest-portal";
|
30
|
+
* //
|
31
|
+
* getGroup("fxb988") // id
|
32
|
+
* .then(response)
|
33
|
+
* ```
|
34
|
+
* Fetch a group using its id. See the [REST Documentation](https://developers.arcgis.com/rest/users-groups-and-items/group.htm) for more information.
|
35
|
+
*
|
36
|
+
* @param id - Group Id
|
37
|
+
* @param requestOptions - Options for the request
|
38
|
+
* @returns A Promise that will resolve with the data from the response.
|
39
|
+
*/
|
40
|
+
export function getGroup(
|
41
|
+
id: string,
|
42
|
+
requestOptions?: IRequestOptions
|
43
|
+
): Promise<IGroup> {
|
44
|
+
const url = `${getPortalUrl(requestOptions)}/community/groups/${id}`;
|
45
|
+
// default to a GET request
|
46
|
+
const options: IRequestOptions = {
|
47
|
+
...{ httpMethod: "GET" },
|
48
|
+
...requestOptions
|
49
|
+
};
|
50
|
+
return request(url, options);
|
51
|
+
}
|
52
|
+
|
53
|
+
/**
|
54
|
+
* Returns the content of a Group. Since the group may contain 1000s of items
|
55
|
+
* the requestParams allow for paging.
|
56
|
+
* @param id - Group Id
|
57
|
+
* @param requestOptions - Options for the request, including paging parameters.
|
58
|
+
* @returns A Promise that will resolve with the content of the group.
|
59
|
+
*/
|
60
|
+
export function getGroupContent(
|
61
|
+
id: string,
|
62
|
+
requestOptions?: IGetGroupContentOptions
|
63
|
+
): Promise<IGroup> {
|
64
|
+
const url = `${getPortalUrl(requestOptions)}/content/groups/${id}`;
|
65
|
+
|
66
|
+
// default to a GET request
|
67
|
+
const options: IRequestOptions = {
|
68
|
+
...{ httpMethod: "GET" },
|
69
|
+
params: { start: 1, num: 100 },
|
70
|
+
...requestOptions
|
71
|
+
} as IGetGroupContentOptions;
|
72
|
+
|
73
|
+
// is this the most concise way to mixin with the defaults above?
|
74
|
+
if (requestOptions && requestOptions.paging) {
|
75
|
+
options.params = { ...requestOptions.paging };
|
76
|
+
}
|
77
|
+
|
78
|
+
return request(url, options);
|
79
|
+
}
|
80
|
+
|
81
|
+
/**
|
82
|
+
* Get the usernames of the admins and members. Does not return actual 'User' objects. Those must be
|
83
|
+
* retrieved via separate calls to the User's API.
|
84
|
+
* @param id - Group Id
|
85
|
+
* @param requestOptions - Options for the request
|
86
|
+
* @returns A Promise that will resolve with arrays of the group admin usernames and the member usernames
|
87
|
+
*/
|
88
|
+
export function getGroupUsers(
|
89
|
+
id: string,
|
90
|
+
requestOptions?: IRequestOptions
|
91
|
+
): Promise<IGroupUsersResult> {
|
92
|
+
const url = `${getPortalUrl(requestOptions)}/community/groups/${id}/users`;
|
93
|
+
// default to a GET request
|
94
|
+
const options: IRequestOptions = {
|
95
|
+
...{ httpMethod: "GET" },
|
96
|
+
...requestOptions
|
97
|
+
};
|
98
|
+
return request(url, options);
|
99
|
+
}
|
@@ -0,0 +1,14 @@
|
|
1
|
+
/* Copyright (c) 2017-2019 Environmental Systems Research Institute, Inc.
|
2
|
+
* Apache-2.0 */
|
3
|
+
|
4
|
+
import { IUserRequestOptions } from "@esri/arcgis-rest-auth";
|
5
|
+
|
6
|
+
/**
|
7
|
+
* Base options interface for making authenticated requests for groups.
|
8
|
+
*/
|
9
|
+
export interface IUserGroupOptions extends IUserRequestOptions {
|
10
|
+
/**
|
11
|
+
* Unique identifier of the group.
|
12
|
+
*/
|
13
|
+
id: string;
|
14
|
+
}
|
@@ -0,0 +1,57 @@
|
|
1
|
+
/* Copyright (c) 2017-2018 Environmental Systems Research Institute, Inc.
|
2
|
+
* Apache-2.0 */
|
3
|
+
|
4
|
+
import { request } from "@esri/arcgis-rest-request";
|
5
|
+
|
6
|
+
import { getPortalUrl } from "../util/get-portal-url";
|
7
|
+
import { IUserGroupOptions } from "./helpers";
|
8
|
+
|
9
|
+
/**
|
10
|
+
* ```js
|
11
|
+
* import { joinGroup } from '@esri/arcgis-rest-portal';
|
12
|
+
* //
|
13
|
+
* joinGroup({
|
14
|
+
* id: groupId,
|
15
|
+
* authentication
|
16
|
+
* })
|
17
|
+
* .then(response)
|
18
|
+
* ```
|
19
|
+
* Make a request as the authenticated user to join a Group. See the [REST Documentation](https://developers.arcgis.com/rest/users-groups-and-items/join-group.htm) for more information.
|
20
|
+
*
|
21
|
+
* @param requestOptions - Options for the request
|
22
|
+
* @returns A Promise that will resolve with the success/failure status of the request and the groupId.
|
23
|
+
*/
|
24
|
+
export function joinGroup(
|
25
|
+
requestOptions: IUserGroupOptions
|
26
|
+
): Promise<{ success: boolean; groupId: string }> {
|
27
|
+
const url = `${getPortalUrl(requestOptions)}/community/groups/${
|
28
|
+
requestOptions.id
|
29
|
+
}/join`;
|
30
|
+
|
31
|
+
return request(url, requestOptions);
|
32
|
+
}
|
33
|
+
|
34
|
+
/**
|
35
|
+
* ```js
|
36
|
+
* import { leaveGroup } from '@esri/arcgis-rest-portal';
|
37
|
+
* //
|
38
|
+
* leaveGroup({
|
39
|
+
* id: groupId,
|
40
|
+
* authentication
|
41
|
+
* })
|
42
|
+
* .then(response)
|
43
|
+
* ```
|
44
|
+
* Make a request as the authenticated user to leave a Group. See the [REST Documentation](https://developers.arcgis.com/rest/users-groups-and-items/leave-group.htm) for more information.
|
45
|
+
*
|
46
|
+
* @param requestOptions - Options for the request
|
47
|
+
* @returns A Promise that will resolve with the success/failure status of the request and the groupId.
|
48
|
+
*/
|
49
|
+
export function leaveGroup(
|
50
|
+
requestOptions: IUserGroupOptions
|
51
|
+
): Promise<{ success: boolean; groupId: string }> {
|
52
|
+
const url = `${getPortalUrl(requestOptions)}/community/groups/${
|
53
|
+
requestOptions.id
|
54
|
+
}/leave`;
|
55
|
+
|
56
|
+
return request(url, requestOptions);
|
57
|
+
}
|
@@ -0,0 +1,77 @@
|
|
1
|
+
/* Copyright (c) 2017-2018 Environmental Systems Research Institute, Inc.
|
2
|
+
* Apache-2.0 */
|
3
|
+
|
4
|
+
import { request } from "@esri/arcgis-rest-request";
|
5
|
+
import { IUserGroupOptions } from "./helpers";
|
6
|
+
|
7
|
+
import { getPortalUrl } from "../util/get-portal-url";
|
8
|
+
|
9
|
+
export type NotificationChannelType = "push" | "email" | "builtin";
|
10
|
+
|
11
|
+
export interface ICreateGroupNotificationOptions extends IUserGroupOptions {
|
12
|
+
/**
|
13
|
+
* Subject of the notification. This only applies to email and builtin notifications. For push notifications, subject/title is provided as a part of the message payload.
|
14
|
+
*/
|
15
|
+
subject?: string;
|
16
|
+
/**
|
17
|
+
* Message to be sent. For builtin and email notifications this is a string. For push notifications, this will be JSON.
|
18
|
+
*/
|
19
|
+
message: string | object;
|
20
|
+
/**
|
21
|
+
* Array of usernames of the users in the group to whom the message should be sent. If not provided, the message will be sent to all users in the group if the user is an admin. Only group admins will be able to send notifications to a list of users. Group users will be able to send notifications to only one user at a time.
|
22
|
+
*/
|
23
|
+
users?: string[];
|
24
|
+
/**
|
25
|
+
* The channel through which the notification is to be delivered. Supported values are push, email, or builtin. If push is chosen, a message will be delivered only to those group members that have registered their devices to receive push notifications. If the user has registered more than one device for the app, then message will be sent to all the registered devices. Email will be sent when the email option is chosen. If the builtin option is chosen, a notification will be added to the notifications list that the user can see when logged into the home app.
|
26
|
+
*/
|
27
|
+
notificationChannelType?: NotificationChannelType;
|
28
|
+
/**
|
29
|
+
* ClientId of the application through which user receives messages on the mobile device. This only applies to push notifications.
|
30
|
+
*/
|
31
|
+
clientId?: string;
|
32
|
+
/**
|
33
|
+
* This only applies to push notifications. When set to true, message will be delivered to the app and it will not show as an alert to the user.
|
34
|
+
*/
|
35
|
+
silentNotification?: boolean;
|
36
|
+
}
|
37
|
+
|
38
|
+
/**
|
39
|
+
* ```js
|
40
|
+
* import { createGroupNotification } from '@esri/arcgis-rest-portal';
|
41
|
+
* // send an email to an entire group
|
42
|
+
* createGroupNotification({
|
43
|
+
* authentication: UserSession,
|
44
|
+
* subject: "hello",
|
45
|
+
* message: "world!",
|
46
|
+
* id: groupId
|
47
|
+
* })
|
48
|
+
* ```
|
49
|
+
* Create a group notification.
|
50
|
+
*
|
51
|
+
* @param requestOptions - Options for the request
|
52
|
+
*
|
53
|
+
* @returns A Promise that will resolve with the success/failure status of the request
|
54
|
+
*/
|
55
|
+
export function createGroupNotification(
|
56
|
+
requestOptions: ICreateGroupNotificationOptions
|
57
|
+
): Promise<any> {
|
58
|
+
const url = `${getPortalUrl(requestOptions)}/community/groups/${
|
59
|
+
requestOptions.id
|
60
|
+
}/createNotification`;
|
61
|
+
|
62
|
+
const options: ICreateGroupNotificationOptions = {
|
63
|
+
params: {
|
64
|
+
subject: requestOptions.subject,
|
65
|
+
message: requestOptions.message,
|
66
|
+
users: requestOptions.users,
|
67
|
+
notificationChannelType:
|
68
|
+
requestOptions.notificationChannelType || "email",
|
69
|
+
clientId: requestOptions.clientId,
|
70
|
+
silentNotification: requestOptions.silentNotification,
|
71
|
+
notifyAll: !requestOptions.users || requestOptions.users.length === 0,
|
72
|
+
...requestOptions.params
|
73
|
+
},
|
74
|
+
...requestOptions
|
75
|
+
};
|
76
|
+
return request(url, options);
|
77
|
+
}
|