ethyca-fides 2.70.1b0__py2.py3-none-any.whl → 2.70.1b1__py2.py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of ethyca-fides might be problematic. Click here for more details.

Files changed (198) hide show
  1. {ethyca_fides-2.70.1b0.dist-info → ethyca_fides-2.70.1b1.dist-info}/METADATA +3 -3
  2. {ethyca_fides-2.70.1b0.dist-info → ethyca_fides-2.70.1b1.dist-info}/RECORD +191 -192
  3. fides/_version.py +3 -3
  4. fides/api/api/v1/endpoints/system.py +1 -5
  5. fides/api/db/crud.py +2 -30
  6. fides/api/models/policy.py +0 -24
  7. fides/api/models/privacy_notice.py +1 -1
  8. fides/api/models/privacy_request/privacy_request.py +0 -62
  9. fides/api/models/privacy_request/webhook.py +1 -3
  10. fides/service/system/system_service.py +2 -17
  11. fides/ui-build/static/admin/404.html +1 -1
  12. fides/ui-build/static/admin/_next/static/DjKAJy5iQVbNLYvoAn3Oe/_buildManifest.js +1 -0
  13. fides/ui-build/static/admin/_next/static/chunks/155-88303b05c6e115a5.js +1 -0
  14. fides/ui-build/static/admin/_next/static/chunks/{3700-865408b36fbee782.js → 3700-de7c9f02ca184f7a.js} +1 -1
  15. fides/ui-build/static/admin/_next/static/chunks/{7725-fdc4298dfbea6f80.js → 7725-dd6736855807936a.js} +1 -1
  16. fides/ui-build/static/admin/_next/static/chunks/pages/{_app-91cae6157e6f09b5.js → _app-302177edeb0dc4f5.js} +1 -1
  17. fides/ui-build/static/admin/_next/static/chunks/pages/consent/{reporting-ae4909cad9b67822.js → reporting-09be5455ba85db39.js} +1 -1
  18. fides/ui-build/static/admin/_next/static/chunks/pages/data-discovery/action-center/[monitorId]/[systemId]-758d51b4d37dbd09.js +1 -0
  19. fides/ui-build/static/admin/_next/static/chunks/pages/data-discovery/action-center/{[monitorId]-b74dfaf4f4126e57.js → [monitorId]-0e4d9ff89c63793c.js} +1 -1
  20. fides/ui-build/static/admin/_next/static/chunks/pages/integrations/{[id]-9f6c82e14ff2cad2.js → [id]-8b13bb5f7bee61c6.js} +1 -1
  21. fides/ui-build/static/admin/_next/static/chunks/pages/{integrations-ebc9c90fe99ee68d.js → integrations-6f109ef64304ef59.js} +1 -1
  22. fides/ui-build/static/admin/_next/static/chunks/pages/{privacy-requests-14a2efa72f0d4d12.js → privacy-requests-2c82cf73d20416f2.js} +1 -1
  23. fides/ui-build/static/admin/_next/static/chunks/pages/systems-e99fbd1b2d1bfd12.js +1 -0
  24. fides/ui-build/static/admin/_next/static/chunks/pages/taxonomy-9ffcf98b8ad56bf7.js +1 -0
  25. fides/ui-build/static/admin/_next/static/css/018c12b58ee7f861.css +1 -0
  26. fides/ui-build/static/admin/add-systems/manual.html +1 -1
  27. fides/ui-build/static/admin/add-systems/multiple.html +1 -1
  28. fides/ui-build/static/admin/add-systems.html +1 -1
  29. fides/ui-build/static/admin/consent/configure/add-vendors.html +1 -1
  30. fides/ui-build/static/admin/consent/configure.html +1 -1
  31. fides/ui-build/static/admin/consent/privacy-experience/[id].html +1 -1
  32. fides/ui-build/static/admin/consent/privacy-experience/new.html +1 -1
  33. fides/ui-build/static/admin/consent/privacy-experience.html +1 -1
  34. fides/ui-build/static/admin/consent/privacy-notices/[id].html +1 -1
  35. fides/ui-build/static/admin/consent/privacy-notices/new.html +1 -1
  36. fides/ui-build/static/admin/consent/privacy-notices.html +1 -1
  37. fides/ui-build/static/admin/consent/properties.html +1 -1
  38. fides/ui-build/static/admin/consent/reporting.html +1 -1
  39. fides/ui-build/static/admin/consent.html +1 -1
  40. fides/ui-build/static/admin/data-catalog/[systemId]/projects/[projectUrn]/[resourceUrn].html +1 -1
  41. fides/ui-build/static/admin/data-catalog/[systemId]/projects/[projectUrn].html +1 -1
  42. fides/ui-build/static/admin/data-catalog/[systemId]/projects.html +1 -1
  43. fides/ui-build/static/admin/data-catalog/[systemId]/resources/[resourceUrn].html +1 -1
  44. fides/ui-build/static/admin/data-catalog/[systemId]/resources.html +1 -1
  45. fides/ui-build/static/admin/data-catalog.html +1 -1
  46. fides/ui-build/static/admin/data-discovery/action-center/[monitorId]/[systemId].html +1 -1
  47. fides/ui-build/static/admin/data-discovery/action-center/[monitorId].html +1 -1
  48. fides/ui-build/static/admin/data-discovery/action-center.html +1 -1
  49. fides/ui-build/static/admin/data-discovery/activity.html +1 -1
  50. fides/ui-build/static/admin/data-discovery/detection/[resourceUrn].html +1 -1
  51. fides/ui-build/static/admin/data-discovery/detection.html +1 -1
  52. fides/ui-build/static/admin/data-discovery/discovery/[resourceUrn].html +1 -1
  53. fides/ui-build/static/admin/data-discovery/discovery.html +1 -1
  54. fides/ui-build/static/admin/datamap.html +1 -1
  55. fides/ui-build/static/admin/dataset/[datasetId]/[collectionName]/[...subfieldNames].html +1 -1
  56. fides/ui-build/static/admin/dataset/[datasetId]/[collectionName].html +1 -1
  57. fides/ui-build/static/admin/dataset/[datasetId].html +1 -1
  58. fides/ui-build/static/admin/dataset/new.html +1 -1
  59. fides/ui-build/static/admin/dataset.html +1 -1
  60. fides/ui-build/static/admin/datastore-connection/[id].html +1 -1
  61. fides/ui-build/static/admin/datastore-connection/new.html +1 -1
  62. fides/ui-build/static/admin/datastore-connection.html +1 -1
  63. fides/ui-build/static/admin/index.html +1 -1
  64. fides/ui-build/static/admin/integrations/[id].html +1 -1
  65. fides/ui-build/static/admin/integrations.html +1 -1
  66. fides/ui-build/static/admin/login/[provider].html +1 -1
  67. fides/ui-build/static/admin/login.html +1 -1
  68. fides/ui-build/static/admin/messaging/[id].html +1 -1
  69. fides/ui-build/static/admin/messaging/add-template.html +1 -1
  70. fides/ui-build/static/admin/messaging.html +1 -1
  71. fides/ui-build/static/admin/poc/ant-components.html +1 -1
  72. fides/ui-build/static/admin/poc/form-experiments/AntForm.html +1 -1
  73. fides/ui-build/static/admin/poc/form-experiments/FormikAntFormItem.html +1 -1
  74. fides/ui-build/static/admin/poc/form-experiments/FormikControlled.html +1 -1
  75. fides/ui-build/static/admin/poc/form-experiments/FormikField.html +1 -1
  76. fides/ui-build/static/admin/poc/form-experiments/FormikSpreadField.html +1 -1
  77. fides/ui-build/static/admin/poc/forms.html +1 -1
  78. fides/ui-build/static/admin/poc/table-migration.html +1 -1
  79. fides/ui-build/static/admin/privacy-requests/[id].html +1 -1
  80. fides/ui-build/static/admin/privacy-requests/configure/storage.html +1 -1
  81. fides/ui-build/static/admin/privacy-requests/configure.html +1 -1
  82. fides/ui-build/static/admin/privacy-requests.html +1 -1
  83. fides/ui-build/static/admin/properties/[id].html +1 -1
  84. fides/ui-build/static/admin/properties/add-property.html +1 -1
  85. fides/ui-build/static/admin/properties.html +1 -1
  86. fides/ui-build/static/admin/reporting/datamap.html +1 -1
  87. fides/ui-build/static/admin/settings/about/alpha.html +1 -1
  88. fides/ui-build/static/admin/settings/about.html +1 -1
  89. fides/ui-build/static/admin/settings/consent/[configuration_id]/[purpose_id].html +1 -1
  90. fides/ui-build/static/admin/settings/consent.html +1 -1
  91. fides/ui-build/static/admin/settings/custom-fields.html +1 -1
  92. fides/ui-build/static/admin/settings/domain-records.html +1 -1
  93. fides/ui-build/static/admin/settings/domains.html +1 -1
  94. fides/ui-build/static/admin/settings/email-templates.html +1 -1
  95. fides/ui-build/static/admin/settings/locations.html +1 -1
  96. fides/ui-build/static/admin/settings/messaging-providers/[key].html +1 -1
  97. fides/ui-build/static/admin/settings/messaging-providers/new.html +1 -1
  98. fides/ui-build/static/admin/settings/messaging-providers.html +1 -1
  99. fides/ui-build/static/admin/settings/organization.html +1 -1
  100. fides/ui-build/static/admin/settings/privacy-requests.html +1 -1
  101. fides/ui-build/static/admin/settings/regulations.html +1 -1
  102. fides/ui-build/static/admin/systems/configure/[id]/test-datasets.html +1 -1
  103. fides/ui-build/static/admin/systems/configure/[id].html +1 -1
  104. fides/ui-build/static/admin/systems.html +1 -1
  105. fides/ui-build/static/admin/taxonomy.html +1 -1
  106. fides/ui-build/static/admin/user-management/new.html +1 -1
  107. fides/ui-build/static/admin/user-management/profile/[id].html +1 -1
  108. fides/ui-build/static/admin/user-management.html +1 -1
  109. fides/api/db/safe_crud.py +0 -377
  110. fides/ui-build/static/admin/_next/static/6oPWh0EXUTEVS_OTLA_S1/_buildManifest.js +0 -1
  111. fides/ui-build/static/admin/_next/static/chunks/155-047c3806cc41295e.js +0 -1
  112. fides/ui-build/static/admin/_next/static/chunks/pages/data-discovery/action-center/[monitorId]/[systemId]-3d03cd31cd99fa07.js +0 -1
  113. fides/ui-build/static/admin/_next/static/chunks/pages/systems-916238dcc0596957.js +0 -1
  114. fides/ui-build/static/admin/_next/static/chunks/pages/taxonomy-616f5a7cbb99e46d.js +0 -1
  115. fides/ui-build/static/admin/_next/static/css/1866822702989bb3.css +0 -1
  116. {ethyca_fides-2.70.1b0.dist-info → ethyca_fides-2.70.1b1.dist-info}/WHEEL +0 -0
  117. {ethyca_fides-2.70.1b0.dist-info → ethyca_fides-2.70.1b1.dist-info}/entry_points.txt +0 -0
  118. {ethyca_fides-2.70.1b0.dist-info → ethyca_fides-2.70.1b1.dist-info}/licenses/LICENSE +0 -0
  119. {ethyca_fides-2.70.1b0.dist-info → ethyca_fides-2.70.1b1.dist-info}/top_level.txt +0 -0
  120. /fides/ui-build/static/admin/_next/static/{6oPWh0EXUTEVS_OTLA_S1 → DjKAJy5iQVbNLYvoAn3Oe}/_ssgManifest.js +0 -0
  121. /fides/ui-build/static/admin/_next/static/chunks/{1115-90baef2a89f361ad.js → 1115-7888473b3dc28cda.js} +0 -0
  122. /fides/ui-build/static/admin/_next/static/chunks/{1817-dbde9966025d7970.js → 1817-ee9e29a6b8c4af50.js} +0 -0
  123. /fides/ui-build/static/admin/_next/static/chunks/{2040-fdecc41a18e40bdc.js → 2040-ab6212a3074f34f9.js} +0 -0
  124. /fides/ui-build/static/admin/_next/static/chunks/{3696-90c8b336bbc46782.js → 3696-c25dc8d1b0e1aee1.js} +0 -0
  125. /fides/ui-build/static/admin/_next/static/chunks/{3872-04d3afbfa41a7782.js → 3872-3514b712afd683c0.js} +0 -0
  126. /fides/ui-build/static/admin/_next/static/chunks/{4608-63fbb1f4f258a66e.js → 4608-96f480766541124b.js} +0 -0
  127. /fides/ui-build/static/admin/_next/static/chunks/{502-d3ecae97b67befbd.js → 502-a40d39e615f7b664.js} +0 -0
  128. /fides/ui-build/static/admin/_next/static/chunks/{5185-51eaa78e3ed6bfb7.js → 5185-33f50cf9ae17b42e.js} +0 -0
  129. /fides/ui-build/static/admin/_next/static/chunks/{5574-c31ea831371610d5.js → 5574-b8c4cba5a6938c00.js} +0 -0
  130. /fides/ui-build/static/admin/_next/static/chunks/{5783-8f5713517ebc35f3.js → 5783-8de76df87af55e98.js} +0 -0
  131. /fides/ui-build/static/admin/_next/static/chunks/{6084-dc473a58c3e2889b.js → 6084-2cd165179c428a6f.js} +0 -0
  132. /fides/ui-build/static/admin/_next/static/chunks/{6416-39d12ffc78833cb1.js → 6416-18d438ff85d807f8.js} +0 -0
  133. /fides/ui-build/static/admin/_next/static/chunks/{6882-10296485ec326e6b.js → 6882-447f15e87b8c48a5.js} +0 -0
  134. /fides/ui-build/static/admin/_next/static/chunks/{6954-4b24e1731c1cc3b3.js → 6954-599f2de2c902e9b2.js} +0 -0
  135. /fides/ui-build/static/admin/_next/static/chunks/{7158-04745cc8d684b2e7.js → 7158-835ba42fd881d8dd.js} +0 -0
  136. /fides/ui-build/static/admin/_next/static/chunks/{7476-c709d0610ebf7e2e.js → 7476-0b6e114658b15eaa.js} +0 -0
  137. /fides/ui-build/static/admin/_next/static/chunks/{7630-d0d3a0fe3f95e971.js → 7630-e7ea13be69c118a1.js} +0 -0
  138. /fides/ui-build/static/admin/_next/static/chunks/{796-876998c86754da97.js → 796-e07ac2c543f569e3.js} +0 -0
  139. /fides/ui-build/static/admin/_next/static/chunks/{8002-ed832921ad190832.js → 8002-25fd174aec9b077b.js} +0 -0
  140. /fides/ui-build/static/admin/_next/static/chunks/{9226-4a7027057f55ca2a.js → 9226-2f960b7ca530642a.js} +0 -0
  141. /fides/ui-build/static/admin/_next/static/chunks/{9826-ccedc28e978ca9e1.js → 9826-c02be5882205bbbc.js} +0 -0
  142. /fides/ui-build/static/admin/_next/static/chunks/pages/add-systems/{manual-16ecb33f09224fbb.js → manual-939253f8daf349b2.js} +0 -0
  143. /fides/ui-build/static/admin/_next/static/chunks/pages/add-systems/{multiple-2ca59996860a33c5.js → multiple-83ed7da0bb90b0a5.js} +0 -0
  144. /fides/ui-build/static/admin/_next/static/chunks/pages/{add-systems-caff552fce501f82.js → add-systems-f90aa48500c1cbde.js} +0 -0
  145. /fides/ui-build/static/admin/_next/static/chunks/pages/consent/configure/{add-vendors-7a258b7ecd6da4b8.js → add-vendors-46b88bda3d7b15c5.js} +0 -0
  146. /fides/ui-build/static/admin/_next/static/chunks/pages/consent/{configure-259ad2e10fe6f413.js → configure-c0db068d1863222f.js} +0 -0
  147. /fides/ui-build/static/admin/_next/static/chunks/pages/consent/{privacy-experience-7e78616b7b048978.js → privacy-experience-92a337ee96845af2.js} +0 -0
  148. /fides/ui-build/static/admin/_next/static/chunks/pages/consent/privacy-notices/{[id]-9c23fbe813c997d0.js → [id]-1fd2cda8707314f6.js} +0 -0
  149. /fides/ui-build/static/admin/_next/static/chunks/pages/consent/privacy-notices/{new-0e5e38bbcfe59fd2.js → new-2987e397445713c5.js} +0 -0
  150. /fides/ui-build/static/admin/_next/static/chunks/pages/consent/{privacy-notices-3ff2fd2570f02f1c.js → privacy-notices-59a8aff5935482ec.js} +0 -0
  151. /fides/ui-build/static/admin/_next/static/chunks/pages/{consent-d2bf72508c3cad55.js → consent-e5a33654a2dfaf35.js} +0 -0
  152. /fides/ui-build/static/admin/_next/static/chunks/pages/data-catalog/[systemId]/projects/[projectUrn]/{[resourceUrn]-06a08970907ed3f0.js → [resourceUrn]-293c1f2d9aefb447.js} +0 -0
  153. /fides/ui-build/static/admin/_next/static/chunks/pages/data-catalog/[systemId]/projects/{[projectUrn]-4a1af12d2d7cd660.js → [projectUrn]-6a4b0d49dcbf17a8.js} +0 -0
  154. /fides/ui-build/static/admin/_next/static/chunks/pages/data-catalog/[systemId]/{projects-99573a1ee3ef8f4c.js → projects-be7b385073f22414.js} +0 -0
  155. /fides/ui-build/static/admin/_next/static/chunks/pages/data-catalog/[systemId]/resources/{[resourceUrn]-4c84d952bb1db690.js → [resourceUrn]-18501152fa1e4f40.js} +0 -0
  156. /fides/ui-build/static/admin/_next/static/chunks/pages/data-catalog/[systemId]/{resources-6e429b7511028d60.js → resources-af80fdca3bbdc82f.js} +0 -0
  157. /fides/ui-build/static/admin/_next/static/chunks/pages/{data-catalog-56fd0f3e465e52b6.js → data-catalog-351caadeef03876a.js} +0 -0
  158. /fides/ui-build/static/admin/_next/static/chunks/pages/data-discovery/{action-center-040813022f0890c9.js → action-center-1554afcb8b9da2ab.js} +0 -0
  159. /fides/ui-build/static/admin/_next/static/chunks/pages/data-discovery/detection/{[resourceUrn]-844a8de0d1b506e2.js → [resourceUrn]-0497f3ffdb632516.js} +0 -0
  160. /fides/ui-build/static/admin/_next/static/chunks/pages/data-discovery/{detection-11b07cf2d91b17ef.js → detection-a780390da99f3e43.js} +0 -0
  161. /fides/ui-build/static/admin/_next/static/chunks/pages/data-discovery/discovery/{[resourceUrn]-65dc7f5a2ce3eae7.js → [resourceUrn]-1901c26cdde820da.js} +0 -0
  162. /fides/ui-build/static/admin/_next/static/chunks/pages/data-discovery/{discovery-4d378516817cf00b.js → discovery-0cea22af5929c81f.js} +0 -0
  163. /fides/ui-build/static/admin/_next/static/chunks/pages/{datamap-4a05303416dcb657.js → datamap-619f27c745188adb.js} +0 -0
  164. /fides/ui-build/static/admin/_next/static/chunks/pages/dataset/[datasetId]/[collectionName]/{[...subfieldNames]-d4031e438c363fff.js → [...subfieldNames]-ef71f387fbbab425.js} +0 -0
  165. /fides/ui-build/static/admin/_next/static/chunks/pages/dataset/[datasetId]/{[collectionName]-9463af37079762d0.js → [collectionName]-d790553662caf5c3.js} +0 -0
  166. /fides/ui-build/static/admin/_next/static/chunks/pages/dataset/{[datasetId]-60a4a9eb4aab4c11.js → [datasetId]-cb63db8594fe8dc1.js} +0 -0
  167. /fides/ui-build/static/admin/_next/static/chunks/pages/dataset/{new-910e28bce6a98f3d.js → new-78e052c8f95110c4.js} +0 -0
  168. /fides/ui-build/static/admin/_next/static/chunks/pages/{dataset-108630926347724e.js → dataset-d6d7ee8bd8858a8a.js} +0 -0
  169. /fides/ui-build/static/admin/_next/static/chunks/pages/datastore-connection/{[id]-5119e6602507157f.js → [id]-cc149157d290a94d.js} +0 -0
  170. /fides/ui-build/static/admin/_next/static/chunks/pages/datastore-connection/{new-cda4e7b5b888e17c.js → new-4c9fb068a5561658.js} +0 -0
  171. /fides/ui-build/static/admin/_next/static/chunks/pages/{datastore-connection-223c2d1ded51bfb1.js → datastore-connection-a832084ce294f8af.js} +0 -0
  172. /fides/ui-build/static/admin/_next/static/chunks/pages/{index-b74d1e8608ae5b5d.js → index-269b8f81546dad66.js} +0 -0
  173. /fides/ui-build/static/admin/_next/static/chunks/pages/messaging/{[id]-e8d2140787045acd.js → [id]-d8c5c03fb2f31d65.js} +0 -0
  174. /fides/ui-build/static/admin/_next/static/chunks/pages/messaging/{add-template-e3f93462a08251bf.js → add-template-0e0c06e3c8aabe02.js} +0 -0
  175. /fides/ui-build/static/admin/_next/static/chunks/pages/{messaging-b5f7d6afdecd013d.js → messaging-3f15804cf9625f01.js} +0 -0
  176. /fides/ui-build/static/admin/_next/static/chunks/pages/poc/{table-migration-329333a88f3826eb.js → table-migration-e551fccfcaae76e7.js} +0 -0
  177. /fides/ui-build/static/admin/_next/static/chunks/pages/privacy-requests/{[id]-989c77898de2da75.js → [id]-8566e3b7b2a632fa.js} +0 -0
  178. /fides/ui-build/static/admin/_next/static/chunks/pages/privacy-requests/configure/{storage-648d775d0fce49dc.js → storage-1b38b656807ed0cd.js} +0 -0
  179. /fides/ui-build/static/admin/_next/static/chunks/pages/privacy-requests/{configure-8f577df28ebca869.js → configure-b00532a0ad4f6927.js} +0 -0
  180. /fides/ui-build/static/admin/_next/static/chunks/pages/properties/{[id]-57a75c7e9659271a.js → [id]-322a01e2bceab3fb.js} +0 -0
  181. /fides/ui-build/static/admin/_next/static/chunks/pages/properties/{add-property-8964c2300206bc89.js → add-property-777ed2d73812043d.js} +0 -0
  182. /fides/ui-build/static/admin/_next/static/chunks/pages/settings/{consent-1ae1257f5b388924.js → consent-55e36839d219a503.js} +0 -0
  183. /fides/ui-build/static/admin/_next/static/chunks/pages/settings/{custom-fields-c2f1376aca192114.js → custom-fields-26ce8fc493993765.js} +0 -0
  184. /fides/ui-build/static/admin/_next/static/chunks/pages/settings/{domain-records-586505df9d853f1f.js → domain-records-7ddf9d992fe714a6.js} +0 -0
  185. /fides/ui-build/static/admin/_next/static/chunks/pages/settings/{domains-a3275554ffe8e640.js → domains-7c78ae51f0dd7102.js} +0 -0
  186. /fides/ui-build/static/admin/_next/static/chunks/pages/settings/{email-templates-604790638c656fbd.js → email-templates-05ffbda19ab894b9.js} +0 -0
  187. /fides/ui-build/static/admin/_next/static/chunks/pages/settings/{locations-be2a885150adc133.js → locations-77fb85bdd0be42b5.js} +0 -0
  188. /fides/ui-build/static/admin/_next/static/chunks/pages/settings/messaging-providers/{[key]-8df31428446a6a96.js → [key]-b0d93bf478bf63ee.js} +0 -0
  189. /fides/ui-build/static/admin/_next/static/chunks/pages/settings/messaging-providers/{new-af1471bf4571d5d3.js → new-084f9756b9987285.js} +0 -0
  190. /fides/ui-build/static/admin/_next/static/chunks/pages/settings/{messaging-providers-8d92be437793c96f.js → messaging-providers-6c51ffd46bb598e7.js} +0 -0
  191. /fides/ui-build/static/admin/_next/static/chunks/pages/settings/{organization-3c86162afe9759df.js → organization-44456bfe54ac4ad5.js} +0 -0
  192. /fides/ui-build/static/admin/_next/static/chunks/pages/settings/{privacy-requests-8cbdfd08e0fa88fb.js → privacy-requests-fbe7e8030d837aed.js} +0 -0
  193. /fides/ui-build/static/admin/_next/static/chunks/pages/settings/{regulations-4fe3b90747d885e5.js → regulations-2866ac99faa5a542.js} +0 -0
  194. /fides/ui-build/static/admin/_next/static/chunks/pages/systems/configure/[id]/{test-datasets-2deb6becece69d46.js → test-datasets-a86bafe1b4e1205f.js} +0 -0
  195. /fides/ui-build/static/admin/_next/static/chunks/pages/systems/configure/{[id]-589952aa1a31c33d.js → [id]-1895c6a13b543436.js} +0 -0
  196. /fides/ui-build/static/admin/_next/static/chunks/pages/user-management/{new-629c88e90699369b.js → new-6304dad2c5fab694.js} +0 -0
  197. /fides/ui-build/static/admin/_next/static/chunks/pages/user-management/profile/{[id]-98f737e735eaa0f0.js → [id]-ff4711db191099cd.js} +0 -0
  198. /fides/ui-build/static/admin/_next/static/chunks/pages/{user-management-562624e5461083ec.js → user-management-82fcf1151e2fe2ba.js} +0 -0
