autculpa 1.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (489) hide show
  1. package/.env.example +2 -0
  2. package/.eslintrc.json +37 -0
  3. package/.github/workflows/deploy-docs.yml +27 -0
  4. package/.github/workflows/pre-release-tests.yml +49 -0
  5. package/.github/workflows/pull-request-tests.yml +49 -0
  6. package/.github/workflows/release.yml +75 -0
  7. package/.prettierignore +2 -0
  8. package/.prettierrc +19 -0
  9. package/.vscode/launch.json +25 -0
  10. package/.vscode/settings.json +5 -0
  11. package/codecov.yml +7 -0
  12. package/commitlint.config.cjs +41 -0
  13. package/demos/.eslintrc.js +13 -0
  14. package/demos/ago-node-cli/README.md +30 -0
  15. package/demos/ago-node-cli/ago.js +31 -0
  16. package/demos/ago-node-cli/index.js +11 -0
  17. package/demos/ago-node-cli/lib/item-export-command.js +48 -0
  18. package/demos/ago-node-cli/lib/item-search-command.js +32 -0
  19. package/demos/ago-node-cli/package.json +29 -0
  20. package/demos/attachments-browser/README.md +7 -0
  21. package/demos/attachments-browser/index.html +165 -0
  22. package/demos/attachments-browser/package.json +15 -0
  23. package/demos/attachments-node/README.md +4 -0
  24. package/demos/attachments-node/image.jpg +0 -0
  25. package/demos/attachments-node/index.js +89 -0
  26. package/demos/attachments-node/package.json +19 -0
  27. package/demos/batch-geocoder-node/NYC_Restaurant_Inspection_Results.csv +100 -0
  28. package/demos/batch-geocoder-node/README.md +13 -0
  29. package/demos/batch-geocoder-node/batch-geocode.js +112 -0
  30. package/demos/batch-geocoder-node/config-template.js +18 -0
  31. package/demos/batch-geocoder-node/package.json +34 -0
  32. package/demos/browser-es-modules/README.md +7 -0
  33. package/demos/browser-es-modules/index.html +38 -0
  34. package/demos/browser-es-modules/package.json +15 -0
  35. package/demos/deno/README.md +1 -0
  36. package/demos/deno/import_map.json +8 -0
  37. package/demos/deno/index.js +5 -0
  38. package/demos/express/README.md +16 -0
  39. package/demos/express/config.json.template +3 -0
  40. package/demos/express/package.json +15 -0
  41. package/demos/express/server.js +37 -0
  42. package/demos/feature-service-browser/README.md +8 -0
  43. package/demos/feature-service-browser/index.html +122 -0
  44. package/demos/feature-service-browser/package.json +15 -0
  45. package/demos/geocoder-browser/README.md +12 -0
  46. package/demos/geocoder-browser/authenticate.html +29 -0
  47. package/demos/geocoder-browser/config.js.template +1 -0
  48. package/demos/geocoder-browser/index.html +139 -0
  49. package/demos/geocoder-browser/package.json +15 -0
  50. package/demos/jsapi-integration/README.md +26 -0
  51. package/demos/jsapi-integration/authenticate.html +29 -0
  52. package/demos/jsapi-integration/config.js +6 -0
  53. package/demos/jsapi-integration/index.html +91 -0
  54. package/demos/jsapi-integration/package.json +15 -0
  55. package/demos/node-cli-item-management/README.md +11 -0
  56. package/demos/node-cli-item-management/index.js +229 -0
  57. package/demos/node-cli-item-management/package.json +24 -0
  58. package/demos/node-cli-item-management/screenshot.png +0 -0
  59. package/demos/node-common-js/README.md +4 -0
  60. package/demos/node-common-js/index.js +5 -0
  61. package/demos/node-common-js/package.json +15 -0
  62. package/demos/node-es-modules/README.md +4 -0
  63. package/demos/node-es-modules/index.js +5 -0
  64. package/demos/node-es-modules/package.json +16 -0
  65. package/demos/oauth2-browser/README.md +17 -0
  66. package/demos/oauth2-browser/authenticate.html +29 -0
  67. package/demos/oauth2-browser/config.js.template +6 -0
  68. package/demos/oauth2-browser/index.html +223 -0
  69. package/demos/oauth2-browser/logo.svg +4 -0
  70. package/demos/oauth2-browser/package.json +15 -0
  71. package/demos/oauth2-browser/style.css +36 -0
  72. package/demos/oauth2-browser-retry/README.md +32 -0
  73. package/demos/oauth2-browser-retry/authenticate.html +21 -0
  74. package/demos/oauth2-browser-retry/index.html +114 -0
  75. package/demos/oauth2-browser-retry/logo.svg +4 -0
  76. package/demos/oauth2-browser-retry/package.json +15 -0
  77. package/demos/parcel/README.md +8 -0
  78. package/demos/parcel/index.html +16 -0
  79. package/demos/parcel/index.js +8 -0
  80. package/demos/parcel/package.json +20 -0
  81. package/demos/snowpack/README.md +8 -0
  82. package/demos/snowpack/index.html +16 -0
  83. package/demos/snowpack/index.js +8 -0
  84. package/demos/snowpack/package.json +20 -0
  85. package/demos/snowpack/snowpack.config.js +3 -0
  86. package/demos/stream-response-to-file/README.md +7 -0
  87. package/demos/stream-response-to-file/index.js +36 -0
  88. package/demos/stream-response-to-file/output/.gitkeep +0 -0
  89. package/demos/stream-response-to-file/package.json +31 -0
  90. package/demos/tree-shaking-rollup/.babelrc +3 -0
  91. package/demos/tree-shaking-rollup/README.md +9 -0
  92. package/demos/tree-shaking-rollup/index.html +11 -0
  93. package/demos/tree-shaking-rollup/package.json +22 -0
  94. package/demos/tree-shaking-rollup/rollup.config.js +13 -0
  95. package/demos/tree-shaking-rollup/src/index.js +8 -0
  96. package/demos/tree-shaking-webpack/README.md +9 -0
  97. package/demos/tree-shaking-webpack/index.html +11 -0
  98. package/demos/tree-shaking-webpack/package.json +26 -0
  99. package/demos/tree-shaking-webpack/src/index.js +8 -0
  100. package/demos/tree-shaking-webpack/webpack.config.js +29 -0
  101. package/demos/vite/README.md +6 -0
  102. package/demos/vite/favicon.svg +15 -0
  103. package/demos/vite/index.html +13 -0
  104. package/demos/vite/main.js +8 -0
  105. package/demos/vite/package.json +18 -0
  106. package/demos/vue/.env.example +11 -0
  107. package/demos/vue/.eslintrc.js +17 -0
  108. package/demos/vue/.postcssrc.js +5 -0
  109. package/demos/vue/README.md +17 -0
  110. package/demos/vue/babel.config.js +3 -0
  111. package/demos/vue/package.json +35 -0
  112. package/demos/vue/public/favicon.ico +0 -0
  113. package/demos/vue/public/index.html +24 -0
  114. package/demos/vue/src/assets/logo.svg +29 -0
  115. package/demos/vue/src/components/App.vue +303 -0
  116. package/demos/vue/src/components/Authenticate.vue +65 -0
  117. package/demos/vue/src/components/Loader.vue +230 -0
  118. package/demos/vue/src/main.js +92 -0
  119. package/demos/webmap-checker-sapper/.env.example +5 -0
  120. package/demos/webmap-checker-sapper/README.md +124 -0
  121. package/demos/webmap-checker-sapper/appveyor.yml +18 -0
  122. package/demos/webmap-checker-sapper/cypress/fixtures/example.json +5 -0
  123. package/demos/webmap-checker-sapper/cypress/integration/spec.js +19 -0
  124. package/demos/webmap-checker-sapper/cypress/plugins/index.js +17 -0
  125. package/demos/webmap-checker-sapper/cypress/support/commands.js +25 -0
  126. package/demos/webmap-checker-sapper/cypress/support/index.js +20 -0
  127. package/demos/webmap-checker-sapper/cypress.json +4 -0
  128. package/demos/webmap-checker-sapper/package.json +47 -0
  129. package/demos/webmap-checker-sapper/rollup.config.js +87 -0
  130. package/demos/webmap-checker-sapper/src/client.js +20 -0
  131. package/demos/webmap-checker-sapper/src/components/LayerStatus.html +108 -0
  132. package/demos/webmap-checker-sapper/src/components/Nav.html +21 -0
  133. package/demos/webmap-checker-sapper/src/components/WebMap.html +62 -0
  134. package/demos/webmap-checker-sapper/src/routes/_error.html +41 -0
  135. package/demos/webmap-checker-sapper/src/routes/_layout.html +21 -0
  136. package/demos/webmap-checker-sapper/src/routes/auth/authorize.js +18 -0
  137. package/demos/webmap-checker-sapper/src/routes/auth/exchange-token.js +20 -0
  138. package/demos/webmap-checker-sapper/src/routes/auth/post-sign-in.js +24 -0
  139. package/demos/webmap-checker-sapper/src/routes/auth/sign-out.js +10 -0
  140. package/demos/webmap-checker-sapper/src/routes/index.html +20 -0
  141. package/demos/webmap-checker-sapper/src/routes/webmaps/[webmapId].html +83 -0
  142. package/demos/webmap-checker-sapper/src/routes/webmaps/index.html +59 -0
  143. package/demos/webmap-checker-sapper/src/server.js +102 -0
  144. package/demos/webmap-checker-sapper/src/service-worker.js +82 -0
  145. package/demos/webmap-checker-sapper/src/template.html +33 -0
  146. package/demos/webmap-checker-sapper/src/userInfoMiddleware.js +21 -0
  147. package/demos/webmap-checker-sapper/src/utils.js +33 -0
  148. package/demos/webmap-checker-sapper/static/favicon.png +0 -0
  149. package/demos/webmap-checker-sapper/static/global.css +36 -0
  150. package/demos/webmap-checker-sapper/static/manifest.json +20 -0
  151. package/demos/webmap-checker-sapper/static/svelte-logo-192.png +0 -0
  152. package/demos/webmap-checker-sapper/static/svelte-logo-512.png +0 -0
  153. package/docs/.eslintrc.js +12 -0
  154. package/docs/FAQ.md +48 -0
  155. package/docs/HISTORY.md +62 -0
  156. package/docs/acetate.config.js +262 -0
  157. package/docs/build-typedoc.js +434 -0
  158. package/docs/generate-srihashes.js +61 -0
  159. package/docs/package.json +3 -0
  160. package/docs/src/_layout.html +86 -0
  161. package/docs/src/api/_declaration.html +600 -0
  162. package/docs/src/api/_layout.html +204 -0
  163. package/docs/src/api/_package.html +38 -0
  164. package/docs/src/api/index.html +16 -0
  165. package/docs/src/guides/_layout.html +24 -0
  166. package/docs/src/guides/amd-requirejs-dojo.md +40 -0
  167. package/docs/src/guides/browser-authentication.md +39 -0
  168. package/docs/src/guides/bundlers.md +52 -0
  169. package/docs/src/guides/cli-authentication.md +9 -0
  170. package/docs/src/guides/client-server-authentication.md +9 -0
  171. package/docs/src/guides/embedded-apps.md +106 -0
  172. package/docs/src/guides/from-a-cdn.md +38 -0
  173. package/docs/src/guides/index.md +59 -0
  174. package/docs/src/guides/node.md +84 -0
  175. package/docs/src/guides/package-overview.md +111 -0
  176. package/docs/src/guides/server-authentication.md +9 -0
  177. package/docs/src/guides/whats-new-v2-0.md +305 -0
  178. package/docs/src/img/icons.png +0 -0
  179. package/docs/src/img/icons@2x.png +0 -0
  180. package/docs/src/img/oauth-browser.png +0 -0
  181. package/docs/src/index.html +12 -0
  182. package/docs/src/js/api-search.js +112 -0
  183. package/docs/src/js/nav-toggle.js +41 -0
  184. package/docs/src/sass/_highlight.scss +96 -0
  185. package/docs/src/sass/_icons.scss +157 -0
  186. package/docs/src/sass/style.scss +242 -0
  187. package/jasmine.json +7 -0
  188. package/jasmine.live.json +7 -0
  189. package/karma.conf.cjs +128 -0
  190. package/package.json +140 -0
  191. package/packages/arcgis-rest-auth/CHANGELOG.md +80 -0
  192. package/packages/arcgis-rest-auth/README.md +71 -0
  193. package/packages/arcgis-rest-auth/package.json +66 -0
  194. package/packages/arcgis-rest-auth/src/index.ts +34 -0
  195. package/packages/arcgis-rest-auth/tsconfig.json +6 -0
  196. package/packages/arcgis-rest-demographics/CHANGELOG.md +14 -0
  197. package/packages/arcgis-rest-demographics/README.md +74 -0
  198. package/packages/arcgis-rest-demographics/package.json +69 -0
  199. package/packages/arcgis-rest-demographics/src/getAvailableCountries.ts +113 -0
  200. package/packages/arcgis-rest-demographics/src/getAvailableDataCollections.ts +161 -0
  201. package/packages/arcgis-rest-demographics/src/getAvailableGeographyLevels.ts +86 -0
  202. package/packages/arcgis-rest-demographics/src/getGeography.ts +152 -0
  203. package/packages/arcgis-rest-demographics/src/helpers.ts +27 -0
  204. package/packages/arcgis-rest-demographics/src/index.ts +16 -0
  205. package/packages/arcgis-rest-demographics/src/queryDemographicData.ts +108 -0
  206. package/packages/arcgis-rest-demographics/test/getAvailableCountries.test.ts +89 -0
  207. package/packages/arcgis-rest-demographics/test/getAvailableDataCollections.test.ts +114 -0
  208. package/packages/arcgis-rest-demographics/test/getAvailableGeographyLevels.test.ts +69 -0
  209. package/packages/arcgis-rest-demographics/test/getGeography.test.ts +150 -0
  210. package/packages/arcgis-rest-demographics/test/mocks/responses.ts +4 -0
  211. package/packages/arcgis-rest-demographics/test/queryDemographicData.test.live.ts +50 -0
  212. package/packages/arcgis-rest-demographics/test/queryDemographicData.test.ts +127 -0
  213. package/packages/arcgis-rest-demographics/tsconfig.json +6 -0
  214. package/packages/arcgis-rest-feature-service/CHANGELOG.md +44 -0
  215. package/packages/arcgis-rest-feature-service/README.md +75 -0
  216. package/packages/arcgis-rest-feature-service/package.json +70 -0
  217. package/packages/arcgis-rest-feature-service/src/add.ts +55 -0
  218. package/packages/arcgis-rest-feature-service/src/addAttachment.ts +53 -0
  219. package/packages/arcgis-rest-feature-service/src/addToServiceDefinition.ts +74 -0
  220. package/packages/arcgis-rest-feature-service/src/applyEdits.ts +94 -0
  221. package/packages/arcgis-rest-feature-service/src/createFeatureService.ts +191 -0
  222. package/packages/arcgis-rest-feature-service/src/decodeValues.ts +126 -0
  223. package/packages/arcgis-rest-feature-service/src/delete.ts +62 -0
  224. package/packages/arcgis-rest-feature-service/src/deleteAttachments.ts +52 -0
  225. package/packages/arcgis-rest-feature-service/src/getAllLayersAndTables.ts +30 -0
  226. package/packages/arcgis-rest-feature-service/src/getAttachments.ts +55 -0
  227. package/packages/arcgis-rest-feature-service/src/getLayer.ts +23 -0
  228. package/packages/arcgis-rest-feature-service/src/getService.ts +25 -0
  229. package/packages/arcgis-rest-feature-service/src/getServiceAdminInfo.ts +33 -0
  230. package/packages/arcgis-rest-feature-service/src/getViewSources.ts +19 -0
  231. package/packages/arcgis-rest-feature-service/src/helpers.ts +768 -0
  232. package/packages/arcgis-rest-feature-service/src/index.ts +37 -0
  233. package/packages/arcgis-rest-feature-service/src/query.ts +200 -0
  234. package/packages/arcgis-rest-feature-service/src/queryRelated.ts +86 -0
  235. package/packages/arcgis-rest-feature-service/src/update.ts +65 -0
  236. package/packages/arcgis-rest-feature-service/src/updateAttachment.ts +59 -0
  237. package/packages/arcgis-rest-feature-service/src/updateServiceDefinition.ts +53 -0
  238. package/packages/arcgis-rest-feature-service/test/addToServiceDefinition.test.ts +350 -0
  239. package/packages/arcgis-rest-feature-service/test/attachments.test.ts +188 -0
  240. package/packages/arcgis-rest-feature-service/test/createFeatureService.test.ts +279 -0
  241. package/packages/arcgis-rest-feature-service/test/crud.test.ts +196 -0
  242. package/packages/arcgis-rest-feature-service/test/decodeValues.test.ts +66 -0
  243. package/packages/arcgis-rest-feature-service/test/getAllLayersAndTables.test.ts +27 -0
  244. package/packages/arcgis-rest-feature-service/test/getLayer.test.ts +30 -0
  245. package/packages/arcgis-rest-feature-service/test/getService.test.ts +30 -0
  246. package/packages/arcgis-rest-feature-service/test/getServiceAdminInfo.test.ts +41 -0
  247. package/packages/arcgis-rest-feature-service/test/getViewSources.test.ts +45 -0
  248. package/packages/arcgis-rest-feature-service/test/helpers.test.ts +27 -0
  249. package/packages/arcgis-rest-feature-service/test/mocks/allLayersAndTablesResponse.ts +950 -0
  250. package/packages/arcgis-rest-feature-service/test/mocks/cvdQueryResponse.ts +225 -0
  251. package/packages/arcgis-rest-feature-service/test/mocks/feature.ts +302 -0
  252. package/packages/arcgis-rest-feature-service/test/mocks/fields.ts +779 -0
  253. package/packages/arcgis-rest-feature-service/test/mocks/foo.txt +1 -0
  254. package/packages/arcgis-rest-feature-service/test/mocks/layerDefinition.ts +80 -0
  255. package/packages/arcgis-rest-feature-service/test/mocks/service.ts +476 -0
  256. package/packages/arcgis-rest-feature-service/test/query.test.ts +166 -0
  257. package/packages/arcgis-rest-feature-service/test/updateServiceDefinition.test.ts +103 -0
  258. package/packages/arcgis-rest-feature-service/tsconfig.json +9 -0
  259. package/packages/arcgis-rest-fetch/README.md +17 -0
  260. package/packages/arcgis-rest-fetch/browser-ponyfill.js +8 -0
  261. package/packages/arcgis-rest-fetch/browser-ponyfill.mjs +8 -0
  262. package/packages/arcgis-rest-fetch/index.types.d.ts +8 -0
  263. package/packages/arcgis-rest-fetch/node-ponyfill.js +10 -0
  264. package/packages/arcgis-rest-fetch/node-ponyfill.mjs +10 -0
  265. package/packages/arcgis-rest-fetch/package.json +21 -0
  266. package/packages/arcgis-rest-form-data/README.md +15 -0
  267. package/packages/arcgis-rest-form-data/browser-ponyfill.js +5 -0
  268. package/packages/arcgis-rest-form-data/browser-ponyfill.mjs +3 -0
  269. package/packages/arcgis-rest-form-data/index.types.d.ts +9 -0
  270. package/packages/arcgis-rest-form-data/node-ponyfill.js +7 -0
  271. package/packages/arcgis-rest-form-data/node-ponyfill.mjs +5 -0
  272. package/packages/arcgis-rest-form-data/package.json +21 -0
  273. package/packages/arcgis-rest-geocoding/CHANGELOG.md +26 -0
  274. package/packages/arcgis-rest-geocoding/README.md +85 -0
  275. package/packages/arcgis-rest-geocoding/package.json +69 -0
  276. package/packages/arcgis-rest-geocoding/src/bulk.ts +106 -0
  277. package/packages/arcgis-rest-geocoding/src/geocode.ts +169 -0
  278. package/packages/arcgis-rest-geocoding/src/helpers.ts +56 -0
  279. package/packages/arcgis-rest-geocoding/src/index.ts +17 -0
  280. package/packages/arcgis-rest-geocoding/src/reverse.ts +82 -0
  281. package/packages/arcgis-rest-geocoding/src/suggest.ts +45 -0
  282. package/packages/arcgis-rest-geocoding/test/bulk.test.ts +193 -0
  283. package/packages/arcgis-rest-geocoding/test/geocode.test.ts +254 -0
  284. package/packages/arcgis-rest-geocoding/test/helpers.test.ts +85 -0
  285. package/packages/arcgis-rest-geocoding/test/mocks/responses.ts +1031 -0
  286. package/packages/arcgis-rest-geocoding/test/reverse.test.ts +124 -0
  287. package/packages/arcgis-rest-geocoding/test/suggest.test.ts +53 -0
  288. package/packages/arcgis-rest-geocoding/tsconfig.json +6 -0
  289. package/packages/arcgis-rest-portal/README.md +72 -0
  290. package/packages/arcgis-rest-portal/package.json +68 -0
  291. package/packages/arcgis-rest-portal/src/groups/add-users.ts +140 -0
  292. package/packages/arcgis-rest-portal/src/groups/create.ts +42 -0
  293. package/packages/arcgis-rest-portal/src/groups/get.ts +187 -0
  294. package/packages/arcgis-rest-portal/src/groups/helpers.ts +14 -0
  295. package/packages/arcgis-rest-portal/src/groups/invite-users.ts +141 -0
  296. package/packages/arcgis-rest-portal/src/groups/join.ts +57 -0
  297. package/packages/arcgis-rest-portal/src/groups/notification.ts +77 -0
  298. package/packages/arcgis-rest-portal/src/groups/protect.ts +56 -0
  299. package/packages/arcgis-rest-portal/src/groups/remove-users.ts +84 -0
  300. package/packages/arcgis-rest-portal/src/groups/remove.ts +32 -0
  301. package/packages/arcgis-rest-portal/src/groups/search.ts +48 -0
  302. package/packages/arcgis-rest-portal/src/groups/update-user-membership.ts +63 -0
  303. package/packages/arcgis-rest-portal/src/groups/update.ts +39 -0
  304. package/packages/arcgis-rest-portal/src/helpers.ts +83 -0
  305. package/packages/arcgis-rest-portal/src/index.ts +68 -0
  306. package/packages/arcgis-rest-portal/src/items/add.ts +145 -0
  307. package/packages/arcgis-rest-portal/src/items/content.ts +70 -0
  308. package/packages/arcgis-rest-portal/src/items/create.ts +149 -0
  309. package/packages/arcgis-rest-portal/src/items/export.ts +92 -0
  310. package/packages/arcgis-rest-portal/src/items/get.ts +444 -0
  311. package/packages/arcgis-rest-portal/src/items/helpers.ts +272 -0
  312. package/packages/arcgis-rest-portal/src/items/protect.ts +41 -0
  313. package/packages/arcgis-rest-portal/src/items/reassign.ts +59 -0
  314. package/packages/arcgis-rest-portal/src/items/remove.ts +139 -0
  315. package/packages/arcgis-rest-portal/src/items/search.ts +25 -0
  316. package/packages/arcgis-rest-portal/src/items/update.ts +188 -0
  317. package/packages/arcgis-rest-portal/src/items/upload.ts +124 -0
  318. package/packages/arcgis-rest-portal/src/orgs/notification.ts +148 -0
  319. package/packages/arcgis-rest-portal/src/services/get-unique-service-name.ts +35 -0
  320. package/packages/arcgis-rest-portal/src/services/is-service-name-available.ts +29 -0
  321. package/packages/arcgis-rest-portal/src/sharing/access.ts +84 -0
  322. package/packages/arcgis-rest-portal/src/sharing/helpers.ts +80 -0
  323. package/packages/arcgis-rest-portal/src/sharing/is-item-shared-with-group.ts +42 -0
  324. package/packages/arcgis-rest-portal/src/sharing/share-item-with-group.ts +335 -0
  325. package/packages/arcgis-rest-portal/src/sharing/unshare-item-with-group.ts +114 -0
  326. package/packages/arcgis-rest-portal/src/users/get-user-tags.ts +52 -0
  327. package/packages/arcgis-rest-portal/src/users/get-user-url.ts +18 -0
  328. package/packages/arcgis-rest-portal/src/users/get-user.ts +60 -0
  329. package/packages/arcgis-rest-portal/src/users/invitation.ts +157 -0
  330. package/packages/arcgis-rest-portal/src/users/notification.ts +67 -0
  331. package/packages/arcgis-rest-portal/src/users/search-users.ts +35 -0
  332. package/packages/arcgis-rest-portal/src/users/update.ts +63 -0
  333. package/packages/arcgis-rest-portal/src/util/SearchQueryBuilder.ts +391 -0
  334. package/packages/arcgis-rest-portal/src/util/array.ts +16 -0
  335. package/packages/arcgis-rest-portal/src/util/generic-search.ts +111 -0
  336. package/packages/arcgis-rest-portal/src/util/get-portal-settings.ts +44 -0
  337. package/packages/arcgis-rest-portal/src/util/get-portal-url.ts +32 -0
  338. package/packages/arcgis-rest-portal/src/util/get-portal.ts +53 -0
  339. package/packages/arcgis-rest-portal/src/util/get-subscription-info.ts +43 -0
  340. package/packages/arcgis-rest-portal/src/util/scrub-control-chars.ts +13 -0
  341. package/packages/arcgis-rest-portal/src/util/search.ts +48 -0
  342. package/packages/arcgis-rest-portal/test/groups/add-users.test.ts +238 -0
  343. package/packages/arcgis-rest-portal/test/groups/crud.test.ts +183 -0
  344. package/packages/arcgis-rest-portal/test/groups/get.test.ts +174 -0
  345. package/packages/arcgis-rest-portal/test/groups/invite-users.test.ts +146 -0
  346. package/packages/arcgis-rest-portal/test/groups/join.test.ts +71 -0
  347. package/packages/arcgis-rest-portal/test/groups/notification.test.ts +111 -0
  348. package/packages/arcgis-rest-portal/test/groups/protect.test.ts +71 -0
  349. package/packages/arcgis-rest-portal/test/groups/remove-users.test.ts +140 -0
  350. package/packages/arcgis-rest-portal/test/groups/search.test.ts +151 -0
  351. package/packages/arcgis-rest-portal/test/groups/update-user-membership.test.ts +64 -0
  352. package/packages/arcgis-rest-portal/test/items/add.test.ts +320 -0
  353. package/packages/arcgis-rest-portal/test/items/content.test.ts +161 -0
  354. package/packages/arcgis-rest-portal/test/items/create.test.ts +404 -0
  355. package/packages/arcgis-rest-portal/test/items/export.test.ts +115 -0
  356. package/packages/arcgis-rest-portal/test/items/get.test.ts +606 -0
  357. package/packages/arcgis-rest-portal/test/items/helpers.test.ts +60 -0
  358. package/packages/arcgis-rest-portal/test/items/protect.test.ts +120 -0
  359. package/packages/arcgis-rest-portal/test/items/reassign.test.ts +130 -0
  360. package/packages/arcgis-rest-portal/test/items/remove.test.ts +259 -0
  361. package/packages/arcgis-rest-portal/test/items/search.test.ts +274 -0
  362. package/packages/arcgis-rest-portal/test/items/update.test.ts +549 -0
  363. package/packages/arcgis-rest-portal/test/items/upload.test.ts +286 -0
  364. package/packages/arcgis-rest-portal/test/mocks/groups/responses.ts +208 -0
  365. package/packages/arcgis-rest-portal/test/mocks/items/foo.zip +0 -0
  366. package/packages/arcgis-rest-portal/test/mocks/items/item.ts +526 -0
  367. package/packages/arcgis-rest-portal/test/mocks/items/resources.ts +38 -0
  368. package/packages/arcgis-rest-portal/test/mocks/items/search.ts +121 -0
  369. package/packages/arcgis-rest-portal/test/mocks/portal/response.ts +126 -0
  370. package/packages/arcgis-rest-portal/test/mocks/portal/settings-response.ts +56 -0
  371. package/packages/arcgis-rest-portal/test/mocks/sharing/sharing.ts +18 -0
  372. package/packages/arcgis-rest-portal/test/mocks/users/invitation.ts +70 -0
  373. package/packages/arcgis-rest-portal/test/mocks/users/notification.ts +34 -0
  374. package/packages/arcgis-rest-portal/test/mocks/users/user-search.ts +388 -0
  375. package/packages/arcgis-rest-portal/test/mocks/users/user-tags.ts +5 -0
  376. package/packages/arcgis-rest-portal/test/mocks/users/user.ts +174 -0
  377. package/packages/arcgis-rest-portal/test/orgs/notification.test.ts +142 -0
  378. package/packages/arcgis-rest-portal/test/services/get-unique-service-name.test.ts +64 -0
  379. package/packages/arcgis-rest-portal/test/services/is-service-name-available.test.ts +41 -0
  380. package/packages/arcgis-rest-portal/test/sharing/access.test.ts +162 -0
  381. package/packages/arcgis-rest-portal/test/sharing/helpers.test.ts +55 -0
  382. package/packages/arcgis-rest-portal/test/sharing/share-item-with-group.test.ts +1328 -0
  383. package/packages/arcgis-rest-portal/test/sharing/unshare-item-with-group.test.ts +288 -0
  384. package/packages/arcgis-rest-portal/test/users/get-user-tags.test.ts +71 -0
  385. package/packages/arcgis-rest-portal/test/users/get-user-url.test.ts +40 -0
  386. package/packages/arcgis-rest-portal/test/users/get-user.test.ts +90 -0
  387. package/packages/arcgis-rest-portal/test/users/invitation.test.ts +126 -0
  388. package/packages/arcgis-rest-portal/test/users/notification.test.ts +76 -0
  389. package/packages/arcgis-rest-portal/test/users/search.test.ts +41 -0
  390. package/packages/arcgis-rest-portal/test/users/update.test.ts +150 -0
  391. package/packages/arcgis-rest-portal/test/util/SearchQueryBuilder.test.ts +295 -0
  392. package/packages/arcgis-rest-portal/test/util/array.test.ts +33 -0
  393. package/packages/arcgis-rest-portal/test/util/get-portal-settings.test.ts +57 -0
  394. package/packages/arcgis-rest-portal/test/util/get-portal-url.test.ts +37 -0
  395. package/packages/arcgis-rest-portal/test/util/portal.test.ts +137 -0
  396. package/packages/arcgis-rest-portal/test/util/scrub-control-chars.test.ts +25 -0
  397. package/packages/arcgis-rest-portal/tsconfig.json +6 -0
  398. package/packages/arcgis-rest-request/README.md +72 -0
  399. package/packages/arcgis-rest-request/package.json +69 -0
  400. package/packages/arcgis-rest-request/post-message-auth-spec.md +70 -0
  401. package/packages/arcgis-rest-request/src/ApiKeyManager.ts +60 -0
  402. package/packages/arcgis-rest-request/src/ApplicationCredentialsManager.ts +141 -0
  403. package/packages/arcgis-rest-request/src/ArcGISIdentityManager.ts +1470 -0
  404. package/packages/arcgis-rest-request/src/app-tokens.ts +132 -0
  405. package/packages/arcgis-rest-request/src/authenticated-request-options.ts +23 -0
  406. package/packages/arcgis-rest-request/src/federation-utils.ts +88 -0
  407. package/packages/arcgis-rest-request/src/fetch-token.ts +48 -0
  408. package/packages/arcgis-rest-request/src/generate-token.ts +32 -0
  409. package/packages/arcgis-rest-request/src/index.ts +45 -0
  410. package/packages/arcgis-rest-request/src/request.ts +446 -0
  411. package/packages/arcgis-rest-request/src/revoke-token.ts +73 -0
  412. package/packages/arcgis-rest-request/src/types/feature.ts +42 -0
  413. package/packages/arcgis-rest-request/src/types/geometry.ts +239 -0
  414. package/packages/arcgis-rest-request/src/types/group.ts +72 -0
  415. package/packages/arcgis-rest-request/src/types/service.ts +87 -0
  416. package/packages/arcgis-rest-request/src/types/symbol.ts +21 -0
  417. package/packages/arcgis-rest-request/src/types/user.ts +49 -0
  418. package/packages/arcgis-rest-request/src/utils/ArcGISRequestError.ts +82 -0
  419. package/packages/arcgis-rest-request/src/utils/ErrorTypes.ts +29 -0
  420. package/packages/arcgis-rest-request/src/utils/GrantTypes.ts +5 -0
  421. package/packages/arcgis-rest-request/src/utils/HTTPMethods.ts +6 -0
  422. package/packages/arcgis-rest-request/src/utils/IAuthenticationManager.ts +22 -0
  423. package/packages/arcgis-rest-request/src/utils/IFetchTokenParams.ts +11 -0
  424. package/packages/arcgis-rest-request/src/utils/IGenerateTokenParams.ts +9 -0
  425. package/packages/arcgis-rest-request/src/utils/IParamBuilder.ts +3 -0
  426. package/packages/arcgis-rest-request/src/utils/IParams.ts +6 -0
  427. package/packages/arcgis-rest-request/src/utils/IParamsBuilder.ts +5 -0
  428. package/packages/arcgis-rest-request/src/utils/IRequestOptions.ts +59 -0
  429. package/packages/arcgis-rest-request/src/utils/ITokenRequestOptions.ts +9 -0
  430. package/packages/arcgis-rest-request/src/utils/ResponseFormats.ts +10 -0
  431. package/packages/arcgis-rest-request/src/utils/append-custom-params.ts +46 -0
  432. package/packages/arcgis-rest-request/src/utils/clean-url.ts +20 -0
  433. package/packages/arcgis-rest-request/src/utils/decode-query-string.ts +27 -0
  434. package/packages/arcgis-rest-request/src/utils/encode-form-data.ts +41 -0
  435. package/packages/arcgis-rest-request/src/utils/encode-query-string.ts +37 -0
  436. package/packages/arcgis-rest-request/src/utils/process-params.ts +109 -0
  437. package/packages/arcgis-rest-request/src/utils/retryAuthError.ts +10 -0
  438. package/packages/arcgis-rest-request/src/utils/warn.ts +11 -0
  439. package/packages/arcgis-rest-request/src/utils/with-options.ts +48 -0
  440. package/packages/arcgis-rest-request/src/validate-app-access.ts +69 -0
  441. package/packages/arcgis-rest-request/test/ApiKey.test.ts +53 -0
  442. package/packages/arcgis-rest-request/test/ApplicationSession.test.ts +148 -0
  443. package/packages/arcgis-rest-request/test/ArcGISIdentityManager.test.ts +2579 -0
  444. package/packages/arcgis-rest-request/test/app-tokens.test.ts +91 -0
  445. package/packages/arcgis-rest-request/test/federation-utils.test.ts +323 -0
  446. package/packages/arcgis-rest-request/test/fetchToken.test.ts +110 -0
  447. package/packages/arcgis-rest-request/test/generateToken.test.ts +40 -0
  448. package/packages/arcgis-rest-request/test/mocks/errors.ts +76 -0
  449. package/packages/arcgis-rest-request/test/mocks/geojson-feature-collection.ts +13 -0
  450. package/packages/arcgis-rest-request/test/mocks/param-builder.ts +7 -0
  451. package/packages/arcgis-rest-request/test/mocks/sharing-rest-info.ts +41 -0
  452. package/packages/arcgis-rest-request/test/mocks/webmap.ts +41 -0
  453. package/packages/arcgis-rest-request/test/request.test.ts +563 -0
  454. package/packages/arcgis-rest-request/test/revoke-token.test.ts +55 -0
  455. package/packages/arcgis-rest-request/test/utils/ArcGISAuthError.test.ts +196 -0
  456. package/packages/arcgis-rest-request/test/utils/ArcGISRequestError.test.ts +51 -0
  457. package/packages/arcgis-rest-request/test/utils/check-for-errors.test.ts +111 -0
  458. package/packages/arcgis-rest-request/test/utils/clean-url.test.ts +50 -0
  459. package/packages/arcgis-rest-request/test/utils/encode-form-data.test.ts +146 -0
  460. package/packages/arcgis-rest-request/test/utils/encode-query-string.test.ts +22 -0
  461. package/packages/arcgis-rest-request/test/utils/process-params.test.ts +205 -0
  462. package/packages/arcgis-rest-request/test/utils/with-options.test.ts +135 -0
  463. package/packages/arcgis-rest-request/test/validate-app-access.test.ts +44 -0
  464. package/packages/arcgis-rest-request/tsconfig.json +4 -0
  465. package/packages/arcgis-rest-routing/README.md +74 -0
  466. package/packages/arcgis-rest-routing/package.json +69 -0
  467. package/packages/arcgis-rest-routing/src/closestFacility.ts +223 -0
  468. package/packages/arcgis-rest-routing/src/helpers.ts +104 -0
  469. package/packages/arcgis-rest-routing/src/index.ts +20 -0
  470. package/packages/arcgis-rest-routing/src/originDestinationMatrix.ts +219 -0
  471. package/packages/arcgis-rest-routing/src/serviceArea.ts +169 -0
  472. package/packages/arcgis-rest-routing/src/solveRoute.ts +179 -0
  473. package/packages/arcgis-rest-routing/test/closestFacility.test.ts +686 -0
  474. package/packages/arcgis-rest-routing/test/mocks/inputs.ts +132 -0
  475. package/packages/arcgis-rest-routing/test/mocks/responses.ts +13316 -0
  476. package/packages/arcgis-rest-routing/test/originDestinationMatrix.test.ts +795 -0
  477. package/packages/arcgis-rest-routing/test/serviceArea.test.ts +601 -0
  478. package/packages/arcgis-rest-routing/test/solveRoute.test.ts +681 -0
  479. package/packages/arcgis-rest-routing/tsconfig.json +6 -0
  480. package/prettier-package-json.config.cjs +81 -0
  481. package/rollup.js +152 -0
  482. package/scripts/create-dist-package-jsons.js +17 -0
  483. package/scripts/deploy-doc-site.js +16 -0
  484. package/scripts/generate-sri-hashes.js +52 -0
  485. package/scripts/get-package-json.js +27 -0
  486. package/scripts/run-demo-server.js +21 -0
  487. package/scripts/test-helpers.ts +20 -0
  488. package/tsconfig.json +62 -0
  489. package/typedoc.json +14 -0
@@ -0,0 +1,1328 @@
1
+ /* Copyright (c) 2018 Environmental Systems Research Institute, Inc.
2
+ * Apache-2.0 */
3
+
4
+ import fetchMock from "fetch-mock";
5
+ import {
6
+ shareItemWithGroup,
7
+ ensureMembership
8
+ } from "../../src/sharing/share-item-with-group.js";
9
+ import { MOCK_USER_SESSION } from "../mocks/sharing/sharing.js";
10
+ import { TOMORROW } from "../../../../scripts/test-helpers.js";
11
+ import { ArcGISAuthError } from "@esri/arcgis-rest-request";
12
+
13
+ import {
14
+ GroupNonMemberUserResponse,
15
+ GroupMemberUserResponse,
16
+ GroupAdminUserResponse,
17
+ OrgAdminUserResponse,
18
+ AnonUserResponse
19
+ } from "../mocks/users/user.js";
20
+
21
+ import { SearchResponse } from "../mocks/items/search.js";
22
+ import { ISharingResponse } from "../../src/sharing/helpers.js";
23
+
24
+ const SharingResponse = {
25
+ notSharedWith: [] as any,
26
+ itemId: "n3v"
27
+ };
28
+
29
+ const FailedSharingResponse = {
30
+ notSharedWith: ["t6b"],
31
+ itemId: "n3v"
32
+ };
33
+
34
+ const CachedSharingResponse = {
35
+ notSharedWith: [] as any,
36
+ itemId: "a5b",
37
+ shortcut: true
38
+ };
39
+
40
+ const NoResultsSearchResponse = {
41
+ query: "",
42
+ total: 0,
43
+ start: 0,
44
+ num: 0,
45
+ nextStart: 0,
46
+ results: [] as any
47
+ };
48
+
49
+ export const GroupOwnerResponse = {
50
+ id: "tb6",
51
+ title: "fake group",
52
+ userMembership: {
53
+ memberType: "owner"
54
+ }
55
+ };
56
+
57
+ export const GroupMemberResponse = {
58
+ id: "tb6",
59
+ title: "fake group",
60
+ userMembership: {
61
+ memberType: "member"
62
+ }
63
+ };
64
+
65
+ export const GroupNonMemberResponse = {
66
+ id: "tb6",
67
+ title: "fake group",
68
+ userMembership: {
69
+ memberType: "none"
70
+ }
71
+ };
72
+
73
+ export const GroupAdminResponse = {
74
+ id: "tb6",
75
+ title: "fake group",
76
+ userMembership: {
77
+ memberType: "admin"
78
+ }
79
+ };
80
+
81
+ export const GroupNoAccessResponse = {
82
+ error: {
83
+ code: 400,
84
+ messageCode: "COM_0003",
85
+ message: "Group does not exist or is inaccessible.",
86
+ details: [] as any[]
87
+ }
88
+ };
89
+
90
+ describe("shareItemWithGroup() ::", () => {
91
+ // make sure session doesnt cache metadata
92
+ beforeEach((done) => {
93
+ fetchMock.post("https://myorg.maps.arcgis.com/sharing/rest/generateToken", {
94
+ token: "fake-token",
95
+ expires: TOMORROW.getTime(),
96
+ username: "jsmith"
97
+ });
98
+
99
+ // make sure session doesnt cache metadata
100
+ MOCK_USER_SESSION.refreshSession()
101
+ .then(() => done())
102
+ .catch();
103
+ });
104
+
105
+ afterEach(fetchMock.restore);
106
+ describe("share item as owner::", () => {
107
+ it("should share an item with a group by owner", (done) => {
108
+ // this is called when we try to determine if the item is already in the group
109
+ fetchMock.once(
110
+ "https://myorg.maps.arcgis.com/sharing/rest/search",
111
+ SearchResponse
112
+ );
113
+
114
+ // the actual sharing request
115
+ fetchMock.once(
116
+ "https://myorg.maps.arcgis.com/sharing/rest/content/users/jsmith/items/n3v/share",
117
+ SharingResponse
118
+ );
119
+
120
+ shareItemWithGroup({
121
+ authentication: MOCK_USER_SESSION,
122
+ id: "n3v",
123
+ groupId: "t6b"
124
+ })
125
+ .then((response) => {
126
+ expect(fetchMock.done()).toBeTruthy(
127
+ "All fetchMocks should have been called"
128
+ );
129
+ const [url, options]: [string, RequestInit] = fetchMock.lastCall(
130
+ "https://myorg.maps.arcgis.com/sharing/rest/content/users/jsmith/items/n3v/share"
131
+ );
132
+ expect(url).toBe(
133
+ "https://myorg.maps.arcgis.com/sharing/rest/content/users/jsmith/items/n3v/share"
134
+ );
135
+ expect(options.method).toBe("POST");
136
+ expect(response).toEqual(SharingResponse);
137
+ expect(options.body).toContain("f=json");
138
+ expect(options.body).toContain("groups=t6b");
139
+ done();
140
+ })
141
+ .catch((e) => {
142
+ expect(fetchMock.done()).toBeTruthy(
143
+ "All fetchMocks should have been called"
144
+ );
145
+ fail(e);
146
+ });
147
+ });
148
+
149
+ it("should share an item with a group by org administrator", (done) => {
150
+ fetchMock.once(
151
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/jsmith?f=json&token=fake-token",
152
+ OrgAdminUserResponse
153
+ );
154
+
155
+ fetchMock.once(
156
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/casey?f=json&token=fake-token",
157
+ {
158
+ username: "casey",
159
+ orgId: "qWAReEOCnD7eTxOe",
160
+ groups: [] as any[]
161
+ }
162
+ );
163
+
164
+ fetchMock.once(
165
+ "https://myorg.maps.arcgis.com/sharing/rest/search",
166
+ NoResultsSearchResponse
167
+ );
168
+
169
+ // called when we determine if the user is a member of the group
170
+ fetchMock.get(
171
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b?f=json&token=fake-token",
172
+ GroupOwnerResponse
173
+ );
174
+
175
+ fetchMock.once(
176
+ "https://myorg.maps.arcgis.com/sharing/rest/content/users/casey/items/n3v/share",
177
+ SharingResponse
178
+ );
179
+ shareItemWithGroup({
180
+ authentication: MOCK_USER_SESSION,
181
+ id: "n3v",
182
+ groupId: "t6b",
183
+ owner: "casey"
184
+ })
185
+ .then((response) => {
186
+ expect(fetchMock.done()).toBeTruthy(
187
+ "All fetchMocks should have been called"
188
+ );
189
+ const [url, options]: [string, RequestInit] = fetchMock.lastCall(
190
+ "https://myorg.maps.arcgis.com/sharing/rest/content/users/casey/items/n3v/share"
191
+ );
192
+ expect(url).toBe(
193
+ "https://myorg.maps.arcgis.com/sharing/rest/content/users/casey/items/n3v/share"
194
+ );
195
+ expect(options.method).toBe("POST");
196
+ expect(response).toEqual(SharingResponse);
197
+ expect(options.body).toContain("f=json");
198
+ expect(options.body).toContain("groups=t6b");
199
+ done();
200
+ })
201
+ .catch((e) => {
202
+ fail(e);
203
+ });
204
+ });
205
+
206
+ it("should share an item with a group by group owner/admin", (done) => {
207
+ fetchMock.once(
208
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/jsmith?f=json&token=fake-token",
209
+ GroupAdminUserResponse
210
+ );
211
+
212
+ fetchMock.once(
213
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/otherguy?f=json&token=fake-token",
214
+ {
215
+ username: "otherguy",
216
+ orgId: "qWAReEOCnD7eTxOe",
217
+ groups: [] as any[]
218
+ }
219
+ );
220
+
221
+ fetchMock.once(
222
+ "https://myorg.maps.arcgis.com/sharing/rest/search",
223
+ SearchResponse
224
+ );
225
+
226
+ // called when we determine if the user is a member of the group
227
+ fetchMock.get(
228
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b?f=json&token=fake-token",
229
+ GroupOwnerResponse
230
+ );
231
+
232
+ fetchMock.once(
233
+ "https://myorg.maps.arcgis.com/sharing/rest/content/items/n3v/share",
234
+ SharingResponse
235
+ );
236
+
237
+ shareItemWithGroup({
238
+ authentication: MOCK_USER_SESSION,
239
+ id: "n3v",
240
+ groupId: "t6b",
241
+ owner: "otherguy"
242
+ })
243
+ .then((response) => {
244
+ expect(fetchMock.done()).toBeTruthy(
245
+ "All fetchMocks should have been called"
246
+ );
247
+ const [url, options]: [string, RequestInit] = fetchMock.lastCall(
248
+ "https://myorg.maps.arcgis.com/sharing/rest/content/items/n3v/share"
249
+ );
250
+ expect(url).toBe(
251
+ "https://myorg.maps.arcgis.com/sharing/rest/content/items/n3v/share"
252
+ );
253
+ expect(options.method).toBe("POST");
254
+ expect(response).toEqual(SharingResponse);
255
+ expect(options.body).toContain("f=json");
256
+ expect(options.body).toContain("groups=t6b");
257
+ done();
258
+ })
259
+ .catch((e) => {
260
+ expect(fetchMock.done()).toBeTruthy(
261
+ "All fetchMocks should have been called"
262
+ );
263
+ fail(e);
264
+ });
265
+ });
266
+
267
+ it("should mock the response if an item was previously shared with a group", (done) => {
268
+ fetchMock.once(
269
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/jsmith?f=json&token=fake-token",
270
+ GroupAdminUserResponse
271
+ );
272
+
273
+ fetchMock.once(
274
+ "https://myorg.maps.arcgis.com/sharing/rest/search",
275
+ SearchResponse
276
+ );
277
+
278
+ shareItemWithGroup({
279
+ authentication: MOCK_USER_SESSION,
280
+ id: "a5b",
281
+ groupId: "t6b"
282
+ })
283
+ .then((response) => {
284
+ // no web request to share at all
285
+ expect(response).toEqual(CachedSharingResponse);
286
+ done();
287
+ })
288
+ .catch((e) => {
289
+ expect(fetchMock.done()).toBeTruthy(
290
+ "All fetchMocks should have been called"
291
+ );
292
+ fail(e);
293
+ });
294
+ });
295
+
296
+ it("should allow group owner/admin/member to share item they do not own", (done) => {
297
+ fetchMock.once(
298
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/jsmith?f=json&token=fake-token",
299
+ GroupMemberUserResponse
300
+ );
301
+
302
+ fetchMock.once(
303
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/casey?f=json&token=fake-token",
304
+ {
305
+ username: "casey",
306
+ orgId: "qWAReEOCnD7eTxOe",
307
+ groups: [] as any[]
308
+ }
309
+ );
310
+
311
+ fetchMock.once(
312
+ "https://myorg.maps.arcgis.com/sharing/rest/search",
313
+ SearchResponse
314
+ );
315
+
316
+ // called when we determine if the user is a member of the group
317
+ fetchMock.get(
318
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b?f=json&token=fake-token",
319
+ GroupMemberResponse
320
+ );
321
+
322
+ fetchMock.once(
323
+ "https://myorg.maps.arcgis.com/sharing/rest/content/items/n3v/share",
324
+ SharingResponse
325
+ );
326
+
327
+ shareItemWithGroup({
328
+ authentication: MOCK_USER_SESSION,
329
+ id: "n3v",
330
+ groupId: "t6b",
331
+ owner: "casey"
332
+ })
333
+ .then((response) => {
334
+ expect(fetchMock.done()).toBeTruthy(
335
+ "All fetchMocks should have been called"
336
+ );
337
+ const [url, options]: [string, RequestInit] = fetchMock.lastCall(
338
+ "https://myorg.maps.arcgis.com/sharing/rest/content/items/n3v/share"
339
+ );
340
+ expect(url).toBe(
341
+ "https://myorg.maps.arcgis.com/sharing/rest/content/items/n3v/share"
342
+ );
343
+ expect(options.method).toBe("POST");
344
+ expect(response).toEqual(SharingResponse);
345
+ expect(options.body).toContain("f=json");
346
+ expect(options.body).toContain("groups=t6b");
347
+ done();
348
+ })
349
+ .catch((e) => {
350
+ fail(e);
351
+ });
352
+ });
353
+
354
+ it("should throw if non-owner tries to share to shared editing group", (done) => {
355
+ fetchMock.once(
356
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/jsmith?f=json&token=fake-token",
357
+ GroupMemberUserResponse
358
+ );
359
+
360
+ fetchMock.once(
361
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/casey?f=json&token=fake-token",
362
+ {
363
+ username: "casey",
364
+ orgId: "qWAReEOCnD7eTxOe",
365
+ groups: [] as any[]
366
+ }
367
+ );
368
+
369
+ fetchMock.once(
370
+ "https://myorg.maps.arcgis.com/sharing/rest/search",
371
+ SearchResponse
372
+ );
373
+
374
+ // called when we determine if the user is a member of the group
375
+ fetchMock.get(
376
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b?f=json&token=fake-token",
377
+ GroupMemberResponse
378
+ );
379
+
380
+ shareItemWithGroup({
381
+ authentication: MOCK_USER_SESSION,
382
+ id: "n3v",
383
+ groupId: "t6b",
384
+ owner: "casey",
385
+ confirmItemControl: true
386
+ }).catch((e) => {
387
+ expect(fetchMock.done()).toBeTruthy(
388
+ "All fetchMocks should have been called"
389
+ );
390
+ expect(e.message).toContain(
391
+ "This item can not be shared to shared editing group t6b by jsmith as they not the item owner or org admin."
392
+ );
393
+ done();
394
+ });
395
+ });
396
+
397
+ it("should throw if the response from the server is fishy", (done) => {
398
+ fetchMock.once(
399
+ "https://myorg.maps.arcgis.com/sharing/rest/search",
400
+ SearchResponse
401
+ );
402
+
403
+ fetchMock.once(
404
+ "https://myorg.maps.arcgis.com/sharing/rest/content/users/jsmith/items/n3v/share",
405
+ FailedSharingResponse
406
+ );
407
+
408
+ shareItemWithGroup({
409
+ authentication: MOCK_USER_SESSION,
410
+ id: "n3v",
411
+ groupId: "t6b"
412
+ }).catch((e) => {
413
+ expect(fetchMock.done()).toBeTruthy(
414
+ "All fetchMocks should have been called"
415
+ );
416
+ expect(e.message).toBe("Item n3v could not be shared to group t6b.");
417
+ done();
418
+ });
419
+ });
420
+ });
421
+
422
+ describe("share item as org admin on behalf of other user ::", () => {
423
+ it("should add user to group then share item", (done) => {
424
+ fetchMock
425
+ .once(
426
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/jsmith?f=json&token=fake-token",
427
+ OrgAdminUserResponse
428
+ )
429
+ .once(
430
+ "https://myorg.maps.arcgis.com/sharing/rest/search",
431
+ NoResultsSearchResponse
432
+ )
433
+ .get(
434
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b?f=json&token=fake-token",
435
+ GroupOwnerResponse
436
+ )
437
+ .once(
438
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/casey?f=json&token=fake-token",
439
+ {
440
+ username: "casey",
441
+ orgId: "qWAReEOCnD7eTxOe",
442
+ groups: [] as any[]
443
+ }
444
+ )
445
+ .post(
446
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b/addUsers",
447
+ { notAdded: [] }
448
+ )
449
+ .post(
450
+ "https://myorg.maps.arcgis.com/sharing/rest/content/users/casey/items/n3v/share",
451
+ { notSharedWith: [], itemId: "n3v" }
452
+ );
453
+
454
+ shareItemWithGroup({
455
+ authentication: MOCK_USER_SESSION,
456
+ id: "n3v",
457
+ groupId: "t6b",
458
+ owner: "casey",
459
+ confirmItemControl: true
460
+ })
461
+ .then((result) => {
462
+ expect(fetchMock.done()).toBeTruthy(
463
+ "All fetchMocks should have been called"
464
+ );
465
+ // verify we added casey to t6b
466
+ const addUsersOptions: RequestInit = fetchMock.lastOptions(
467
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b/addUsers"
468
+ );
469
+ expect(addUsersOptions.body).toContain("admins=casey");
470
+ // verify we shared the item
471
+ const shareOptions: RequestInit = fetchMock.lastOptions(
472
+ "https://myorg.maps.arcgis.com/sharing/rest/content/users/casey/items/n3v/share"
473
+ );
474
+ expect(shareOptions.body).toContain("groups=t6b");
475
+ expect(shareOptions.body).toContain("confirmItemControl=true");
476
+
477
+ done();
478
+ })
479
+ .catch((e) => {
480
+ fail();
481
+ });
482
+ });
483
+ it("should add user to group the returned user lacks groups array", (done) => {
484
+ // tbh, not 100% sure this can even happen, but... 100% coverage
485
+ fetchMock
486
+ .once(
487
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/jsmith?f=json&token=fake-token",
488
+ OrgAdminUserResponse
489
+ )
490
+ .once(
491
+ "https://myorg.maps.arcgis.com/sharing/rest/search",
492
+ NoResultsSearchResponse
493
+ )
494
+ .get(
495
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b?f=json&token=fake-token",
496
+ GroupOwnerResponse
497
+ )
498
+ .once(
499
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/casey?f=json&token=fake-token",
500
+ {
501
+ username: "casey",
502
+ orgId: "qWAReEOCnD7eTxOe"
503
+ }
504
+ )
505
+ .post(
506
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b/addUsers",
507
+ { notAdded: [] }
508
+ )
509
+ .post(
510
+ "https://myorg.maps.arcgis.com/sharing/rest/content/users/casey/items/n3v/share",
511
+ { notSharedWith: [], itemId: "n3v" }
512
+ );
513
+
514
+ shareItemWithGroup({
515
+ authentication: MOCK_USER_SESSION,
516
+ id: "n3v",
517
+ groupId: "t6b",
518
+ owner: "casey",
519
+ confirmItemControl: true
520
+ })
521
+ .then((result) => {
522
+ expect(fetchMock.done()).toBeTruthy(
523
+ "All fetchMocks should have been called"
524
+ );
525
+ // verify we added casey to t6b
526
+ const addUsersOptions: RequestInit = fetchMock.lastOptions(
527
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b/addUsers"
528
+ );
529
+ expect(addUsersOptions.body).toContain("admins=casey");
530
+ // verify we shared the item
531
+ const shareOptions: RequestInit = fetchMock.lastOptions(
532
+ "https://myorg.maps.arcgis.com/sharing/rest/content/users/casey/items/n3v/share"
533
+ );
534
+ expect(shareOptions.body).toContain("groups=t6b");
535
+ expect(shareOptions.body).toContain("confirmItemControl=true");
536
+
537
+ done();
538
+ })
539
+ .catch((e) => {
540
+ fail();
541
+ });
542
+ });
543
+ it("should upgrade user to admin then share item", (done) => {
544
+ fetchMock
545
+ .once(
546
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/jsmith?f=json&token=fake-token",
547
+ OrgAdminUserResponse
548
+ )
549
+ .once(
550
+ "https://myorg.maps.arcgis.com/sharing/rest/search",
551
+ NoResultsSearchResponse
552
+ )
553
+ .get(
554
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b?f=json&token=fake-token",
555
+ GroupOwnerResponse
556
+ )
557
+ .once(
558
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/casey?f=json&token=fake-token",
559
+ {
560
+ username: "casey",
561
+ orgId: "qWAReEOCnD7eTxOe",
562
+ groups: [
563
+ {
564
+ id: "t6b",
565
+ userMembership: {
566
+ memberType: "member"
567
+ }
568
+ }
569
+ ] as any[]
570
+ }
571
+ )
572
+ .post(
573
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b/updateUsers",
574
+ { results: [{ username: "casey", success: true }] }
575
+ )
576
+ .post(
577
+ "https://myorg.maps.arcgis.com/sharing/rest/content/users/casey/items/n3v/share",
578
+ { notSharedWith: [], itemId: "n3v" }
579
+ );
580
+
581
+ shareItemWithGroup({
582
+ authentication: MOCK_USER_SESSION,
583
+ id: "n3v",
584
+ groupId: "t6b",
585
+ owner: "casey",
586
+ confirmItemControl: true
587
+ })
588
+ .then((result) => {
589
+ expect(fetchMock.done()).toBeTruthy(
590
+ "All fetchMocks should have been called"
591
+ );
592
+ // verify we added casey to t6b
593
+ const addUsersOptions: RequestInit = fetchMock.lastOptions(
594
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b/updateUsers"
595
+ );
596
+ expect(addUsersOptions.body).toContain("admins=casey");
597
+ // verify we shared the item
598
+ const shareOptions: RequestInit = fetchMock.lastOptions(
599
+ "https://myorg.maps.arcgis.com/sharing/rest/content/users/casey/items/n3v/share"
600
+ );
601
+ expect(shareOptions.body).toContain("groups=t6b");
602
+ expect(shareOptions.body).toContain("confirmItemControl=true");
603
+
604
+ done();
605
+ })
606
+ .catch((e) => {
607
+ fail();
608
+ });
609
+ });
610
+ it("should share item if user is already admin in group", (done) => {
611
+ fetchMock
612
+ .once(
613
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/jsmith?f=json&token=fake-token",
614
+ OrgAdminUserResponse
615
+ )
616
+ .once(
617
+ "https://myorg.maps.arcgis.com/sharing/rest/search",
618
+ NoResultsSearchResponse
619
+ )
620
+ .get(
621
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b?f=json&token=fake-token",
622
+ GroupOwnerResponse
623
+ )
624
+ .once(
625
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/casey?f=json&token=fake-token",
626
+ {
627
+ username: "casey",
628
+ orgId: "qWAReEOCnD7eTxOe",
629
+ groups: [
630
+ {
631
+ id: "t6b",
632
+ userMembership: {
633
+ memberType: "admin"
634
+ }
635
+ }
636
+ ] as any[]
637
+ }
638
+ )
639
+ .post(
640
+ "https://myorg.maps.arcgis.com/sharing/rest/content/users/casey/items/n3v/share",
641
+ { notSharedWith: [], itemId: "n3v" }
642
+ );
643
+
644
+ shareItemWithGroup({
645
+ authentication: MOCK_USER_SESSION,
646
+ id: "n3v",
647
+ groupId: "t6b",
648
+ owner: "casey",
649
+ confirmItemControl: true
650
+ })
651
+ .then((result) => {
652
+ expect(fetchMock.done()).toBeTruthy(
653
+ "All fetchMocks should have been called"
654
+ );
655
+ // verify we shared the item
656
+ const shareOptions: RequestInit = fetchMock.lastOptions(
657
+ "https://myorg.maps.arcgis.com/sharing/rest/content/users/casey/items/n3v/share"
658
+ );
659
+ expect(shareOptions.body).toContain("groups=t6b");
660
+ expect(shareOptions.body).toContain("confirmItemControl=true");
661
+
662
+ done();
663
+ })
664
+ .catch((e) => {
665
+ fail();
666
+ });
667
+ });
668
+ it("should throw if we can not upgrade user membership", (done) => {
669
+ fetchMock
670
+ .once(
671
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/jsmith?f=json&token=fake-token",
672
+ OrgAdminUserResponse
673
+ )
674
+ .once(
675
+ "https://myorg.maps.arcgis.com/sharing/rest/search",
676
+ NoResultsSearchResponse
677
+ )
678
+ .get(
679
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b?f=json&token=fake-token",
680
+ GroupOwnerResponse
681
+ )
682
+ .once(
683
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/casey?f=json&token=fake-token",
684
+ {
685
+ username: "casey",
686
+ orgId: "qWAReEOCnD7eTxOe",
687
+ groups: [
688
+ {
689
+ id: "t6b",
690
+ userMembership: {
691
+ memberType: "member"
692
+ }
693
+ }
694
+ ] as any[]
695
+ }
696
+ )
697
+ .post(
698
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b/updateUsers",
699
+ { results: [{ username: "casey", success: false }] }
700
+ );
701
+
702
+ shareItemWithGroup({
703
+ authentication: MOCK_USER_SESSION,
704
+ id: "n3v",
705
+ groupId: "t6b",
706
+ owner: "casey",
707
+ confirmItemControl: true
708
+ })
709
+ .then(() => {
710
+ expect("").toBe("Should Throw, but it returned");
711
+ fail();
712
+ })
713
+ .catch((e) => {
714
+ expect(fetchMock.done()).toBeTruthy(
715
+ "All fetchMocks should have been called"
716
+ );
717
+ const addUsersOptions: RequestInit = fetchMock.lastOptions(
718
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b/updateUsers"
719
+ );
720
+ expect(addUsersOptions.body).toContain("admins=casey");
721
+ expect(e.message).toBe(
722
+ "Error promoting user casey to admin in edit group t6b. Consequently item n3v was not shared to the group."
723
+ );
724
+ done();
725
+ });
726
+ });
727
+ it("should throw if we cannot add the user as a group admin", (done) => {
728
+ fetchMock
729
+ .once(
730
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/jsmith?f=json&token=fake-token",
731
+ {
732
+ ...OrgAdminUserResponse,
733
+ groups: []
734
+ }
735
+ )
736
+ .once(
737
+ "https://myorg.maps.arcgis.com/sharing/rest/search",
738
+ NoResultsSearchResponse
739
+ )
740
+ .get(
741
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b?f=json&token=fake-token",
742
+ GroupNonMemberUserResponse
743
+ )
744
+ .once(
745
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/casey?f=json&token=fake-token",
746
+ {
747
+ username: "casey",
748
+ orgId: "qWAReEOCnD7eTxOe",
749
+ groups: [
750
+ {
751
+ id: "t6b",
752
+ userMembership: {
753
+ memberType: "admin"
754
+ }
755
+ }
756
+ ] as any[]
757
+ }
758
+ )
759
+ .post(
760
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b/addUsers",
761
+ { errors: [new ArcGISAuthError("my error", 717)] }
762
+ );
763
+
764
+ shareItemWithGroup({
765
+ authentication: MOCK_USER_SESSION,
766
+ id: "n3v",
767
+ groupId: "t6b",
768
+ owner: "casey",
769
+ confirmItemControl: true
770
+ })
771
+ .then(() => {
772
+ expect("").toBe("Should Throw, but it returned");
773
+ fail();
774
+ })
775
+ .catch((e) => {
776
+ expect(fetchMock.done()).toBeTruthy(
777
+ "All fetchMocks should have been called"
778
+ );
779
+ expect(e.message).toBe(
780
+ "Error adding jsmith as member to edit group t6b. Consequently item n3v was not shared to the group."
781
+ );
782
+ done();
783
+ });
784
+ });
785
+ it("should throw when a non org admin, non group member attempts to share a view group", (done) => {
786
+ fetchMock
787
+ .once(
788
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/jsmith?f=json&token=fake-token",
789
+ { ...AnonUserResponse, orgId: "qWAReEOCnD7eTxOe" }
790
+ )
791
+ .once(
792
+ "https://myorg.maps.arcgis.com/sharing/rest/search",
793
+ NoResultsSearchResponse
794
+ )
795
+ .get(
796
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b?f=json&token=fake-token",
797
+ GroupNonMemberUserResponse
798
+ )
799
+ .once(
800
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/casey?f=json&token=fake-token",
801
+ {
802
+ username: "casey",
803
+ orgId: "qWAReEOCnD7eTxOe",
804
+ groups: [
805
+ {
806
+ id: "t6b",
807
+ userMembership: {
808
+ memberType: "member"
809
+ }
810
+ }
811
+ ] as any[]
812
+ }
813
+ );
814
+
815
+ shareItemWithGroup({
816
+ authentication: MOCK_USER_SESSION,
817
+ id: "n3v",
818
+ groupId: "t6b",
819
+ owner: "casey",
820
+ confirmItemControl: false
821
+ })
822
+ .then(() => {
823
+ expect("").toBe("Should Throw, but it returned");
824
+ fail();
825
+ })
826
+ .catch((e) => {
827
+ expect(fetchMock.done()).toBeTruthy(
828
+ "All fetchMocks should have been called"
829
+ );
830
+ expect(e.message).toBe(
831
+ "This item can not be shared by jsmith as they are not a member of the specified group t6b."
832
+ );
833
+ done();
834
+ });
835
+ });
836
+ it("should throw if owner is in other org", (done) => {
837
+ fetchMock
838
+ .get(
839
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/jsmith?f=json&token=fake-token",
840
+ OrgAdminUserResponse
841
+ )
842
+ .once(
843
+ "https://myorg.maps.arcgis.com/sharing/rest/search",
844
+ NoResultsSearchResponse
845
+ )
846
+ .get(
847
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b?f=json&token=fake-token",
848
+ GroupOwnerResponse
849
+ )
850
+ .get(
851
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/casey?f=json&token=fake-token",
852
+ {
853
+ username: "casey",
854
+ orgId: "some-other-org",
855
+ groups: [] as any[]
856
+ }
857
+ );
858
+
859
+ shareItemWithGroup({
860
+ authentication: MOCK_USER_SESSION,
861
+ id: "n3v",
862
+ groupId: "t6b",
863
+ owner: "casey",
864
+ confirmItemControl: true
865
+ })
866
+ .then(() => {
867
+ expect("").toBe("Should Throw, but it returned");
868
+ fail();
869
+ })
870
+ .catch((e) => {
871
+ expect(fetchMock.done()).toBeTruthy(
872
+ "All fetchMocks should have been called"
873
+ );
874
+
875
+ expect(e.message).toBe(
876
+ "User casey is not a member of the same org as jsmith. Consequently they can not be added added to group t6b nor can item n3v be shared to the group."
877
+ );
878
+ done();
879
+ });
880
+ });
881
+ it("should throw if owner has > 511 groups", (done) => {
882
+ const caseyUser = {
883
+ username: "casey",
884
+ orgId: "qWAReEOCnD7eTxOe",
885
+ groups: new Array(512)
886
+ };
887
+ caseyUser.groups.fill({ id: "not-real-group" });
888
+ fetchMock
889
+ .get(
890
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/jsmith?f=json&token=fake-token",
891
+ OrgAdminUserResponse
892
+ )
893
+ .once(
894
+ "https://myorg.maps.arcgis.com/sharing/rest/search",
895
+ NoResultsSearchResponse
896
+ )
897
+ .get(
898
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b?f=json&token=fake-token",
899
+ GroupOwnerResponse
900
+ )
901
+ .get(
902
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/casey?f=json&token=fake-token",
903
+ caseyUser
904
+ );
905
+
906
+ shareItemWithGroup({
907
+ authentication: MOCK_USER_SESSION,
908
+ id: "n3v",
909
+ groupId: "t6b",
910
+ owner: "casey",
911
+ confirmItemControl: true
912
+ })
913
+ .then(() => {
914
+ expect("").toBe("Should Throw, but it returned");
915
+ fail();
916
+ })
917
+ .catch((e) => {
918
+ expect(fetchMock.done()).toBeTruthy(
919
+ "All fetchMocks should have been called"
920
+ );
921
+
922
+ expect(e.message).toBe(
923
+ "User casey already has 512 groups, and can not be added to group t6b. Consequently item n3v can not be shared to the group."
924
+ );
925
+ done();
926
+ });
927
+ });
928
+
929
+ it("should throw when updateUserMemberships fails", (done) => {
930
+ fetchMock
931
+ .once(
932
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/jsmith?f=json&token=fake-token",
933
+ OrgAdminUserResponse
934
+ )
935
+ .once(
936
+ "https://myorg.maps.arcgis.com/sharing/rest/search",
937
+ NoResultsSearchResponse
938
+ )
939
+ .get(
940
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b?f=json&token=fake-token",
941
+ GroupOwnerResponse
942
+ )
943
+ .once(
944
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/casey?f=json&token=fake-token",
945
+ {
946
+ username: "casey",
947
+ orgId: "qWAReEOCnD7eTxOe",
948
+ groups: [
949
+ {
950
+ id: "t6b",
951
+ userMembership: {
952
+ memberType: "member"
953
+ }
954
+ }
955
+ ] as any[]
956
+ }
957
+ )
958
+ .post(
959
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b/updateUsers",
960
+ { throws: true }
961
+ );
962
+
963
+ shareItemWithGroup({
964
+ authentication: MOCK_USER_SESSION,
965
+ id: "n3v",
966
+ groupId: "t6b",
967
+ owner: "casey",
968
+ confirmItemControl: true
969
+ })
970
+ .then(() => {
971
+ expect("").toBe("Should Throw, but it returned");
972
+ fail();
973
+ })
974
+ .catch((e) => {
975
+ expect(fetchMock.done()).toBeTruthy(
976
+ "All fetchMocks should have been called"
977
+ );
978
+ const addUsersOptions: RequestInit = fetchMock.lastOptions(
979
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b/updateUsers"
980
+ );
981
+ expect(addUsersOptions.body).toContain("admins=casey");
982
+ expect(e.message).toBe(
983
+ "Error promoting user casey to admin in edit group t6b. Consequently item n3v was not shared to the group."
984
+ );
985
+ done();
986
+ });
987
+ });
988
+
989
+ it("should add the admin user as a member, share the item, then remove the admin from the group", (done) => {
990
+ fetchMock
991
+ .once(
992
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/jsmith?f=json&token=fake-token",
993
+ {
994
+ ...OrgAdminUserResponse,
995
+ groups: []
996
+ }
997
+ )
998
+ .once(
999
+ "https://myorg.maps.arcgis.com/sharing/rest/search",
1000
+ NoResultsSearchResponse
1001
+ )
1002
+ .get(
1003
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b?f=json&token=fake-token",
1004
+ GroupNonMemberUserResponse
1005
+ )
1006
+ .once(
1007
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/casey?f=json&token=fake-token",
1008
+ {
1009
+ username: "casey",
1010
+ orgId: "qWAReEOCnD7eTxOe",
1011
+ groups: [
1012
+ {
1013
+ id: "t6b",
1014
+ userMembership: {
1015
+ memberType: "admin"
1016
+ }
1017
+ }
1018
+ ] as any[]
1019
+ }
1020
+ )
1021
+ .post(
1022
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b/addUsers",
1023
+ { notAdded: [] }
1024
+ )
1025
+ .post(
1026
+ "https://myorg.maps.arcgis.com/sharing/rest/content/users/casey/items/n3v/share",
1027
+ { notSharedWith: [], itemId: "nv3" }
1028
+ )
1029
+ .post(
1030
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b/removeUsers",
1031
+ { notRemoved: [] }
1032
+ );
1033
+
1034
+ shareItemWithGroup({
1035
+ authentication: MOCK_USER_SESSION,
1036
+ id: "n3v",
1037
+ groupId: "t6b",
1038
+ owner: "casey",
1039
+ confirmItemControl: true
1040
+ })
1041
+ .then((result) => {
1042
+ expect(fetchMock.done()).toBeTruthy(
1043
+ "All fetchMocks should have been called"
1044
+ );
1045
+ const shareOptions: RequestInit = fetchMock.lastOptions(
1046
+ "https://myorg.maps.arcgis.com/sharing/rest/content/users/casey/items/n3v/share"
1047
+ );
1048
+ expect(shareOptions.body).toContain("groups=t6b");
1049
+ expect(shareOptions.body).toContain("confirmItemControl=true");
1050
+
1051
+ done();
1052
+ })
1053
+ .catch((e) => {
1054
+ fail();
1055
+ });
1056
+ });
1057
+ it("should add the admin user as a member, share the item, then suppress any removeUser errors", (done) => {
1058
+ fetchMock
1059
+ .once(
1060
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/jsmith?f=json&token=fake-token",
1061
+ {
1062
+ ...OrgAdminUserResponse,
1063
+ groups: []
1064
+ }
1065
+ )
1066
+ .once(
1067
+ "https://myorg.maps.arcgis.com/sharing/rest/search",
1068
+ NoResultsSearchResponse
1069
+ )
1070
+ .get(
1071
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b?f=json&token=fake-token",
1072
+ GroupNonMemberUserResponse
1073
+ )
1074
+ .once(
1075
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/casey?f=json&token=fake-token",
1076
+ {
1077
+ username: "casey",
1078
+ orgId: "qWAReEOCnD7eTxOe",
1079
+ groups: [
1080
+ {
1081
+ id: "t6b",
1082
+ userMembership: {
1083
+ memberType: "admin"
1084
+ }
1085
+ }
1086
+ ] as any[]
1087
+ }
1088
+ )
1089
+ .post(
1090
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b/addUsers",
1091
+ { notAdded: [] }
1092
+ )
1093
+ .post(
1094
+ "https://myorg.maps.arcgis.com/sharing/rest/content/users/casey/items/n3v/share",
1095
+ { notSharedWith: [], itemId: "nv3" }
1096
+ )
1097
+ .post(
1098
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b/removeUsers",
1099
+ { throws: true }
1100
+ );
1101
+
1102
+ shareItemWithGroup({
1103
+ authentication: MOCK_USER_SESSION,
1104
+ id: "n3v",
1105
+ groupId: "t6b",
1106
+ owner: "casey",
1107
+ confirmItemControl: true
1108
+ })
1109
+ .then((result) => {
1110
+ expect(fetchMock.done()).toBeTruthy(
1111
+ "All fetchMocks should have been called"
1112
+ );
1113
+ const shareOptions: RequestInit = fetchMock.lastOptions(
1114
+ "https://myorg.maps.arcgis.com/sharing/rest/content/users/casey/items/n3v/share"
1115
+ );
1116
+ expect(shareOptions.body).toContain("groups=t6b");
1117
+ expect(shareOptions.body).toContain("confirmItemControl=true");
1118
+
1119
+ done();
1120
+ })
1121
+ .catch((e) => {
1122
+ fail();
1123
+ });
1124
+ });
1125
+ it("should upgrade user to group admin, add admin as member, then share item, then remove admin user", (done) => {
1126
+ fetchMock
1127
+ .once(
1128
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/jsmith?f=json&token=fake-token",
1129
+ {
1130
+ ...OrgAdminUserResponse,
1131
+ groups: [
1132
+ {
1133
+ ...OrgAdminUserResponse.groups[0],
1134
+ userMembership: {
1135
+ ...OrgAdminUserResponse.groups[0].userMembership,
1136
+ memberType: "member"
1137
+ }
1138
+ }
1139
+ ]
1140
+ }
1141
+ )
1142
+ .once(
1143
+ "https://myorg.maps.arcgis.com/sharing/rest/search",
1144
+ NoResultsSearchResponse
1145
+ )
1146
+ .get(
1147
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b?f=json&token=fake-token",
1148
+ GroupNonMemberResponse
1149
+ )
1150
+ .once(
1151
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/casey?f=json&token=fake-token",
1152
+ {
1153
+ username: "casey",
1154
+ orgId: "qWAReEOCnD7eTxOe",
1155
+ groups: [
1156
+ {
1157
+ id: "t6b",
1158
+ userMembership: {
1159
+ memberType: "member"
1160
+ }
1161
+ }
1162
+ ] as any[]
1163
+ }
1164
+ )
1165
+ .once(
1166
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b/updateUsers",
1167
+ { results: [{ username: "casey", success: true }] }
1168
+ )
1169
+ .post(
1170
+ "https://myorg.maps.arcgis.com/sharing/rest/content/users/casey/items/n3v/share",
1171
+ { notSharedWith: [], itemId: "n3v" }
1172
+ );
1173
+
1174
+ shareItemWithGroup({
1175
+ authentication: MOCK_USER_SESSION,
1176
+ id: "n3v",
1177
+ groupId: "t6b",
1178
+ owner: "casey",
1179
+ confirmItemControl: true
1180
+ })
1181
+ .then((result) => {
1182
+ expect(fetchMock.done()).toBeTruthy(
1183
+ "All fetchMocks should have been called"
1184
+ );
1185
+ // verify we added casey to t6b
1186
+ const addUsersOptions: RequestInit = fetchMock.lastOptions(
1187
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b/updateUsers"
1188
+ );
1189
+ expect(addUsersOptions.body).toContain("admins=casey");
1190
+ // verify we shared the item
1191
+ const shareOptions: RequestInit = fetchMock.lastOptions(
1192
+ "https://myorg.maps.arcgis.com/sharing/rest/content/users/casey/items/n3v/share"
1193
+ );
1194
+ expect(shareOptions.body).toContain("groups=t6b");
1195
+ expect(shareOptions.body).toContain("confirmItemControl=true");
1196
+
1197
+ done();
1198
+ })
1199
+ .catch((e) => {
1200
+ fail();
1201
+ });
1202
+ });
1203
+ });
1204
+ describe("ensureMembership", function () {
1205
+ it("should revert the user promotion and suppress resolved error", (done) => {
1206
+ fetchMock
1207
+ .once(
1208
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b/updateUsers",
1209
+ { results: [{ username: "jsmith", success: true }] }
1210
+ )
1211
+ .once(
1212
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b/updateUsers",
1213
+ { results: [{ username: "jsmith", success: false }] }
1214
+ );
1215
+ const { revert } = ensureMembership(
1216
+ GroupAdminUserResponse,
1217
+ GroupMemberUserResponse,
1218
+ true,
1219
+ "some error message",
1220
+ {
1221
+ authentication: MOCK_USER_SESSION,
1222
+ id: "n3v",
1223
+ groupId: "t6b",
1224
+ owner: "casey",
1225
+ confirmItemControl: true
1226
+ }
1227
+ );
1228
+ revert({ notSharedWith: [] } as ISharingResponse)
1229
+ .then(() => {
1230
+ expect(fetchMock.done()).toBeTruthy(
1231
+ "All fetchMocks should have been called"
1232
+ );
1233
+ done();
1234
+ })
1235
+ .catch((e) => {
1236
+ fail();
1237
+ });
1238
+ });
1239
+ it("should revert the user promotion and suppress rejected error", (done) => {
1240
+ fetchMock
1241
+ .once(
1242
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b/updateUsers",
1243
+ { results: [{ username: "jsmith", success: true }] }
1244
+ )
1245
+ .once(
1246
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b/updateUsers",
1247
+ { throws: true }
1248
+ );
1249
+ const { revert } = ensureMembership(
1250
+ GroupAdminUserResponse,
1251
+ GroupMemberUserResponse,
1252
+ true,
1253
+ "some error message",
1254
+ {
1255
+ authentication: MOCK_USER_SESSION,
1256
+ id: "n3v",
1257
+ groupId: "t6b",
1258
+ owner: "casey",
1259
+ confirmItemControl: true
1260
+ }
1261
+ );
1262
+ revert({ notSharedWith: [] } as ISharingResponse)
1263
+ .then(() => {
1264
+ expect(fetchMock.done()).toBeTruthy(
1265
+ "All fetchMocks should have been called"
1266
+ );
1267
+ done();
1268
+ })
1269
+ .catch((e) => {
1270
+ fail();
1271
+ });
1272
+ });
1273
+ });
1274
+ describe("share item to admin user's favorites group ::", () => {
1275
+ it("should share item", (done) => {
1276
+ fetchMock
1277
+ .once(
1278
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/jsmith?f=json&token=fake-token",
1279
+ {
1280
+ ...OrgAdminUserResponse,
1281
+ favGroupId: "t6b"
1282
+ }
1283
+ )
1284
+ .once(
1285
+ "https://myorg.maps.arcgis.com/sharing/rest/search",
1286
+ NoResultsSearchResponse
1287
+ )
1288
+ .get(
1289
+ "https://myorg.maps.arcgis.com/sharing/rest/community/groups/t6b?f=json&token=fake-token",
1290
+ GroupOwnerResponse
1291
+ )
1292
+ .once(
1293
+ "https://myorg.maps.arcgis.com/sharing/rest/community/users/casey?f=json&token=fake-token",
1294
+ {
1295
+ username: "casey",
1296
+ orgId: "qWAReEOCnD7eTxOe",
1297
+ groups: [] as any[]
1298
+ }
1299
+ )
1300
+ .post(
1301
+ "https://myorg.maps.arcgis.com/sharing/rest/content/users/casey/items/n3v/share",
1302
+ { notSharedWith: [], itemId: "n3v" }
1303
+ );
1304
+
1305
+ shareItemWithGroup({
1306
+ authentication: MOCK_USER_SESSION,
1307
+ id: "n3v",
1308
+ groupId: "t6b",
1309
+ owner: "casey"
1310
+ })
1311
+ .then((result) => {
1312
+ expect(fetchMock.done()).toBeTruthy(
1313
+ "All fetchMocks should have been called"
1314
+ );
1315
+ // verify we shared the item
1316
+ const shareOptions: RequestInit = fetchMock.lastOptions(
1317
+ "https://myorg.maps.arcgis.com/sharing/rest/content/users/casey/items/n3v/share"
1318
+ );
1319
+ expect(shareOptions.body).toContain("groups=t6b");
1320
+
1321
+ done();
1322
+ })
1323
+ .catch((e) => {
1324
+ fail();
1325
+ });
1326
+ });
1327
+ });
1328
+ });