fides/_version.py CHANGED
@@ -8,11 +8,11 @@ import json
8
8
 
9
9
  version_json = '''
10
10
  {
11
- "date": "2025-09-17T11:54:23-0700",
11
+ "date": "2025-09-18T19:50:11-0400",
12
12
  "dirty": false,
13
13
  "error": null,
14
- "full-revisionid": "f42db9940a5b753019726d317e93e58db908e929",
15
- "version": "2.70.1b0"
14
+ "full-revisionid": "bede3060b132ae966597ccfc670b080f3dd65a60",
15
+ "version": "2.70.1b1"
16
16
  }
17
17
  ''' # END VERSION_JSON
18
18
 
@@ -1,4 +1,4 @@
1
- from typing import Annotated, Dict, List, Literal, Optional, Union
1
+ from typing import Annotated, Dict, List, Optional, Union
2
2
 
3
3
  from fastapi import Depends, HTTPException, Query, Response, Security
4
4
  from fastapi_pagination import Page, Params
@@ -509,8 +509,6 @@ async def ls( # pylint: disable=invalid-name
509
509
  data_categories: Optional[List[FidesKey]] = Query(None),
510
510
  data_subjects: Optional[List[FidesKey]] = Query(None),
511
511
  show_deleted: bool = Query(False),
512
- sort_by: Optional[List[Literal["name"]]] = Query(None),
513
- sort_asc: Optional[bool] = Query(True),
514
512
  ) -> Union[List[System], Page[System]]:
515
513
  """Get a list of all of the Systems.
516
514
  If any parameters or filters are provided the response will be paginated and/or filtered.
@@ -526,8 +524,6 @@ async def ls( # pylint: disable=invalid-name
526
524
  size=size,
527
525
  page=page,
528
526
  show_deleted=show_deleted,
529
- sort_by=sort_by,
530
- sort_asc=sort_asc,
531
527
  )
532
528
 
533
529
 
fides/api/db/crud.py CHANGED
@@ -1,6 +1,6 @@
1
1
  """
2
- DEPRECATED: This module uses manual transaction handling which can
3
- lead to unexpected behavior. Use fides.api.db.safe_crud instead.
2
+ Contains all of the generic CRUD endpoints that can be
3
+ generated programmatically for each resource.
4
4
  """
5
5
 
6
6
  from collections import defaultdict
@@ -18,7 +18,6 @@ from sqlalchemy.ext.asyncio import AsyncSession
18
18
  from sqlalchemy.future import select
19
19
  from sqlalchemy.sql import Select
20
20
  from starlette.status import HTTP_422_UNPROCESSABLE_ENTITY
21
- from typing_extensions import deprecated
22
21
 
23
22
  from fides.api.models.sql_models import ( # type: ignore[attr-defined]
24
23
  CustomField,
@@ -33,9 +32,6 @@ T = TypeVar("T", bound="FidesBase")
33
32
 
34
33
 
35
34
  # CRUD Functions
36
- @deprecated(
37
- "This function uses a manual session.begin() which can lead to unexpected transaction handling. Use create_resource from safe_crud instead."
38
- )
39
35
  async def create_resource(
40
36
  sql_model: Type[T], resource_dict: Dict, async_session: AsyncSession
41
37
  ) -> T:
@@ -70,9 +66,6 @@ async def create_resource(
70
66
  return await get_resource(sql_model, resource_dict["fides_key"], async_session)
71
67
 
72
68
 
73
- @deprecated(
74
- "This function uses manual session.begin() which can lead to unexpected transaction handling. Use get_custom_fields_filtered from safe_crud instead."
75
- )
76
69
  async def get_custom_fields_filtered(
77
70
  async_session: AsyncSession,
78
71
  resource_types_to_ids: Dict[ResourceTypes, List[str]] = defaultdict(list),
@@ -118,9 +111,6 @@ async def get_custom_fields_filtered(
118
111
  raise sa_error
119
112
 
120
113
 
121
- @deprecated(
122
- "This function uses manual session.begin() which can lead to unexpected transaction handling. Use get_resource from safe_crud instead."
123
- )
124
114
  async def get_resource(
125
115
  sql_model: Type[T],
126
116
  fides_key: str,
@@ -152,9 +142,6 @@ async def get_resource(
152
142
  return sql_resource
153
143
 
154
144
 
155
- @deprecated(
156
- "This function uses manual session.begin() which can lead to unexpected transaction handling. Use get_resource_with_custom_fields from safe_crud instead."
157
- )
158
145
  async def get_resource_with_custom_fields(
159
146
  sql_model: Type[T], fides_key: str, async_session: AsyncSession
160
147
  ) -> Dict[str, Any]:
@@ -206,9 +193,6 @@ async def get_resource_with_custom_fields(
206
193
  return resource_dict
207
194
 
208
195
 
209
- @deprecated(
210
- "This function uses manual session.begin() which can lead to unexpected transaction handling. Use list_resource from safe_crud instead."
211
- )
212
196
  async def list_resource(sql_model: Type[T], async_session: AsyncSession) -> List[T]:
213
197
  """
214
198
  Get a list of all of the resources of this type from the database.
@@ -219,9 +203,6 @@ async def list_resource(sql_model: Type[T], async_session: AsyncSession) -> List
219
203
  return await list_resource_query(async_session, query, sql_model)
220
204
 
221
205
 
222
- @deprecated(
223
- "This function uses manual session.begin() which can lead to unexpected transaction handling. Use list_resource_query from safe_crud instead."
224
- )
225
206
  async def list_resource_query(
226
207
  async_session: AsyncSession, query: Select, sql_model: Type[T]
227
208
  ) -> List[T]:
@@ -244,9 +225,6 @@ async def list_resource_query(
244
225
  return sql_resources
245
226
 
246
227
 
247
- @deprecated(
248
- "This function uses manual session.begin() which can lead to unexpected transaction handling. Use update_resource from safe_crud instead."
249
- )
250
228
  async def update_resource(
251
229
  sql_model: Type[T], resource_dict: Dict, async_session: AsyncSession
252
230
  ) -> Dict:
@@ -273,9 +251,6 @@ async def update_resource(
273
251
  return await get_resource(sql_model, resource_dict["fides_key"], async_session)
274
252
 
275
253
 
276
- @deprecated(
277
- "This function uses manual session.begin() which can lead to unexpected transaction handling. Use upsert_resources from safe_crud instead."
278
- )
279
254
  async def upsert_resources(
280
255
  sql_model: Type[T], resource_dicts: List[Dict], async_session: AsyncSession
281
256
  ) -> Tuple[int, int]:
@@ -325,9 +300,6 @@ async def upsert_resources(
325
300
  raise sa_error
326
301
 
327
302
 
328
- @deprecated(
329
- "This function uses manual session.begin() which can lead to unexpected transaction handling. Use delete_resource from safe_crud instead."
330
- )
331
303
  async def delete_resource(
332
304
  sql_model: Type[T], fides_key: str, async_session: AsyncSession
333
305
  ) -> T:
@@ -177,30 +177,6 @@ class Policy(Base):
177
177
  for category in node.get_data_categories()
178
178
  )
179
179
 
180
- def to_safe_dict(self) -> Dict[str, Any]:
181
- """
182
- Returns a dictionary representation of the Policy, excluding sensitive information.
183
- """
184
- return {
185
- "id": self.id,
186
- "name": self.name,
187
- "key": self.key,
188
- "drp_action": self.drp_action.value if self.drp_action else None, # type: ignore[attr-defined]
189
- "execution_timeframe": self.execution_timeframe,
190
- "client_id": self.client_id,
191
- "rules": [
192
- {
193
- "id": rule.id,
194
- "name": rule.name,
195
- "key": rule.key,
196
- "action_type": rule.action_type.value,
197
- "masking_strategy": rule.masking_strategy,
198
- "storage_destination_id": rule.storage_destination_id,
199
- }
200
- for rule in self.rules # type: ignore[attr-defined]
201
- ],
202
- }
203
-
204
180
 
205
181
  def _get_ref_from_taxonomy(
206
182
  fides_key: FidesKey,
@@ -41,7 +41,7 @@ class UserConsentPreference(Enum):
41
41
  tcf = "tcf" # Overall preference set for TCF where there are numerous preferences under the single notice
42
42
 
43
43
 
44
- class ConsentMechanism(str, Enum):
44
+ class ConsentMechanism(Enum):
45
45
  """
46
46
  Enum is not formalized in the DB because it may be subject to frequent change
47
47
  """
@@ -355,64 +355,6 @@ class PrivacyRequest(
355
355
 
356
356
  return super().create(db=db, data=data, check_name=check_name)
357
357
 
358
- def to_safe_dict(self) -> Dict[str, Any]:
359
- """
360
- Return a dict representation of the PrivacyRequest, excluding any fields
361
- that may contain sensitive information.
362
- """
363
- return {
364
- "id": self.id,
365
- "external_id": self.external_id,
366
- "status": self.status.value,
367
- "requested_at": (
368
- self.requested_at.isoformat() if self.requested_at else None
369
- ),
370
- "started_processing_at": (
371
- self.started_processing_at.isoformat()
372
- if self.started_processing_at
373
- else None
374
- ),
375
- "finished_processing_at": (
376
- self.finished_processing_at.isoformat()
377
- if self.finished_processing_at
378
- else None
379
- ),
380
- "reviewed_at": self.reviewed_at.isoformat() if self.reviewed_at else None,
381
- "reviewed_by": self.reviewed_by,
382
- "finalized_at": (
383
- self.finalized_at.isoformat() if self.finalized_at else None
384
- ),
385
- "finalized_by": self.finalized_by,
386
- "submitted_by": self.submitted_by,
387
- "custom_privacy_request_fields_approved_by": (
388
- self.custom_privacy_request_fields_approved_by
389
- ),
390
- "identity_verified_at": (
391
- self.identity_verified_at.isoformat()
392
- if self.identity_verified_at
393
- else None
394
- ),
395
- "custom_privacy_request_fields_approved_at": (
396
- self.custom_privacy_request_fields_approved_at.isoformat()
397
- if self.custom_privacy_request_fields_approved_at
398
- else None
399
- ),
400
- "client_id": self.client_id,
401
- "origin": self.origin,
402
- "policy_id": self.policy_id,
403
- "policy": self.policy.to_safe_dict() if self.policy else None,
404
- "property_id": self.property_id,
405
- "cancel_reason": self.cancel_reason,
406
- "canceled_at": self.canceled_at.isoformat() if self.canceled_at else None,
407
- "consent_preferences": self.consent_preferences,
408
- "source": self.source.value if self.source else None,
409
- "paused_at": self.paused_at.isoformat() if self.paused_at else None,
410
- "due_date": self.due_date.isoformat() if self.due_date else None,
411
- "days_left": self.days_left,
412
- "custom_fields": self.get_persisted_custom_privacy_request_fields() if self.custom_fields else None, # type: ignore[attr-defined]
413
- "location": self.location,
414
- }
415
-
416
358
  def clear_cached_values(self) -> None:
417
359
  """
418
360
  Clears all cached values associated with this privacy request from Redis.
@@ -961,8 +903,6 @@ class PrivacyRequest(
961
903
  callback_type=CallbackType.pre_approval,
962
904
  identity=self.get_cached_identity_data(),
963
905
  policy_action=policy_action,
964
- privacy_request=self.to_safe_dict(),
965
- timestamp=datetime.utcnow(),
966
906
  )
967
907
  headers = {
968
908
  "reply-to-approve": f"/privacy-request/{self.id}/pre-approve/eligible",
@@ -1003,8 +943,6 @@ class PrivacyRequest(
1003
943
  callback_type=webhook.prefix,
1004
944
  identity=self.get_cached_identity_data(),
1005
945
  policy_action=policy_action,
1006
- privacy_request=self.to_safe_dict(),
1007
- timestamp=datetime.utcnow(),
1008
946
  )
1009
947
 
1010
948
  headers = {}
@@ -5,7 +5,7 @@ from __future__ import annotations
5
5
  import json
6
6
  from datetime import datetime
7
7
  from enum import Enum as EnumType
8
- from typing import Any, Dict, Optional
8
+ from typing import Optional
9
9
 
10
10
  from pydantic import BaseModel, ConfigDict
11
11
 
@@ -51,8 +51,6 @@ class SecondPartyRequestFormat(BaseModel):
51
51
  identity: Identity
52
52
  policy_action: Optional[ActionType] = None
53
53
  model_config = ConfigDict(use_enum_values=True)
54
- privacy_request: Dict[str, Any]
55
- timestamp: datetime
56
54
 
57
55
 
58
56
  def generate_request_callback_resume_jwe(webhook: PolicyPreWebhook) -> str:
@@ -1,5 +1,5 @@
1
1
  import datetime
2
- from typing import Any, List, Literal, Optional, Union
2
+ from typing import Any, List, Optional, Union
3
3
 
4
4
  from fastapi_pagination import Page, Params
5
5
  from fastapi_pagination.ext.async_sqlalchemy import paginate as async_paginate
@@ -36,8 +36,6 @@ class SystemService:
36
36
  size: Optional[int] = None,
37
37
  page: Optional[int] = None,
38
38
  show_deleted: bool = False,
39
- sort_by: Optional[List[Literal["name"]]] = None,
40
- sort_asc: Optional[bool] = True,
41
39
  **kwargs: Any,
42
40
  ) -> Union[List[System], Page[System]]:
43
41
  """
@@ -80,20 +78,7 @@ class SystemService:
80
78
  )
81
79
 
82
80
  # Ensure distinct results
83
- if sort_by:
84
- for sort_column_name in sort_by:
85
- if sort_column_name == "name":
86
- name_order = System.name.asc() if sort_asc else System.name.desc()
87
- # For name sorting, we need name first in ORDER BY, then id for uniqueness
88
- query = query.distinct(System.name, System.id).order_by(
89
- name_order, System.id
90
- )
91
- else:
92
- # Default to ascending name sort when no sorting parameters are provided
93
- name_order = System.name.asc()
94
- query = query.distinct(System.name, System.id).order_by(
95
- name_order, System.id
96
- )
81
+ query = query.distinct(System.id)
97
82
 
98
83
  # Return paginated or non-paginated results
99
84
  if size or page:
@@ -1 +1 @@
1
- <!DOCTYPE html><html lang="en"><head><meta charSet="utf-8"/><meta name="viewport" content="width=device-width"/><meta name="next-head-count" content="2"/><link data-next-font="" rel="preconnect" href="/" crossorigin="anonymous"/><link rel="preload" href="/_next/static/css/1866822702989bb3.css" as="style"/><link rel="stylesheet" href="/_next/static/css/1866822702989bb3.css" data-n-g=""/><noscript data-n-css=""></noscript><script defer="" nomodule="" src="/_next/static/chunks/polyfills-42372ed130431b0a.js"></script><script src="/_next/static/chunks/webpack-2766492c5dbceb0a.js" defer=""></script><script src="/_next/static/chunks/framework-c92fc3344e6fd165.js" defer=""></script><script src="/_next/static/chunks/main-090643377c8254e6.js" defer=""></script><script src="/_next/static/chunks/pages/_app-91cae6157e6f09b5.js" defer=""></script><script src="/_next/static/chunks/pages/404-2eb8aed4939f1142.js" defer=""></script><script src="/_next/static/6oPWh0EXUTEVS_OTLA_S1/_buildManifest.js" defer=""></script><script src="/_next/static/6oPWh0EXUTEVS_OTLA_S1/_ssgManifest.js" defer=""></script><style>.data-ant-cssinjs-cache-path{content:"";}</style></head><body><div id="__next"><div style="height:100%;display:flex"></div></div><script id="__NEXT_DATA__" type="application/json">{"props":{"pageProps":{}},"page":"/404","query":{},"buildId":"6oPWh0EXUTEVS_OTLA_S1","nextExport":true,"autoExport":true,"isFallback":false,"scriptLoader":[]}</script></body></html>
1
+ <!DOCTYPE html><html lang="en"><head><meta charSet="utf-8"/><meta name="viewport" content="width=device-width"/><meta name="next-head-count" content="2"/><link data-next-font="" rel="preconnect" href="/" crossorigin="anonymous"/><link rel="preload" href="/_next/static/css/018c12b58ee7f861.css" as="style"/><link rel="stylesheet" href="/_next/static/css/018c12b58ee7f861.css" data-n-g=""/><noscript data-n-css=""></noscript><script defer="" nomodule="" src="/_next/static/chunks/polyfills-42372ed130431b0a.js"></script><script src="/_next/static/chunks/webpack-2766492c5dbceb0a.js" defer=""></script><script src="/_next/static/chunks/framework-c92fc3344e6fd165.js" defer=""></script><script src="/_next/static/chunks/main-090643377c8254e6.js" defer=""></script><script src="/_next/static/chunks/pages/_app-302177edeb0dc4f5.js" defer=""></script><script src="/_next/static/chunks/pages/404-2eb8aed4939f1142.js" defer=""></script><script src="/_next/static/DjKAJy5iQVbNLYvoAn3Oe/_buildManifest.js" defer=""></script><script src="/_next/static/DjKAJy5iQVbNLYvoAn3Oe/_ssgManifest.js" defer=""></script><style>.data-ant-cssinjs-cache-path{content:"";}</style></head><body><div id="__next"><div style="height:100%;display:flex"></div></div><script id="__NEXT_DATA__" type="application/json">{"props":{"pageProps":{}},"page":"/404","query":{},"buildId":"DjKAJy5iQVbNLYvoAn3Oe","nextExport":true,"autoExport":true,"isFallback":false,"scriptLoader":[]}</script></body></html>
@@ -0,0 +1 @@
1
+ self.__BUILD_MANIFEST=function(s,e,t,a,c,n,i,d,o,r,p,f,g,u,m,b,j,k,h,y,l,v,I,F,x,_,U,w,q,N,A,S,B,C,z,D,E,L,M,T,P,G,H,J,K,O,Q,R,V,W,X,Y,Z,$,ss,se){return{__rewrites:{afterFiles:[],beforeFiles:[],fallback:[]},"/":[q,"static/chunks/pages/index-269b8f81546dad66.js"],"/404":["static/chunks/pages/404-2eb8aed4939f1142.js"],"/_error":["static/chunks/pages/_error-bede3a8288930dcf.js"],"/add-systems":[s,q,"static/chunks/pages/add-systems-f90aa48500c1cbde.js"],"/add-systems/manual":[s,e,t,a,n,g,c,i,r,u,m,l,N,A,"static/chunks/pages/add-systems/manual-939253f8daf349b2.js"],"/add-systems/multiple":[r,b,S,"static/chunks/pages/add-systems/multiple-83ed7da0bb90b0a5.js"],"/consent":["static/chunks/pages/consent-e5a33654a2dfaf35.js"],"/consent/configure":[r,b,"static/chunks/pages/consent/configure-c0db068d1863222f.js"],"/consent/configure/add-vendors":[r,b,S,"static/chunks/pages/consent/configure/add-vendors-46b88bda3d7b15c5.js"],"/consent/privacy-experience":[g,B,"static/chunks/pages/consent/privacy-experience-92a337ee96845af2.js"],"/consent/privacy-experience/new":[e,d,j,k,C,"static/chunks/pages/consent/privacy-experience/new-e74cb5ea87f15b40.js"],"/consent/privacy-experience/[id]":[e,d,j,k,C,"static/chunks/pages/consent/privacy-experience/[id]-fd41ffaff543e05a.js"],"/consent/privacy-notices":[B,"static/chunks/pages/consent/privacy-notices-59a8aff5935482ec.js"],"/consent/privacy-notices/new":[e,d,j,k,z,"static/chunks/pages/consent/privacy-notices/new-2987e397445713c5.js"],"/consent/privacy-notices/[id]":[e,d,j,k,z,"static/chunks/pages/consent/privacy-notices/[id]-1fd2cda8707314f6.js"],"/consent/properties":[h,D,"static/chunks/pages/consent/properties-069f4e3ee96ebf77.js"],"/consent/reporting":[s,"static/chunks/2150-930ffaf2c4718edc.js","static/chunks/pages/consent/reporting-09be5455ba85db39.js"],"/data-catalog":[e,t,a,c,"static/css/95ac327e5d70148d.css","static/chunks/pages/data-catalog-351caadeef03876a.js"],"/data-catalog/[systemId]/projects":[e,t,a,c,v,o,"static/chunks/pages/data-catalog/[systemId]/projects-be7b385073f22414.js"],"/data-catalog/[systemId]/projects/[projectUrn]":[E,"static/chunks/pages/data-catalog/[systemId]/projects/[projectUrn]-6a4b0d49dcbf17a8.js"],"/data-catalog/[systemId]/projects/[projectUrn]/[resourceUrn]":[s,e,t,a,c,v,L,o,"static/chunks/pages/data-catalog/[systemId]/projects/[projectUrn]/[resourceUrn]-293c1f2d9aefb447.js"],"/data-catalog/[systemId]/resources":[E,"static/chunks/pages/data-catalog/[systemId]/resources-af80fdca3bbdc82f.js"],"/data-catalog/[systemId]/resources/[resourceUrn]":[s,e,t,a,c,v,L,o,"static/chunks/pages/data-catalog/[systemId]/resources/[resourceUrn]-18501152fa1e4f40.js"],"/data-discovery/action-center":[I,"static/chunks/pages/data-discovery/action-center-1554afcb8b9da2ab.js"],"/data-discovery/action-center/[monitorId]":[s,e,t,a,i,I,M,F,"static/chunks/pages/data-discovery/action-center/[monitorId]-0e4d9ff89c63793c.js"],"/data-discovery/action-center/[monitorId]/[systemId]":[s,e,t,a,i,r,l,I,M,"static/css/23cf870196941c9a.css","static/chunks/pages/data-discovery/action-center/[monitorId]/[systemId]-758d51b4d37dbd09.js"],"/data-discovery/activity":[s,f,"static/chunks/pages/data-discovery/activity-2635ef588bf06145.js"],"/data-discovery/detection":[s,i,f,T,"static/chunks/pages/data-discovery/detection-a780390da99f3e43.js"],"/data-discovery/detection/[resourceUrn]":[s,i,f,T,"static/chunks/pages/data-discovery/detection/[resourceUrn]-0497f3ffdb632516.js"],"/data-discovery/discovery":[s,e,t,a,c,i,f,P,o,"static/chunks/pages/data-discovery/discovery-0cea22af5929c81f.js"],"/data-discovery/discovery/[resourceUrn]":[s,e,t,a,c,i,f,P,o,"static/chunks/pages/data-discovery/discovery/[resourceUrn]-1901c26cdde820da.js"],"/datamap":[s,a,"static/chunks/255-1bc0cbef7a59cdc6.js",u,G,"static/chunks/pages/datamap-619f27c745188adb.js"],"/dataset":[p,y,"static/chunks/pages/dataset-d6d7ee8bd8858a8a.js"],"/dataset/new":[s,p,y,"static/chunks/pages/dataset/new-78e052c8f95110c4.js"],"/dataset/[datasetId]":["static/chunks/9729-fcf6ff4e3534e4a8.js",x,"static/chunks/pages/dataset/[datasetId]-cb63db8594fe8dc1.js"],"/dataset/[datasetId]/[collectionName]":[e,t,a,n,c,x,o,"static/chunks/pages/dataset/[datasetId]/[collectionName]-d790553662caf5c3.js"],"/dataset/[datasetId]/[collectionName]/[...subfieldNames]":[e,t,a,n,c,x,o,"static/chunks/pages/dataset/[datasetId]/[collectionName]/[...subfieldNames]-ef71f387fbbab425.js"],"/datastore-connection":["static/css/5f393dea1c0d031c.css","static/chunks/pages/datastore-connection-a832084ce294f8af.js"],"/datastore-connection/new":[s,e,n,p,g,H,y,J,"static/chunks/pages/datastore-connection/new-4c9fb068a5561658.js"],"/datastore-connection/[id]":[s,e,n,p,H,y,J,"static/chunks/pages/datastore-connection/[id]-cc149157d290a94d.js"],"/fides-js-docs":["static/chunks/2fbcc6de-a6c61724c327e9fa.js","static/chunks/e3251fe7-5777b5d778e6fffa.js",e,t,a,n,p,"static/chunks/5619-9b50cec521203989.js",K,"static/css/0b4b1b65cc874774.css","static/chunks/5596-29a7c8322530b7cf.js","static/chunks/pages/fides-js-docs-1f4335dca5c09860.js"],"/integrations":[s,e,t,a,n,d,O,m,Q,o,"static/chunks/pages/integrations-6f109ef64304ef59.js"],"/integrations/[id]":[s,e,t,a,n,d,O,i,m,Q,o,"static/chunks/pages/integrations/[id]-8b13bb5f7bee61c6.js"],"/login":["static/chunks/pages/login-0cb0eb44bf2dd24c.js"],"/login/[provider]":["static/chunks/pages/login/[provider]-c58beef131c3a82d.js"],"/messaging":[e,t,"static/chunks/346-aa3b88efb85f2e28.js","static/chunks/pages/messaging-3f15804cf9625f01.js"],"/messaging/add-template":[R,"static/chunks/pages/messaging/add-template-0e0c06e3c8aabe02.js"],"/messaging/[id]":[R,"static/chunks/pages/messaging/[id]-d8c5c03fb2f31d65.js"],"/poc/ant-components":["static/chunks/pages/poc/ant-components-248ad9f65a872442.js"],"/poc/form-experiments/AntForm":["static/chunks/pages/poc/form-experiments/AntForm-aedb66a62042b10a.js"],"/poc/form-experiments/FormikAntFormItem":["static/chunks/pages/poc/form-experiments/FormikAntFormItem-018df38b7cd77fdb.js"],"/poc/form-experiments/FormikControlled":["static/chunks/pages/poc/form-experiments/FormikControlled-6ca9099d03aab817.js"],"/poc/form-experiments/FormikField":["static/chunks/pages/poc/form-experiments/FormikField-0f2c90786ea005a4.js"],"/poc/form-experiments/FormikSpreadField":[V,"static/chunks/pages/poc/form-experiments/FormikSpreadField-af097d661f6abcf4.js"],"/poc/forms":[V,"static/chunks/pages/poc/forms-200b51a725f8b2d1.js"],"/poc/table-migration":[r,b,"static/chunks/pages/poc/table-migration-e551fccfcaae76e7.js"],"/privacy-requests":[s,e,"static/chunks/3550-d04125c828d591a1.js",W,"static/chunks/pages/privacy-requests-2c82cf73d20416f2.js"],"/privacy-requests/configure":["static/chunks/pages/privacy-requests/configure-b00532a0ad4f6927.js"],"/privacy-requests/configure/storage":[s,"static/chunks/pages/privacy-requests/configure/storage-1b38b656807ed0cd.js"],"/privacy-requests/[id]":[s,W,"static/css/073713cd1eddda79.css","static/chunks/pages/privacy-requests/[id]-8566e3b7b2a632fa.js"],"/properties":[h,D,"static/chunks/pages/properties-08472b2a6bf1d392.js"],"/properties/add-property":[h,X,"static/chunks/pages/properties/add-property-777ed2d73812043d.js"],"/properties/[id]":[h,X,"static/chunks/pages/properties/[id]-322a01e2bceab3fb.js"],"/reporting/datamap":[s,e,t,a,K,u,_,G,"static/chunks/pages/reporting/datamap-5b423687e227ad4d.js"],"/settings/about":[Y,"static/chunks/pages/settings/about-6c4904c157477285.js"],"/settings/about/alpha":[Y,"static/chunks/pages/settings/about/alpha-68eaac2d79133679.js"],"/settings/consent":["static/chunks/pages/settings/consent-55e36839d219a503.js"],"/settings/consent/[configuration_id]/[purpose_id]":["static/chunks/pages/settings/consent/[configuration_id]/[purpose_id]-f3e6e74e0efb005c.js"],"/settings/custom-fields":[s,"static/chunks/pages/settings/custom-fields-26ce8fc493993765.js"],"/settings/domain-records":["static/chunks/pages/settings/domain-records-7ddf9d992fe714a6.js"],"/settings/domains":["static/chunks/pages/settings/domains-7c78ae51f0dd7102.js"],"/settings/email-templates":["static/chunks/pages/settings/email-templates-05ffbda19ab894b9.js"],"/settings/locations":[Z,F,"static/chunks/pages/settings/locations-77fb85bdd0be42b5.js"],"/settings/messaging-providers":[s,U,"static/chunks/pages/settings/messaging-providers-6c51ffd46bb598e7.js"],"/settings/messaging-providers/new":[s,e,t,d,$,U,ss,"static/chunks/pages/settings/messaging-providers/new-084f9756b9987285.js"],"/settings/messaging-providers/[key]":[s,e,t,d,$,U,ss,"static/chunks/pages/settings/messaging-providers/[key]-b0d93bf478bf63ee.js"],"/settings/organization":["static/chunks/pages/settings/organization-44456bfe54ac4ad5.js"],"/settings/privacy-requests":[s,"static/chunks/pages/settings/privacy-requests-fbe7e8030d837aed.js"],"/settings/regulations":[Z,F,"static/chunks/pages/settings/regulations-2866ac99faa5a542.js"],"/systems":[s,e,t,a,"static/chunks/1896-49010da5c2705fc5.js",_,"static/chunks/pages/systems-e99fbd1b2d1bfd12.js"],"/systems/configure/[id]":[s,e,t,a,n,g,c,i,r,u,m,l,N,A,"static/chunks/pages/systems/configure/[id]-1895c6a13b543436.js"],"/systems/configure/[id]/test-datasets":[p,"static/chunks/pages/systems/configure/[id]/test-datasets-a86bafe1b4e1205f.js"],"/taxonomy":["static/chunks/678d4732-50255cc09048e643.js",s,e,t,a,d,"static/chunks/6148-59a59d5c5925344f.js",_,"static/css/34a7eb08b86ddb57.css","static/chunks/pages/taxonomy-9ffcf98b8ad56bf7.js"],"/user-management":[w,"static/chunks/pages/user-management-82fcf1151e2fe2ba.js"],"/user-management/new":[w,se,"static/chunks/pages/user-management/new-6304dad2c5fab694.js"],"/user-management/profile/[id]":[w,se,"static/chunks/pages/user-management/profile/[id]-ff4711db191099cd.js"],sortedPages:["/","/404","/_app","/_error","/add-systems","/add-systems/manual","/add-systems/multiple","/consent","/consent/configure","/consent/configure/add-vendors","/consent/privacy-experience","/consent/privacy-experience/new","/consent/privacy-experience/[id]","/consent/privacy-notices","/consent/privacy-notices/new","/consent/privacy-notices/[id]","/consent/properties","/consent/reporting","/data-catalog","/data-catalog/[systemId]/projects","/data-catalog/[systemId]/projects/[projectUrn]","/data-catalog/[systemId]/projects/[projectUrn]/[resourceUrn]","/data-catalog/[systemId]/resources","/data-catalog/[systemId]/resources/[resourceUrn]","/data-discovery/action-center","/data-discovery/action-center/[monitorId]","/data-discovery/action-center/[monitorId]/[systemId]","/data-discovery/activity","/data-discovery/detection","/data-discovery/detection/[resourceUrn]","/data-discovery/discovery","/data-discovery/discovery/[resourceUrn]","/datamap","/dataset","/dataset/new","/dataset/[datasetId]","/dataset/[datasetId]/[collectionName]","/dataset/[datasetId]/[collectionName]/[...subfieldNames]","/datastore-connection","/datastore-connection/new","/datastore-connection/[id]","/fides-js-docs","/integrations","/integrations/[id]","/login","/login/[provider]","/messaging","/messaging/add-template","/messaging/[id]","/poc/ant-components","/poc/form-experiments/AntForm","/poc/form-experiments/FormikAntFormItem","/poc/form-experiments/FormikControlled","/poc/form-experiments/FormikField","/poc/form-experiments/FormikSpreadField","/poc/forms","/poc/table-migration","/privacy-requests","/privacy-requests/configure","/privacy-requests/configure/storage","/privacy-requests/[id]","/properties","/properties/add-property","/properties/[id]","/reporting/datamap","/settings/about","/settings/about/alpha","/settings/consent","/settings/consent/[configuration_id]/[purpose_id]","/settings/custom-fields","/settings/domain-records","/settings/domains","/settings/email-templates","/settings/locations","/settings/messaging-providers","/settings/messaging-providers/new","/settings/messaging-providers/[key]","/settings/organization","/settings/privacy-requests","/settings/regulations","/systems","/systems/configure/[id]","/systems/configure/[id]/test-datasets","/taxonomy","/user-management","/user-management/new","/user-management/profile/[id]"]}}("static/chunks/431-78bf05f35d7eec4f.js","static/chunks/8765-f622a35b40a7ec63.js","static/chunks/9278-08cc704317fe535e.js","static/chunks/5163-e682273cd76a7d07.js","static/chunks/409-c1256ecda1b15db6.js","static/chunks/699-8ca44b0de9fa20f0.js","static/chunks/7045-f15044a4d4525946.js","static/chunks/3662-f6a1ddca5ee42076.js","static/css/d2d4e9a6923e6730.css","static/chunks/401-ffe4e8436e1eceb9.js","static/chunks/6527-0eed08abe252a918.js","static/chunks/8002-25fd174aec9b077b.js","static/chunks/5277-e8a036319456127f.js","static/chunks/9951-651d521d9a02b6df.js","static/chunks/6416-18d438ff85d807f8.js","static/chunks/3923-a551756b413367ea.js","static/chunks/6419-d0c00d661b01f8fa.js","static/chunks/6084-2cd165179c428a6f.js","static/chunks/2040-ab6212a3074f34f9.js","static/chunks/5574-b8c4cba5a6938c00.js","static/chunks/3585-451504ea5ed7a1ea.js","static/chunks/6882-447f15e87b8c48a5.js","static/chunks/7725-dd6736855807936a.js","static/css/10994e916bc9a00a.css","static/chunks/9226-2f960b7ca530642a.js","static/chunks/4718-6585c97c26647e65.js","static/chunks/502-a40d39e615f7b664.js","static/chunks/7476-0b6e114658b15eaa.js","static/css/972dc7eef106ee7c.css","static/chunks/3700-de7c9f02ca184f7a.js","static/css/304c6f148886a8d4.css","static/chunks/796-e07ac2c543f569e3.js","static/chunks/6853-7004a8c420b1ca02.js","static/chunks/1817-ee9e29a6b8c4af50.js","static/chunks/6954-599f2de2c902e9b2.js","static/chunks/5783-8de76df87af55e98.js","static/chunks/3872-3514b712afd683c0.js","static/chunks/3855-12ee1dfbbe47fd28.js","static/chunks/7929-0fd0d4948bc8d70e.js","static/chunks/5309-3b6cf0cc9d0c6a83.js","static/chunks/9046-2a332fe338535c84.js","static/chunks/504-afd3588f1908ac33.js","static/chunks/1467-8808ec8836e033f9.js","static/chunks/4608-96f480766541124b.js","static/chunks/9187-7438242f0d380bb0.js","static/chunks/1316-2606e19807c08aa5.js","static/chunks/155-88303b05c6e115a5.js","static/chunks/7630-e7ea13be69c118a1.js","static/chunks/2921-66f65496c3a09316.js","static/chunks/4558-de5ced790b3380dc.js","static/chunks/5185-33f50cf9ae17b42e.js","static/chunks/1115-7888473b3dc28cda.js","static/chunks/9826-c02be5882205bbbc.js","static/chunks/9037-453224ba3ee65b13.js","static/chunks/7158-835ba42fd881d8dd.js","static/chunks/3696-c25dc8d1b0e1aee1.js"),self.__BUILD_MANIFEST_CB&&self.__BUILD_MANIFEST_CB();
@@ -0,0 +1 @@
1
+ (self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[155],{18225:function(e,t,s){"use strict";var a=s(24246),i=s(96306);t.Z=e=>{let{alignment:t="center",...s}=e;return(0,a.jsx)(i.kCb,{boxSize:"full",align:"center",justify:t,children:(0,a.jsx)(i.$jN,{color:"primary",...s})})}},58754:function(e,t,s){"use strict";var a=s(24246),i=s(96306),n=s(70788);t.Z=e=>{let{heading:t,breadcrumbItems:s,isSticky:r=!0,children:o,rightContent:c,style:d,...l}=e;return(0,a.jsxs)("div",{...l,style:r?{position:"sticky",top:"-24px",paddingTop:"24px",paddingBottom:"24px",paddingLeft:"40px",marginLeft:"-40px",paddingRight:"40px",marginRight:"-40px",marginTop:"-24px",left:0,zIndex:20,backgroundColor:"white",...d}:{paddingBottom:"24px",...d},children:[(0,a.jsxs)(i.jqI,{justify:"space-between",children:["string"==typeof t?(0,a.jsx)(i.lQT,{className:s||o?"pb-4":void 0,level:1,"data-testid":"page-heading",children:t}):t,c&&(0,a.jsx)("div",{"data-testid":"page-header-right-content",children:c})]}),!!s&&(0,a.jsx)(n.m,{className:o?"pb-4":void 0,items:s,"data-testid":"page-breadcrumb"}),o]})}},79789:function(e,t,s){"use strict";s.d(t,{Hn:function(){return o},XU:function(){return r},Z5:function(){return c},aG:function(){return h},cB:function(){return n},hX:function(){return l},vQ:function(){return d}});var a=s(24246),i=s(96306);let n=e=>{let{text:t,...s}=e;return(0,a.jsx)(i.X6q,{fontSize:"sm",mt:4,mb:1,...s,children:t})},r=e=>{let{children:t}=e;return(0,a.jsx)(i.xvT,{fontSize:"14px",mb:4,children:t})},o=e=>{let{children:t,href:s}=e;return(0,a.jsx)(i.rUS,{href:s,textDecoration:"underline",isExternal:!0,children:t})},c=e=>{let{children:t}=e;return(0,a.jsx)(i.QI$,{fontSize:"14px",mb:4,children:t})},d=e=>{let{children:t}=e;return(0,a.jsx)(i.GSI,{fontSize:"14px",mb:4,ml:6,children:t})},l=e=>{let{children:t}=e;return(0,a.jsx)(i.EKh,{display:"block",whiteSpace:"pre",p:4,mb:4,overflowX:"scroll",children:t})},h=e=>{let{data:t}=e;return(0,a.jsxs)(i.iA_,{fontSize:"14px",children:[(0,a.jsx)(i.hrZ,{children:(0,a.jsxs)(i.Tr,{children:[(0,a.jsx)(i.Th,{children:"Permission"}),(0,a.jsx)(i.Th,{children:"Description"})]})}),(0,a.jsx)(i.p3B,{children:t.map(e=>(0,a.jsxs)(i.Tr,{children:[(0,a.jsx)(i.Td,{children:(0,a.jsx)(i.Vp9,{children:e.permission})}),(0,a.jsx)(i.Td,{children:e.description})]},e.permission))})]})}},12627:function(e,t,s){"use strict";var a=s(24246),i=s(79283),n=s(34929);t.Z=e=>{let{selectedTaxonomies:t,showDisabled:s=!1,...r}=e,{getDataCategoryDisplayNameProps:o,getDataCategories:c}=(0,n.Z)(),d=(s?c():c().filter(e=>e.active)).filter(e=>!(null==t?void 0:t.includes(e.fides_key))).map(e=>{let{name:t,primaryName:s}=o(e.fides_key);return{value:e.fides_key,name:t,primaryName:s,description:e.description||""}});return(0,a.jsx)(i.l,{options:d,...r})}},79283:function(e,t,s){"use strict";s.d(t,{l:function(){return c}});var a=s(24246),i=s(96306),n=s(72707),r=s.n(n);let o=e=>{let{data:{formattedTitle:t,description:s,name:n,primaryName:r}}=e;return(0,a.jsxs)(i.jqI,{gap:12,title:"".concat(t," - ").concat(s),children:[(0,a.jsxs)("div",{children:[(0,a.jsx)("strong",{children:r||n}),r&&": ".concat(n)]}),(0,a.jsx)("em",{children:s})]})},c=e=>{let{options:t,...s}=e,n=null==t?void 0:t.map(e=>({...e,className:r().option,formattedTitle:[e.primaryName,e.name].filter(e=>e).join(": ")}));return(0,a.jsx)(i.WPr,{options:n,filterOption:(e,t)=>(null==t?void 0:t.formattedTitle.toLowerCase().includes(e.toLowerCase()))||(null==t?void 0:t.value.toLowerCase().includes(e.toLowerCase()))||!1,optionFilterProp:"label",autoFocus:!0,variant:"borderless",optionRender:o,styles:{popup:{root:{minWidth:"500px"}}},className:"w-full p-0","data-testid":"taxonomy-select",...s})}},97181:function(e,t,s){"use strict";s.d(t,{d:function(){return d}});var a=s(24246),i=s(96306),n=s(34090),r=s(27378),o=s(46238),c=s(40324);let d=e=>{let{name:t,label:s,labelProps:d,tooltip:l,isRequired:h,layout:u="inline",helperText:m,...x}=e,[p,g,{setValue:j}]=(0,n.U$)(t),y=!!(g.touched&&g.error),[v,f]=(0,r.useState)("");p.value||"tags"!==x.mode&&"multiple"!==x.mode||(p.value=[]),"tags"===x.mode&&"string"==typeof p.value&&(p.value=[p.value]);let C="tags"===x.mode?(e,t)=>e?e.value!==v||p.value.includes(v)?x.optionRender?x.optionRender(e,t):e.label:'Create "'.concat(v,'"'):void 0:x.optionRender||void 0,S=e=>{f(e),x.onSearch&&x.onSearch(e)},A=(e,t)=>{j(e),x.onChange&&x.onChange(e,t)};return"inline"===u?(0,a.jsx)(i.NIc,{isInvalid:y,isRequired:h,children:(0,a.jsxs)(i.rjZ,{templateColumns:s?"1fr 3fr":"1fr",children:[s?(0,a.jsx)(c.__,{htmlFor:x.id||t,...d,children:s}):null,(0,a.jsxs)(i.jqI,{align:"center",children:[(0,a.jsxs)(i.jqI,{vertical:!0,flex:1,className:"mr-2",children:[(0,a.jsx)(i.WPr,{...p,id:x.id||t,"data-testid":"controlled-select-".concat(p.name),...x,optionRender:C,onSearch:"tags"===x.mode?S:void 0,onChange:A,value:p.value||void 0,status:y?"error":void 0}),m&&(0,a.jsx)(i.Q6r,{children:m}),(0,a.jsx)(c.Bc,{isInvalid:y,message:g.error,fieldName:p.name})]}),(0,a.jsx)(o.b,{label:l,className:y?"mt-2 self-start":void 0})]})]})}):(0,a.jsx)(i.NIc,{isInvalid:y,isRequired:h,children:(0,a.jsxs)(i.gCW,{alignItems:"start",children:[(0,a.jsxs)(i.jqI,{align:"center",children:[s?(0,a.jsx)(c.__,{htmlFor:x.id||t,fontSize:"xs",my:0,mr:1,...d,children:s}):null,(0,a.jsx)(o.b,{label:l})]}),(0,a.jsx)(i.WPr,{...p,id:x.id||t,"data-testid":"controlled-select-".concat(p.name),...x,optionRender:C,onSearch:"tags"===x.mode?S:void 0,onChange:A,value:p.value||void 0,status:y?"error":void 0}),m&&(0,a.jsx)(i.Q6r,{style:{marginTop:0},children:m}),(0,a.jsx)(c.Bc,{isInvalid:y,message:g.error,fieldName:p.name})]})})}},34929:function(e,t,s){"use strict";var a=s(24246),i=s(64925),n=s.n(i),r=s(27378),o=s(16134),c=s(30002),d=s(28079),l=s(57072);let h=()=>{let{isLoading:e}=(0,d.fd)(),t=(0,o.C)(d.U3),{isLoading:s}=(0,l.MO)(),a=(0,o.C)(l.qb),{isLoading:i}=(0,c.te)();return{dataUses:t,dataSubjects:(0,o.C)(c.ZL),dataCategories:a,isLoading:e||s||i}};t.Z=()=>{let{dataUses:e,dataCategories:t,dataSubjects:s,isLoading:i}=h(),o=function(e){let t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:1;return e.split(".").slice(0,t).join(".")},c=function(e,t){let s=arguments.length>2&&void 0!==arguments[2]?arguments[2]:1,a=t(e);if(!a)return{};let i=t(o(e,s)),n=!!a.parent_key;return{name:a.name||void 0,primaryName:n&&(null==i?void 0:i.name)!==a.name&&(null==i?void 0:i.name)||void 0}},d=function(e,t){let s=arguments.length>2&&void 0!==arguments[2]?arguments[2]:1,{name:i,primaryName:n}=c(e,t,s);return i?n?(0,a.jsxs)(r.Fragment,{children:[(0,a.jsxs)("strong",{children:[n,":"]})," ",i]},e):(0,a.jsx)("strong",{children:i},e):e},l=t=>n()(e,{fides_key:t}),u=e=>n()(t,{fides_key:e}),m=e=>n()(s,{fides_key:e});return{getDataUses:()=>e,getDataUseByKey:l,getDataUseDisplayName:e=>d(e,l,1),getDataUseDisplayNameProps:e=>c(e,l,1),getDataCategories:()=>t,getDataCategoryByKey:u,getDataCategoryDisplayName:e=>d(e,u,2),getDataCategoryDisplayNameProps:e=>c(e,u,2),getDataSubjects:()=>s,getDataSubjectByKey:m,getDataSubjectDisplayName:e=>{let t=m(e);return t?t.name:e},getPrimaryKey:o,isLoading:i}}},8133:function(e,t,s){"use strict";var a=s(24246),i=s(96306);t.Z=e=>{let{title:t,children:s,isOpen:n,onClose:r,modalContentProps:o,showCloseButton:c=!1,footer:d,...l}=e;return(0,a.jsxs)(i.u_l,{isOpen:n,onClose:r,isCentered:!0,scrollBehavior:"inside",size:"xl",id:"add-modal",...l,children:[(0,a.jsx)(i.ZAr,{}),(0,a.jsxs)(i.hzk,{textAlign:"left",p:0,"data-testid":"add-modal-content",...o,children:[c&&(0,a.jsx)(i.olH,{}),(0,a.jsx)(i.xBx,{p:0,children:(0,a.jsx)(i.xuv,{backgroundColor:"gray.50",px:6,py:4,border:"1px",borderColor:"gray.200",borderTopRadius:6,display:"flex",justifyContent:"space-between",alignItems:"center",children:(0,a.jsx)(i.X6q,{as:"h3",size:"sm",children:t})})}),(0,a.jsx)(i.fef,{pb:4,overflow:"auto",children:s}),d&&(0,a.jsx)(i.mzw,{children:d})]})]})}},90980:function(e,t,s){"use strict";s.d(t,{R:function(){return c}});var a=s(24246),i=s(96306),n=s(79894),r=s.n(n),o=s(63662);let c=e=>{let{onClick:t,...s}=e;return(0,a.jsxs)(i.kCb,{alignItems:"center",mt:-4,mb:3,onClick:t,cursor:"pointer",...s,children:[(0,a.jsx)(i.wpx,{"aria-label":"Back",icon:(0,a.jsx)(i.Rpv,{}),className:"mr-2",size:"small"}),(0,a.jsx)(i.xvT,{as:"a",fontSize:"sm",fontWeight:"500",children:"Back"})]})};t.Z=e=>{let{backPath:t,...s}=e,n=(0,o.useRouter)();return(0,a.jsxs)(i.kCb,{alignItems:"center",mb:6,...s,children:[(0,a.jsx)(i.wpx,{onClick:()=>n.push(t),"aria-label":"Back",icon:(0,a.jsx)(i.Rpv,{}),className:"mr-2",size:"small"}),(0,a.jsx)(i.xvT,{as:r(),href:t,fontSize:"sm",fontWeight:"500",children:"Back"})]})}},70788:function(e,t,s){"use strict";s.d(t,{m:function(){return d}});var a=s(24246),i=s(96306),n=s(79894),r=s.n(n),o=s(27378);let{Text:c}=i.AntTypography,d=e=>{let{items:t,...s}=e,n=(0,o.useMemo)(()=>null==t?void 0:t.map((e,s)=>{let n=s===t.length-1,o={...e},d=o.onClick&&!o.href;return("string"==typeof o.title&&(o.title=(0,a.jsx)(c,{style:{color:"inherit",maxWidth:n?void 0:400},ellipsis:!n,id:n?"breadcrumb-current-page":void 0,children:o.title})),d)?o.title=(0,a.jsx)(i.wpx,{type:"text",size:"small",icon:o.icon,onClick:o.onClick,className:"ant-breadcrumb-link -mt-px px-1 text-inherit",children:o.title}):(o.icon&&(o.title=(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)("span",{className:"anticon align-text-bottom",children:o.icon}),o.title]})),o.href&&o.title&&(o.title=(0,a.jsx)(r(),{href:o.href,className:"ant-breadcrumb-link",children:o.title}),delete o.href)),o}),[t]);return(0,a.jsx)(i.zrq,{items:n,...s})}},15872:function(e,t,s){"use strict";var a=s(24246),i=s(96306),n=s(86677);s(27378);var r=s(77830),o=s(14207);t.Z=e=>{let{connection_key:t,showMenu:s}=e,{isOpen:c,onOpen:d,onClose:l}=(0,i.qY0)(),[h,u]=(0,o.R5)(),m=(0,n.useRouter)(),x=()=>{u.isLoading||l()};return(0,a.jsxs)(a.Fragment,{children:[s&&(0,a.jsx)(i.sNh,{_focus:{color:"complimentary.500",bg:"gray.100"},onClick:d,children:(0,a.jsx)(i.xvT,{fontSize:"sm",children:"Delete"})}),!s&&(0,a.jsx)(i.wpx,{onClick:d,children:"Delete integration"}),(0,a.jsxs)(i.u_l,{isCentered:!0,isOpen:c,onClose:x,children:[(0,a.jsx)(i.ZAr,{}),(0,a.jsxs)(i.hzk,{children:[(0,a.jsx)(i.xBx,{children:"Delete integration"}),(0,a.jsx)(i.olH,{}),(0,a.jsx)(i.fef,{pb:6,children:(0,a.jsx)(i.Kqy,{direction:"column",spacing:"15px",children:(0,a.jsx)(i.xvT,{color:"gray.600",fontSize:"sm",fontWeight:"sm",lineHeight:"20px",children:"Deleting an integration may impact any privacy request that is currently in progress. Do you wish to proceed?"})})}),(0,a.jsxs)(i.mzw,{className:"flex gap-4",children:[(0,a.jsx)(i.wpx,{onClick:x,className:"w-1/2",children:"Cancel"}),(0,a.jsx)(i.wpx,{onClick:()=>{t&&(h(t),s||m.push(r.KH))},loading:u.isLoading,type:"primary",className:"w-1/2",children:"Delete integration"})]})]})]})]})}},33335:function(e,t,s){"use strict";s.d(t,{E:function(){return a}});let a=e=>e.toLowerCase().replace(/[ .]/g,"_").replace(/[^a-zA-Z0-9_<>-]/g,"")},45216:function(e,t,s){"use strict";var a=s(96306),i=s(812),n=s(16394),r=s(14207);t.Z=e=>{let[t,{data:s,fulfilledTimeStamp:o,isLoading:c,isFetching:d}]=(0,r.h2)(),l=(0,a.pmc)();return{testConnection:async()=>{var s,a,n,r;if(!e)return;let o=await t(e.key);if(o.isError)l({status:"error",description:(0,i.e$)(o.error,"Unable to test connection. Please try again.")});else if((null===(s=o.data)||void 0===s?void 0:s.test_status)==="succeeded")l({status:"success",description:"Connected successfully"});else if((null===(a=o.data)||void 0===a?void 0:a.test_status)==="failed"){let e="Connection test failed.";(null===(n=o.data)||void 0===n?void 0:n.failure_reason)&&(e+=" ".concat(null===(r=o.data)||void 0===r?void 0:r.failure_reason)),l({status:"warning",description:e})}},isLoading:c||d,testData:{timestamp:o?(0,n.p6)(o):null==e?void 0:e.last_test_timestamp,succeeded:s?"succeeded"===s.test_status:!!(null==e?void 0:e.last_test_succeeded),authorized:!!(null==e?void 0:e.authorized),connectionKey:null==e?void 0:e.key}}}},41553:function(e,t,s){"use strict";var a=s(24246),i=s(96306),n=s(16394);t.Z=e=>{let{testData:t,connectionOption:s}=e;if((null==s?void 0:s.authorization_required)&&!t.authorized)return(0,a.jsx)(i.kCb,{align:"center","data-testid":"connection-status",children:(0,a.jsx)(i.xvT,{color:"error-text.900",children:"Authorization required"})});if(!t.timestamp)return(0,a.jsx)(i.xvT,{"data-testid":"connection-status",children:"Connection not tested"});let r=(0,n.p6)(t.timestamp);return t.succeeded?(0,a.jsxs)(i.kCb,{color:"success-text.900",align:"center","data-testid":"connection-status",children:[(0,a.jsx)(i.rE2,{mr:2,boxSize:4}),(0,a.jsxs)(i.xvT,{children:["Last connected ",r]})]}):(0,a.jsxs)(i.kCb,{color:"error-text.900",align:"center","data-testid":"connection-status",children:[(0,a.jsx)(i.iid,{mr:2,boxSize:4}),(0,a.jsxs)(i.xvT,{children:["Last connection failed ",r]})]})}},75595:function(e,t,s){"use strict";var a=s(24246),i=s(96306),n=s(17245),r=s(20682),o=s(41337),c=s(15872),d=s(45216),l=s(38187),h=s(41553),u=s(93633),m=s(80388),x=s(64176),p=s(35030);t.Z=e=>{var t,s;let{integration:g,integrationTypeInfo:j,showTestNotice:y,otherButtons:v,showDeleteButton:f,configureButtonLabel:C="Configure",onConfigureClick:S}=e,{testConnection:A,isLoading:b,testData:D}=(0,d.Z)(g),R=(0,n.pI)(g),{data:w}=(0,r.$I)({}),T=(null==w?void 0:w.items)||[],E=j||(0,l.ZP)(null==g?void 0:g.connection_type,null==g?void 0:null===(t=g.saas_config)||void 0===t?void 0:t.type,T),_=null==g?void 0:null===(s=g.saas_config)||void 0===s?void 0:s.type,k=(0,x.Z)(null==g?void 0:g.connection_type,_&&Object.values(m.m).includes(_)?_:void 0),{handleAuthorize:H,needsAuthorization:F}=(0,u.z)({connection:g,connectionOption:k,testData:D});return(0,a.jsxs)(i.xuv,{borderWidth:1,borderColor:"gray.200",borderRadius:"lg",overflow:"hidden",padding:"12px",marginBottom:"24px","data-testid":"integration-info-".concat(null==g?void 0:g.key),children:[(0,a.jsxs)(i.kCb,{children:[(0,a.jsx)(o.Z,{data:null!=R?R:"",boxSize:"50px"}),(0,a.jsxs)(i.kCb,{direction:"column",flexGrow:1,marginLeft:"16px",children:[(0,a.jsx)(i.xvT,{color:"gray.700",fontWeight:"semibold",children:(null==g?void 0:g.name)||"(No name)"}),y?(0,a.jsx)(h.Z,{testData:D,connectionOption:k}):(0,a.jsx)(i.xvT,{color:"gray.700",fontSize:"sm",fontWeight:"semibold",mt:1,children:(0,p.qS)(E.category)})]}),(0,a.jsxs)("div",{className:"flex gap-4",children:[f&&g&&(0,a.jsx)(c.Z,{showMenu:!1,connection_key:g.key}),y&&F&&(0,a.jsx)(i.wpx,{onClick:H,"data-testid":"authorize-integration-btn",children:"Authorize integration"}),y&&!F&&(0,a.jsx)(i.wpx,{onClick:A,loading:b,"data-testid":"test-connection-btn",children:"Test connection"}),v,S&&(0,a.jsx)(i.wpx,{onClick:S,"data-testid":"configure-btn",children:C})]})]}),(0,a.jsx)(i.Eq9,{marginTop:"16px",children:E.tags.map(e=>(0,a.jsx)(i.j8w,{children:e},e))})]})}},40774:function(e,t,s){"use strict";s.d(t,{Z:function(){return S}});var a,i,n=s(24246),r=s(96306),o=s(27378),c=s(87145),d=s(46381),l=s(12627),h=s(812),u=s(46238),m=s(90980),x=s(46628),p=s(11013),g=s(31883);let j={rules:[{regex:void 0,dataCategory:void 0}]};var y=e=>{var t,s,a;let{config:i,onBackClick:o}=e,[y]=r.PPS.useForm(),v=(0,r.pmc)(),[f,{isLoading:C}]=(0,p.$y)(),[S,{isLoading:A}]=(0,p.ww)(),b=e=>({name:e.name,description:e.description,classify_params:{context_regex_pattern_mapping:e.rules.map(e=>{let{regex:t,dataCategory:s}=e;return[t,s]})}}),D=(e,t)=>{(0,g.D4)(e)?v((0,x.Vo)((0,h.e$)(e.error,"A problem occurred"))):(v((0,x.t5)(t?"Monitor config created successfully":"Monitor config updated successfully")),o())},R=async e=>{let t=b(e);D(i?await S({...t,id:i.id}):await f(t),!i)},w=e=>{let{file:t}=e;if(!t)return;let s=new FileReader;s.onload=e=>{try{var t;let s=null===(t=e.target)||void 0===t?void 0:t.result,{data:a}=(0,d.parse)(s,{skipEmptyLines:!0,header:!1}),i=a.map(e=>{let[t,s]=e;return{regex:t,dataCategory:s}});y.setFieldValue("rules",i),v((0,x.t5)("CSV patterns imported successfully"))}catch(e){v((0,x.Vo)("Failed to parse CSV file"))}},s.readAsText(t)};return(0,n.jsxs)(n.Fragment,{children:[(0,n.jsx)(m.R,{onClick:o,className:"pt-3"}),(0,n.jsx)(c.ZT.Title,{level:2,children:i?"Edit ".concat(i.name):"Create new configuration"}),(0,n.jsx)(c.ZT.Paragraph,{className:"mt-2",children:'Match regular expressions to data categories to customize classification. Use the "shared monitor configuration" field when editing monitors to apply this configuration.'}),(0,n.jsxs)(r.PPS,{name:"monitor-template",layout:"vertical",form:y,onFinish:R,className:"mt-4",initialValues:i?{...i,rules:null!==(a=null==i?void 0:null===(s=i.classify_params)||void 0===s?void 0:null===(t=s.context_regex_pattern_mapping)||void 0===t?void 0:t.map(e=>{let[t,s]=e;return{regex:t,dataCategory:s}}))&&void 0!==a?a:[]}:j,validateTrigger:["onBlur","onChange"],children:[(0,n.jsx)(r.bue,{children:(0,n.jsxs)(r.JGx,{span:24,children:[(0,n.jsx)(r.PPS.Item,{label:"Configuration name",name:"name",rules:[{required:!0,message:"Config name is required"}],"data-testid":"form-item-name",children:(0,n.jsx)(r.uFc,{autoFocus:!0,"data-testid":"input-name"})}),(0,n.jsx)(r.PPS.Item,{label:"Description",name:"description","data-testid":"form-item-description",children:(0,n.jsx)(r.uFc.TextArea,{"data-testid":"input-description"})})]})}),(0,n.jsx)(r.PPS.List,{name:"rules",rules:[{validator:(e,t)=>0===t.length?Promise.reject(Error("Please input at least one pattern")):Promise.resolve()}],children:(e,t,s)=>{let{add:a,remove:d}=t,{errors:h}=s;return(0,n.jsxs)(n.Fragment,{children:[(0,n.jsxs)(r.jqI,{justify:"space-between",children:[(0,n.jsx)(c.ZT.Title,{level:3,className:"pb-5",children:"Regex patterns"}),!i&&(0,n.jsxs)(r.jqI,{gap:8,align:"center",children:[(0,n.jsx)(u.b,{label:"Upload a CSV to map regex patterns to data categories. Format: regex,data_category",placement:"left"}),(0,n.jsx)(r.pMK,{accept:".csv",showUploadList:!1,beforeUpload:()=>!1,onChange:w,children:(0,n.jsx)(r.wpx,{icon:(0,n.jsx)(r.PJP.gqx,{}),iconPosition:"end",size:"small","data-testid":"upload-csv-btn",children:"Upload CSV"})})]})]}),e.map((t,s)=>{let{key:i,name:o,...c}=t;return(0,n.jsxs)(r.bue,{align:"middle",children:[(0,n.jsx)(r.JGx,{span:11,children:(0,n.jsx)(r.PPS.Item,{label:"On match",...c,name:[o,"regex"],rules:[{required:!0,message:"Regex is required"}],"data-testid":"form-item-rules.".concat(o,".regex"),children:(0,n.jsx)(r.uFc,{placeholder:"Enter a regular expression","data-testid":"input-rules.".concat(o,".regex")})})}),(0,n.jsx)(r.JGx,{span:1,className:"flex justify-center pt-[5px]",children:"->"}),(0,n.jsx)(r.JGx,{span:11,className:"pr-2",children:(0,n.jsx)(r.PPS.Item,{label:"Assign",...c,name:[o,"dataCategory"],rules:[{required:!0,message:"Data category is required"}],"data-testid":"form-item-rules.".concat(o,".dataCategory"),children:(0,n.jsx)(l.Z,{selectedTaxonomies:[],variant:"outlined",placeholder:"Select a data category",autoFocus:!1,allowClear:!0,"data-testid":"input-rules.".concat(o,".dataCategory")})})}),(0,n.jsx)(r.JGx,{span:1,className:"mt-[7.25px]",children:s===e.length-1?(0,n.jsx)(r.wpx,{onClick:()=>a(),icon:(0,n.jsx)(r.PJP.mm_,{}),"aria-label":"Add new rule","data-testid":"add-rule-btn"}):(0,n.jsx)(r.wpx,{onClick:()=>d(o),icon:(0,n.jsx)(r.PJP.ZNm,{}),"aria-label":"Remove rule","data-testid":"remove-rule-".concat(o)})})]},i)}),(0,n.jsx)(r.PPS.ErrorList,{errors:h}),(0,n.jsx)(r.PPS.Item,{label:null,className:"mb-0",children:(0,n.jsxs)(r.jqI,{justify:"end",gap:8,children:[(0,n.jsx)(r.wpx,{onClick:o,children:"Cancel"}),(0,n.jsx)(r.wpx,{type:"primary",htmlType:"submit",loading:C||A,"data-testid":"save-btn",children:"Save"})]})})]})}})]})]})},v=s(47935),f=e=>{let{onEditClick:t}=e,[s]=(0,p.m5)(),a=(0,r.pmc)(),i=async e=>{let t=await s({id:e});(0,g.D4)(t)?a((0,x.Vo)((0,h.e$)(t.error,"A problem occurred deleting this config"))):a((0,x.t5)("Monitor config deleted successfully"))};return[{title:"Name",dataIndex:"name",key:"name"},{title:"Description",dataIndex:"description",key:"description"},{title:"Actions",key:"actions",render:(e,s)=>(0,n.jsxs)(r.jqI,{className:"gap-2",children:[(0,n.jsx)(r.wpx,{size:"small",onClick:()=>t(s),icon:(0,n.jsx)(r.PJP.I8b,{}),"data-testid":"edit-btn"}),(0,n.jsx)(r.wpx,{size:"small",onClick:()=>i(s.id),icon:(0,n.jsx)(r.PJP.ZNm,{})})]})}]},C=e=>{let{onNewClick:t,onRowClick:s}=e,{onPreviousPageClick:a,isPreviousPageDisabled:i,onNextPageClick:o,isNextPageDisabled:d,pageSize:l,setPageSize:h,PAGE_SIZES:u,startRange:m,endRange:x,pageIndex:g}=(0,v.oi)(),{data:j,isLoading:y,isFetching:C}=(0,p.eV)({page:g,size:l}),S=f({onEditClick:s});return y||C?(0,n.jsx)(r.ZJQ,{size:"large",className:"flex h-full items-center justify-center"}):(0,n.jsxs)(n.Fragment,{children:[(0,n.jsx)(c.ZT.Title,{level:2,children:"Shared monitor configurations"}),(0,n.jsx)(c.ZT.Paragraph,{className:"mb-2 mt-4",children:"Shared monitor configurations can be applied to monitors to customize classification."}),(0,n.jsx)(r.wpx,{type:"primary",onClick:t,"data-testid":"create-new-btn",className:"mb-3",children:"Create new"}),(0,n.jsx)(r.V5H,{columns:S,dataSource:null==j?void 0:j.items,pagination:!1,onRow:e=>({"data-testid":"config-".concat(e.id)}),locale:{emptyText:(0,n.jsx)(c.ZT.Paragraph,{className:"py-8",children:"No shared monitor configs found"})}}),(0,n.jsx)(r.jqI,{justify:"space-between",className:"mt-4",children:(0,n.jsx)(v.s8,{totalRows:(null==j?void 0:j.total)||0,pageSizes:u,setPageSize:h,onPreviousPageClick:a,isPreviousPageDisabled:i,onNextPageClick:o,isNextPageDisabled:d,startRange:m,endRange:x})})]})};(a=i||(i={})).MAIN_VIEW="main",a.FORM_VIEW="form";var S=()=>{let[e,t]=(0,o.useState)(!1),[s,a]=(0,o.useState)(void 0),[i,c]=(0,o.useState)("main"),d=()=>{c("main"),a(void 0)};return(0,n.jsxs)(n.Fragment,{children:[(0,n.jsx)(r.wpx,{icon:(0,n.jsx)(r.PJP.Zrf,{}),iconPosition:"end",onClick:()=>t(!0),"data-testid":"configurations-btn",children:"Shared configs"}),(0,n.jsxs)(r.$zI,{open:e,onCancel:()=>{d(),t(!1)},destroyOnHidden:!0,centered:!0,width:768,footer:null,children:["form"===i&&(0,n.jsx)(y,{config:s,onBackClick:d}),"main"===i&&(0,n.jsx)(C,{onNewClick:()=>c("form"),onRowClick:e=>{a(e),c("form"),t(!0)}})]})]})}},21365:function(e,t,s){"use strict";var a=s(24246),i=s(96306),n=s(34090),r=s(90104),o=s.n(r),c=s(92465),d=s.n(c),l=s(25389),h=s.n(l),u=s(15539),m=s.n(u),x=s(27378),p=s(18225),g=s(97181),j=s(71248),y=s(40324),v=s(46782),f=s(812),C=s(20682),S=s(41966),A=s(94725),b=s(19812),D=s(33335),R=s(1315),w=s(21910),T=s(31883);let E=e=>{let{dirty:t,isValid:s,submitForm:a,loading:i,onFormStateChange:n}=e;return(0,x.useEffect)(()=>{n&&n({dirty:t,isValid:s,submitForm:a,loading:i})},[t,s,a,i,n]),null};t.Z=e=>{var t,s;let{connection:r,connectionOption:c,onCancel:l,description:u,onFormStateChange:x}=e,[_,{isLoading:k}]=(0,A.Pp)(),[H,{isLoading:F}]=(0,A.pH)(),[I,{isLoading:B}]=(0,R.qd)(),[L]=(0,A.pL)(),O=c.identifier!==w.Rj.MANUAL_TASK,{data:P,isLoading:q}=(0,C.n3)(c.identifier,{skip:!O}),{data:M}=(0,R.K3)(),N=null==M?void 0:M.map(e=>{var t;return{label:null!==(t=e.name)&&void 0!==t?t:e.fides_key,value:e.fides_key}}),{data:U}=(0,S.LH)({minimal:!0,connection_type:w.Rj.BIGQUERY}),z=null==U?void 0:U.map(e=>{var t;return{label:null!==(t=e.name)&&void 0!==t?t:e.fides_key,value:e.fides_key}}),{patchConnectionDatasetConfig:Z,initialDatasets:G}=(0,b.t)({connectionConfig:r}),{getFieldValidation:Q,preprocessValues:W}=(0,v.l)(P),X={name:null!==(t=null==r?void 0:r.name)&&void 0!==t?t:"",description:null!==(s=null==r?void 0:r.description)&&void 0!==s?s:"",...O&&{secrets:h()(null==P?void 0:P.properties,(e,t)=>{var s,a,i;return null!==(i=null!==(a=null==r?void 0:null===(s=r.secrets)||void 0===s?void 0:s[t])&&void 0!==a?a:e.default)&&void 0!==i?i:""})},dataset:G},Y=(0,i.pmc)(),V=!!r,K=c.type===w.Zi.SAAS,J=c.identifier===w.Rj.WEBSITE,$=e=>m()(h()(e,(e,t)=>{var s,a;return(null!==(a=null==r?void 0:null===(s=r.secrets)||void 0===s?void 0:s[t])&&void 0!==a?a:"")===e?void 0:e}),d()),ee=async e=>{var t;let s;let a=W(e),i=O?$(a.secrets):{},n=V?{...r,disabled:null!==(t=r.disabled)&&void 0!==t&&t,name:e.name,description:e.description,secrets:void 0}:{name:e.name,key:(0,D.E)(e.name),connection_type:c.identifier,access:w.uv.READ,disabled:!1,description:e.description,secrets:a.secrets,dataset:e.dataset};if(s=e.system_fides_key?await I({systemFidesKey:e.system_fides_key,connectionConfigs:[n]}):K&&!V?await L({...n,instance_key:(0,D.E)(e.name),saas_connector_type:c.identifier,secrets:e.secrets||{}}):await H(n),(0,T.D4)(s)){Y({status:"error",description:(0,f.e$)(s.error,"A problem occurred while ".concat(V?"updating":"creating"," this integration. Please try again."))});return}if(!O||!e.secrets){Y({status:"success",description:"Integration ".concat(V?"updated":"created"," successfully")}),l();return}if(!o()(i)){let e=await _({connection_key:n.key,secrets:i});if((0,T.D4)(e)){Y({status:"error",description:(0,f.e$)(e.error,"An error occurred while ".concat(V?"updating":"creating"," this integration's secret. Please try again."))});return}}Y({status:"success",description:"Integration secret ".concat(V?"updated":"created"," successfully")}),l(),n&&e.dataset&&c.identifier===w.Rj.DATAHUB&&await Z(e,n.key,{showSuccessAlert:!1})},et=k||F||B;if(q)return(0,a.jsx)(p.Z,{});let es=e=>Object.entries(e.properties).map(t=>{let[s,i]=t,n="secrets.".concat(s);return(0,a.jsx)(j.A,{name:n,fieldSchema:i,isRequired:e.required.includes(s),secretsSchema:e,validate:Q(s,i)},n)});return(0,a.jsxs)(a.Fragment,{children:[u&&(0,a.jsx)(i.xuv,{padding:"20px 24px",backgroundColor:"gray.50",borderRadius:"md",border:"1px solid",borderColor:"gray.200",fontSize:"sm",marginTop:"16px",children:u}),(0,a.jsx)(n.J9,{initialValues:X,enableReinitialize:!0,onSubmit:ee,children:e=>{let{dirty:t,isValid:s,submitForm:r}=e;return(0,a.jsxs)(n.l0,{children:[(0,a.jsxs)(i.gCW,{alignItems:"start",spacing:6,mt:4,children:[(0,a.jsx)(y.j0,{id:"name",name:"name",label:"Name",variant:"stacked",isRequired:!0}),(0,a.jsx)(y.j0,{id:"description",name:"description",label:"Description",variant:"stacked"}),O&&P&&es(P),!V&&!K&&!J&&(0,a.jsx)(g.d,{id:"system_fides_key",name:"system_fides_key",options:null!=N?N:[],label:"System",tooltip:"The system to associate with the integration",layout:"stacked"}),c.identifier===w.Rj.DATAHUB&&(0,a.jsx)(g.d,{id:"dataset",name:"dataset",options:null!=z?z:[],label:"Datasets",tooltip:"Only BigQuery datasets are supported. Selected datasets will sync with matching DataHub datasets. If none are selected, all datasets will be included by default.",layout:"stacked",mode:"multiple"})]}),(0,a.jsx)(E,{dirty:t,isValid:s,submitForm:r,loading:et,onFormStateChange:x})]})}})]})}},38187:function(e,t,s){"use strict";s.d(t,{FO:function(){return M},jq:function(){return N},ZP:function(){return Z}});var a=s(24246),i=s(96306),n=s(79789),r=e=>{let{children:t}=e,{isOpen:s,onToggle:n}=(0,i.qY0)();return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(i.UO1,{in:s,children:t}),(0,a.jsx)(i.xvT,{fontSize:"sm",cursor:"pointer",textDecoration:"underline",onClick:n,children:s?"Show less":"Show more"})]})},o=s(21910),c=s(28946),d=s(87174);let l={name:"Google BigQuery",key:"bq_placeholder",connection_type:o.Rj.BIGQUERY,access:o.uv.READ,created_at:""},h=[{permission:"bigquery.jobs.create",description:"Run jobs (e.g. queries) within the project. This is only needed for the Fides Project where the Fides service account is located."},{permission:"bigquery.jobs.list",description:"Manage the queries that the service account performs. This is only needed for the Fides Project where the Fides service account is located."},{permission:"bigquery.routines.get",description:"Allow the service account to retrieve custom routines (e.g. queries) on associated datasets and tables."},{permission:"bigquery.routines.list",description:"Allow the service account to manage the custom routines (e.g. queries) that run on associated datasets and tables."}],u=[{permission:"bigquery.datasets.get",description:"Retrieve metadata and list tables for the specified project."},{permission:"bigquery.tables.get",description:"Retrieve metadata for the specified table."},{permission:"bigquery.tables.getData",description:"Read data in the specified table."},{permission:"bigquery.tables.list",description:"List all tables in the specified dataset."},{permission:"resourcemanager.projects.get",description:"Retrieve metadata for the specified project."}],m={placeholder:l,category:c.k.DATA_WAREHOUSE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.cB,{text:"Overview"}),(0,a.jsx)(n.XU,{children:"Continuously monitor BigQuery to detect and track schema-level changes, automatically discover and label data categories as well as automatically process DSR (privacy requests) and consent enforcement to proactively manage data governance risks."}),(0,a.jsxs)(r,{children:[(0,a.jsx)(n.cB,{text:"Categories"}),(0,a.jsxs)(n.Z5,{children:[(0,a.jsx)(i.HCh,{children:"Data Warehouse"}),(0,a.jsx)(i.HCh,{children:"Storage system"}),(0,a.jsx)(i.HCh,{children:"Cloud provider"}),(0,a.jsx)(i.HCh,{children:"Data detection"}),(0,a.jsx)(i.HCh,{children:"Data discovery"}),(0,a.jsx)(i.HCh,{children:"DSR automation"}),(0,a.jsx)(i.HCh,{children:"Consent orchestration"})]}),(0,a.jsx)(n.cB,{text:"Permissions"}),(0,a.jsx)(n.XU,{children:"For detection and discovery, Fides requires a read-only BigQuery service account with limited permissions. If you intend to automate governance for DSR or Consent, Fides requires a read-and-write BigQuery service account to any project you would like Fides to govern."}),(0,a.jsx)(n.XU,{children:"A BigQuery administrator can create the necessary role for Fides using BigQuery's roles guide and assign this to a service account using BigQuery's service account guide."}),(0,a.jsx)(n.XU,{children:"The permissions allow Fides to read the schema of, and data stored in projects, datasets and tables as well write restricted updates based on your policy configurations to tables you specify as part of DSR and Consent orchestration."}),(0,a.jsx)(n.cB,{text:"Permissions list"}),(0,a.jsxs)(n.Z5,{children:[(0,a.jsx)(i.HCh,{children:"bigquery.jobs.create"}),(0,a.jsx)(i.HCh,{children:"bigquery.jobs.list"}),(0,a.jsx)(i.HCh,{children:"bigquery.routines.get"}),(0,a.jsx)(i.HCh,{children:"bigquery.routines.list"}),(0,a.jsx)(i.HCh,{children:"bigquery.datasets.get"}),(0,a.jsx)(i.HCh,{children:"bigquery.tables.get"}),(0,a.jsx)(i.HCh,{children:"bigquery.tables.getData"}),(0,a.jsx)(i.HCh,{children:"bigquery.tables.list"}),(0,a.jsx)(i.HCh,{children:"bigquery.tables.updateData"}),(0,a.jsx)(i.HCh,{children:"resourcemanager.projects.get"})]})]})]}),{}),instructions:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.cB,{text:"Configuring a Fides -> BigQuery Integration"}),(0,a.jsx)(n.cB,{text:"Step 1: Create a Fides project"}),(0,a.jsxs)(n.XU,{children:["Create a Fides Project using"," ",(0,a.jsx)(n.Hn,{href:"https://cloud.google.com/resource-manager/docs/creating-managing-projects#creating_a_project",children:"BigQuery's project creation guide"}),"."]}),(0,a.jsx)(n.cB,{text:"Step 2: Create a Fides role in GCP"}),(0,a.jsxs)(n.vQ,{children:[(0,a.jsxs)(i.HCh,{children:["Create a custom role for Fides using BigQuery's"," ",(0,a.jsx)(n.Hn,{href:"https://cloud.google.com/iam/docs/creating-custom-roles#creating_a_custom_role",children:"roles guide"}),"."]}),(0,a.jsx)(i.HCh,{children:"Follow the sections below to grant permissions to this role for the Fides project and any project you would like Fides to manage."})]}),(0,a.jsxs)(r,{children:[(0,a.jsx)(n.cB,{text:"Step 3: Assign permissions to the Fides project"}),(0,a.jsx)(n.XU,{children:"Assign the following permissions to the Fides Project that will be used by your Fides service account to run queries:"}),(0,a.jsx)(n.aG,{data:h}),(0,a.jsx)(n.cB,{text:"Step 4: Assign permissions to any project you'd like Fides to monitor"}),(0,a.jsx)(n.XU,{children:"Grant the following permissions to the Fides service account in every project where you would like Fides detection and discovery monitoring."}),(0,a.jsx)(n.aG,{data:u}),(0,a.jsx)(n.cB,{text:"Step 5: Create a Fides service account in the Fides Project"}),(0,a.jsxs)(n.vQ,{children:[(0,a.jsxs)(i.HCh,{children:["Create a service account for Fides using BigQuery's"," ",(0,a.jsx)(n.Hn,{href:"https://cloud.google.com/iam/docs/service-accounts-create",children:"service account guide"}),"."]}),(0,a.jsx)(i.HCh,{children:"Assign the previously created role to this service account."}),(0,a.jsxs)(i.HCh,{children:["Download the service account JSON keyfile."," ",(0,a.jsx)("strong",{children:"Note: this is sensitive information that should not be shared."})," ","An example of this is below:"]})]}),(0,a.jsx)(n.hX,{children:'{\n "type": "service_account",\n "project_id": "project-id-123456",\n "private_key_id": "0123456789abcdef0123456789abcdef01234567",\n "private_key": "-----BEGIN PRIVATE KEY-----\\nMIIyourkey-----\\nEND PRIVATE KEY-----\\n",\n "client_email": "test@project-id-123456.iam.gserviceaccount.com",\n "client_id": "012345678901234567890",\n "auth_uri": "https://accounts.google.com/o/oauth2/auth",\n "token_uri": "https://oauth2.googleapis.com/token",\n "auth_provider_x509_cert_url": "https://www.googleapis.com/oauth2/v1/certs",\n "client_x509_cert_url": "https://www.googleapis.com/robot/v1/metadata/x509/test%40project-id-123456.iam.gserviceaccount.com"\n}'}),(0,a.jsx)(n.cB,{text:"Step 6: Use the JSON key to authenticate your integration"}),(0,a.jsx)(n.XU,{children:"Provide the JSON key to your Fides instance to securely connect Fides."})]})]}),{}),tags:["DSR Automation","Discovery","Detection"],enabledFeatures:[d.q.DATA_DISCOVERY]},x={name:"Datahub",key:"datahub_placeholder",connection_type:o.Rj.DATAHUB,access:o.uv.READ,created_at:""},p=(0,a.jsx)(a.Fragment,{children:"Set up a connection to your DataHub instance by providing a name, server URL, and access token. You can also select the BigQuery datasets you'd like to sync—these will be matched with corresponding datasets in DataHub. If no datasets are selected, all available BigQuery datasets will be included by default."}),g={placeholder:x,category:c.k.DATA_CATALOG,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.cB,{text:"Overview"}),(0,a.jsx)(n.XU,{children:"DataHub is a metadata platform designed to help organizations manage and govern their data. It acts as a centralized repository for tracking and discovering data assets across an organization, helping data teams understand where their data resides, how it's used, and how it flows through various systems."}),(0,a.jsxs)(r,{children:[(0,a.jsx)(n.cB,{text:"Categories"}),(0,a.jsx)(n.Z5,{children:(0,a.jsx)(i.HCh,{children:"Data Catalog"})}),(0,a.jsx)(n.cB,{text:"Permissions"}),(0,a.jsx)(n.Z5,{children:(0,a.jsx)(i.HCh,{children:"The related user to the access token must have at least the Editor role on DataHub."})})]})]}),{}),tags:["Sync"],description:p,enabledFeatures:[d.q.DATA_SYNC]},j={name:"DynamoDB",key:"dynamo_placeholder",connection_type:o.Rj.DYNAMODB,access:o.uv.READ,created_at:""},y=[{permission:"AmazonDynamoDBReadOnlyAccess",description:"Provides read-only access to Amazon DynamoDB via the AWS Management Console."},{permission:"AmazonDynamoDBFullAccess",description:"Provides full access to Amazon DynamoDB via the AWS Management Console. Only needed if automating governance for DSR or Consent."}],v={placeholder:j,category:c.k.DATABASE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.cB,{text:"Overview"}),(0,a.jsx)(n.XU,{children:"Continuously monitor DynamoDB to detect and track schema-level changes, automatically discover and label data categories as well as automatically process DSR (privacy requests) and consent enforcement to proactively manage data governance risks."}),(0,a.jsxs)(r,{children:[(0,a.jsx)(n.cB,{text:"Categories"}),(0,a.jsxs)(n.Z5,{children:[(0,a.jsx)(i.HCh,{children:"NoSQL database"}),(0,a.jsx)(i.HCh,{children:"Storage system"}),(0,a.jsx)(i.HCh,{children:"Cloud provider"}),(0,a.jsx)(i.HCh,{children:"Data detection"}),(0,a.jsx)(i.HCh,{children:"Data discovery"})]}),(0,a.jsx)(n.cB,{text:"Permissions and Policies"}),(0,a.jsxs)(n.XU,{children:["For detection and discovery, Fides requires an IAM user with read-only DynamoDB permissions in order to detect, discover, and classify sensitive data. The AWS-managed"," ",(0,a.jsx)(i.EKh,{children:"AmazonDynamoDBReadOnlyAccess"})," policy can be used to assign these permissions. If you intend to automate governance for DSR or Consent, Fides requires an IAM user with read-and-write DynamoDB permissions. The AWS-managed",(0,a.jsx)(i.EKh,{children:"AmazonDynamoDBFullAccess"})," policy can be used to assign these permissions. An IAM administrator can create the necessary principal for Fides using the AWS IAM guides, and assign the appropriate permissions policy to the IAM user."]}),(0,a.jsx)(n.XU,{children:"The permissions allow Fides to read the schema of, and data stored in, DynamoDB tables. This data is inspected only for the purpose of detecting sensitive data risks and no data is stored by Fides. As part of DSR or Consent orchestration, Fides will only write restricted updates to the tables specified by your Fides policy configuration."}),(0,a.jsx)(n.cB,{text:"Policy List"}),(0,a.jsx)(n.XU,{children:"The following AWS-managed policies provide the necessary permissions for Fides:"}),(0,a.jsxs)(n.Z5,{children:[(0,a.jsx)(i.HCh,{children:"AmazonDynamoDBReadOnlyAccess"}),(0,a.jsx)(i.HCh,{children:"AmazonDynamoDBFullAccess (only needed if automating governance for DSR or Consent)"})]})]})]}),{}),instructions:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.cB,{text:"Configuring a Fides -> DynamoDB Integration"}),(0,a.jsx)(n.cB,{text:"Step 1: Create an IAM user in AWS"}),(0,a.jsxs)(n.XU,{children:["Create an IAM user for Fides' DynamoDB access following the"," ",(0,a.jsx)(n.Hn,{href:"https://docs.aws.amazon.com/IAM/latest/UserGuide/getting-started.html#getting-started-iam-user",children:"AWS IAM user guide"}),"."]}),(0,a.jsxs)(r,{children:[(0,a.jsx)(n.cB,{text:"Step 2: Assign policies to the IAM user"}),(0,a.jsx)(n.XU,{children:"Grant the necessary permissions to the IAM user by attaching directly the appropriate AWS-managed policy for your use case:"}),(0,a.jsx)(n.aG,{data:y}),(0,a.jsx)(n.cB,{text:"Step 3: Create an access key for the IAM user"}),(0,a.jsxs)(n.vQ,{children:[(0,a.jsxs)(i.HCh,{children:["Create an access key for the IAM user under"," ",(0,a.jsx)("strong",{children:"Security credentials"})]}),(0,a.jsx)(i.HCh,{children:"Select the Other use case"}),(0,a.jsx)(i.HCh,{children:"Copy the Access Key ID and Secret Access Key"})]}),(0,a.jsx)(n.cB,{text:"Use the Credentials to Authenticate Your Integration"}),(0,a.jsx)(n.XU,{children:"Provide the credentials to your Fides instance to securely connect Fides."})]})]}),{}),tags:["DSR Automation","Discovery","Detection"],enabledFeatures:[d.q.DATA_DISCOVERY]},f={placeholder:{name:"Cloud SQL - MySQL",key:"google_cloud_sql_for_mysql_placeholder",connection_type:o.Rj.GOOGLE_CLOUD_SQL_MYSQL,access:o.uv.READ,created_at:""},category:c.k.DATABASE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.cB,{text:"Overview"}),(0,a.jsx)(n.XU,{children:"Google Cloud SQL for MySQL is a fully-managed relational database service that simplifies the setup, maintenance, management, and administration of MySQL databases. Connect Fides to your Google Cloud SQL for MySQL to detect and track changes in schemas and tables and automatically discover and label data categories to proactively manage data governance risks."}),(0,a.jsxs)(r,{children:[(0,a.jsx)(n.cB,{text:"Categories"}),(0,a.jsxs)(n.Z5,{children:[(0,a.jsx)(i.HCh,{children:"Database"}),(0,a.jsx)(i.HCh,{children:"SQL database"}),(0,a.jsx)(i.HCh,{children:"Storage system"}),(0,a.jsx)(i.HCh,{children:"Data detection"}),(0,a.jsx)(i.HCh,{children:"Data discovery"}),(0,a.jsx)(i.HCh,{children:"DSR automation"})]}),(0,a.jsx)(n.cB,{text:"Permissions"}),(0,a.jsx)(n.XU,{children:"For detection and discovery, Fides requires a user with the SELECT permission on the database. If you intend to automate governance for DSR or Consent, Fides requires a user with the SELECT, UPDATE, and DELETE The permissions allow Fides to read the schema of, and data stored in tables, and fields as well as write restricted updates based on your policy configurations to tables you specify as part of DSR and Consent orchestration. For a complete list of permissions view the Google Cloud SQL for MySQL DB documentation."}),(0,a.jsx)(n.cB,{text:"Permissions list"}),(0,a.jsxs)(n.Z5,{children:[(0,a.jsx)(i.HCh,{children:"GRANT SELECT"}),(0,a.jsx)(i.HCh,{children:"GRANT UPDATE"}),(0,a.jsx)(i.HCh,{children:"GRANT DELETE"})]})]})]}),{}),tags:["Discovery","Detection"],enabledFeatures:[d.q.DATA_DISCOVERY]},C={placeholder:{name:"Cloud SQL - Postgres",key:"google_cloud_sql_for_postgres_placeholder",connection_type:o.Rj.GOOGLE_CLOUD_SQL_POSTGRES,access:o.uv.READ,created_at:""},category:c.k.DATABASE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.cB,{text:"Overview"}),(0,a.jsx)(n.XU,{children:"Google Cloud SQL for Postgres is a fully-managed relational database service that simplifies the setup, maintenance, management, and administration of Postgres databases. Connect Fides to your Google Cloud SQL for Postgres to detect and track changes in schemas and tables and automatically discover and label data categories to proactively manage data governance risks."}),(0,a.jsxs)(r,{children:[(0,a.jsx)(n.cB,{text:"Categories"}),(0,a.jsxs)(n.Z5,{children:[(0,a.jsx)(i.HCh,{children:"Database"}),(0,a.jsx)(i.HCh,{children:"SQL database"}),(0,a.jsx)(i.HCh,{children:"Storage system"}),(0,a.jsx)(i.HCh,{children:"Data detection"}),(0,a.jsx)(i.HCh,{children:"Data discovery"}),(0,a.jsx)(i.HCh,{children:"DSR automation"})]}),(0,a.jsx)(n.cB,{text:"Permissions"}),(0,a.jsx)(n.XU,{children:"For detection and discovery, Fides requires a user with the SELECT permission on the database. If you intend to automate governance for DSR or Consent, Fides requires a user with the SELECT, UPDATE, and DELETE permission. The permissions allow Fides to read the schema of, and data stored in tables, and fields as well as write restricted updates based on your policy configurations to tables you specify as part of DSR and orchestration. For a complete list of permissions view the Google Cloud SQL for Postgres DB documentation."}),(0,a.jsx)(n.XU,{children:"The following GCP service account permissions are needed when setting up Google Cloud SQL for Postgres."}),(0,a.jsx)(n.cB,{text:"Permissions list"}),(0,a.jsxs)(n.Z5,{children:[(0,a.jsx)(i.HCh,{children:"cloudsql.instances.connect"}),(0,a.jsx)(i.HCh,{children:"cloudsql.instances.get"}),(0,a.jsx)(i.HCh,{children:"cloudsql.instances.login"})]})]})]}),{}),tags:["Discovery","Detection"],enabledFeatures:[d.q.DATA_DISCOVERY]};var S=s(88337);let A={placeholder:{name:"Manual Tasks",key:"manual_placeholder",connection_type:S.R.MANUAL_TASK,access:o.uv.READ,created_at:""},category:c.k.MANUAL,tags:["DSR","Manual tasks"],overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.cB,{text:"Overview"}),(0,a.jsx)(n.XU,{children:"Manual Integrations enable you to create and assign tasks for data that requires manual handling during access and erasure requests. Tasks can be assigned to internal users within Fides or external users who complete them securely through the external task portal."}),(0,a.jsxs)(n.XU,{children:["When privacy requests involve manual integrations, execution will pause in a ",(0,a.jsx)("em",{children:"Requires input"})," state until all assigned tasks are completed."]})]}),{}),enabledFeatures:[d.q.TASKS,d.q.WITHOUT_CONNECTION,d.q.CONDITIONS]},b={placeholder:{name:"Microsoft SQL Server",key:"microsoft_sql_server_placeholder",connection_type:o.Rj.MSSQL,access:o.uv.READ,created_at:""},category:c.k.DATABASE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.cB,{text:"Overview"}),(0,a.jsx)(n.XU,{children:"Microsoft SQL Server, is a relational database management system (RDBMS) developed by Microsoft. It is designed to store, manage, and retrieve data as requested by other software applications, which may run either on the same computer or across a network."}),(0,a.jsxs)(r,{children:[(0,a.jsx)(n.cB,{text:"Categories"}),(0,a.jsxs)(n.Z5,{children:[(0,a.jsx)(i.HCh,{children:"Database"}),(0,a.jsx)(i.HCh,{children:"SQL database"}),(0,a.jsx)(i.HCh,{children:"Storage system"}),(0,a.jsx)(i.HCh,{children:"Data detection"}),(0,a.jsx)(i.HCh,{children:"Data discovery"})]}),(0,a.jsx)(n.cB,{text:"Permissions"}),(0,a.jsx)(n.XU,{children:"For detecting databases, Fides requires a user with the following permissions/role:"}),(0,a.jsxs)(n.Z5,{children:[(0,a.jsx)(i.HCh,{children:"CREATE LOGIN username WITH PASSWORD = 'password';"}),(0,a.jsx)(i.HCh,{children:"GRANT SELECT, INSERT, UPDATE TO username;"})]})]})]}),{}),tags:["DSR Automation","Discovery","Detection"],enabledFeatures:[d.q.DATA_DISCOVERY]},D={placeholder:{name:"MySQL",key:"mysql_placeholder",connection_type:S.R.MYSQL,access:o.uv.READ,created_at:""},category:c.k.DATABASE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.cB,{text:"Overview"}),(0,a.jsx)(n.XU,{children:"Continuously monitor MySQL databases to detect and track schema-level changes, automatically discover and label data categories as well as automatically process DSR (privacy requests) and consent enforcement to proactively manage data governance risks."}),(0,a.jsxs)(r,{children:[(0,a.jsx)(n.cB,{text:"Categories"}),(0,a.jsxs)(n.Z5,{children:[(0,a.jsx)(i.HCh,{children:"Database"}),(0,a.jsx)(i.HCh,{children:"SQL database"}),(0,a.jsx)(i.HCh,{children:"Storage system"}),(0,a.jsx)(i.HCh,{children:"Data detection"}),(0,a.jsx)(i.HCh,{children:"Data discovery"})]}),(0,a.jsx)(n.cB,{text:"Permissions"}),(0,a.jsx)(n.XU,{children:"For detecting databases, Fides requires a user with the following permissions/role:"}),(0,a.jsxs)(n.Z5,{children:[(0,a.jsx)(i.HCh,{children:"CREATE USER 'username' IDENTIFIED WITH authentication_plugin BY 'password';"}),(0,a.jsx)(i.HCh,{children:"GRANT SELECT, INSERT ON database.* TO 'username'@'%';"})]})]})]}),{}),tags:["DSR Automation","Discovery","Detection"],enabledFeatures:[d.q.DATA_DISCOVERY]},R={name:"Okta",key:"okta_placeholder",connection_type:S.R.OKTA,access:o.uv.READ,created_at:""},w=(0,a.jsx)(a.Fragment,{children:"SSO providers manage user authentication and can help identify systems within your infrastructure. Adding an SSO provider as a data source allows you to detect connected systems, monitor access patterns, and enhance your data map for better visibility and control."}),T={placeholder:R,category:c.k.IDENTITY_PROVIDER,tags:["Discovery","Inventory"],overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.cB,{text:"Overview"}),(0,a.jsx)(n.XU,{children:"SSO providers manage user authentication and can help identify systems within your infrastructure. Adding an SSO provider as a data source allows you to detect connected systems, monitor access patterns, and enhance your data map for better visibility and control."})]}),{}),description:w,enabledFeatures:[d.q.DATA_DISCOVERY]},E={placeholder:{name:"Postgres",key:"postgres_placeholder",connection_type:S.R.POSTGRES,access:o.uv.READ,created_at:""},category:c.k.DATABASE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.cB,{text:"Overview"}),(0,a.jsx)(n.XU,{children:"Postgres is a relational database. Connect Fides to your Postgres Datbase to detect and track changes in schemas and tables and automatically discover and label data categories to proactively manage data governance risks."}),(0,a.jsxs)(r,{children:[(0,a.jsx)(n.cB,{text:"Categories"}),(0,a.jsxs)(n.Z5,{children:[(0,a.jsx)(i.HCh,{children:"Database"}),(0,a.jsx)(i.HCh,{children:"SQL database"}),(0,a.jsx)(i.HCh,{children:"Storage system"}),(0,a.jsx)(i.HCh,{children:"Data detection"}),(0,a.jsx)(i.HCh,{children:"Data discovery"})]}),(0,a.jsx)(n.XU,{children:"For each database, Fides requires the following permissions, where 'username' is the user set up for Fides, and 'database' is the name of the database you want to connect to."}),(0,a.jsxs)(n.Z5,{children:[(0,a.jsx)(i.HCh,{children:"CREATE USER username WITH LOGIN;"}),(0,a.jsx)(i.HCh,{children:"GRANT SELECT ON ALL TABLES IN SCHEMA public TO username;"}),(0,a.jsx)(i.HCh,{children:"GRANT ALL PRIVILEGES ON ALL TABLES IN SCHEMA public TO username;"})]})]})]}),{}),tags:["Detection","Discovery"],enabledFeatures:[d.q.DATA_DISCOVERY]},_={placeholder:{name:"Amazon RDS MySQL",key:"rds_mysql_placeholder",connection_type:o.Rj.RDS_MYSQL,access:o.uv.READ,created_at:""},category:c.k.DATABASE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.cB,{text:"Overview"}),(0,a.jsx)(n.XU,{children:"Amazon RDS MySQL is a fully-managed relational database service that simplifies the setup, maintenance, management, and administration of MySQL databases. Connect Fides to your Amazon RDS MySQL to detect and track changes in schemas and tables and automatically discover and label data categories to proactively manage data governance risks."}),(0,a.jsxs)(r,{children:[(0,a.jsx)(n.cB,{text:"Categories"}),(0,a.jsxs)(n.Z5,{children:[(0,a.jsx)(i.HCh,{children:"Database"}),(0,a.jsx)(i.HCh,{children:"SQL database"}),(0,a.jsx)(i.HCh,{children:"Storage system"}),(0,a.jsx)(i.HCh,{children:"Data detection"}),(0,a.jsx)(i.HCh,{children:"Data discovery"})]}),(0,a.jsx)(n.cB,{text:"Permissions"}),(0,a.jsx)(n.XU,{children:"For detecting database RDS instances and clusters, Fides requires an IAM user with the following permissions/role:"}),(0,a.jsxs)(n.Z5,{children:[(0,a.jsx)(i.HCh,{children:"rds:DescribeDBClusters"}),(0,a.jsx)(i.HCh,{children:"rds:DescribeDBInstances"}),(0,a.jsx)(i.HCh,{children:"rds-db:connect"})]}),(0,a.jsx)(n.XU,{children:"And per database instance and database it requires the following permissions, where 'username' is the user set up for Fides, and 'database' is the database name, you want to connect to."}),(0,a.jsxs)(n.Z5,{children:[(0,a.jsx)(i.HCh,{children:"CREATE USER 'username' IDENTIFIED WITH AWSAuthenticationPlugin AS 'RDS';"}),(0,a.jsx)(i.HCh,{children:"GRANT SELECT, INSERT ON database.* TO 'username'@'%';"})]})]})]}),{}),tags:["Discovery","Detection"],enabledFeatures:[d.q.DATA_DISCOVERY]},k={placeholder:{name:"Amazon RDS Postgres",key:"rds_postgres_placeholder",connection_type:o.Rj.RDS_POSTGRES,access:o.uv.READ,created_at:""},category:c.k.DATABASE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.cB,{text:"Overview"}),(0,a.jsx)(n.XU,{children:"Amazon RDS Postgres is a fully-managed relational database service that simplifies the setup, maintenance, management, and administration of Postgres databases. Connect Fides to your Amazon RDS Postgres to detect and track changes in schemas and tables and automatically discover and label data categories to proactively manage data governance risks."}),(0,a.jsxs)(r,{children:[(0,a.jsx)(n.cB,{text:"Categories"}),(0,a.jsxs)(n.Z5,{children:[(0,a.jsx)(i.HCh,{children:"Database"}),(0,a.jsx)(i.HCh,{children:"SQL database"}),(0,a.jsx)(i.HCh,{children:"Storage system"}),(0,a.jsx)(i.HCh,{children:"Data detection"}),(0,a.jsx)(i.HCh,{children:"Data discovery"})]}),(0,a.jsx)(n.cB,{text:"Permissions"}),(0,a.jsx)(n.XU,{children:"For detecting database RDS instances and clusters, Fides requires an IAM user with the following permissions/role:"}),(0,a.jsxs)(n.Z5,{children:[(0,a.jsx)(i.HCh,{children:"rds:DescribeDBClusters"}),(0,a.jsx)(i.HCh,{children:"rds:DescribeDBInstances"}),(0,a.jsx)(i.HCh,{children:"rds-db:connect"})]}),(0,a.jsx)(n.XU,{children:"For each database instance and database, Fides requires the following permissions, where 'username' is the user set up for Fides, and 'database' is the name of the database you want to connect to."}),(0,a.jsxs)(n.Z5,{children:[(0,a.jsx)(i.HCh,{children:"CREATE USER username WITH LOGIN;"}),(0,a.jsx)(i.HCh,{children:"GRANT rds_iam TO username;"}),(0,a.jsx)(i.HCh,{children:"GRANT SELECT ON ALL TABLES IN SCHEMA public TO username;"}),(0,a.jsx)(i.HCh,{children:"GRANT ALL PRIVILEGES ON ALL TABLES IN SCHEMA public TO username;"})]})]})]}),{}),tags:["Discovery","Detection"],enabledFeatures:[d.q.DATA_DISCOVERY]},H={placeholder:{name:"Amazon S3",key:"s3_placeholder",connection_type:o.Rj.S3,access:o.uv.READ,created_at:""},category:c.k.DATA_WAREHOUSE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.cB,{text:"Overview"}),(0,a.jsx)(n.XU,{children:"Continuously monitor S3 to detect and track schema-level changes, automatically discover and label data categories as well as automatically process DSR (privacy requests) and consent enforcement to proactively manage data governance risks."}),(0,a.jsxs)(r,{children:[(0,a.jsx)(n.cB,{text:"Categories"}),(0,a.jsxs)(n.Z5,{children:[(0,a.jsx)(i.HCh,{children:"Object storage"}),(0,a.jsx)(i.HCh,{children:"Storage system"}),(0,a.jsx)(i.HCh,{children:"Cloud provider"}),(0,a.jsx)(i.HCh,{children:"Data detection"}),(0,a.jsx)(i.HCh,{children:"Data discovery"})]}),(0,a.jsx)(n.cB,{text:"Permissions"}),(0,a.jsx)(n.XU,{children:"Fides requires an IAM principal with read-only S3 permissions in order to detect, discover, and classify sensitive data. The AWS-managed AmazonS3ReadOnlyAccess policy can be used to assign these permissions. An IAM administrator can create the necessary principal for Fides using the AWS IAM guides, and assign the appropriate permissions policy to the IAM principal."}),(0,a.jsx)(n.XU,{children:"The permissions allow Fides to list buckets and read object data data stored in those buckets. This data is inspected only for the purpose of detecting sensitive data risks and no data is stored by Fides."}),(0,a.jsx)(n.XU,{children:"Ethyca recommends creating an IAM role with the appropriate permissions, which will be assumed by Fides at runtime, with ephemeral credentials. There must also be an IAM user with fixed credentials that Fides uses strictly for assuming the IAM role with the appropriate permissions. If desired, Fides also supports authenticating directly as an IAM user with the appropriate permissions, but this is considered a less secure option."}),(0,a.jsx)(n.cB,{text:"Permissions list"}),(0,a.jsx)(n.Z5,{children:(0,a.jsx)(i.HCh,{children:"AmazonS3ReadOnlyAccess"})})]})]}),{}),instructions:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.cB,{text:"Configuring a Fides -> Amazon S3 Integration"}),(0,a.jsx)(n.cB,{text:"Step 1: Create an IAM role in AWS"}),(0,a.jsx)(n.XU,{children:"Create an IAM role for Fides' S3 access following the AWS IAM roles guide. This role will be referred to below as the Fides S3 Access Role."}),(0,a.jsxs)(r,{children:[(0,a.jsx)(n.cB,{text:"Step 2: Assign policies to the IAM role"}),(0,a.jsx)(n.XU,{children:"Grant the necessary permissions to the IAM role by attaching the following AWS-managed policy:"}),(0,a.jsx)(n.aG,{data:[{permission:"AmazonS3ReadOnlyAccess",description:"Provides read-only access to all buckets via the AWS Management Console."}]}),(0,a.jsx)(n.cB,{text:"Step 3: Create an IAM user for assuming a role"}),(0,a.jsxs)(n.XU,{children:["Follow the ",(0,a.jsx)(n.Hn,{href:"https://docs.aws.amazon.com/IAM/latest/UserGuide/getting-started.html#getting-started-iam-user",children:"AWS guide"})," for creating an IAM user to create an IAM user that Fides will authenticate as in order to assume the Fides S3 Access Role created above, and retrieve ephemeral credentials."]}),(0,a.jsx)(n.cB,{text:"Step 4: Grant the IAM user permission to assume the Fides S3 Access Role"}),(0,a.jsx)(n.XU,{children:"Navigate to the IAM user's Permissions page and add a permission by creating an inline policy. This permission should grant the IAM user permission to assume the Fides S3 Access Role created above (you'll need to retrieve the role ARN). The inline policy should look similar to this:"}),(0,a.jsx)(n.hX,{children:'{\n "Version": "2012-10-17",\n "Statement": [\n {\n "Sid": "VisualEditor0",\n "Effect": "Allow",\n "Action": "sts:AssumeRole",\n "Resource": "arn:aws:iam::[AWS ACCOUNT NUMBER]:role/[Fides S3 Access Role ARN]"\n }\n ]\n}'}),(0,a.jsx)(n.cB,{text:"Step 5: Create an access key for the IAM user"}),(0,a.jsxs)(n.vQ,{children:[(0,a.jsxs)(i.HCh,{children:["Create an access key for the IAM user under"," ",(0,a.jsx)("strong",{children:"Security credentials"}),"."]}),(0,a.jsx)(i.HCh,{children:"Select the Other use case"}),(0,a.jsx)(i.HCh,{children:"Copy the Access Key ID and Secret Access Key"})]}),(0,a.jsx)(n.cB,{text:"Step 6: Use the credentials to authenticate your integration"}),(0,a.jsxs)(n.XU,{children:["Provide the credentials to your Fides instance to securely connect Fides. For the Assume Role ARN, provide the ARN for the Fides S3 Access Role created in step 1."," "]})]})]}),{}),tags:["DSR Automation","Discovery","Detection"],enabledFeatures:[d.q.DATA_DISCOVERY]};var F=s(80388);let I={placeholder:{name:"Salesforce",key:"salesforce_placeholder",connection_type:S.R.SAAS,saas_config:{fides_key:"salesforce",name:"Salesforce",type:F.m.SALESFORCE},access:o.uv.WRITE,created_at:""},category:c.k.CRM,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.cB,{text:"Overview"}),(0,a.jsx)(n.XU,{children:"Salesforce is a cloud-based customer relationship management (CRM) platform that helps businesses manage sales, marketing, and customer service interactions in a unified system. Connect Fides to your Salesforce instance to automatically discover and track data across both standard and custom objects, detect sensitive information, and automate DSR fulfillment."}),(0,a.jsxs)(r,{children:[(0,a.jsx)(n.cB,{text:"What this integration does"}),(0,a.jsxs)(n.Z5,{children:[(0,a.jsx)(i.HCh,{children:"Discover personal data in standard Salesforce objects"}),(0,a.jsx)(i.HCh,{children:"Detect sensitive information across your Salesforce instance"}),(0,a.jsx)(i.HCh,{children:"Automate data subject access requests including data retrieval, updates, and deletions"}),(0,a.jsx)(i.HCh,{children:"Map Salesforce data to your organization's data map"}),(0,a.jsx)(i.HCh,{children:"Discover and map custom Salesforce objects (requires setting up a monitor)"})]}),(0,a.jsx)(n.XU,{children:"Once integrated, the system will automatically map sensitive personal data for standard Salesforce objects. By setting up a monitor, you can also detect and map custom objects in your Salesforce instance."}),(0,a.jsx)(n.cB,{text:"Categories"}),(0,a.jsxs)(n.Z5,{children:[(0,a.jsx)(i.HCh,{children:"CRM System"}),(0,a.jsx)(i.HCh,{children:"Data detection"}),(0,a.jsx)(i.HCh,{children:"Data discovery"}),(0,a.jsx)(i.HCh,{children:"DSR automation"})]}),(0,a.jsx)(n.cB,{text:"Prerequisites"}),(0,a.jsx)(n.XU,{children:"To integrate with Salesforce, you need to create a Connected App in your Salesforce instance. This ensures exclusive data control and enhances security by reducing unauthorized access risks."}),(0,a.jsx)(n.cB,{text:"Setup instructions"}),(0,a.jsx)(n.XU,{children:"Follow these steps to set up your Salesforce integration:"}),(0,a.jsxs)(n.vQ,{children:[(0,a.jsx)(i.HCh,{children:"Create a Connected App in Salesforce by following the Salesforce guide"}),(0,a.jsx)(i.HCh,{children:"Configure Basic Connected App Settings"}),(0,a.jsx)(i.HCh,{children:'Uncheck "Require Proof Key for Code Exchange (PKCE) Extension for Supported Authorization Flows"'}),(0,a.jsx)(i.HCh,{children:"Enable OAuth Settings for API Integration with the required scopes"}),(0,a.jsx)(i.HCh,{children:"Enter your Fides Redirect URL (typically https://fides-host.com/api/v1/oauth/callback)"})]}),(0,a.jsx)(n.cB,{text:"Required information"}),(0,a.jsxs)(n.Z5,{children:[(0,a.jsx)(i.HCh,{children:"Domain: Your Salesforce URL"}),(0,a.jsx)(i.HCh,{children:"Consumer Key: Your OAuth client ID"}),(0,a.jsx)(i.HCh,{children:"Consumer Secret: Your OAuth client secret"}),(0,a.jsx)(i.HCh,{children:"Redirect URL: The Fides URL for OAuth callback"}),(0,a.jsx)(i.HCh,{children:"Token Refresh URL: The Salesforce URL for refresh tokens"})]}),(0,a.jsx)(n.cB,{text:"Required OAuth scopes"}),(0,a.jsxs)(n.Z5,{children:[(0,a.jsx)(i.HCh,{children:"Manage user data via APIs (api)"}),(0,a.jsx)(i.HCh,{children:"Perform requests at any time (refresh_token, offline_access)"})]}),(0,a.jsx)(n.cB,{text:"Supported objects"}),(0,a.jsx)(n.XU,{children:"Fides supports both standard and custom Salesforce objects. The integration includes built-in support for common objects such as:"}),(0,a.jsxs)(n.Z5,{children:[(0,a.jsx)(i.HCh,{children:"Contacts"}),(0,a.jsx)(i.HCh,{children:"Cases"}),(0,a.jsx)(i.HCh,{children:"Leads"}),(0,a.jsx)(i.HCh,{children:"Accounts"}),(0,a.jsx)(i.HCh,{children:"Campaign Members"}),(0,a.jsx)(i.HCh,{children:"Custom Objects"})]})]})]}),{}),tags:["API","DSR Automation","Discovery","Detection"],enabledFeatures:[d.q.DATA_DISCOVERY,d.q.DSR_AUTOMATION]},B={placeholder:{name:"Scylla",key:"scylla_placeholder",connection_type:o.Rj.SCYLLA,access:o.uv.READ,created_at:""},category:c.k.DATABASE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.cB,{text:"Overview"}),(0,a.jsx)(n.XU,{children:"ScyllaDB is an open-sources distributed NoSQL data store designed to be compatible with Apache Cassandra. Connect Fides to your ScyllaDB to detect and track changes in keyspaces and tables and automatically discover and label data categories to proactively manage data governance risks."}),(0,a.jsxs)(r,{children:[(0,a.jsx)(n.cB,{text:"Categories"}),(0,a.jsxs)(n.Z5,{children:[(0,a.jsx)(i.HCh,{children:"Database"}),(0,a.jsx)(i.HCh,{children:"NoSQL database"}),(0,a.jsx)(i.HCh,{children:"Storage system"}),(0,a.jsx)(i.HCh,{children:"Data detection"}),(0,a.jsx)(i.HCh,{children:"Data discovery"}),(0,a.jsx)(i.HCh,{children:"DSR automation"})]}),(0,a.jsx)(n.cB,{text:"Permissions"}),(0,a.jsx)(n.XU,{children:"For detection and discovery, Fides requires a user with the SELECT permission on all keyspaces. If you intend to automate governance for DSR or Consent, Fides requires the role to to be granted SELECT and MODIFY on all keyspaces. The permissions allow Fides to read the schema of, and data stored in keyspaces, tables, and fields as well as write restricted updates based on your policy configurations to tables you specify as part of DSR and Consent orchestration. For a complete list of permissions view the Scylla DB documentation."}),(0,a.jsx)(n.cB,{text:"Permissions list"}),(0,a.jsxs)(n.Z5,{children:[(0,a.jsx)(i.HCh,{children:"SELECT ALL KEYSPACES"}),(0,a.jsx)(i.HCh,{children:"MODIFY ALL KEYSPACES"})]})]})]}),{}),tags:["DSR Automation","Discovery","Detection"],enabledFeatures:[d.q.DATA_DISCOVERY]},L={placeholder:{name:"Snowflake",key:"snowflake_placeholder",connection_type:o.Rj.SNOWFLAKE,access:o.uv.READ,created_at:""},category:c.k.DATA_WAREHOUSE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.cB,{text:"Overview"}),(0,a.jsx)(n.XU,{children:"Snowflake is a cloud-based data warehousing platform designed for handling large-scale data storage and analytics. It enables organizations to store, manage, and analyze massive amounts of data efficiently, offering features like scalability, performance, and flexibility."}),(0,a.jsxs)(r,{children:[(0,a.jsx)(n.cB,{text:"Categories"}),(0,a.jsxs)(n.Z5,{children:[(0,a.jsx)(i.HCh,{children:"Database"}),(0,a.jsx)(i.HCh,{children:"SQL database"}),(0,a.jsx)(i.HCh,{children:"Storage system"}),(0,a.jsx)(i.HCh,{children:"Data detection"}),(0,a.jsx)(i.HCh,{children:"Data discovery"})]}),(0,a.jsx)(n.cB,{text:"Permissions"}),(0,a.jsxs)(n.Z5,{children:[(0,a.jsx)(i.HCh,{children:"CREATE ROLE my_monitor_role;"}),(0,a.jsx)(i.HCh,{children:"GRANT USAGE ON DATABASE DATABASE_1 TO ROLE my_monitor_role;"}),(0,a.jsx)(i.HCh,{children:"GRANT USAGE ON SCHEMA DATABASE_1.TEST_SCHEMA TO ROLE my_monitor_role;"}),(0,a.jsx)(i.HCh,{children:"GRANT SELECT ON ALL TABLES IN SCHEMA DATABASE_1.TEST_SCHEMA TO ROLE my_monitor_role;"}),(0,a.jsx)(i.HCh,{children:"CREATE USER test_user PASSWORD='***';"}),(0,a.jsx)(i.HCh,{children:"GRANT ROLE my_monitor_role TO USER test_user;"})]})]})]}),{}),tags:["DSR Automation","Discovery","Detection"],enabledFeatures:[d.q.DATA_DISCOVERY]},O={placeholder:{name:"Website",key:"website_placeholder",connection_type:S.R.WEBSITE,access:o.uv.READ,created_at:""},category:c.k.WEBSITE,tags:["Consent","Discovery","Detection"],overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(n.cB,{text:"Overview"}),(0,a.jsx)(n.XU,{children:'Websites, or "properties", often process user data. Adding a website as an integration lets you configure a Consent Management Platform (CMP), a site-specific privacy center, and Cross-Origin requests via Fides. You can configure the various security settings, styling, and user experience settings for the privacy center and CMP on a per-website basis.'})]}),{}),enabledFeatures:[d.q.DATA_DISCOVERY]},P=[I],q={[S.R.BIGQUERY]:m,[S.R.DATAHUB]:g,[S.R.DYNAMODB]:v,[S.R.GOOGLE_CLOUD_SQL_MYSQL]:f,[S.R.GOOGLE_CLOUD_SQL_POSTGRES]:C,[S.R.MSSQL]:b,[S.R.OKTA]:T,[S.R.RDS_MYSQL]:_,[S.R.RDS_POSTGRES]:k,[S.R.S3]:H,[S.R.SCYLLA]:B,[S.R.SNOWFLAKE]:L,[S.R.MYSQL]:D,[S.R.WEBSITE]:O,[S.R.POSTGRES]:E,[S.R.MANUAL_TASK]:A},M=[...Object.values(q),...P],N=[...Object.keys(q),S.R.SAAS],U=e=>({placeholder:{name:e.human_readable,key:"".concat(e.identifier,"_placeholder"),connection_type:S.R.SAAS,saas_config:{fides_key:e.identifier,name:e.human_readable,type:e.identifier},access:o.uv.WRITE,created_at:""},category:e.category||c.k.CUSTOM,tags:e.tags||["API","Custom"],enabledFeatures:e.enabled_features||[d.q.DSR_AUTOMATION]}),z={placeholder:{name:"",key:"placeholder",connection_type:S.R.MANUAL,access:o.uv.READ,created_at:""},category:c.k.DATA_WAREHOUSE,tags:[],enabledFeatures:[]};var Z=(e,t,s)=>{if(!e)return z;if(e===S.R.SAAS&&t){if(s){let e=s.find(e=>e.identifier===t);if(e){let s=U(e),a=P.find(e=>{var s;return(null===(s=e.placeholder.saas_config)||void 0===s?void 0:s.type)===t});return a&&a.overview?{...s,overview:a.overview}:s}}let e=P.find(e=>{var s;return(null===(s=e.placeholder.saas_config)||void 0===s?void 0:s.type)===t});if(e)return e}if(e!==S.R.SAAS){let t=q[e];if(t)return t}return z}},93633:function(e,t,s){"use strict";s.d(t,{z:function(){return r}});var a=s(17245),i=s(96306),n=s(14207);let r=e=>{let{connection:t,connectionOption:s,testData:r}=e,[o]=(0,n.rO)(),{handleError:c}=(0,a.HK)();return{handleAuthorize:async()=>{if(!(null==t?void 0:t.key)){i.Pg3.error("Authorization failed: connection key not found");return}try{let e=await o(t.key).unwrap();window.location.href=e}catch(e){c(e)}},needsAuthorization:!!(null==s?void 0:s.authorization_required)&&!r.authorized}}},64176:function(e,t,s){"use strict";var a=s(27378),i=s(20682),n=s(88337);t.Z=(e,t)=>{let{data:s}=(0,i.$I)({});return(0,a.useMemo)(()=>e===n.R.SAAS?null==s?void 0:s.items.find(e=>e.identifier===t):null==s?void 0:s.items.find(t=>t.identifier===e),[s,e,t])}},35030:function(e,t,s){"use strict";s.d(t,{qS:function(){return i}});var a=s(28946);let i=e=>{switch(e){case a.k.DATA_CATALOG:return"Data Catalog";case a.k.DATA_WAREHOUSE:return"Data Warehouse";case a.k.DATABASE:return"Database";case a.k.IDENTITY_PROVIDER:return"Identity Provider";case a.k.WEBSITE:return"Website";case a.k.CRM:return"CRM";case a.k.MANUAL:return"Manual";case a.k.MARKETING:return"Marketing";case a.k.ANALYTICS:return"Analytics";case a.k.ECOMMERCE:return"E-commerce";case a.k.COMMUNICATION:return"Communication";case a.k.CUSTOM:return"Custom";default:return e}}},11013:function(e,t,s){"use strict";s.d(t,{$y:function(){return n},eV:function(){return a},m5:function(){return o},ww:function(){return r}});let{useGetSharedMonitorConfigsQuery:a,useGetSharedMonitorConfigByIdQuery:i,useCreateSharedMonitorConfigMutation:n,useUpdateSharedMonitorConfigMutation:r,useDeleteSharedMonitorConfigMutation:o}=s(78780).u.injectEndpoints({endpoints:e=>({getSharedMonitorConfigs:e.query({query:e=>({method:"GET",url:"/plus/shared-monitor-config",params:e}),providesTags:["Shared Monitor Configs"]}),getSharedMonitorConfigById:e.query({query:e=>{let{id:t}=e;return{method:"GET",url:"/plus/shared-monitor-config/".concat(t)}},providesTags:["Shared Monitor Configs"]}),createSharedMonitorConfig:e.mutation({query:e=>({method:"POST",url:"/plus/shared-monitor-config",body:e}),invalidatesTags:["Shared Monitor Configs"]}),updateSharedMonitorConfig:e.mutation({query:e=>({method:"PUT",url:"/plus/shared-monitor-config/".concat(e.id),body:e}),invalidatesTags:["Shared Monitor Configs"]}),deleteSharedMonitorConfig:e.mutation({query:e=>{let{id:t}=e;return{method:"DELETE",url:"/plus/shared-monitor-config/".concat(t)}},invalidatesTags:["Shared Monitor Configs"]})})})},57072:function(e,t,s){"use strict";s.d(t,{Bd:function(){return a.Bd},L5:function(){return a.L5},MO:function(){return a.MO},qb:function(){return a.qb}});var a=s(5785)},31883:function(e,t,s){"use strict";s.d(t,{Bw:function(){return a.Bw},D4:function(){return a.D4}});var a=s(19043)},72707:function(e){e.exports={option:"TaxonomySelect_option__vY6v2"}}}]);