ethyca-fides 2.64.1b1__py2.py3-none-any.whl → 2.64.1rc0__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.
Files changed (107) hide show
  1. {ethyca_fides-2.64.1b1.dist-info → ethyca_fides-2.64.1rc0.dist-info}/METADATA +2 -2
  2. {ethyca_fides-2.64.1b1.dist-info → ethyca_fides-2.64.1rc0.dist-info}/RECORD +104 -107
  3. fides/_version.py +3 -3
  4. fides/api/db/base.py +0 -4
  5. fides/api/models/manual_tasks/__init__.py +1 -7
  6. fides/api/models/manual_tasks/manual_task.py +3 -19
  7. fides/api/models/manual_tasks/manual_task_config.py +6 -39
  8. fides/api/models/manual_tasks/manual_task_log.py +7 -20
  9. fides/api/schemas/manual_tasks/manual_task_schemas.py +0 -42
  10. fides/api/schemas/manual_tasks/manual_task_status.py +46 -107
  11. fides/service/manual_tasks/manual_task_config_service.py +5 -17
  12. fides/service/manual_tasks/manual_task_service.py +10 -66
  13. fides/ui-build/static/admin/404.html +1 -1
  14. fides/ui-build/static/admin/_next/static/chunks/{6662-cb11881dcaabe5e2.js → 6662-6a6b90fc8f11558f.js} +1 -1
  15. fides/ui-build/static/admin/_next/static/{zBkPKRGECPjwEx0G7BvHe → hCJxUAFBWobWrps6RkP0K}/_buildManifest.js +1 -1
  16. fides/ui-build/static/admin/add-systems/manual.html +1 -1
  17. fides/ui-build/static/admin/add-systems/multiple.html +1 -1
  18. fides/ui-build/static/admin/add-systems.html +1 -1
  19. fides/ui-build/static/admin/consent/configure/add-vendors.html +1 -1
  20. fides/ui-build/static/admin/consent/configure.html +1 -1
  21. fides/ui-build/static/admin/consent/privacy-experience/[id].html +1 -1
  22. fides/ui-build/static/admin/consent/privacy-experience/new.html +1 -1
  23. fides/ui-build/static/admin/consent/privacy-experience.html +1 -1
  24. fides/ui-build/static/admin/consent/privacy-notices/[id].html +1 -1
  25. fides/ui-build/static/admin/consent/privacy-notices/new.html +1 -1
  26. fides/ui-build/static/admin/consent/privacy-notices.html +1 -1
  27. fides/ui-build/static/admin/consent/properties.html +1 -1
  28. fides/ui-build/static/admin/consent/reporting.html +1 -1
  29. fides/ui-build/static/admin/consent.html +1 -1
  30. fides/ui-build/static/admin/data-catalog/[systemId]/projects/[projectUrn]/[resourceUrn].html +1 -1
  31. fides/ui-build/static/admin/data-catalog/[systemId]/projects/[projectUrn].html +1 -1
  32. fides/ui-build/static/admin/data-catalog/[systemId]/projects.html +1 -1
  33. fides/ui-build/static/admin/data-catalog/[systemId]/resources/[resourceUrn].html +1 -1
  34. fides/ui-build/static/admin/data-catalog/[systemId]/resources.html +1 -1
  35. fides/ui-build/static/admin/data-catalog.html +1 -1
  36. fides/ui-build/static/admin/data-discovery/action-center/[monitorId]/[systemId].html +1 -1
  37. fides/ui-build/static/admin/data-discovery/action-center/[monitorId].html +1 -1
  38. fides/ui-build/static/admin/data-discovery/action-center.html +1 -1
  39. fides/ui-build/static/admin/data-discovery/activity.html +1 -1
  40. fides/ui-build/static/admin/data-discovery/detection/[resourceUrn].html +1 -1
  41. fides/ui-build/static/admin/data-discovery/detection.html +1 -1
  42. fides/ui-build/static/admin/data-discovery/discovery/[resourceUrn].html +1 -1
  43. fides/ui-build/static/admin/data-discovery/discovery.html +1 -1
  44. fides/ui-build/static/admin/datamap.html +1 -1
  45. fides/ui-build/static/admin/dataset/[datasetId]/[collectionName]/[...subfieldNames].html +1 -1
  46. fides/ui-build/static/admin/dataset/[datasetId]/[collectionName].html +1 -1
  47. fides/ui-build/static/admin/dataset/[datasetId].html +1 -1
  48. fides/ui-build/static/admin/dataset/new.html +1 -1
  49. fides/ui-build/static/admin/dataset.html +1 -1
  50. fides/ui-build/static/admin/datastore-connection/[id].html +1 -1
  51. fides/ui-build/static/admin/datastore-connection/new.html +1 -1
  52. fides/ui-build/static/admin/datastore-connection.html +1 -1
  53. fides/ui-build/static/admin/index.html +1 -1
  54. fides/ui-build/static/admin/integrations/[id].html +1 -1
  55. fides/ui-build/static/admin/integrations.html +1 -1
  56. fides/ui-build/static/admin/lib/fides-headless.js +1 -1
  57. fides/ui-build/static/admin/lib/fides-preview.js +1 -1
  58. fides/ui-build/static/admin/lib/fides-tcf.js +2 -2
  59. fides/ui-build/static/admin/lib/fides.js +2 -2
  60. fides/ui-build/static/admin/login/[provider].html +1 -1
  61. fides/ui-build/static/admin/login.html +1 -1
  62. fides/ui-build/static/admin/messaging/[id].html +1 -1
  63. fides/ui-build/static/admin/messaging/add-template.html +1 -1
  64. fides/ui-build/static/admin/messaging.html +1 -1
  65. fides/ui-build/static/admin/poc/ant-components.html +1 -1
  66. fides/ui-build/static/admin/poc/form-experiments/AntForm.html +1 -1
  67. fides/ui-build/static/admin/poc/form-experiments/FormikAntFormItem.html +1 -1
  68. fides/ui-build/static/admin/poc/form-experiments/FormikControlled.html +1 -1
  69. fides/ui-build/static/admin/poc/form-experiments/FormikField.html +1 -1
  70. fides/ui-build/static/admin/poc/form-experiments/FormikSpreadField.html +1 -1
  71. fides/ui-build/static/admin/poc/forms.html +1 -1
  72. fides/ui-build/static/admin/poc/table-migration.html +1 -1
  73. fides/ui-build/static/admin/privacy-requests/[id].html +1 -1
  74. fides/ui-build/static/admin/privacy-requests/configure/messaging.html +1 -1
  75. fides/ui-build/static/admin/privacy-requests/configure/storage.html +1 -1
  76. fides/ui-build/static/admin/privacy-requests/configure.html +1 -1
  77. fides/ui-build/static/admin/privacy-requests.html +1 -1
  78. fides/ui-build/static/admin/properties/[id].html +1 -1
  79. fides/ui-build/static/admin/properties/add-property.html +1 -1
  80. fides/ui-build/static/admin/properties.html +1 -1
  81. fides/ui-build/static/admin/reporting/datamap.html +1 -1
  82. fides/ui-build/static/admin/settings/about/alpha.html +1 -1
  83. fides/ui-build/static/admin/settings/about.html +1 -1
  84. fides/ui-build/static/admin/settings/consent/[configuration_id]/[purpose_id].html +1 -1
  85. fides/ui-build/static/admin/settings/consent.html +1 -1
  86. fides/ui-build/static/admin/settings/custom-fields.html +1 -1
  87. fides/ui-build/static/admin/settings/domain-records.html +1 -1
  88. fides/ui-build/static/admin/settings/domains.html +1 -1
  89. fides/ui-build/static/admin/settings/email-templates.html +1 -1
  90. fides/ui-build/static/admin/settings/locations.html +1 -1
  91. fides/ui-build/static/admin/settings/organization.html +1 -1
  92. fides/ui-build/static/admin/settings/regulations.html +1 -1
  93. fides/ui-build/static/admin/systems/configure/[id]/test-datasets.html +1 -1
  94. fides/ui-build/static/admin/systems/configure/[id].html +1 -1
  95. fides/ui-build/static/admin/systems.html +1 -1
  96. fides/ui-build/static/admin/taxonomy.html +1 -1
  97. fides/ui-build/static/admin/user-management/new.html +1 -1
  98. fides/ui-build/static/admin/user-management/profile/[id].html +1 -1
  99. fides/ui-build/static/admin/user-management.html +1 -1
  100. fides/api/alembic/migrations/versions/6a76a1fa4f3f_add_manual_task_instance_table.py +0 -256
  101. fides/api/models/manual_tasks/manual_task_instance.py +0 -187
  102. fides/service/manual_tasks/manual_task_instance_service.py +0 -285
  103. {ethyca_fides-2.64.1b1.dist-info → ethyca_fides-2.64.1rc0.dist-info}/WHEEL +0 -0
  104. {ethyca_fides-2.64.1b1.dist-info → ethyca_fides-2.64.1rc0.dist-info}/entry_points.txt +0 -0
  105. {ethyca_fides-2.64.1b1.dist-info → ethyca_fides-2.64.1rc0.dist-info}/licenses/LICENSE +0 -0
  106. {ethyca_fides-2.64.1b1.dist-info → ethyca_fides-2.64.1rc0.dist-info}/top_level.txt +0 -0
  107. /fides/ui-build/static/admin/_next/static/{zBkPKRGECPjwEx0G7BvHe → hCJxUAFBWobWrps6RkP0K}/_ssgManifest.js +0 -0
@@ -1 +1 @@
1
- (self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[6662],{18225:function(e,t,s){"use strict";var i=s(24246),n=s(62051);t.Z=e=>{let{alignment:t="center",...s}=e;return(0,i.jsx)(n.kCb,{boxSize:"full",align:"center",justify:t,children:(0,i.jsx)(n.$jN,{color:"primary",...s})})}},77213:function(e,t,s){"use strict";s.d(t,{Z:function(){return h}});var i=s(24246),n=s(62051),a=s(88038),r=s.n(a),o=s(86677);s(27378);var c=s(25980),l=s(90867),d=s(77830),u=()=>{let e=(0,o.useRouter)();return(0,i.jsx)(n.xuv,{bg:"gray.50",border:"1px solid",borderColor:"blue.400",borderRadius:"md",justifyContent:"space-between",p:5,mb:5,mt:5,children:(0,i.jsxs)(n.xuv,{children:[(0,i.jsxs)(n.Kqy,{direction:{base:"column",sm:"row"},justifyContent:"space-between",children:[(0,i.jsx)(n.xvT,{fontWeight:"semibold",children:"Configure your storage and messaging provider"}),(0,i.jsx)(n.wpx,{onClick:()=>{e.push(d.fz)},children:"Configure"})]}),(0,i.jsxs)(n.xvT,{children:["Before Fides can process your privacy requests we need two simple steps to configure your storage and email client."," "]})]})})},h=e=>{let{children:t,title:s,padded:a=!0,mainProps:d}=e,h=(0,c.hz)(),m=(0,o.useRouter)(),x="/privacy-requests"===m.pathname||"/datastore-connection"===m.pathname,p=!(h.flags.privacyRequestsConfiguration&&x),{data:j}=(0,l.JE)(void 0,{skip:p}),{data:g}=(0,l.PW)(void 0,{skip:p}),y=h.flags.privacyRequestsConfiguration&&(!j||!g)&&x;return(0,i.jsxs)(n.kCb,{"data-testid":s,direction:"column",h:"100vh",children:[(0,i.jsxs)(r(),{children:[(0,i.jsxs)("title",{children:["Fides Admin UI - ",s]}),(0,i.jsx)("meta",{name:"description",content:"Privacy Engineering Platform"}),(0,i.jsx)("link",{rel:"icon",href:"/favicon.ico"})]}),(0,i.jsxs)(n.kCb,{as:"main",direction:"column",py:a?6:0,px:a?10:0,h:a?"calc(100% - 48px)":"full",flex:1,minWidth:0,overflow:"auto",...d,children:[y?(0,i.jsx)(u,{}):null,t]})]})}},58754:function(e,t,s){"use strict";var i=s(24246),n=s(62051),a=s(70788);t.Z=e=>{let{heading:t,breadcrumbItems:s,isSticky:r=!0,children:o,rightContent:c,style:l,...d}=e;return(0,i.jsxs)("div",{...d,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",...l}:{paddingBottom:"24px",...l},children:[(0,i.jsxs)(n.jqI,{justify:"space-between",children:["string"==typeof t?(0,i.jsx)(n.lQT,{className:s||o?"pb-4":void 0,level:1,"data-testid":"page-heading",children:t}):t,c&&(0,i.jsx)("div",{"data-testid":"page-header-right-content",children:c})]}),!!s&&(0,i.jsx)(a.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 u},cB:function(){return a},hX:function(){return d},vQ:function(){return l}});var i=s(24246),n=s(62051);let a=e=>{let{text:t,...s}=e;return(0,i.jsx)(n.X6q,{fontSize:"sm",mt:4,mb:1,...s,children:t})},r=e=>{let{children:t}=e;return(0,i.jsx)(n.xvT,{fontSize:"14px",mb:4,children:t})},o=e=>{let{children:t,href:s}=e;return(0,i.jsx)(n.rUS,{href:s,textDecoration:"underline",isExternal:!0,children:t})},c=e=>{let{children:t}=e;return(0,i.jsx)(n.QI$,{fontSize:"14px",mb:4,children:t})},l=e=>{let{children:t}=e;return(0,i.jsx)(n.GSI,{fontSize:"14px",mb:4,ml:6,children:t})},d=e=>{let{children:t}=e;return(0,i.jsx)(n.EKh,{display:"block",whiteSpace:"pre",p:4,mb:4,overflowX:"scroll",children:t})},u=e=>{let{data:t}=e;return(0,i.jsxs)(n.iA_,{fontSize:"14px",children:[(0,i.jsx)(n.hrZ,{children:(0,i.jsxs)(n.Tr,{children:[(0,i.jsx)(n.Th,{children:"Permission"}),(0,i.jsx)(n.Th,{children:"Description"})]})}),(0,i.jsx)(n.p3B,{children:t.map(e=>(0,i.jsxs)(n.Tr,{children:[(0,i.jsx)(n.Td,{children:(0,i.jsx)(n.Vp9,{children:e.permission})}),(0,i.jsx)(n.Td,{children:e.description})]},e.permission))})]})}},12627:function(e,t,s){"use strict";var i=s(24246),n=s(79283),a=s(34929);t.Z=e=>{let{selectedTaxonomies:t,showDisabled:s=!1,...r}=e,{getDataCategoryDisplayNameProps:o,getDataCategories:c}=(0,a.Z)(),l=(s?c():c().filter(e=>e.active)).filter(e=>!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,i.jsx)(n.l,{options:l,...r})}},79283:function(e,t,s){"use strict";s.d(t,{l:function(){return c}});var i=s(24246),n=s(62051),a=s(72707),r=s.n(a);let o=e=>{let{data:t}=e;return(0,i.jsxs)(n.jqI,{gap:12,title:"".concat(t.primaryName||"").concat(t.primaryName?": ":"").concat(t.name," - ").concat(t.description),children:[(0,i.jsxs)("div",{children:[(0,i.jsx)("strong",{children:t.primaryName||t.name}),t.primaryName&&": ".concat(t.name)]}),(0,i.jsx)("em",{children:t.description})]})},c=e=>{let{options:t,...s}=e,a=null==t?void 0:t.map(e=>({...e,className:r().option}));return(0,i.jsx)(n.WPr,{options:a,autoFocus:!0,variant:"borderless",optionRender:o,dropdownStyle:{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 l}});var i=s(24246),n=s(62051),a=s(34090),r=s(27378),o=s(46238),c=s(40324);let l=e=>{let{name:t,label:s,labelProps:l,tooltip:d,isRequired:u,layout:h="inline",helperText:m,...x}=e,[p,j,{setValue:g}]=(0,a.U$)(t),y=!!(j.touched&&j.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)=>{g(e),x.onChange&&x.onChange(e,t)};return"inline"===h?(0,i.jsx)(n.NIc,{isInvalid:y,isRequired:u,children:(0,i.jsxs)(n.rjZ,{templateColumns:s?"1fr 3fr":"1fr",children:[s?(0,i.jsx)(c.__,{htmlFor:x.id||t,...l,children:s}):null,(0,i.jsxs)(n.jqI,{align:"center",children:[(0,i.jsxs)(n.jqI,{vertical:!0,flex:1,className:"mr-2",children:[(0,i.jsx)(n.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,i.jsx)(n.Q6r,{children:m}),(0,i.jsx)(c.Bc,{isInvalid:y,message:j.error,fieldName:p.name})]}),(0,i.jsx)(o.b,{label:d,className:y?"mt-2 self-start":void 0})]})]})}):(0,i.jsx)(n.NIc,{isInvalid:y,isRequired:u,children:(0,i.jsxs)(n.gCW,{alignItems:"start",children:[(0,i.jsxs)(n.jqI,{align:"center",children:[s?(0,i.jsx)(c.__,{htmlFor:x.id||t,fontSize:"xs",my:0,mr:1,...l,children:s}):null,(0,i.jsx)(o.b,{label:d})]}),(0,i.jsx)(n.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,i.jsx)(n.Q6r,{style:{marginTop:0},children:m}),(0,i.jsx)(c.Bc,{isInvalid:y,message:j.error,fieldName:p.name})]})})}},71248:function(e,t,s){"use strict";s.d(t,{A:function(){return c}});var i=s(24246),n=s(34090),a=s(46782),r=s(97181),o=s(40324);let c=e=>{var t,s;let{name:c,fieldSchema:l,isRequired:d,layout:u="stacked",secretsSchema:h,validate:m}=e,x=(null===(s=l.allOf)||void 0===s?void 0:null===(t=s[0])||void 0===t?void 0:t.$ref)&&l.allOf[0].$ref!==a.j?null==h?void 0:h.definitions[l.allOf[0].$ref.replace("#/definitions/","")]:void 0,p=!!(null==x?void 0:x.enum)||l.options,j="boolean"===l.type,g="integer"===l.type,y=()=>{var e;if((null===(e=l.allOf)||void 0===e?void 0:e[0].$ref)===a.j)return"Enter dataset.collection.field"};return(0,i.jsx)(n.gN,{id:c,name:c,validate:m,children:e=>{let{field:t}=e;if(p){var s,n,a;let e=null!==(a=null==x?void 0:null===(s=x.enum)||void 0===s?void 0:s.map(e=>({label:e,value:e})))&&void 0!==a?a:null===(n=l.options)||void 0===n?void 0:n.map(e=>({label:e,value:e}));return(0,i.jsx)(r.d,{name:t.name,id:t.name,label:l.title,isRequired:d,tooltip:l.description,layout:u,options:e,mode:l.multiselect?"multiple":void 0},t.name)}return j?(0,i.jsx)(r.d,{name:t.name,id:t.name,label:l.title,isRequired:d,tooltip:l.description,layout:u,options:[{label:"False",value:"false"},{label:"True",value:"true"}]},t.name):g?(0,i.jsx)(o.aJ,{...t,label:l.title,tooltip:l.description,isRequired:d,placeholder:y(),variant:u}):(0,i.jsx)(o.j0,{...t,label:l.title,tooltip:l.description,isRequired:d,type:l.sensitive?"password":"text",placeholder:y(),autoComplete:"off",color:"gray.700",variant:u})}},c)}},46782:function(e,t,s){"use strict";s.d(t,{j:function(){return a},l:function(){return r}});var i=s(30454),n=s.n(i);let a="#/definitions/FidesDatasetReference",r=e=>{let t=(e,t,s)=>{let i;return(void 0===t||""===t||void 0===t)&&(i="".concat(e," is required")),s===a&&((null==t?void 0:t.includes("."))?t.split(".").length<3&&(i="Dataset reference must include at least three parts"):i="Dataset reference must be dot delimited"),i},s=t=>{var s,i;return(null==e?void 0:null===(s=e.required)||void 0===s?void 0:s.includes(t))||(null==e?void 0:null===(i=e.properties)||void 0===i?void 0:i[t])!==void 0&&"default"in e.properties[t]};return{validateField:t,isRequiredField:s,getFieldValidation:(e,i)=>{if(s(e)||"integer"===i.type)return e=>{var s;return t(i.title,e,null===(s=i.allOf)||void 0===s?void 0:s[0].$ref)}},preprocessValues:t=>{let s=n()(t);return e&&Object.keys(e.properties).forEach(t=>{var i,n;if((null===(i=e.properties[t].allOf)||void 0===i?void 0:i[0].$ref)===a){let e=null===(n=s.secrets[t])||void 0===n?void 0:n.split(".");e&&(s.secrets[t]={dataset:e.shift(),field:e.join("."),direction:"from"})}"WebsiteSchema"!==e.title||"URL"!==e.properties[t].title||s.secrets[t].startsWith("http://")||s.secrets[t].startsWith("https://")||(s.secrets[t]="https://".concat(s.secrets[t]))}),s}}}},14047:function(e,t,s){"use strict";s.d(t,{H:function(){return a},V:function(){return i.V}});var i=s(84306),n=s(812);let a=()=>{let{errorAlert:e}=(0,i.V)();return{handleError:t=>{let s="An unexpected error occurred. Please try again.";(0,n.Ot)(t)?s=t.data.detail:(0,n.tB)(t)&&(s=t.data.detail[0].msg),e(s)}}}},84306:function(e,t,s){"use strict";s.d(t,{V:function(){return a}});var i=s(24246),n=s(62051);let a=()=>{let e=(0,n.pmc)();return{errorAlert:(t,s,a)=>{let r={...a,position:(null==a?void 0:a.position)||"top",render:e=>{let{onClose:a}=e;return(0,i.jsxs)(n.bZj,{alignItems:"normal",status:"error","data-testid":"error-alert",children:[(0,i.jsx)(n.zMQ,{}),(0,i.jsxs)(n.xuv,{children:[s&&(0,i.jsx)(n.CdC,{children:s}),(0,i.jsx)(n.XaZ,{children:t})]}),(0,i.jsx)(n.PZ7,{onClick:a,position:"relative",right:0,size:"sm",top:-1})]})}};(null==a?void 0:a.id)&&e.isActive(a.id)?e.update(a.id,r):e(r)},successAlert:(t,s,a)=>{let r={...a,position:(null==a?void 0:a.position)||"top",render:e=>{let{onClose:a}=e;return(0,i.jsxs)(n.bZj,{alignItems:"normal",status:"success",variant:"subtle","data-testid":"success-alert",children:[(0,i.jsx)(n.zMQ,{}),(0,i.jsxs)(n.xuv,{children:[s&&(0,i.jsx)(n.CdC,{children:s}),(0,i.jsx)(n.XaZ,{children:t})]}),(0,i.jsx)(n.PZ7,{onClick:a,position:"relative",right:0,size:"sm",top:-1})]})}};(null==a?void 0:a.id)&&e.isActive(a.id)?e.update(a.id,r):e(r)}}}},34929:function(e,t,s){"use strict";var i=s(24246),n=s(64925),a=s.n(n),r=s(27378),o=s(16134),c=s(30002),l=s(28079),d=s(57072);let u=()=>{let{isLoading:e}=(0,l.fd)(),t=(0,o.C)(l.U3),{isLoading:s}=(0,d.MO)(),i=(0,o.C)(d.qb),{isLoading:n}=(0,c.te)();return{dataUses:t,dataSubjects:(0,o.C)(c.ZL),dataCategories:i,isLoading:e||s||n}};t.Z=()=>{let{dataUses:e,dataCategories:t,dataSubjects:s,isLoading:n}=u(),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,i=t(e);if(!i)return{};let n=t(o(e,s)),a=!!i.parent_key;return{name:i.name||void 0,primaryName:a&&(null==n?void 0:n.name)!==i.name&&(null==n?void 0:n.name)||void 0}},l=function(e,t){let s=arguments.length>2&&void 0!==arguments[2]?arguments[2]:1,{name:n,primaryName:a}=c(e,t,s);return n?a?(0,i.jsxs)(r.Fragment,{children:[(0,i.jsxs)("strong",{children:[a,":"]})," ",n]},e):(0,i.jsx)("strong",{children:n},e):e},d=t=>a()(e,{fides_key:t}),h=e=>a()(t,{fides_key:e}),m=e=>a()(s,{fides_key:e});return{getDataUses:()=>e,getDataUseByKey:d,getDataUseDisplayName:e=>l(e,d,1),getDataUseDisplayNameProps:e=>c(e,d,1),getDataCategories:()=>t,getDataCategoryByKey:h,getDataCategoryDisplayName:e=>l(e,h,2),getDataCategoryDisplayNameProps:e=>c(e,h,2),getDataSubjects:()=>s,getDataSubjectByKey:m,getDataSubjectDisplayName:e=>{let t=m(e);return t?t.name:e},getPrimaryKey:o,isLoading:n}}},8133:function(e,t,s){"use strict";var i=s(24246),n=s(62051);t.Z=e=>{let{title:t,children:s,isOpen:a,onClose:r,showCloseButton:o=!1,modalContentProps:c,footer:l,...d}=e;return(0,i.jsxs)(n.u_l,{isOpen:a,onClose:r,isCentered:!0,scrollBehavior:"inside",size:"xl",id:"add-modal",...d,children:[(0,i.jsx)(n.ZAr,{}),(0,i.jsxs)(n.hzk,{textAlign:"left",p:0,"data-testid":"add-modal-content",...c,children:[o&&(0,i.jsx)(n.olH,{}),(0,i.jsx)(n.xBx,{p:0,children:(0,i.jsx)(n.xuv,{backgroundColor:"gray.50",px:6,py:4,border:"1px",borderColor:"gray.200",borderTopRadius:6,display:"flex",justifyContent:"space-between",alignItems:"center",children:(0,i.jsx)(n.X6q,{as:"h3",size:"sm",children:t})})}),(0,i.jsx)(n.fef,{pb:4,overflow:"auto",children:s}),l&&(0,i.jsx)(n.mzw,{children:l})]})]})}},90980:function(e,t,s){"use strict";s.d(t,{R:function(){return c}});var i=s(24246),n=s(62051),a=s(79894),r=s.n(a),o=s(63662);let c=e=>{let{onClick:t,...s}=e;return(0,i.jsxs)(n.kCb,{alignItems:"center",mt:-4,mb:3,onClick:t,cursor:"pointer",...s,children:[(0,i.jsx)(n.wpx,{"aria-label":"Back",icon:(0,i.jsx)(n.Rpv,{}),className:"mr-2",size:"small"}),(0,i.jsx)(n.xvT,{as:"a",fontSize:"sm",fontWeight:"500",children:"Back"})]})};t.Z=e=>{let{backPath:t,...s}=e,a=(0,o.useRouter)();return(0,i.jsxs)(n.kCb,{alignItems:"center",mb:6,...s,children:[(0,i.jsx)(n.wpx,{onClick:()=>a.push(t),"aria-label":"Back",icon:(0,i.jsx)(n.Rpv,{}),className:"mr-2",size:"small"}),(0,i.jsx)(n.xvT,{as:r(),href:t,fontSize:"sm",fontWeight:"500",children:"Back"})]})}},70788:function(e,t,s){"use strict";s.d(t,{m:function(){return l}});var i=s(24246),n=s(62051),a=s(79894),r=s.n(a),o=s(27378);let{Text:c}=n.AntTypography,l=e=>{let{items:t,...s}=e,a=(0,o.useMemo)(()=>null==t?void 0:t.map((e,s)=>{let a=s===t.length-1,o={...e},l=o.onClick&&!o.href;return("string"==typeof o.title&&(o.title=(0,i.jsx)(c,{style:{color:"inherit",maxWidth:a?void 0:400},ellipsis:!a,children:o.title})),l)?o.title=(0,i.jsx)(n.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,i.jsxs)(i.Fragment,{children:[(0,i.jsx)("span",{className:"anticon align-text-bottom",children:o.icon}),o.title]})),o.href&&o.title&&(o.title=(0,i.jsx)(r(),{href:o.href,className:"ant-breadcrumb-link",children:o.title}),delete o.href)),o}),[t]);return(0,i.jsx)(n.zrq,{items:a,...s})}},41337:function(e,t,s){"use strict";var i=s(24246),n=s(62051);s(27378);var a=s(88337),r=s(16394),o=s(14746);let c=o.Ny+o.iW.get(a.R.WEBSITE),l=e=>void 0!==e.connection_type,d=e=>void 0!==e.encoded_icon,u=e=>(null==e?void 0:e.connection_type)===a.R.WEBSITE,h=e=>(null==e?void 0:e.connection_type)===a.R.SAAS;t.Z=e=>{let{data:t,...s}=e;return(0,i.jsx)(n.Eep,{boxSize:"32px",objectFit:"cover",src:(()=>{var e,s;let i;if(d(t)&&t.encoded_icon)return"data:image/svg+xml;base64,".concat(t.encoded_icon);if(u(t)){let s=null===(e=t.secrets)||void 0===e?void 0:e.url;if(!s)return c;let i=(0,r.ge)(s);return(0,r.tl)(i,100)}if(l(t)){if(h(t)&&(null===(s=t.saas_config)||void 0===s?void 0:s.type)){let e=t.saas_config.type,s=o.LN.get(e);return s?o.Ny+s:o.Ny+o.iW.get(a.R.SAAS)}i=[...o.iW].find(e=>{let[s]=e;return t.connection_type.toString()===s.toString()})}else if(d(t)){let{identifier:e}=t;i=[...o.iW].find(t=>{let[s]=t;return s.toLowerCase()===e.toLowerCase()})}return i?o.Ny+i[1]:o.VD})(),fallbackSrc:u(t)?c:o.VD,alt:(()=>{if(l(t)){var e;return null!==(e=t.name)&&void 0!==e?e:t.key}return d(t)?t.human_readable:t})(),...s})}},15872:function(e,t,s){"use strict";var i=s(24246),n=s(62051),a=s(86677);s(27378);var r=s(77830),o=s(14207);t.Z=e=>{let{connection_key:t,showMenu:s}=e,{isOpen:c,onOpen:l,onClose:d}=(0,n.qY0)(),[u,h]=(0,o.R5)(),m=(0,a.useRouter)(),x=()=>{h.isLoading||d()};return(0,i.jsxs)(i.Fragment,{children:[s&&(0,i.jsx)(n.sNh,{_focus:{color:"complimentary.500",bg:"gray.100"},onClick:l,children:(0,i.jsx)(n.xvT,{fontSize:"sm",children:"Delete"})}),!s&&(0,i.jsx)(n.wpx,{onClick:l,children:"Delete integration"}),(0,i.jsxs)(n.u_l,{isCentered:!0,isOpen:c,onClose:x,children:[(0,i.jsx)(n.ZAr,{}),(0,i.jsxs)(n.hzk,{children:[(0,i.jsx)(n.xBx,{children:"Delete integration"}),(0,i.jsx)(n.olH,{}),(0,i.jsx)(n.fef,{pb:6,children:(0,i.jsx)(n.Kqy,{direction:"column",spacing:"15px",children:(0,i.jsx)(n.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,i.jsxs)(n.mzw,{className:"flex gap-4",children:[(0,i.jsx)(n.wpx,{onClick:x,className:"w-1/2",children:"Cancel"}),(0,i.jsx)(n.wpx,{onClick:()=>{t&&(u(t),s||m.push(r.KH))},loading:h.isLoading,type:"primary",className:"w-1/2",children:"Delete integration"})]})]})]})]})}},19812:function(e,t,s){"use strict";s.d(t,{t:function(){return o}});var i=s(14047),n=s(14207),a=s(27378),r=s(41966);let o=e=>{var t,s,o;let{connectionConfig:c}=e,[l]=(0,n.S6)(),{data:d}=(0,n.Eg)(null!==(s=null==c?void 0:c.key)&&void 0!==s?s:""),u=null!==(o=null==d?void 0:null===(t=d.items)||void 0===t?void 0:t.map(e=>e.fides_key))&&void 0!==o?o:[],h=u.map(e=>({label:e,value:e})),{data:m}=(0,r.LH)({onlyUnlinkedDatasets:!0}),x=(0,a.useMemo)(()=>{var e;return null!==(e=null==m?void 0:m.map(e=>({value:e.fides_key,label:"".concat(e.name," (").concat(e.fides_key,")")||0})))&&void 0!==e?e:[]},[m]),{errorAlert:p,successAlert:j}=(0,i.V)();return{dropdownOptions:[...h,...x],initialDatasets:u,patchConnectionDatasetConfig:async function(e,t){var s,i,n;let{showSuccessAlert:a=!0}=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},r=null!==(n=null===(s=e.dataset)||void 0===s?void 0:s.map(e=>({fides_key:e,ctl_dataset_fides_key:e})))&&void 0!==n?n:[],o=await l({connection_key:t,dataset_pairs:r}).unwrap();(null===(i=o.failed)||void 0===i?void 0:i.length)>0?p(o.failed[0].message):a&&j("Dataset successfully updated!")}}}},33335:function(e,t,s){"use strict";s.d(t,{E:function(){return i}});let i=e=>e.toLowerCase().replace(/[ .]/g,"_").replace(/[^a-zA-Z0-9_<>-]/g,"")},45216:function(e,t,s){"use strict";var i=s(62051),n=s(812),a=s(16394),r=s(14207);t.Z=e=>{let[t,{data:s,fulfilledTimeStamp:o,isLoading:c,isFetching:l}]=(0,r.h2)(),d=(0,i.pmc)();return{testConnection:async()=>{var s,i,a,r;if(!e)return;let o=await t(e.key);if(o.isError)d({status:"error",description:(0,n.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")d({status:"success",description:"Connected successfully"});else if((null===(i=o.data)||void 0===i?void 0:i.test_status)==="failed"){let e="Connection test failed.";(null===(a=o.data)||void 0===a?void 0:a.failure_reason)&&(e+=" ".concat(null===(r=o.data)||void 0===r?void 0:r.failure_reason)),d({status:"warning",description:e})}},isLoading:c||l,testData:{timestamp:o?(0,a.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 i=s(24246),n=s(62051),a=s(16394);t.Z=e=>{let{testData:t,connectionOption:s}=e;if((null==s?void 0:s.authorization_required)&&!t.authorized)return(0,i.jsx)(n.kCb,{align:"center","data-testid":"connection-status",children:(0,i.jsx)(n.xvT,{color:"error-text.900",children:"Authorization required"})});if(!t.timestamp)return(0,i.jsx)(n.xvT,{"data-testid":"connection-status",children:"Connection not tested"});let r=(0,a.p6)(t.timestamp);return t.succeeded?(0,i.jsxs)(n.kCb,{color:"success-text.900",align:"center","data-testid":"connection-status",children:[(0,i.jsx)(n.rE2,{mr:2,boxSize:4}),(0,i.jsxs)(n.xvT,{children:["Last connected ",r]})]}):(0,i.jsxs)(n.kCb,{color:"error-text.900",align:"center","data-testid":"connection-status",children:[(0,i.jsx)(n.iid,{mr:2,boxSize:4}),(0,i.jsxs)(n.xvT,{children:["Last connection failed ",r]})]})}},75595:function(e,t,s){"use strict";var i=s(24246),n=s(62051),a=s(41337),r=s(15872),o=s(45216),c=s(52352),l=s(41553),d=s(93633),u=s(80388),h=s(64176);t.Z=e=>{var t,s;let{integration:m,showTestNotice:x,otherButtons:p,showDeleteButton:j,configureButtonLabel:g="Configure",onConfigureClick:y}=e,{testConnection:v,isLoading:f,testData:C}=(0,o.Z)(m),S=(0,c.ZP)(null==m?void 0:m.connection_type,null==m?void 0:null===(t=m.saas_config)||void 0===t?void 0:t.type),A=null==m?void 0:null===(s=m.saas_config)||void 0===s?void 0:s.type,b=(0,h.Z)(null==m?void 0:m.connection_type,A&&Object.values(u.m).includes(A)?A:void 0),{handleAuthorize:D,needsAuthorization:R}=(0,d.z)({connection:m,connectionOption:b,testData:C});return(0,i.jsxs)(n.xuv,{borderWidth:1,borderColor:"gray.200",borderRadius:"lg",overflow:"hidden",padding:"12px",marginBottom:"24px","data-testid":"integration-info-".concat(null==m?void 0:m.key),children:[(0,i.jsxs)(n.kCb,{children:[(0,i.jsx)(a.Z,{data:null!=m?m:"",boxSize:"50px"}),(0,i.jsxs)(n.kCb,{direction:"column",flexGrow:1,marginLeft:"16px",children:[(0,i.jsx)(n.xvT,{color:"gray.700",fontWeight:"semibold",children:(null==m?void 0:m.name)||"(No name)"}),x?(0,i.jsx)(l.Z,{testData:C,connectionOption:b}):(0,i.jsx)(n.xvT,{color:"gray.700",fontSize:"sm",fontWeight:"semibold",mt:1,children:S.category})]}),(0,i.jsxs)("div",{className:"flex gap-4",children:[j&&m&&(0,i.jsx)(r.Z,{showMenu:!1,connection_key:m.key}),x&&R&&(0,i.jsx)(n.wpx,{onClick:D,"data-testid":"authorize-integration-btn",children:"Authorize integration"}),x&&!R&&(0,i.jsx)(n.wpx,{onClick:v,loading:f,"data-testid":"test-connection-btn",children:"Test connection"}),p,y&&(0,i.jsx)(n.wpx,{onClick:y,"data-testid":"configure-btn",children:g})]})]}),(0,i.jsx)(n.Eq9,{marginTop:"16px",children:S.tags.map(e=>(0,i.jsx)(n.j8w,{children:e},e))})]})}},29379:function(e,t,s){"use strict";var i,n;s.d(t,{j:function(){return i}}),(n=i||(i={})).DATA_DISCOVERY="data_discovery",n.DATA_SYNC="data_sync",n.TASKS="tasks",n.WITHOUT_CONNECTION="without_connection"},40774:function(e,t,s){"use strict";s.d(t,{Z:function(){return S}});var i,n,a=s(24246),r=s(62051),o=s(27378),c=s(60018),l=s(46381),d=s(12627),u=s(812),h=s(46238),m=s(90980),x=s(46628),p=s(11013),j=s(31883);let g={rules:[{regex:void 0,dataCategory:void 0}]};var y=e=>{var t,s,i;let{config:n,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,j.D4)(e)?v((0,x.Vo)((0,u.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(n?await S({...t,id:n.id}):await f(t),!n)},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:i}=(0,l.parse)(s,{skipEmptyLines:!0,header:!1}),n=i.map(e=>{let[t,s]=e;return{regex:t,dataCategory:s}});y.setFieldValue("rules",n),v((0,x.t5)("CSV patterns imported successfully"))}catch(e){v((0,x.Vo)("Failed to parse CSV file"))}},s.readAsText(t)};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(m.R,{onClick:o,className:"pt-3"}),(0,a.jsx)(c.ZT.Title,{level:2,children:n?"Edit ".concat(n.name):"Create new configuration"}),(0,a.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,a.jsxs)(r.PPS,{name:"monitor-template",layout:"vertical",form:y,onFinish:R,className:"mt-4",initialValues:n?{...n,rules:null!==(i=null==n?void 0:null===(s=n.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!==i?i:[]}:g,validateTrigger:["onBlur","onChange"],children:[(0,a.jsx)(r.bue,{children:(0,a.jsxs)(r.JGx,{span:24,children:[(0,a.jsx)(r.PPS.Item,{label:"Configuration name",name:"name",rules:[{required:!0,message:"Config name is required"}],"data-testid":"form-item-name",children:(0,a.jsx)(r.uFc,{autoFocus:!0,"data-testid":"input-name"})}),(0,a.jsx)(r.PPS.Item,{label:"Description",name:"description","data-testid":"form-item-description",children:(0,a.jsx)(r.uFc.TextArea,{"data-testid":"input-description"})})]})}),(0,a.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:i,remove:l}=t,{errors:u}=s;return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsxs)(r.jqI,{justify:"space-between",children:[(0,a.jsx)(c.ZT.Title,{level:3,className:"pb-5",children:"Regex patterns"}),!n&&(0,a.jsxs)(r.jqI,{gap:8,align:"center",children:[(0,a.jsx)(h.b,{label:"Upload a CSV to map regex patterns to data categories. Format: regex,data_category",placement:"left"}),(0,a.jsx)(r.pMK,{accept:".csv",showUploadList:!1,beforeUpload:()=>!1,onChange:w,children:(0,a.jsx)(r.wpx,{icon:(0,a.jsx)(r.PJP.gqx,{}),iconPosition:"end",size:"small","data-testid":"upload-csv-btn",children:"Upload CSV"})})]})]}),e.map((t,s)=>{let{key:n,name:o,...c}=t;return(0,a.jsxs)(r.bue,{align:"middle",children:[(0,a.jsx)(r.JGx,{span:11,children:(0,a.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,a.jsx)(r.uFc,{placeholder:"Enter a regular expression","data-testid":"input-rules.".concat(o,".regex")})})}),(0,a.jsx)(r.JGx,{span:1,className:"flex justify-center pt-[5px]",children:"->"}),(0,a.jsx)(r.JGx,{span:11,className:"pr-2",children:(0,a.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,a.jsx)(d.Z,{selectedTaxonomies:[],variant:"outlined",placeholder:"Select a data category",autoFocus:!1,allowClear:!0,"data-testid":"input-rules.".concat(o,".dataCategory")})})}),(0,a.jsx)(r.JGx,{span:1,className:"mt-[7.25px]",children:s===e.length-1?(0,a.jsx)(r.wpx,{onClick:()=>i(),icon:(0,a.jsx)(r.PJP.mm_,{}),"aria-label":"Add new rule","data-testid":"add-rule-btn"}):(0,a.jsx)(r.wpx,{onClick:()=>l(o),icon:(0,a.jsx)(r.PJP.ZNm,{}),"aria-label":"Remove rule","data-testid":"remove-rule-".concat(o)})})]},n)}),(0,a.jsx)(r.PPS.ErrorList,{errors:u}),(0,a.jsx)(r.PPS.Item,{label:null,className:"mb-0",children:(0,a.jsxs)(r.jqI,{justify:"end",gap:8,children:[(0,a.jsx)(r.wpx,{onClick:o,children:"Cancel"}),(0,a.jsx)(r.wpx,{type:"primary",htmlType:"submit",loading:C||A,"data-testid":"save-btn",children:"Save"})]})})]})}})]})]})},v=s(14481),f=e=>{let{onEditClick:t}=e,[s]=(0,p.m5)(),i=(0,r.pmc)(),n=async e=>{let t=await s({id:e});(0,j.D4)(t)?i((0,x.Vo)((0,u.e$)(t.error,"A problem occurred deleting this config"))):i((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,a.jsxs)(r.jqI,{className:"gap-2",children:[(0,a.jsx)(r.wpx,{size:"small",onClick:()=>t(s),icon:(0,a.jsx)(r.PJP.I8b,{}),"data-testid":"edit-btn"}),(0,a.jsx)(r.wpx,{size:"small",onClick:()=>n(s.id),icon:(0,a.jsx)(r.PJP.ZNm,{})})]})}]},C=e=>{let{onNewClick:t,onRowClick:s}=e,{onPreviousPageClick:i,isPreviousPageDisabled:n,onNextPageClick:o,isNextPageDisabled:l,pageSize:d,setPageSize:u,PAGE_SIZES:h,startRange:m,endRange:x,pageIndex:j}=(0,v.oi)(),{data:g,isLoading:y,isFetching:C}=(0,p.eV)({page:j,size:d}),S=f({onEditClick:s});return y||C?(0,a.jsx)(r.ZJQ,{size:"large",className:"flex h-full items-center justify-center"}):(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(c.ZT.Title,{level:2,children:"Shared monitor configurations"}),(0,a.jsx)(c.ZT.Paragraph,{className:"mb-2 mt-4",children:"Shared monitor configurations can be applied to monitors to customize classification."}),(0,a.jsx)(r.wpx,{type:"primary",onClick:t,"data-testid":"create-new-btn",className:"mb-3",children:"Create new"}),(0,a.jsx)(r.V5H,{columns:S,dataSource:null==g?void 0:g.items,size:"small",pagination:!1,onRow:e=>({"data-testid":"config-".concat(e.id)}),locale:{emptyText:(0,a.jsx)(c.ZT.Paragraph,{className:"py-8",children:"No shared monitor configs found"})}}),(0,a.jsx)(r.jqI,{justify:"space-between",className:"mt-4",children:(0,a.jsx)(v.s8,{totalRows:(null==g?void 0:g.total)||0,pageSizes:h,setPageSize:u,onPreviousPageClick:i,isPreviousPageDisabled:n,onNextPageClick:o,isNextPageDisabled:l,startRange:m,endRange:x})})]})};(i=n||(n={})).MAIN_VIEW="main",i.FORM_VIEW="form";var S=()=>{let[e,t]=(0,o.useState)(!1),[s,i]=(0,o.useState)(void 0),[n,c]=(0,o.useState)("main"),l=()=>{c("main"),i(void 0)};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(r.wpx,{icon:(0,a.jsx)(r.PJP.Zrf,{}),iconPosition:"end",onClick:()=>t(!0),"data-testid":"configurations-btn",children:"Shared configs"}),(0,a.jsxs)(r.$zI,{open:e,onCancel:()=>{l(),t(!1)},destroyOnClose:!0,centered:!0,width:768,footer:null,children:["form"===n&&(0,a.jsx)(y,{config:s,onBackClick:l}),"main"===n&&(0,a.jsx)(C,{onNewClick:()=>c("form"),onRowClick:e=>{i(e),c("form"),t(!0)}})]})]})}},15987:function(e,t,s){"use strict";var i=s(24246),n=s(62051),a=s(34090),r=s(90104),o=s.n(r),c=s(92465),l=s.n(c),d=s(25389),u=s.n(d),h=s(15539),m=s.n(h),x=s(27378),p=s(18225),j=s(97181),g=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(46420),_=s(31883);let E=e=>{let{dirty:t,isValid:s,submitForm:i,loading:n,onFormStateChange:a}=e;return(0,x.useEffect)(()=>{a&&a({dirty:t,isValid:s,submitForm:i,loading:n})},[t,s,i,n,a]),null};t.Z=e=>{var t,s;let{connection:r,connectionOption:c,onCancel:d,description:h,onFormStateChange:x}=e,[T,{isLoading:H}]=(0,A.Pp)(),[k,{isLoading:F}]=(0,A.pH)(),[I,{isLoading:B}]=(0,R.qd)(),[O]=(0,A.pL)(),L=c.identifier!==w.Rj.MANUAL_WEBHOOK,{data:P,isLoading:N}=(0,C.n3)(c.identifier,{skip:!L}),{data:M}=(0,R.K3)(),U=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:q}=(0,S.LH)({minimal:!0,connection_type:w.Rj.BIGQUERY}),z=null==q?void 0:q.map(e=>{var t;return{label:null!==(t=e.name)&&void 0!==t?t:e.fides_key,value:e.fides_key}}),{patchConnectionDatasetConfig:Z,initialDatasets:Q}=(0,b.t)({connectionConfig:r}),{getFieldValidation:W,preprocessValues:G}=(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:"",...L&&{secrets:u()(null==P?void 0:P.properties,(e,t)=>{var s,i,n;return null!==(n=null!==(i=null==r?void 0:null===(s=r.secrets)||void 0===s?void 0:s[t])&&void 0!==i?i:e.default)&&void 0!==n?n:""})},dataset:Q},V=(0,n.pmc)(),Y=!!r,K=c.type===w.Zi.SAAS,J=e=>m()(u()(e,(e,t)=>{var s,i;return(null!==(i=null==r?void 0:null===(s=r.secrets)||void 0===s?void 0:s[t])&&void 0!==i?i:"")===e?void 0:e}),l()),$=async e=>{var t;let s;let i=G(e),n=L?J(i.secrets):{},a=Y?{...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:i.secrets,dataset:e.dataset};if(s=e.system_fides_key?await I({systemFidesKey:e.system_fides_key,connectionConfigs:[a]}):K&&!Y?await O({...a,instance_key:(0,D.E)(e.name),saas_connector_type:c.identifier,secrets:e.secrets||{}}):await k(a),(0,_.D4)(s)){V({status:"error",description:(0,f.e$)(s.error,"A problem occurred while ".concat(Y?"updating":"creating"," this integration. Please try again."))});return}if(!L||!e.secrets){V({status:"success",description:"Integration ".concat(Y?"updated":"created"," successfully")}),d();return}if(!o()(n)){let e=await T({connection_key:a.key,secrets:n});if((0,_.D4)(e)){V({status:"error",description:(0,f.e$)(e.error,"An error occurred while ".concat(Y?"updating":"creating"," this integration's secret. Please try again."))});return}}V({status:"success",description:"Integration secret ".concat(Y?"updated":"created"," successfully")}),d(),a&&e.dataset&&c.identifier===w.Rj.DATAHUB&&await Z(e,a.key,{showSuccessAlert:!1})},ee=H||F||B;if(N)return(0,i.jsx)(p.Z,{});let et=e=>Object.entries(e.properties).map(t=>{let[s,n]=t,a="secrets.".concat(s);return(0,i.jsx)(g.A,{name:a,fieldSchema:n,isRequired:e.required.includes(s),secretsSchema:e,validate:W(s,n)},a)});return(0,i.jsxs)(i.Fragment,{children:[h&&(0,i.jsx)(n.xuv,{padding:"20px 24px",backgroundColor:"gray.50",borderRadius:"md",border:"1px solid",borderColor:"gray.200",fontSize:"sm",marginTop:"16px",children:h}),(0,i.jsx)(a.J9,{initialValues:X,enableReinitialize:!0,onSubmit:$,children:e=>{let{dirty:t,isValid:s,submitForm:r}=e;return(0,i.jsxs)(a.l0,{children:[(0,i.jsxs)(n.gCW,{alignItems:"start",spacing:6,mt:4,children:[(0,i.jsx)(y.j0,{id:"name",name:"name",label:"Name",variant:"stacked",isRequired:!0}),(0,i.jsx)(y.j0,{id:"description",name:"description",label:"Description",variant:"stacked"}),L&&P&&et(P),!Y&&!K&&(0,i.jsx)(j.d,{id:"system_fides_key",name:"system_fides_key",options:null!=U?U:[],label:"System",tooltip:"The system to associate with the integration",layout:"stacked"}),c.identifier===w.Rj.DATAHUB&&(0,i.jsx)(j.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,i.jsx)(E,{dirty:t,isValid:s,submitForm:r,loading:ee,onFormStateChange:x})]})}})]})}},52352:function(e,t,s){"use strict";s.d(t,{FO:function(){return M},jq:function(){return U},ZP:function(){return z}}),(i=n||(n={})).DATA_CATALOG="Data Catalog",i.DATA_WAREHOUSE="Data Warehouse",i.DATABASE="Database",i.IDENTITY_PROVIDER="Identity Provider",i.WEBSITE="Website",i.CRM="CRM",i.MANUAL="Manual";var i,n,a=s(24246),r=s(62051),o=s(79789),c=e=>{let{children:t}=e,{isOpen:s,onToggle:i}=(0,r.qY0)();return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(r.UO1,{in:s,children:t}),(0,a.jsx)(r.xvT,{fontSize:"sm",cursor:"pointer",textDecoration:"underline",onClick:i,children:s?"Show less":"Show more"})]})},l=s(29379),d=s(46420);let u={name:"Google BigQuery",key:"bq_placeholder",connection_type:d.Rj.BIGQUERY,access:d.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."}],m=[{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."}],x={placeholder:u,category:n.DATA_WAREHOUSE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Overview"}),(0,a.jsx)(o.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)(c,{children:[(0,a.jsx)(o.cB,{text:"Categories"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"Data Warehouse"}),(0,a.jsx)(r.HCh,{children:"Storage system"}),(0,a.jsx)(r.HCh,{children:"Cloud provider"}),(0,a.jsx)(r.HCh,{children:"Data detection"}),(0,a.jsx)(r.HCh,{children:"Data discovery"}),(0,a.jsx)(r.HCh,{children:"DSR automation"}),(0,a.jsx)(r.HCh,{children:"Consent orchestration"})]}),(0,a.jsx)(o.cB,{text:"Permissions"}),(0,a.jsx)(o.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)(o.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)(o.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)(o.cB,{text:"Permissions list"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"bigquery.jobs.create"}),(0,a.jsx)(r.HCh,{children:"bigquery.jobs.list"}),(0,a.jsx)(r.HCh,{children:"bigquery.routines.get"}),(0,a.jsx)(r.HCh,{children:"bigquery.routines.list"}),(0,a.jsx)(r.HCh,{children:"bigquery.datasets.get"}),(0,a.jsx)(r.HCh,{children:"bigquery.tables.get"}),(0,a.jsx)(r.HCh,{children:"bigquery.tables.getData"}),(0,a.jsx)(r.HCh,{children:"bigquery.tables.list"}),(0,a.jsx)(r.HCh,{children:"bigquery.tables.updateData"}),(0,a.jsx)(r.HCh,{children:"resourcemanager.projects.get"})]})]})]}),{}),instructions:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Configuring a Fides -> BigQuery Integration"}),(0,a.jsx)(o.cB,{text:"Step 1: Create a Fides project"}),(0,a.jsxs)(o.XU,{children:["Create a Fides Project using"," ",(0,a.jsx)(o.Hn,{href:"https://cloud.google.com/resource-manager/docs/creating-managing-projects#creating_a_project",children:"BigQuery's project creation guide"}),"."]}),(0,a.jsx)(o.cB,{text:"Step 2: Create a Fides role in GCP"}),(0,a.jsxs)(o.vQ,{children:[(0,a.jsxs)(r.HCh,{children:["Create a custom role for Fides using BigQuery's"," ",(0,a.jsx)(o.Hn,{href:"https://cloud.google.com/iam/docs/creating-custom-roles#creating_a_custom_role",children:"roles guide"}),"."]}),(0,a.jsx)(r.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)(c,{children:[(0,a.jsx)(o.cB,{text:"Step 3: Assign permissions to the Fides project"}),(0,a.jsx)(o.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)(o.aG,{data:h}),(0,a.jsx)(o.cB,{text:"Step 4: Assign permissions to any project you'd like Fides to monitor"}),(0,a.jsx)(o.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)(o.aG,{data:m}),(0,a.jsx)(o.cB,{text:"Step 5: Create a Fides service account in the Fides Project"}),(0,a.jsxs)(o.vQ,{children:[(0,a.jsxs)(r.HCh,{children:["Create a service account for Fides using BigQuery's"," ",(0,a.jsx)(o.Hn,{href:"https://cloud.google.com/iam/docs/service-accounts-create",children:"service account guide"}),"."]}),(0,a.jsx)(r.HCh,{children:"Assign the previously created role to this service account."}),(0,a.jsxs)(r.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)(o.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)(o.cB,{text:"Step 6: Use the JSON key to authenticate your integration"}),(0,a.jsx)(o.XU,{children:"Provide the JSON key to your Fides instance to securely connect Fides."})]})]}),{}),tags:["DSR Automation","Discovery","Detection"],enabledFeatures:[l.j.DATA_DISCOVERY]},p={name:"Datahub",key:"datahub_placeholder",connection_type:d.Rj.DATAHUB,access:d.uv.READ,created_at:""},j=(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:p,category:n.DATA_CATALOG,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Overview"}),(0,a.jsx)(o.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)(c,{children:[(0,a.jsx)(o.cB,{text:"Categories"}),(0,a.jsx)(o.Z5,{children:(0,a.jsx)(r.HCh,{children:"Data Catalog"})}),(0,a.jsx)(o.cB,{text:"Permissions"}),(0,a.jsx)(o.Z5,{children:(0,a.jsx)(r.HCh,{children:"The related user to the access token must have at least the Editor role on DataHub."})})]})]}),{}),tags:["Sync"],description:j,enabledFeatures:[l.j.DATA_SYNC]},y={name:"DynamoDB",key:"dynamo_placeholder",connection_type:d.Rj.DYNAMODB,access:d.uv.READ,created_at:""},v=[{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."}],f={placeholder:y,category:n.DATABASE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Overview"}),(0,a.jsx)(o.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)(c,{children:[(0,a.jsx)(o.cB,{text:"Categories"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"NoSQL database"}),(0,a.jsx)(r.HCh,{children:"Storage system"}),(0,a.jsx)(r.HCh,{children:"Cloud provider"}),(0,a.jsx)(r.HCh,{children:"Data detection"}),(0,a.jsx)(r.HCh,{children:"Data discovery"})]}),(0,a.jsx)(o.cB,{text:"Permissions and Policies"}),(0,a.jsxs)(o.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)(r.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)(r.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)(o.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)(o.cB,{text:"Policy List"}),(0,a.jsx)(o.XU,{children:"The following AWS-managed policies provide the necessary permissions for Fides:"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"AmazonDynamoDBReadOnlyAccess"}),(0,a.jsx)(r.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)(o.cB,{text:"Configuring a Fides -> DynamoDB Integration"}),(0,a.jsx)(o.cB,{text:"Step 1: Create an IAM user in AWS"}),(0,a.jsxs)(o.XU,{children:["Create an IAM user for Fides' DynamoDB access following the"," ",(0,a.jsx)(o.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)(c,{children:[(0,a.jsx)(o.cB,{text:"Step 2: Assign policies to the IAM user"}),(0,a.jsx)(o.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)(o.aG,{data:v}),(0,a.jsx)(o.cB,{text:"Step 3: Create an access key for the IAM user"}),(0,a.jsxs)(o.vQ,{children:[(0,a.jsxs)(r.HCh,{children:["Create an access key for the IAM user under"," ",(0,a.jsx)("strong",{children:"Security credentials"})]}),(0,a.jsx)(r.HCh,{children:"Select the Other use case"}),(0,a.jsx)(r.HCh,{children:"Copy the Access Key ID and Secret Access Key"})]}),(0,a.jsx)(o.cB,{text:"Use the Credentials to Authenticate Your Integration"}),(0,a.jsx)(o.XU,{children:"Provide the credentials to your Fides instance to securely connect Fides."})]})]}),{}),tags:["DSR Automation","Discovery","Detection"],enabledFeatures:[l.j.DATA_DISCOVERY]},C={placeholder:{name:"Cloud SQL - MySQL",key:"google_cloud_sql_for_mysql_placeholder",connection_type:d.Rj.GOOGLE_CLOUD_SQL_MYSQL,access:d.uv.READ,created_at:""},category:n.DATABASE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Overview"}),(0,a.jsx)(o.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)(c,{children:[(0,a.jsx)(o.cB,{text:"Categories"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"Database"}),(0,a.jsx)(r.HCh,{children:"SQL database"}),(0,a.jsx)(r.HCh,{children:"Storage system"}),(0,a.jsx)(r.HCh,{children:"Data detection"}),(0,a.jsx)(r.HCh,{children:"Data discovery"}),(0,a.jsx)(r.HCh,{children:"DSR automation"})]}),(0,a.jsx)(o.cB,{text:"Permissions"}),(0,a.jsx)(o.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)(o.cB,{text:"Permissions list"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"GRANT SELECT"}),(0,a.jsx)(r.HCh,{children:"GRANT UPDATE"}),(0,a.jsx)(r.HCh,{children:"GRANT DELETE"})]})]})]}),{}),tags:["Discovery","Detection"],enabledFeatures:[l.j.DATA_DISCOVERY]},S={placeholder:{name:"Cloud SQL - Postgres",key:"google_cloud_sql_for_postgres_placeholder",connection_type:d.Rj.GOOGLE_CLOUD_SQL_POSTGRES,access:d.uv.READ,created_at:""},category:n.DATABASE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Overview"}),(0,a.jsx)(o.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)(c,{children:[(0,a.jsx)(o.cB,{text:"Categories"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"Database"}),(0,a.jsx)(r.HCh,{children:"SQL database"}),(0,a.jsx)(r.HCh,{children:"Storage system"}),(0,a.jsx)(r.HCh,{children:"Data detection"}),(0,a.jsx)(r.HCh,{children:"Data discovery"}),(0,a.jsx)(r.HCh,{children:"DSR automation"})]}),(0,a.jsx)(o.cB,{text:"Permissions"}),(0,a.jsx)(o.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)(o.XU,{children:"The following GCP service account permissions are needed when setting up Google Cloud SQL for Postgres."}),(0,a.jsx)(o.cB,{text:"Permissions list"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"cloudsql.instances.connect"}),(0,a.jsx)(r.HCh,{children:"cloudsql.instances.get"}),(0,a.jsx)(r.HCh,{children:"cloudsql.instances.login"})]})]})]}),{}),tags:["Discovery","Detection"],enabledFeatures:[l.j.DATA_DISCOVERY]},A={placeholder:{name:"Manual",key:"manual_placeholder",connection_type:d.Rj.MANUAL_WEBHOOK,access:d.uv.READ,created_at:""},category:n.MANUAL,tags:["DSR","Manual tasks"],overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Overview"}),(0,a.jsx)(o.XU,{children:"A Manual Integration provides a simple way for data to be manually uploaded for access and erasure requests."}),(0,a.jsxs)(o.XU,{children:["If you have manual integrations defined, privacy request execution will exit early and remain in a state of ",(0,a.jsx)("em",{children:"Requires input"}),". Once data has been manually uploaded for all the manual integrations, then the privacy request can be resumed. Data uploaded for manual integrations is passed on directly to the data subject alongside the data package."]})]}),{}),enabledFeatures:[l.j.TASKS,l.j.WITHOUT_CONNECTION]},b={placeholder:{name:"Microsoft SQL Server",key:"microsoft_sql_server_placeholder",connection_type:d.Rj.MSSQL,access:d.uv.READ,created_at:""},category:n.DATABASE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Overview"}),(0,a.jsx)(o.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)(c,{children:[(0,a.jsx)(o.cB,{text:"Categories"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"Database"}),(0,a.jsx)(r.HCh,{children:"SQL database"}),(0,a.jsx)(r.HCh,{children:"Storage system"}),(0,a.jsx)(r.HCh,{children:"Data detection"}),(0,a.jsx)(r.HCh,{children:"Data discovery"})]}),(0,a.jsx)(o.cB,{text:"Permissions"}),(0,a.jsx)(o.XU,{children:"For detecting databases, Fides requires a user with the following permissions/role:"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"CREATE LOGIN username WITH PASSWORD = 'password';"}),(0,a.jsx)(r.HCh,{children:"GRANT SELECT, INSERT, UPDATE TO username;"})]})]})]}),{}),tags:["DSR Automation","Discovery","Detection"],enabledFeatures:[l.j.DATA_DISCOVERY]},D={placeholder:{name:"MySQL",key:"mysql_placeholder",connection_type:d.Rj.MYSQL,access:d.uv.READ,created_at:""},category:n.DATABASE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Overview"}),(0,a.jsx)(o.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)(c,{children:[(0,a.jsx)(o.cB,{text:"Categories"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"Database"}),(0,a.jsx)(r.HCh,{children:"SQL database"}),(0,a.jsx)(r.HCh,{children:"Storage system"}),(0,a.jsx)(r.HCh,{children:"Data detection"}),(0,a.jsx)(r.HCh,{children:"Data discovery"})]}),(0,a.jsx)(o.cB,{text:"Permissions"}),(0,a.jsx)(o.XU,{children:"For detecting databases, Fides requires a user with the following permissions/role:"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"CREATE USER 'username' IDENTIFIED WITH authentication_plugin BY 'password';"}),(0,a.jsx)(r.HCh,{children:"GRANT SELECT, INSERT ON database.* TO 'username'@'%';"})]})]})]}),{}),tags:["DSR Automation","Discovery","Detection"],enabledFeatures:[l.j.DATA_DISCOVERY]},R={name:"Okta",key:"okta_placeholder",connection_type:d.Rj.OKTA,access:d.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."}),_={placeholder:R,category:n.IDENTITY_PROVIDER,tags:["Discovery","Inventory"],overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Overview"}),(0,a.jsx)(o.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:[l.j.DATA_DISCOVERY]},E={placeholder:{name:"Postgres",key:"postgres_placeholder",connection_type:d.Rj.POSTGRES,access:d.uv.READ,created_at:""},category:n.DATABASE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Overview"}),(0,a.jsx)(o.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)(c,{children:[(0,a.jsx)(o.cB,{text:"Categories"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"Database"}),(0,a.jsx)(r.HCh,{children:"SQL database"}),(0,a.jsx)(r.HCh,{children:"Storage system"}),(0,a.jsx)(r.HCh,{children:"Data detection"}),(0,a.jsx)(r.HCh,{children:"Data discovery"})]}),(0,a.jsx)(o.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)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"CREATE USER username WITH LOGIN;"}),(0,a.jsx)(r.HCh,{children:"GRANT SELECT ON ALL TABLES IN SCHEMA public TO username;"}),(0,a.jsx)(r.HCh,{children:"GRANT ALL PRIVILEGES ON ALL TABLES IN SCHEMA public TO username;"})]})]})]}),{}),tags:["Detection","Discovery"],enabledFeatures:[l.j.DATA_DISCOVERY]},T={placeholder:{name:"Amazon RDS MySQL",key:"rds_mysql_placeholder",connection_type:d.Rj.RDS_MYSQL,access:d.uv.READ,created_at:""},category:n.DATABASE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Overview"}),(0,a.jsx)(o.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)(c,{children:[(0,a.jsx)(o.cB,{text:"Categories"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"Database"}),(0,a.jsx)(r.HCh,{children:"SQL database"}),(0,a.jsx)(r.HCh,{children:"Storage system"}),(0,a.jsx)(r.HCh,{children:"Data detection"}),(0,a.jsx)(r.HCh,{children:"Data discovery"})]}),(0,a.jsx)(o.cB,{text:"Permissions"}),(0,a.jsx)(o.XU,{children:"For detecting database RDS instances and clusters, Fides requires an IAM user with the following permissions/role:"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"rds:DescribeDBClusters"}),(0,a.jsx)(r.HCh,{children:"rds:DescribeDBInstances"}),(0,a.jsx)(r.HCh,{children:"rds-db:connect"})]}),(0,a.jsx)(o.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)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"CREATE USER 'username' IDENTIFIED WITH AWSAuthenticationPlugin AS 'RDS';"}),(0,a.jsx)(r.HCh,{children:"GRANT SELECT, INSERT ON database.* TO 'username'@'%';"})]})]})]}),{}),tags:["Discovery","Detection"],enabledFeatures:[l.j.DATA_DISCOVERY]},H={placeholder:{name:"Amazon RDS Postgres",key:"rds_postgres_placeholder",connection_type:d.Rj.RDS_POSTGRES,access:d.uv.READ,created_at:""},category:n.DATABASE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Overview"}),(0,a.jsx)(o.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)(c,{children:[(0,a.jsx)(o.cB,{text:"Categories"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"Database"}),(0,a.jsx)(r.HCh,{children:"SQL database"}),(0,a.jsx)(r.HCh,{children:"Storage system"}),(0,a.jsx)(r.HCh,{children:"Data detection"}),(0,a.jsx)(r.HCh,{children:"Data discovery"})]}),(0,a.jsx)(o.cB,{text:"Permissions"}),(0,a.jsx)(o.XU,{children:"For detecting database RDS instances and clusters, Fides requires an IAM user with the following permissions/role:"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"rds:DescribeDBClusters"}),(0,a.jsx)(r.HCh,{children:"rds:DescribeDBInstances"}),(0,a.jsx)(r.HCh,{children:"rds-db:connect"})]}),(0,a.jsx)(o.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)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"CREATE USER username WITH LOGIN;"}),(0,a.jsx)(r.HCh,{children:"GRANT rds_iam TO username;"}),(0,a.jsx)(r.HCh,{children:"GRANT SELECT ON ALL TABLES IN SCHEMA public TO username;"}),(0,a.jsx)(r.HCh,{children:"GRANT ALL PRIVILEGES ON ALL TABLES IN SCHEMA public TO username;"})]})]})]}),{}),tags:["Discovery","Detection"],enabledFeatures:[l.j.DATA_DISCOVERY]},k={placeholder:{name:"Amazon S3",key:"s3_placeholder",connection_type:d.Rj.S3,access:d.uv.READ,created_at:""},category:n.DATA_WAREHOUSE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Overview"}),(0,a.jsx)(o.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)(c,{children:[(0,a.jsx)(o.cB,{text:"Categories"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"Object storage"}),(0,a.jsx)(r.HCh,{children:"Storage system"}),(0,a.jsx)(r.HCh,{children:"Cloud provider"}),(0,a.jsx)(r.HCh,{children:"Data detection"}),(0,a.jsx)(r.HCh,{children:"Data discovery"})]}),(0,a.jsx)(o.cB,{text:"Permissions"}),(0,a.jsx)(o.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)(o.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)(o.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)(o.cB,{text:"Permissions list"}),(0,a.jsx)(o.Z5,{children:(0,a.jsx)(r.HCh,{children:"AmazonS3ReadOnlyAccess"})})]})]}),{}),instructions:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Configuring a Fides -> Amazon S3 Integration"}),(0,a.jsx)(o.cB,{text:"Step 1: Create an IAM role in AWS"}),(0,a.jsx)(o.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)(c,{children:[(0,a.jsx)(o.cB,{text:"Step 2: Assign policies to the IAM role"}),(0,a.jsx)(o.XU,{children:"Grant the necessary permissions to the IAM role by attaching the following AWS-managed policy:"}),(0,a.jsx)(o.aG,{data:[{permission:"AmazonS3ReadOnlyAccess",description:"Provides read-only access to all buckets via the AWS Management Console."}]}),(0,a.jsx)(o.cB,{text:"Step 3: Create an IAM user for assuming a role"}),(0,a.jsxs)(o.XU,{children:["Follow the ",(0,a.jsx)(o.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)(o.cB,{text:"Step 4: Grant the IAM user permission to assume the Fides S3 Access Role"}),(0,a.jsx)(o.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)(o.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)(o.cB,{text:"Step 5: Create an access key for the IAM user"}),(0,a.jsxs)(o.vQ,{children:[(0,a.jsxs)(r.HCh,{children:["Create an access key for the IAM user under"," ",(0,a.jsx)("strong",{children:"Security credentials"}),"."]}),(0,a.jsx)(r.HCh,{children:"Select the Other use case"}),(0,a.jsx)(r.HCh,{children:"Copy the Access Key ID and Secret Access Key"})]}),(0,a.jsx)(o.cB,{text:"Step 6: Use the credentials to authenticate your integration"}),(0,a.jsxs)(o.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:[l.j.DATA_DISCOVERY]};var F=s(80388);let I={placeholder:{name:"Salesforce",key:"salesforce_placeholder",connection_type:s(88337).R.SAAS,saas_config:{fides_key:"salesforce",name:"Salesforce",type:F.m.SALESFORCE},access:d.uv.WRITE,created_at:""},category:n.CRM,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Overview"}),(0,a.jsx)(o.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)(c,{children:[(0,a.jsx)(o.cB,{text:"What this integration does"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"Discover personal data in standard Salesforce objects"}),(0,a.jsx)(r.HCh,{children:"Detect sensitive information across your Salesforce instance"}),(0,a.jsx)(r.HCh,{children:"Automate data subject access requests including data retrieval, updates, and deletions"}),(0,a.jsx)(r.HCh,{children:"Map Salesforce data to your organization's data map"}),(0,a.jsx)(r.HCh,{children:"Discover and map custom Salesforce objects (requires setting up a monitor)"})]}),(0,a.jsx)(o.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)(o.cB,{text:"Categories"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"CRM System"}),(0,a.jsx)(r.HCh,{children:"Data detection"}),(0,a.jsx)(r.HCh,{children:"Data discovery"}),(0,a.jsx)(r.HCh,{children:"DSR automation"})]}),(0,a.jsx)(o.cB,{text:"Prerequisites"}),(0,a.jsx)(o.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)(o.cB,{text:"Setup instructions"}),(0,a.jsx)(o.XU,{children:"Follow these steps to set up your Salesforce integration:"}),(0,a.jsxs)(o.vQ,{children:[(0,a.jsx)(r.HCh,{children:"Create a Connected App in Salesforce by following the Salesforce guide"}),(0,a.jsx)(r.HCh,{children:"Configure Basic Connected App Settings"}),(0,a.jsx)(r.HCh,{children:'Uncheck "Require Proof Key for Code Exchange (PKCE) Extension for Supported Authorization Flows"'}),(0,a.jsx)(r.HCh,{children:"Enable OAuth Settings for API Integration with the required scopes"}),(0,a.jsx)(r.HCh,{children:"Enter your Fides Redirect URL (typically https://fides-host.com/api/v1/oauth/callback)"})]}),(0,a.jsx)(o.cB,{text:"Required information"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"Domain: Your Salesforce URL"}),(0,a.jsx)(r.HCh,{children:"Consumer Key: Your OAuth client ID"}),(0,a.jsx)(r.HCh,{children:"Consumer Secret: Your OAuth client secret"}),(0,a.jsx)(r.HCh,{children:"Redirect URL: The Fides URL for OAuth callback"}),(0,a.jsx)(r.HCh,{children:"Token Refresh URL: The Salesforce URL for refresh tokens"})]}),(0,a.jsx)(o.cB,{text:"Required OAuth scopes"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"Manage user data via APIs (api)"}),(0,a.jsx)(r.HCh,{children:"Perform requests at any time (refresh_token, offline_access)"})]}),(0,a.jsx)(o.cB,{text:"Supported objects"}),(0,a.jsx)(o.XU,{children:"Fides supports both standard and custom Salesforce objects. The integration includes built-in support for common objects such as:"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"Contacts"}),(0,a.jsx)(r.HCh,{children:"Cases"}),(0,a.jsx)(r.HCh,{children:"Leads"}),(0,a.jsx)(r.HCh,{children:"Accounts"}),(0,a.jsx)(r.HCh,{children:"Campaign Members"}),(0,a.jsx)(r.HCh,{children:"Custom Objects"})]})]})]}),{}),tags:["API","DSR Automation","Discovery","Detection"],enabledFeatures:[l.j.DATA_DISCOVERY]},B={placeholder:{name:"Scylla",key:"scylla_placeholder",connection_type:d.Rj.SCYLLA,access:d.uv.READ,created_at:""},category:n.DATABASE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Overview"}),(0,a.jsx)(o.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)(c,{children:[(0,a.jsx)(o.cB,{text:"Categories"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"Database"}),(0,a.jsx)(r.HCh,{children:"NoSQL database"}),(0,a.jsx)(r.HCh,{children:"Storage system"}),(0,a.jsx)(r.HCh,{children:"Data detection"}),(0,a.jsx)(r.HCh,{children:"Data discovery"}),(0,a.jsx)(r.HCh,{children:"DSR automation"})]}),(0,a.jsx)(o.cB,{text:"Permissions"}),(0,a.jsx)(o.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)(o.cB,{text:"Permissions list"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"SELECT ALL KEYSPACES"}),(0,a.jsx)(r.HCh,{children:"MODIFY ALL KEYSPACES"})]})]})]}),{}),tags:["DSR Automation","Discovery","Detection"],enabledFeatures:[l.j.DATA_DISCOVERY]},O={placeholder:{name:"Snowflake",key:"snowflake_placeholder",connection_type:d.Rj.SNOWFLAKE,access:d.uv.READ,created_at:""},category:n.DATA_WAREHOUSE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Overview"}),(0,a.jsx)(o.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)(c,{children:[(0,a.jsx)(o.cB,{text:"Categories"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"Database"}),(0,a.jsx)(r.HCh,{children:"SQL database"}),(0,a.jsx)(r.HCh,{children:"Storage system"}),(0,a.jsx)(r.HCh,{children:"Data detection"}),(0,a.jsx)(r.HCh,{children:"Data discovery"})]}),(0,a.jsx)(o.cB,{text:"Permissions"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"CREATE ROLE my_monitor_role;"}),(0,a.jsx)(r.HCh,{children:"GRANT USAGE ON DATABASE DATABASE_1 TO ROLE my_monitor_role;"}),(0,a.jsx)(r.HCh,{children:"GRANT USAGE ON SCHEMA DATABASE_1.TEST_SCHEMA TO ROLE my_monitor_role;"}),(0,a.jsx)(r.HCh,{children:"GRANT SELECT ON ALL TABLES IN SCHEMA DATABASE_1.TEST_SCHEMA TO ROLE my_monitor_role;"}),(0,a.jsx)(r.HCh,{children:"CREATE USER test_user PASSWORD='***';"}),(0,a.jsx)(r.HCh,{children:"GRANT ROLE my_monitor_role TO USER test_user;"})]})]})]}),{}),tags:["DSR Automation","Discovery","Detection"],enabledFeatures:[l.j.DATA_DISCOVERY]},L={placeholder:{name:"Website",key:"website_placeholder",connection_type:d.Rj.WEBSITE,access:d.uv.READ,created_at:""},category:n.WEBSITE,tags:["Consent","Discovery","Detection"],overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Overview"}),(0,a.jsx)(o.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:[l.j.DATA_DISCOVERY]},P=[I],N={[d.Rj.BIGQUERY]:x,[d.Rj.DATAHUB]:g,[d.Rj.DYNAMODB]:f,[d.Rj.GOOGLE_CLOUD_SQL_MYSQL]:C,[d.Rj.GOOGLE_CLOUD_SQL_POSTGRES]:S,[d.Rj.MSSQL]:b,[d.Rj.OKTA]:_,[d.Rj.RDS_MYSQL]:T,[d.Rj.RDS_POSTGRES]:H,[d.Rj.S3]:k,[d.Rj.SCYLLA]:B,[d.Rj.SNOWFLAKE]:O,[d.Rj.MYSQL]:D,[d.Rj.WEBSITE]:L,[d.Rj.POSTGRES]:E,[d.Rj.MANUAL_WEBHOOK]:A},M=[...Object.values(N),...P],U=[...Object.keys(N),d.Rj.SAAS],q={placeholder:{name:"",key:"placeholder",connection_type:d.Rj.MANUAL,access:d.uv.READ,created_at:""},category:n.DATA_WAREHOUSE,tags:[],enabledFeatures:[]};var z=(e,t)=>{if(!e)return q;if(e===d.Rj.SAAS&&t){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!==d.Rj.SAAS){let t=N[e];if(t)return t}return q}},93633:function(e,t,s){"use strict";s.d(t,{z:function(){return r}});var i=s(14047),n=s(62051),a=s(14207);let r=e=>{let{connection:t,connectionOption:s,testData:r}=e,[o]=(0,a.rO)(),{handleError:c}=(0,i.H)();return{handleAuthorize:async()=>{if(!(null==t?void 0:t.key)){n.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 i=s(27378),n=s(20682),a=s(88337);t.Z=(e,t)=>{let{data:s}=(0,n.$I)({});return(0,i.useMemo)(()=>e===a.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])}},11013:function(e,t,s){"use strict";s.d(t,{$y:function(){return a},eV:function(){return i},m5:function(){return o},ww:function(){return r}});let{useGetSharedMonitorConfigsQuery:i,useGetSharedMonitorConfigByIdQuery:n,useCreateSharedMonitorConfigMutation:a,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"]})})})},31883:function(e,t,s){"use strict";s.d(t,{Bw:function(){return i.Bw},D4:function(){return i.D4}});var i=s(19043)},72707:function(e){e.exports={option:"TaxonomySelect_option__vY6v2"}}}]);
1
+ (self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[6662],{18225:function(e,t,s){"use strict";var i=s(24246),n=s(62051);t.Z=e=>{let{alignment:t="center",...s}=e;return(0,i.jsx)(n.kCb,{boxSize:"full",align:"center",justify:t,children:(0,i.jsx)(n.$jN,{color:"primary",...s})})}},77213:function(e,t,s){"use strict";s.d(t,{Z:function(){return h}});var i=s(24246),n=s(62051),a=s(88038),r=s.n(a),o=s(86677);s(27378);var c=s(25980),l=s(90867),d=s(77830),u=()=>{let e=(0,o.useRouter)();return(0,i.jsx)(n.xuv,{bg:"gray.50",border:"1px solid",borderColor:"blue.400",borderRadius:"md",justifyContent:"space-between",p:5,mb:5,mt:5,children:(0,i.jsxs)(n.xuv,{children:[(0,i.jsxs)(n.Kqy,{direction:{base:"column",sm:"row"},justifyContent:"space-between",children:[(0,i.jsx)(n.xvT,{fontWeight:"semibold",children:"Configure your storage and messaging provider"}),(0,i.jsx)(n.wpx,{onClick:()=>{e.push(d.fz)},children:"Configure"})]}),(0,i.jsxs)(n.xvT,{children:["Before Fides can process your privacy requests we need two simple steps to configure your storage and email client."," "]})]})})},h=e=>{let{children:t,title:s,padded:a=!0,mainProps:d}=e,h=(0,c.hz)(),m=(0,o.useRouter)(),x="/privacy-requests"===m.pathname||"/datastore-connection"===m.pathname,p=!(h.flags.privacyRequestsConfiguration&&x),{data:j}=(0,l.JE)(void 0,{skip:p}),{data:g}=(0,l.PW)(void 0,{skip:p}),y=h.flags.privacyRequestsConfiguration&&(!j||!g)&&x;return(0,i.jsxs)(n.kCb,{"data-testid":s,direction:"column",h:"100vh",children:[(0,i.jsxs)(r(),{children:[(0,i.jsxs)("title",{children:["Fides Admin UI - ",s]}),(0,i.jsx)("meta",{name:"description",content:"Privacy Engineering Platform"}),(0,i.jsx)("link",{rel:"icon",href:"/favicon.ico"})]}),(0,i.jsxs)(n.kCb,{as:"main",direction:"column",py:a?6:0,px:a?10:0,h:a?"calc(100% - 48px)":"full",flex:1,minWidth:0,overflow:"auto",...d,children:[y?(0,i.jsx)(u,{}):null,t]})]})}},58754:function(e,t,s){"use strict";var i=s(24246),n=s(62051),a=s(70788);t.Z=e=>{let{heading:t,breadcrumbItems:s,isSticky:r=!0,children:o,rightContent:c,style:l,...d}=e;return(0,i.jsxs)("div",{...d,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",...l}:{paddingBottom:"24px",...l},children:[(0,i.jsxs)(n.jqI,{justify:"space-between",children:["string"==typeof t?(0,i.jsx)(n.lQT,{className:s||o?"pb-4":void 0,level:1,"data-testid":"page-heading",children:t}):t,c&&(0,i.jsx)("div",{"data-testid":"page-header-right-content",children:c})]}),!!s&&(0,i.jsx)(a.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 u},cB:function(){return a},hX:function(){return d},vQ:function(){return l}});var i=s(24246),n=s(62051);let a=e=>{let{text:t,...s}=e;return(0,i.jsx)(n.X6q,{fontSize:"sm",mt:4,mb:1,...s,children:t})},r=e=>{let{children:t}=e;return(0,i.jsx)(n.xvT,{fontSize:"14px",mb:4,children:t})},o=e=>{let{children:t,href:s}=e;return(0,i.jsx)(n.rUS,{href:s,textDecoration:"underline",isExternal:!0,children:t})},c=e=>{let{children:t}=e;return(0,i.jsx)(n.QI$,{fontSize:"14px",mb:4,children:t})},l=e=>{let{children:t}=e;return(0,i.jsx)(n.GSI,{fontSize:"14px",mb:4,ml:6,children:t})},d=e=>{let{children:t}=e;return(0,i.jsx)(n.EKh,{display:"block",whiteSpace:"pre",p:4,mb:4,overflowX:"scroll",children:t})},u=e=>{let{data:t}=e;return(0,i.jsxs)(n.iA_,{fontSize:"14px",children:[(0,i.jsx)(n.hrZ,{children:(0,i.jsxs)(n.Tr,{children:[(0,i.jsx)(n.Th,{children:"Permission"}),(0,i.jsx)(n.Th,{children:"Description"})]})}),(0,i.jsx)(n.p3B,{children:t.map(e=>(0,i.jsxs)(n.Tr,{children:[(0,i.jsx)(n.Td,{children:(0,i.jsx)(n.Vp9,{children:e.permission})}),(0,i.jsx)(n.Td,{children:e.description})]},e.permission))})]})}},12627:function(e,t,s){"use strict";var i=s(24246),n=s(79283),a=s(34929);t.Z=e=>{let{selectedTaxonomies:t,showDisabled:s=!1,...r}=e,{getDataCategoryDisplayNameProps:o,getDataCategories:c}=(0,a.Z)(),l=(s?c():c().filter(e=>e.active)).filter(e=>!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,i.jsx)(n.l,{options:l,...r})}},79283:function(e,t,s){"use strict";s.d(t,{l:function(){return c}});var i=s(24246),n=s(62051),a=s(72707),r=s.n(a);let o=e=>{let{data:t}=e;return(0,i.jsxs)(n.jqI,{gap:12,title:"".concat(t.primaryName||"").concat(t.primaryName?": ":"").concat(t.name," - ").concat(t.description),children:[(0,i.jsxs)("div",{children:[(0,i.jsx)("strong",{children:t.primaryName||t.name}),t.primaryName&&": ".concat(t.name)]}),(0,i.jsx)("em",{children:t.description})]})},c=e=>{let{options:t,...s}=e,a=null==t?void 0:t.map(e=>({...e,className:r().option}));return(0,i.jsx)(n.WPr,{options:a,autoFocus:!0,variant:"borderless",optionRender:o,dropdownStyle:{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 l}});var i=s(24246),n=s(62051),a=s(34090),r=s(27378),o=s(46238),c=s(40324);let l=e=>{let{name:t,label:s,labelProps:l,tooltip:d,isRequired:u,layout:h="inline",helperText:m,...x}=e,[p,j,{setValue:g}]=(0,a.U$)(t),y=!!(j.touched&&j.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)=>{g(e),x.onChange&&x.onChange(e,t)};return"inline"===h?(0,i.jsx)(n.NIc,{isInvalid:y,isRequired:u,children:(0,i.jsxs)(n.rjZ,{templateColumns:s?"1fr 3fr":"1fr",children:[s?(0,i.jsx)(c.__,{htmlFor:x.id||t,...l,children:s}):null,(0,i.jsxs)(n.jqI,{align:"center",children:[(0,i.jsxs)(n.jqI,{vertical:!0,flex:1,className:"mr-2",children:[(0,i.jsx)(n.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,i.jsx)(n.Q6r,{children:m}),(0,i.jsx)(c.Bc,{isInvalid:y,message:j.error,fieldName:p.name})]}),(0,i.jsx)(o.b,{label:d,className:y?"mt-2 self-start":void 0})]})]})}):(0,i.jsx)(n.NIc,{isInvalid:y,isRequired:u,children:(0,i.jsxs)(n.gCW,{alignItems:"start",children:[(0,i.jsxs)(n.jqI,{align:"center",children:[s?(0,i.jsx)(c.__,{htmlFor:x.id||t,fontSize:"xs",my:0,mr:1,...l,children:s}):null,(0,i.jsx)(o.b,{label:d})]}),(0,i.jsx)(n.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,i.jsx)(n.Q6r,{style:{marginTop:0},children:m}),(0,i.jsx)(c.Bc,{isInvalid:y,message:j.error,fieldName:p.name})]})})}},71248:function(e,t,s){"use strict";s.d(t,{A:function(){return c}});var i=s(24246),n=s(34090),a=s(46782),r=s(97181),o=s(40324);let c=e=>{var t,s;let{name:c,fieldSchema:l,isRequired:d,layout:u="stacked",secretsSchema:h,validate:m}=e,x=(null===(s=l.allOf)||void 0===s?void 0:null===(t=s[0])||void 0===t?void 0:t.$ref)&&l.allOf[0].$ref!==a.j?null==h?void 0:h.definitions[l.allOf[0].$ref.replace("#/definitions/","")]:void 0,p=!!(null==x?void 0:x.enum)||l.options,j="boolean"===l.type,g="integer"===l.type,y=()=>{var e;if((null===(e=l.allOf)||void 0===e?void 0:e[0].$ref)===a.j)return"Enter dataset.collection.field"};return(0,i.jsx)(n.gN,{id:c,name:c,validate:m,children:e=>{let{field:t}=e;if(p){var s,n,a;let e=null!==(a=null==x?void 0:null===(s=x.enum)||void 0===s?void 0:s.map(e=>({label:e,value:e})))&&void 0!==a?a:null===(n=l.options)||void 0===n?void 0:n.map(e=>({label:e,value:e}));return(0,i.jsx)(r.d,{name:t.name,id:t.name,label:l.title,isRequired:d,tooltip:l.description,layout:u,options:e,mode:l.multiselect?"multiple":void 0},t.name)}return j?(0,i.jsx)(r.d,{name:t.name,id:t.name,label:l.title,isRequired:d,tooltip:l.description,layout:u,options:[{label:"False",value:"false"},{label:"True",value:"true"}]},t.name):g?(0,i.jsx)(o.aJ,{...t,label:l.title,tooltip:l.description,isRequired:d,placeholder:y(),variant:u}):(0,i.jsx)(o.j0,{...t,label:l.title,tooltip:l.description,isRequired:d,type:l.sensitive?"password":"text",placeholder:y(),autoComplete:"off",color:"gray.700",variant:u})}},c)}},46782:function(e,t,s){"use strict";s.d(t,{j:function(){return a},l:function(){return r}});var i=s(30454),n=s.n(i);let a="#/definitions/FidesDatasetReference",r=e=>{let t=(e,t,s)=>{let i;return(void 0===t||""===t||void 0===t)&&(i="".concat(e," is required")),s===a&&((null==t?void 0:t.includes("."))?t.split(".").length<3&&(i="Dataset reference must include at least three parts"):i="Dataset reference must be dot delimited"),i},s=t=>{var s,i;return(null==e?void 0:null===(s=e.required)||void 0===s?void 0:s.includes(t))||(null==e?void 0:null===(i=e.properties)||void 0===i?void 0:i[t])!==void 0&&"default"in e.properties[t]};return{validateField:t,isRequiredField:s,getFieldValidation:(e,i)=>{if(s(e)||"integer"===i.type)return e=>{var s;return t(i.title,e,null===(s=i.allOf)||void 0===s?void 0:s[0].$ref)}},preprocessValues:t=>{let s=n()(t);return e&&Object.keys(e.properties).forEach(t=>{var i,n;if((null===(i=e.properties[t].allOf)||void 0===i?void 0:i[0].$ref)===a){let e=null===(n=s.secrets[t])||void 0===n?void 0:n.split(".");e&&(s.secrets[t]={dataset:e.shift(),field:e.join("."),direction:"from"})}"WebsiteSchema"!==e.title||"URL"!==e.properties[t].title||s.secrets[t].startsWith("http://")||s.secrets[t].startsWith("https://")||(s.secrets[t]="https://".concat(s.secrets[t]))}),s}}}},14047:function(e,t,s){"use strict";s.d(t,{H:function(){return a},V:function(){return i.V}});var i=s(84306),n=s(812);let a=()=>{let{errorAlert:e}=(0,i.V)();return{handleError:t=>{let s="An unexpected error occurred. Please try again.";(0,n.Ot)(t)?s=t.data.detail:(0,n.tB)(t)&&(s=t.data.detail[0].msg),e(s)}}}},84306:function(e,t,s){"use strict";s.d(t,{V:function(){return a}});var i=s(24246),n=s(62051);let a=()=>{let e=(0,n.pmc)();return{errorAlert:(t,s,a)=>{let r={...a,position:(null==a?void 0:a.position)||"top",render:e=>{let{onClose:a}=e;return(0,i.jsxs)(n.bZj,{alignItems:"normal",status:"error","data-testid":"error-alert",children:[(0,i.jsx)(n.zMQ,{}),(0,i.jsxs)(n.xuv,{children:[s&&(0,i.jsx)(n.CdC,{children:s}),(0,i.jsx)(n.XaZ,{children:t})]}),(0,i.jsx)(n.PZ7,{onClick:a,position:"relative",right:0,size:"sm",top:-1})]})}};(null==a?void 0:a.id)&&e.isActive(a.id)?e.update(a.id,r):e(r)},successAlert:(t,s,a)=>{let r={...a,position:(null==a?void 0:a.position)||"top",render:e=>{let{onClose:a}=e;return(0,i.jsxs)(n.bZj,{alignItems:"normal",status:"success",variant:"subtle","data-testid":"success-alert",children:[(0,i.jsx)(n.zMQ,{}),(0,i.jsxs)(n.xuv,{children:[s&&(0,i.jsx)(n.CdC,{children:s}),(0,i.jsx)(n.XaZ,{children:t})]}),(0,i.jsx)(n.PZ7,{onClick:a,position:"relative",right:0,size:"sm",top:-1})]})}};(null==a?void 0:a.id)&&e.isActive(a.id)?e.update(a.id,r):e(r)}}}},34929:function(e,t,s){"use strict";var i=s(24246),n=s(64925),a=s.n(n),r=s(27378),o=s(16134),c=s(30002),l=s(28079),d=s(57072);let u=()=>{let{isLoading:e}=(0,l.fd)(),t=(0,o.C)(l.U3),{isLoading:s}=(0,d.MO)(),i=(0,o.C)(d.qb),{isLoading:n}=(0,c.te)();return{dataUses:t,dataSubjects:(0,o.C)(c.ZL),dataCategories:i,isLoading:e||s||n}};t.Z=()=>{let{dataUses:e,dataCategories:t,dataSubjects:s,isLoading:n}=u(),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,i=t(e);if(!i)return{};let n=t(o(e,s)),a=!!i.parent_key;return{name:i.name||void 0,primaryName:a&&(null==n?void 0:n.name)!==i.name&&(null==n?void 0:n.name)||void 0}},l=function(e,t){let s=arguments.length>2&&void 0!==arguments[2]?arguments[2]:1,{name:n,primaryName:a}=c(e,t,s);return n?a?(0,i.jsxs)(r.Fragment,{children:[(0,i.jsxs)("strong",{children:[a,":"]})," ",n]},e):(0,i.jsx)("strong",{children:n},e):e},d=t=>a()(e,{fides_key:t}),h=e=>a()(t,{fides_key:e}),m=e=>a()(s,{fides_key:e});return{getDataUses:()=>e,getDataUseByKey:d,getDataUseDisplayName:e=>l(e,d,1),getDataUseDisplayNameProps:e=>c(e,d,1),getDataCategories:()=>t,getDataCategoryByKey:h,getDataCategoryDisplayName:e=>l(e,h,2),getDataCategoryDisplayNameProps:e=>c(e,h,2),getDataSubjects:()=>s,getDataSubjectByKey:m,getDataSubjectDisplayName:e=>{let t=m(e);return t?t.name:e},getPrimaryKey:o,isLoading:n}}},8133:function(e,t,s){"use strict";var i=s(24246),n=s(62051);t.Z=e=>{let{title:t,children:s,isOpen:a,onClose:r,showCloseButton:o=!1,modalContentProps:c,footer:l,...d}=e;return(0,i.jsxs)(n.u_l,{isOpen:a,onClose:r,isCentered:!0,scrollBehavior:"inside",size:"xl",id:"add-modal",...d,children:[(0,i.jsx)(n.ZAr,{}),(0,i.jsxs)(n.hzk,{textAlign:"left",p:0,"data-testid":"add-modal-content",...c,children:[o&&(0,i.jsx)(n.olH,{}),(0,i.jsx)(n.xBx,{p:0,children:(0,i.jsx)(n.xuv,{backgroundColor:"gray.50",px:6,py:4,border:"1px",borderColor:"gray.200",borderTopRadius:6,display:"flex",justifyContent:"space-between",alignItems:"center",children:(0,i.jsx)(n.X6q,{as:"h3",size:"sm",children:t})})}),(0,i.jsx)(n.fef,{pb:4,overflow:"auto",children:s}),l&&(0,i.jsx)(n.mzw,{children:l})]})]})}},90980:function(e,t,s){"use strict";s.d(t,{R:function(){return c}});var i=s(24246),n=s(62051),a=s(79894),r=s.n(a),o=s(63662);let c=e=>{let{onClick:t,...s}=e;return(0,i.jsxs)(n.kCb,{alignItems:"center",mt:-4,mb:3,onClick:t,cursor:"pointer",...s,children:[(0,i.jsx)(n.wpx,{"aria-label":"Back",icon:(0,i.jsx)(n.Rpv,{}),className:"mr-2",size:"small"}),(0,i.jsx)(n.xvT,{as:"a",fontSize:"sm",fontWeight:"500",children:"Back"})]})};t.Z=e=>{let{backPath:t,...s}=e,a=(0,o.useRouter)();return(0,i.jsxs)(n.kCb,{alignItems:"center",mb:6,...s,children:[(0,i.jsx)(n.wpx,{onClick:()=>a.push(t),"aria-label":"Back",icon:(0,i.jsx)(n.Rpv,{}),className:"mr-2",size:"small"}),(0,i.jsx)(n.xvT,{as:r(),href:t,fontSize:"sm",fontWeight:"500",children:"Back"})]})}},70788:function(e,t,s){"use strict";s.d(t,{m:function(){return l}});var i=s(24246),n=s(62051),a=s(79894),r=s.n(a),o=s(27378);let{Text:c}=n.AntTypography,l=e=>{let{items:t,...s}=e,a=(0,o.useMemo)(()=>null==t?void 0:t.map((e,s)=>{let a=s===t.length-1,o={...e},l=o.onClick&&!o.href;return("string"==typeof o.title&&(o.title=(0,i.jsx)(c,{style:{color:"inherit",maxWidth:a?void 0:400},ellipsis:!a,children:o.title})),l)?o.title=(0,i.jsx)(n.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,i.jsxs)(i.Fragment,{children:[(0,i.jsx)("span",{className:"anticon align-text-bottom",children:o.icon}),o.title]})),o.href&&o.title&&(o.title=(0,i.jsx)(r(),{href:o.href,className:"ant-breadcrumb-link",children:o.title}),delete o.href)),o}),[t]);return(0,i.jsx)(n.zrq,{items:a,...s})}},41337:function(e,t,s){"use strict";var i=s(24246),n=s(62051);s(27378);var a=s(88337),r=s(16394),o=s(14746);let c=o.Ny+o.iW.get(a.R.WEBSITE),l=e=>void 0!==e.connection_type,d=e=>void 0!==e.encoded_icon,u=e=>(null==e?void 0:e.connection_type)===a.R.WEBSITE,h=e=>(null==e?void 0:e.connection_type)===a.R.SAAS;t.Z=e=>{let{data:t,...s}=e;return(0,i.jsx)(n.Eep,{boxSize:"32px",objectFit:"cover",src:(()=>{var e,s;let i;if(d(t)&&t.encoded_icon)return"data:image/svg+xml;base64,".concat(t.encoded_icon);if(u(t)){let s=null===(e=t.secrets)||void 0===e?void 0:e.url;if(!s)return c;let i=(0,r.ge)(s);return(0,r.tl)(i,100)}if(l(t)){if(h(t)&&(null===(s=t.saas_config)||void 0===s?void 0:s.type)){let e=t.saas_config.type,s=o.LN.get(e);return s?o.Ny+s:o.Ny+o.iW.get(a.R.SAAS)}i=[...o.iW].find(e=>{let[s]=e;return t.connection_type.toString()===s.toString()})}else if(d(t)){let{identifier:e}=t;i=[...o.iW].find(t=>{let[s]=t;return s.toLowerCase()===e.toLowerCase()})}return i?o.Ny+i[1]:o.VD})(),fallbackSrc:u(t)?c:o.VD,alt:(()=>{if(l(t)){var e;return null!==(e=t.name)&&void 0!==e?e:t.key}return d(t)?t.human_readable:t})(),...s})}},15872:function(e,t,s){"use strict";var i=s(24246),n=s(62051),a=s(86677);s(27378);var r=s(77830),o=s(14207);t.Z=e=>{let{connection_key:t,showMenu:s}=e,{isOpen:c,onOpen:l,onClose:d}=(0,n.qY0)(),[u,h]=(0,o.R5)(),m=(0,a.useRouter)(),x=()=>{h.isLoading||d()};return(0,i.jsxs)(i.Fragment,{children:[s&&(0,i.jsx)(n.sNh,{_focus:{color:"complimentary.500",bg:"gray.100"},onClick:l,children:(0,i.jsx)(n.xvT,{fontSize:"sm",children:"Delete"})}),!s&&(0,i.jsx)(n.wpx,{onClick:l,children:"Delete integration"}),(0,i.jsxs)(n.u_l,{isCentered:!0,isOpen:c,onClose:x,children:[(0,i.jsx)(n.ZAr,{}),(0,i.jsxs)(n.hzk,{children:[(0,i.jsx)(n.xBx,{children:"Delete integration"}),(0,i.jsx)(n.olH,{}),(0,i.jsx)(n.fef,{pb:6,children:(0,i.jsx)(n.Kqy,{direction:"column",spacing:"15px",children:(0,i.jsx)(n.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,i.jsxs)(n.mzw,{className:"flex gap-4",children:[(0,i.jsx)(n.wpx,{onClick:x,className:"w-1/2",children:"Cancel"}),(0,i.jsx)(n.wpx,{onClick:()=>{t&&(u(t),s||m.push(r.KH))},loading:h.isLoading,type:"primary",className:"w-1/2",children:"Delete integration"})]})]})]})]})}},19812:function(e,t,s){"use strict";s.d(t,{t:function(){return o}});var i=s(14047),n=s(14207),a=s(27378),r=s(41966);let o=e=>{var t,s,o;let{connectionConfig:c}=e,[l]=(0,n.S6)(),{data:d}=(0,n.Eg)(null!==(s=null==c?void 0:c.key)&&void 0!==s?s:""),u=null!==(o=null==d?void 0:null===(t=d.items)||void 0===t?void 0:t.map(e=>e.fides_key))&&void 0!==o?o:[],h=u.map(e=>({label:e,value:e})),{data:m}=(0,r.LH)({onlyUnlinkedDatasets:!0}),x=(0,a.useMemo)(()=>{var e;return null!==(e=null==m?void 0:m.map(e=>({value:e.fides_key,label:"".concat(e.name," (").concat(e.fides_key,")")||0})))&&void 0!==e?e:[]},[m]),{errorAlert:p,successAlert:j}=(0,i.V)();return{dropdownOptions:[...h,...x],initialDatasets:u,patchConnectionDatasetConfig:async function(e,t){var s,i,n;let{showSuccessAlert:a=!0}=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},r=null!==(n=null===(s=e.dataset)||void 0===s?void 0:s.map(e=>({fides_key:e,ctl_dataset_fides_key:e})))&&void 0!==n?n:[],o=await l({connection_key:t,dataset_pairs:r}).unwrap();(null===(i=o.failed)||void 0===i?void 0:i.length)>0?p(o.failed[0].message):a&&j("Dataset successfully updated!")}}}},33335:function(e,t,s){"use strict";s.d(t,{E:function(){return i}});let i=e=>e.toLowerCase().replace(/[ .]/g,"_").replace(/[^a-zA-Z0-9_<>-]/g,"")},45216:function(e,t,s){"use strict";var i=s(62051),n=s(812),a=s(16394),r=s(14207);t.Z=e=>{let[t,{data:s,fulfilledTimeStamp:o,isLoading:c,isFetching:l}]=(0,r.h2)(),d=(0,i.pmc)();return{testConnection:async()=>{var s,i,a,r;if(!e)return;let o=await t(e.key);if(o.isError)d({status:"error",description:(0,n.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")d({status:"success",description:"Connected successfully"});else if((null===(i=o.data)||void 0===i?void 0:i.test_status)==="failed"){let e="Connection test failed.";(null===(a=o.data)||void 0===a?void 0:a.failure_reason)&&(e+=" ".concat(null===(r=o.data)||void 0===r?void 0:r.failure_reason)),d({status:"warning",description:e})}},isLoading:c||l,testData:{timestamp:o?(0,a.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 i=s(24246),n=s(62051),a=s(16394);t.Z=e=>{let{testData:t,connectionOption:s}=e;if((null==s?void 0:s.authorization_required)&&!t.authorized)return(0,i.jsx)(n.kCb,{align:"center","data-testid":"connection-status",children:(0,i.jsx)(n.xvT,{color:"error-text.900",children:"Authorization required"})});if(!t.timestamp)return(0,i.jsx)(n.xvT,{"data-testid":"connection-status",children:"Connection not tested"});let r=(0,a.p6)(t.timestamp);return t.succeeded?(0,i.jsxs)(n.kCb,{color:"success-text.900",align:"center","data-testid":"connection-status",children:[(0,i.jsx)(n.rE2,{mr:2,boxSize:4}),(0,i.jsxs)(n.xvT,{children:["Last connected ",r]})]}):(0,i.jsxs)(n.kCb,{color:"error-text.900",align:"center","data-testid":"connection-status",children:[(0,i.jsx)(n.iid,{mr:2,boxSize:4}),(0,i.jsxs)(n.xvT,{children:["Last connection failed ",r]})]})}},75595:function(e,t,s){"use strict";var i=s(24246),n=s(62051),a=s(41337),r=s(15872),o=s(45216),c=s(52352),l=s(41553),d=s(93633),u=s(80388),h=s(64176);t.Z=e=>{var t,s;let{integration:m,showTestNotice:x,otherButtons:p,showDeleteButton:j,configureButtonLabel:g="Configure",onConfigureClick:y}=e,{testConnection:v,isLoading:f,testData:C}=(0,o.Z)(m),S=(0,c.ZP)(null==m?void 0:m.connection_type,null==m?void 0:null===(t=m.saas_config)||void 0===t?void 0:t.type),A=null==m?void 0:null===(s=m.saas_config)||void 0===s?void 0:s.type,b=(0,h.Z)(null==m?void 0:m.connection_type,A&&Object.values(u.m).includes(A)?A:void 0),{handleAuthorize:D,needsAuthorization:R}=(0,d.z)({connection:m,connectionOption:b,testData:C});return(0,i.jsxs)(n.xuv,{borderWidth:1,borderColor:"gray.200",borderRadius:"lg",overflow:"hidden",padding:"12px",marginBottom:"24px","data-testid":"integration-info-".concat(null==m?void 0:m.key),children:[(0,i.jsxs)(n.kCb,{children:[(0,i.jsx)(a.Z,{data:null!=m?m:"",boxSize:"50px"}),(0,i.jsxs)(n.kCb,{direction:"column",flexGrow:1,marginLeft:"16px",children:[(0,i.jsx)(n.xvT,{color:"gray.700",fontWeight:"semibold",children:(null==m?void 0:m.name)||"(No name)"}),x?(0,i.jsx)(l.Z,{testData:C,connectionOption:b}):(0,i.jsx)(n.xvT,{color:"gray.700",fontSize:"sm",fontWeight:"semibold",mt:1,children:S.category})]}),(0,i.jsxs)("div",{className:"flex gap-4",children:[j&&m&&(0,i.jsx)(r.Z,{showMenu:!1,connection_key:m.key}),x&&R&&(0,i.jsx)(n.wpx,{onClick:D,"data-testid":"authorize-integration-btn",children:"Authorize integration"}),x&&!R&&(0,i.jsx)(n.wpx,{onClick:v,loading:f,"data-testid":"test-connection-btn",children:"Test connection"}),p,y&&(0,i.jsx)(n.wpx,{onClick:y,"data-testid":"configure-btn",children:g})]})]}),(0,i.jsx)(n.Eq9,{marginTop:"16px",children:S.tags.map(e=>(0,i.jsx)(n.j8w,{children:e},e))})]})}},29379:function(e,t,s){"use strict";var i,n;s.d(t,{j:function(){return i}}),(n=i||(i={})).DATA_DISCOVERY="data_discovery",n.DATA_SYNC="data_sync",n.TASKS="tasks",n.WITHOUT_CONNECTION="without_connection"},40774:function(e,t,s){"use strict";s.d(t,{Z:function(){return S}});var i,n,a=s(24246),r=s(62051),o=s(27378),c=s(60018),l=s(46381),d=s(12627),u=s(812),h=s(46238),m=s(90980),x=s(46628),p=s(11013),j=s(31883);let g={rules:[{regex:void 0,dataCategory:void 0}]};var y=e=>{var t,s,i;let{config:n,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,j.D4)(e)?v((0,x.Vo)((0,u.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(n?await S({...t,id:n.id}):await f(t),!n)},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:i}=(0,l.parse)(s,{skipEmptyLines:!0,header:!1}),n=i.map(e=>{let[t,s]=e;return{regex:t,dataCategory:s}});y.setFieldValue("rules",n),v((0,x.t5)("CSV patterns imported successfully"))}catch(e){v((0,x.Vo)("Failed to parse CSV file"))}},s.readAsText(t)};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(m.R,{onClick:o,className:"pt-3"}),(0,a.jsx)(c.ZT.Title,{level:2,children:n?"Edit ".concat(n.name):"Create new configuration"}),(0,a.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,a.jsxs)(r.PPS,{name:"monitor-template",layout:"vertical",form:y,onFinish:R,className:"mt-4",initialValues:n?{...n,rules:null!==(i=null==n?void 0:null===(s=n.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!==i?i:[]}:g,validateTrigger:["onBlur","onChange"],children:[(0,a.jsx)(r.bue,{children:(0,a.jsxs)(r.JGx,{span:24,children:[(0,a.jsx)(r.PPS.Item,{label:"Configuration name",name:"name",rules:[{required:!0,message:"Config name is required"}],"data-testid":"form-item-name",children:(0,a.jsx)(r.uFc,{autoFocus:!0,"data-testid":"input-name"})}),(0,a.jsx)(r.PPS.Item,{label:"Description",name:"description","data-testid":"form-item-description",children:(0,a.jsx)(r.uFc.TextArea,{"data-testid":"input-description"})})]})}),(0,a.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:i,remove:l}=t,{errors:u}=s;return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsxs)(r.jqI,{justify:"space-between",children:[(0,a.jsx)(c.ZT.Title,{level:3,className:"pb-5",children:"Regex patterns"}),!n&&(0,a.jsxs)(r.jqI,{gap:8,align:"center",children:[(0,a.jsx)(h.b,{label:"Upload a CSV to map regex patterns to data categories. Format: regex,data_category",placement:"left"}),(0,a.jsx)(r.pMK,{accept:".csv",showUploadList:!1,beforeUpload:()=>!1,onChange:w,children:(0,a.jsx)(r.wpx,{icon:(0,a.jsx)(r.PJP.gqx,{}),iconPosition:"end",size:"small","data-testid":"upload-csv-btn",children:"Upload CSV"})})]})]}),e.map((t,s)=>{let{key:n,name:o,...c}=t;return(0,a.jsxs)(r.bue,{align:"middle",children:[(0,a.jsx)(r.JGx,{span:11,children:(0,a.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,a.jsx)(r.uFc,{placeholder:"Enter a regular expression","data-testid":"input-rules.".concat(o,".regex")})})}),(0,a.jsx)(r.JGx,{span:1,className:"flex justify-center pt-[5px]",children:"->"}),(0,a.jsx)(r.JGx,{span:11,className:"pr-2",children:(0,a.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,a.jsx)(d.Z,{selectedTaxonomies:[],variant:"outlined",placeholder:"Select a data category",autoFocus:!1,allowClear:!0,"data-testid":"input-rules.".concat(o,".dataCategory")})})}),(0,a.jsx)(r.JGx,{span:1,className:"mt-[7.25px]",children:s===e.length-1?(0,a.jsx)(r.wpx,{onClick:()=>i(),icon:(0,a.jsx)(r.PJP.mm_,{}),"aria-label":"Add new rule","data-testid":"add-rule-btn"}):(0,a.jsx)(r.wpx,{onClick:()=>l(o),icon:(0,a.jsx)(r.PJP.ZNm,{}),"aria-label":"Remove rule","data-testid":"remove-rule-".concat(o)})})]},n)}),(0,a.jsx)(r.PPS.ErrorList,{errors:u}),(0,a.jsx)(r.PPS.Item,{label:null,className:"mb-0",children:(0,a.jsxs)(r.jqI,{justify:"end",gap:8,children:[(0,a.jsx)(r.wpx,{onClick:o,children:"Cancel"}),(0,a.jsx)(r.wpx,{type:"primary",htmlType:"submit",loading:C||A,"data-testid":"save-btn",children:"Save"})]})})]})}})]})]})},v=s(14481),f=e=>{let{onEditClick:t}=e,[s]=(0,p.m5)(),i=(0,r.pmc)(),n=async e=>{let t=await s({id:e});(0,j.D4)(t)?i((0,x.Vo)((0,u.e$)(t.error,"A problem occurred deleting this config"))):i((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,a.jsxs)(r.jqI,{className:"gap-2",children:[(0,a.jsx)(r.wpx,{size:"small",onClick:()=>t(s),icon:(0,a.jsx)(r.PJP.I8b,{}),"data-testid":"edit-btn"}),(0,a.jsx)(r.wpx,{size:"small",onClick:()=>n(s.id),icon:(0,a.jsx)(r.PJP.ZNm,{})})]})}]},C=e=>{let{onNewClick:t,onRowClick:s}=e,{onPreviousPageClick:i,isPreviousPageDisabled:n,onNextPageClick:o,isNextPageDisabled:l,pageSize:d,setPageSize:u,PAGE_SIZES:h,startRange:m,endRange:x,pageIndex:j}=(0,v.oi)(),{data:g,isLoading:y,isFetching:C}=(0,p.eV)({page:j,size:d}),S=f({onEditClick:s});return y||C?(0,a.jsx)(r.ZJQ,{size:"large",className:"flex h-full items-center justify-center"}):(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(c.ZT.Title,{level:2,children:"Shared monitor configurations"}),(0,a.jsx)(c.ZT.Paragraph,{className:"mb-2 mt-4",children:"Shared monitor configurations can be applied to monitors to customize classification."}),(0,a.jsx)(r.wpx,{type:"primary",onClick:t,"data-testid":"create-new-btn",className:"mb-3",children:"Create new"}),(0,a.jsx)(r.V5H,{columns:S,dataSource:null==g?void 0:g.items,size:"small",pagination:!1,onRow:e=>({"data-testid":"config-".concat(e.id)}),locale:{emptyText:(0,a.jsx)(c.ZT.Paragraph,{className:"py-8",children:"No shared monitor configs found"})}}),(0,a.jsx)(r.jqI,{justify:"space-between",className:"mt-4",children:(0,a.jsx)(v.s8,{totalRows:(null==g?void 0:g.total)||0,pageSizes:h,setPageSize:u,onPreviousPageClick:i,isPreviousPageDisabled:n,onNextPageClick:o,isNextPageDisabled:l,startRange:m,endRange:x})})]})};(i=n||(n={})).MAIN_VIEW="main",i.FORM_VIEW="form";var S=()=>{let[e,t]=(0,o.useState)(!1),[s,i]=(0,o.useState)(void 0),[n,c]=(0,o.useState)("main"),l=()=>{c("main"),i(void 0)};return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(r.wpx,{icon:(0,a.jsx)(r.PJP.Zrf,{}),iconPosition:"end",onClick:()=>t(!0),"data-testid":"configurations-btn",children:"Shared configs"}),(0,a.jsxs)(r.$zI,{open:e,onCancel:()=>{l(),t(!1)},destroyOnClose:!0,centered:!0,width:768,footer:null,children:["form"===n&&(0,a.jsx)(y,{config:s,onBackClick:l}),"main"===n&&(0,a.jsx)(C,{onNewClick:()=>c("form"),onRowClick:e=>{i(e),c("form"),t(!0)}})]})]})}},15987:function(e,t,s){"use strict";var i=s(24246),n=s(62051),a=s(34090),r=s(90104),o=s.n(r),c=s(92465),l=s.n(c),d=s(25389),u=s.n(d),h=s(15539),m=s.n(h),x=s(27378),p=s(18225),j=s(97181),g=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(46420),_=s(31883);let E=e=>{let{dirty:t,isValid:s,submitForm:i,loading:n,onFormStateChange:a}=e;return(0,x.useEffect)(()=>{a&&a({dirty:t,isValid:s,submitForm:i,loading:n})},[t,s,i,n,a]),null};t.Z=e=>{var t,s;let{connection:r,connectionOption:c,onCancel:d,description:h,onFormStateChange:x}=e,[T,{isLoading:H}]=(0,A.Pp)(),[k,{isLoading:F}]=(0,A.pH)(),[I,{isLoading:B}]=(0,R.qd)(),[O]=(0,A.pL)(),L=c.identifier!==w.Rj.MANUAL_WEBHOOK,{data:P,isLoading:N}=(0,C.n3)(c.identifier,{skip:!L}),{data:M}=(0,R.K3)(),U=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:q}=(0,S.LH)({minimal:!0,connection_type:w.Rj.BIGQUERY}),z=null==q?void 0:q.map(e=>{var t;return{label:null!==(t=e.name)&&void 0!==t?t:e.fides_key,value:e.fides_key}}),{patchConnectionDatasetConfig:Z,initialDatasets:Q}=(0,b.t)({connectionConfig:r}),{getFieldValidation:W,preprocessValues:G}=(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:"",...L&&{secrets:u()(null==P?void 0:P.properties,(e,t)=>{var s,i,n;return null!==(n=null!==(i=null==r?void 0:null===(s=r.secrets)||void 0===s?void 0:s[t])&&void 0!==i?i:e.default)&&void 0!==n?n:""})},dataset:Q},V=(0,n.pmc)(),Y=!!r,K=c.type===w.Zi.SAAS,J=e=>m()(u()(e,(e,t)=>{var s,i;return(null!==(i=null==r?void 0:null===(s=r.secrets)||void 0===s?void 0:s[t])&&void 0!==i?i:"")===e?void 0:e}),l()),$=async e=>{var t;let s;let i=G(e),n=L?J(i.secrets):{},a=Y?{...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:i.secrets,dataset:e.dataset};if(s=e.system_fides_key?await I({systemFidesKey:e.system_fides_key,connectionConfigs:[a]}):K&&!Y?await O({...a,instance_key:(0,D.E)(e.name),saas_connector_type:c.identifier,secrets:e.secrets||{}}):await k(a),(0,_.D4)(s)){V({status:"error",description:(0,f.e$)(s.error,"A problem occurred while ".concat(Y?"updating":"creating"," this integration. Please try again."))});return}if(!L||!e.secrets){V({status:"success",description:"Integration ".concat(Y?"updated":"created"," successfully")}),d();return}if(!o()(n)){let e=await T({connection_key:a.key,secrets:n});if((0,_.D4)(e)){V({status:"error",description:(0,f.e$)(e.error,"An error occurred while ".concat(Y?"updating":"creating"," this integration's secret. Please try again."))});return}}V({status:"success",description:"Integration secret ".concat(Y?"updated":"created"," successfully")}),d(),a&&e.dataset&&c.identifier===w.Rj.DATAHUB&&await Z(e,a.key,{showSuccessAlert:!1})},ee=H||F||B;if(N)return(0,i.jsx)(p.Z,{});let et=e=>Object.entries(e.properties).map(t=>{let[s,n]=t,a="secrets.".concat(s);return(0,i.jsx)(g.A,{name:a,fieldSchema:n,isRequired:e.required.includes(s),secretsSchema:e,validate:W(s,n)},a)});return(0,i.jsxs)(i.Fragment,{children:[h&&(0,i.jsx)(n.xuv,{padding:"20px 24px",backgroundColor:"gray.50",borderRadius:"md",border:"1px solid",borderColor:"gray.200",fontSize:"sm",marginTop:"16px",children:h}),(0,i.jsx)(a.J9,{initialValues:X,enableReinitialize:!0,onSubmit:$,children:e=>{let{dirty:t,isValid:s,submitForm:r}=e;return(0,i.jsxs)(a.l0,{children:[(0,i.jsxs)(n.gCW,{alignItems:"start",spacing:6,mt:4,children:[(0,i.jsx)(y.j0,{id:"name",name:"name",label:"Name",variant:"stacked",isRequired:!0}),(0,i.jsx)(y.j0,{id:"description",name:"description",label:"Description",variant:"stacked"}),L&&P&&et(P),!Y&&!K&&(0,i.jsx)(j.d,{id:"system_fides_key",name:"system_fides_key",options:null!=U?U:[],label:"System",tooltip:"The system to associate with the integration",layout:"stacked"}),c.identifier===w.Rj.DATAHUB&&(0,i.jsx)(j.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,i.jsx)(E,{dirty:t,isValid:s,submitForm:r,loading:ee,onFormStateChange:x})]})}})]})}},52352:function(e,t,s){"use strict";s.d(t,{FO:function(){return M},jq:function(){return U},ZP:function(){return z}}),(i=n||(n={})).DATA_CATALOG="Data Catalog",i.DATA_WAREHOUSE="Data Warehouse",i.DATABASE="Database",i.IDENTITY_PROVIDER="Identity Provider",i.WEBSITE="Website",i.CRM="CRM",i.MANUAL="Manual";var i,n,a=s(24246),r=s(62051),o=s(79789),c=e=>{let{children:t}=e,{isOpen:s,onToggle:i}=(0,r.qY0)();return(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(r.UO1,{in:s,children:t}),(0,a.jsx)(r.xvT,{fontSize:"sm",cursor:"pointer",textDecoration:"underline",onClick:i,children:s?"Show less":"Show more"})]})},l=s(29379),d=s(46420);let u={name:"Google BigQuery",key:"bq_placeholder",connection_type:d.Rj.BIGQUERY,access:d.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."}],m=[{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."}],x={placeholder:u,category:n.DATA_WAREHOUSE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Overview"}),(0,a.jsx)(o.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)(c,{children:[(0,a.jsx)(o.cB,{text:"Categories"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"Data Warehouse"}),(0,a.jsx)(r.HCh,{children:"Storage system"}),(0,a.jsx)(r.HCh,{children:"Cloud provider"}),(0,a.jsx)(r.HCh,{children:"Data detection"}),(0,a.jsx)(r.HCh,{children:"Data discovery"}),(0,a.jsx)(r.HCh,{children:"DSR automation"}),(0,a.jsx)(r.HCh,{children:"Consent orchestration"})]}),(0,a.jsx)(o.cB,{text:"Permissions"}),(0,a.jsx)(o.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)(o.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)(o.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)(o.cB,{text:"Permissions list"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"bigquery.jobs.create"}),(0,a.jsx)(r.HCh,{children:"bigquery.jobs.list"}),(0,a.jsx)(r.HCh,{children:"bigquery.routines.get"}),(0,a.jsx)(r.HCh,{children:"bigquery.routines.list"}),(0,a.jsx)(r.HCh,{children:"bigquery.datasets.get"}),(0,a.jsx)(r.HCh,{children:"bigquery.tables.get"}),(0,a.jsx)(r.HCh,{children:"bigquery.tables.getData"}),(0,a.jsx)(r.HCh,{children:"bigquery.tables.list"}),(0,a.jsx)(r.HCh,{children:"bigquery.tables.updateData"}),(0,a.jsx)(r.HCh,{children:"resourcemanager.projects.get"})]})]})]}),{}),instructions:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Configuring a Fides -> BigQuery Integration"}),(0,a.jsx)(o.cB,{text:"Step 1: Create a Fides project"}),(0,a.jsxs)(o.XU,{children:["Create a Fides Project using"," ",(0,a.jsx)(o.Hn,{href:"https://cloud.google.com/resource-manager/docs/creating-managing-projects#creating_a_project",children:"BigQuery's project creation guide"}),"."]}),(0,a.jsx)(o.cB,{text:"Step 2: Create a Fides role in GCP"}),(0,a.jsxs)(o.vQ,{children:[(0,a.jsxs)(r.HCh,{children:["Create a custom role for Fides using BigQuery's"," ",(0,a.jsx)(o.Hn,{href:"https://cloud.google.com/iam/docs/creating-custom-roles#creating_a_custom_role",children:"roles guide"}),"."]}),(0,a.jsx)(r.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)(c,{children:[(0,a.jsx)(o.cB,{text:"Step 3: Assign permissions to the Fides project"}),(0,a.jsx)(o.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)(o.aG,{data:h}),(0,a.jsx)(o.cB,{text:"Step 4: Assign permissions to any project you'd like Fides to monitor"}),(0,a.jsx)(o.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)(o.aG,{data:m}),(0,a.jsx)(o.cB,{text:"Step 5: Create a Fides service account in the Fides Project"}),(0,a.jsxs)(o.vQ,{children:[(0,a.jsxs)(r.HCh,{children:["Create a service account for Fides using BigQuery's"," ",(0,a.jsx)(o.Hn,{href:"https://cloud.google.com/iam/docs/service-accounts-create",children:"service account guide"}),"."]}),(0,a.jsx)(r.HCh,{children:"Assign the previously created role to this service account."}),(0,a.jsxs)(r.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)(o.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)(o.cB,{text:"Step 6: Use the JSON key to authenticate your integration"}),(0,a.jsx)(o.XU,{children:"Provide the JSON key to your Fides instance to securely connect Fides."})]})]}),{}),tags:["DSR Automation","Discovery","Detection"],enabledFeatures:[l.j.DATA_DISCOVERY]},p={name:"Datahub",key:"datahub_placeholder",connection_type:d.Rj.DATAHUB,access:d.uv.READ,created_at:""},j=(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:p,category:n.DATA_CATALOG,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Overview"}),(0,a.jsx)(o.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)(c,{children:[(0,a.jsx)(o.cB,{text:"Categories"}),(0,a.jsx)(o.Z5,{children:(0,a.jsx)(r.HCh,{children:"Data Catalog"})}),(0,a.jsx)(o.cB,{text:"Permissions"}),(0,a.jsx)(o.Z5,{children:(0,a.jsx)(r.HCh,{children:"The related user to the access token must have at least the Editor role on DataHub."})})]})]}),{}),tags:["Sync"],description:j,enabledFeatures:[l.j.DATA_SYNC]},y={name:"DynamoDB",key:"dynamo_placeholder",connection_type:d.Rj.DYNAMODB,access:d.uv.READ,created_at:""},v=[{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."}],f={placeholder:y,category:n.DATABASE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Overview"}),(0,a.jsx)(o.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)(c,{children:[(0,a.jsx)(o.cB,{text:"Categories"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"NoSQL database"}),(0,a.jsx)(r.HCh,{children:"Storage system"}),(0,a.jsx)(r.HCh,{children:"Cloud provider"}),(0,a.jsx)(r.HCh,{children:"Data detection"}),(0,a.jsx)(r.HCh,{children:"Data discovery"})]}),(0,a.jsx)(o.cB,{text:"Permissions and Policies"}),(0,a.jsxs)(o.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)(r.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)(r.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)(o.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)(o.cB,{text:"Policy List"}),(0,a.jsx)(o.XU,{children:"The following AWS-managed policies provide the necessary permissions for Fides:"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"AmazonDynamoDBReadOnlyAccess"}),(0,a.jsx)(r.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)(o.cB,{text:"Configuring a Fides -> DynamoDB Integration"}),(0,a.jsx)(o.cB,{text:"Step 1: Create an IAM user in AWS"}),(0,a.jsxs)(o.XU,{children:["Create an IAM user for Fides' DynamoDB access following the"," ",(0,a.jsx)(o.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)(c,{children:[(0,a.jsx)(o.cB,{text:"Step 2: Assign policies to the IAM user"}),(0,a.jsx)(o.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)(o.aG,{data:v}),(0,a.jsx)(o.cB,{text:"Step 3: Create an access key for the IAM user"}),(0,a.jsxs)(o.vQ,{children:[(0,a.jsxs)(r.HCh,{children:["Create an access key for the IAM user under"," ",(0,a.jsx)("strong",{children:"Security credentials"})]}),(0,a.jsx)(r.HCh,{children:"Select the Other use case"}),(0,a.jsx)(r.HCh,{children:"Copy the Access Key ID and Secret Access Key"})]}),(0,a.jsx)(o.cB,{text:"Use the Credentials to Authenticate Your Integration"}),(0,a.jsx)(o.XU,{children:"Provide the credentials to your Fides instance to securely connect Fides."})]})]}),{}),tags:["DSR Automation","Discovery","Detection"],enabledFeatures:[l.j.DATA_DISCOVERY]},C={placeholder:{name:"Cloud SQL - MySQL",key:"google_cloud_sql_for_mysql_placeholder",connection_type:d.Rj.GOOGLE_CLOUD_SQL_MYSQL,access:d.uv.READ,created_at:""},category:n.DATABASE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Overview"}),(0,a.jsx)(o.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)(c,{children:[(0,a.jsx)(o.cB,{text:"Categories"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"Database"}),(0,a.jsx)(r.HCh,{children:"SQL database"}),(0,a.jsx)(r.HCh,{children:"Storage system"}),(0,a.jsx)(r.HCh,{children:"Data detection"}),(0,a.jsx)(r.HCh,{children:"Data discovery"}),(0,a.jsx)(r.HCh,{children:"DSR automation"})]}),(0,a.jsx)(o.cB,{text:"Permissions"}),(0,a.jsx)(o.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)(o.cB,{text:"Permissions list"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"GRANT SELECT"}),(0,a.jsx)(r.HCh,{children:"GRANT UPDATE"}),(0,a.jsx)(r.HCh,{children:"GRANT DELETE"})]})]})]}),{}),tags:["Discovery","Detection"],enabledFeatures:[l.j.DATA_DISCOVERY]},S={placeholder:{name:"Cloud SQL - Postgres",key:"google_cloud_sql_for_postgres_placeholder",connection_type:d.Rj.GOOGLE_CLOUD_SQL_POSTGRES,access:d.uv.READ,created_at:""},category:n.DATABASE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Overview"}),(0,a.jsx)(o.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)(c,{children:[(0,a.jsx)(o.cB,{text:"Categories"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"Database"}),(0,a.jsx)(r.HCh,{children:"SQL database"}),(0,a.jsx)(r.HCh,{children:"Storage system"}),(0,a.jsx)(r.HCh,{children:"Data detection"}),(0,a.jsx)(r.HCh,{children:"Data discovery"}),(0,a.jsx)(r.HCh,{children:"DSR automation"})]}),(0,a.jsx)(o.cB,{text:"Permissions"}),(0,a.jsx)(o.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)(o.XU,{children:"The following GCP service account permissions are needed when setting up Google Cloud SQL for Postgres."}),(0,a.jsx)(o.cB,{text:"Permissions list"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"cloudsql.instances.connect"}),(0,a.jsx)(r.HCh,{children:"cloudsql.instances.get"}),(0,a.jsx)(r.HCh,{children:"cloudsql.instances.login"})]})]})]}),{}),tags:["Discovery","Detection"],enabledFeatures:[l.j.DATA_DISCOVERY]},A={placeholder:{name:"Manual",key:"manual_placeholder",connection_type:d.Rj.MANUAL_WEBHOOK,access:d.uv.READ,created_at:""},category:n.MANUAL,tags:["DSR","Manual tasks"],overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Overview"}),(0,a.jsx)(o.XU,{children:"A Manual Integration provides a simple way for data to be manually uploaded for access and erasure requests."}),(0,a.jsxs)(o.XU,{children:["If you have manual integrations defined, privacy request execution will exit early and remain in a state of ",(0,a.jsx)("em",{children:"Requires input"}),". Once data has been manually uploaded for all the manual integrations, then the privacy request can be resumed. Data uploaded for manual integrations is passed on directly to the data subject alongside the data package."]})]}),{}),enabledFeatures:[l.j.TASKS,l.j.WITHOUT_CONNECTION]},b={placeholder:{name:"Microsoft SQL Server",key:"microsoft_sql_server_placeholder",connection_type:d.Rj.MSSQL,access:d.uv.READ,created_at:""},category:n.DATABASE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Overview"}),(0,a.jsx)(o.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)(c,{children:[(0,a.jsx)(o.cB,{text:"Categories"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"Database"}),(0,a.jsx)(r.HCh,{children:"SQL database"}),(0,a.jsx)(r.HCh,{children:"Storage system"}),(0,a.jsx)(r.HCh,{children:"Data detection"}),(0,a.jsx)(r.HCh,{children:"Data discovery"})]}),(0,a.jsx)(o.cB,{text:"Permissions"}),(0,a.jsx)(o.XU,{children:"For detecting databases, Fides requires a user with the following permissions/role:"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"CREATE LOGIN username WITH PASSWORD = 'password';"}),(0,a.jsx)(r.HCh,{children:"GRANT SELECT, INSERT, UPDATE TO username;"})]})]})]}),{}),tags:["DSR Automation","Discovery","Detection"],enabledFeatures:[l.j.DATA_DISCOVERY]},D={placeholder:{name:"MySQL",key:"mysql_placeholder",connection_type:d.Rj.MYSQL,access:d.uv.READ,created_at:""},category:n.DATABASE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Overview"}),(0,a.jsx)(o.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)(c,{children:[(0,a.jsx)(o.cB,{text:"Categories"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"Database"}),(0,a.jsx)(r.HCh,{children:"SQL database"}),(0,a.jsx)(r.HCh,{children:"Storage system"}),(0,a.jsx)(r.HCh,{children:"Data detection"}),(0,a.jsx)(r.HCh,{children:"Data discovery"})]}),(0,a.jsx)(o.cB,{text:"Permissions"}),(0,a.jsx)(o.XU,{children:"For detecting databases, Fides requires a user with the following permissions/role:"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"CREATE USER 'username' IDENTIFIED WITH authentication_plugin BY 'password';"}),(0,a.jsx)(r.HCh,{children:"GRANT SELECT, INSERT ON database.* TO 'username'@'%';"})]})]})]}),{}),tags:["DSR Automation","Discovery","Detection"],enabledFeatures:[l.j.DATA_DISCOVERY]},R={name:"Okta",key:"okta_placeholder",connection_type:d.Rj.OKTA,access:d.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."}),_={placeholder:R,category:n.IDENTITY_PROVIDER,tags:["Discovery","Inventory"],overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Overview"}),(0,a.jsx)(o.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:[l.j.DATA_DISCOVERY]},E={placeholder:{name:"Postgres",key:"postgres_placeholder",connection_type:d.Rj.POSTGRES,access:d.uv.READ,created_at:""},category:n.DATABASE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Overview"}),(0,a.jsx)(o.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)(c,{children:[(0,a.jsx)(o.cB,{text:"Categories"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"Database"}),(0,a.jsx)(r.HCh,{children:"SQL database"}),(0,a.jsx)(r.HCh,{children:"Storage system"}),(0,a.jsx)(r.HCh,{children:"Data detection"}),(0,a.jsx)(r.HCh,{children:"Data discovery"})]}),(0,a.jsx)(o.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)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"CREATE USER username WITH LOGIN;"}),(0,a.jsx)(r.HCh,{children:"GRANT SELECT ON ALL TABLES IN SCHEMA public TO username;"}),(0,a.jsx)(r.HCh,{children:"GRANT ALL PRIVILEGES ON ALL TABLES IN SCHEMA public TO username;"})]})]})]}),{}),tags:["Detection","Discovery"],enabledFeatures:[l.j.DATA_DISCOVERY]},T={placeholder:{name:"Amazon RDS MySQL",key:"rds_mysql_placeholder",connection_type:d.Rj.RDS_MYSQL,access:d.uv.READ,created_at:""},category:n.DATABASE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Overview"}),(0,a.jsx)(o.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)(c,{children:[(0,a.jsx)(o.cB,{text:"Categories"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"Database"}),(0,a.jsx)(r.HCh,{children:"SQL database"}),(0,a.jsx)(r.HCh,{children:"Storage system"}),(0,a.jsx)(r.HCh,{children:"Data detection"}),(0,a.jsx)(r.HCh,{children:"Data discovery"})]}),(0,a.jsx)(o.cB,{text:"Permissions"}),(0,a.jsx)(o.XU,{children:"For detecting database RDS instances and clusters, Fides requires an IAM user with the following permissions/role:"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"rds:DescribeDBClusters"}),(0,a.jsx)(r.HCh,{children:"rds:DescribeDBInstances"}),(0,a.jsx)(r.HCh,{children:"rds-db:connect"})]}),(0,a.jsx)(o.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)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"CREATE USER 'username' IDENTIFIED WITH AWSAuthenticationPlugin AS 'RDS';"}),(0,a.jsx)(r.HCh,{children:"GRANT SELECT, INSERT ON database.* TO 'username'@'%';"})]})]})]}),{}),tags:["Discovery","Detection"],enabledFeatures:[l.j.DATA_DISCOVERY]},H={placeholder:{name:"Amazon RDS Postgres",key:"rds_postgres_placeholder",connection_type:d.Rj.RDS_POSTGRES,access:d.uv.READ,created_at:""},category:n.DATABASE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Overview"}),(0,a.jsx)(o.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)(c,{children:[(0,a.jsx)(o.cB,{text:"Categories"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"Database"}),(0,a.jsx)(r.HCh,{children:"SQL database"}),(0,a.jsx)(r.HCh,{children:"Storage system"}),(0,a.jsx)(r.HCh,{children:"Data detection"}),(0,a.jsx)(r.HCh,{children:"Data discovery"})]}),(0,a.jsx)(o.cB,{text:"Permissions"}),(0,a.jsx)(o.XU,{children:"For detecting database RDS instances and clusters, Fides requires an IAM user with the following permissions/role:"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"rds:DescribeDBClusters"}),(0,a.jsx)(r.HCh,{children:"rds:DescribeDBInstances"}),(0,a.jsx)(r.HCh,{children:"rds-db:connect"})]}),(0,a.jsx)(o.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)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"CREATE USER username WITH LOGIN;"}),(0,a.jsx)(r.HCh,{children:"GRANT rds_iam TO username;"}),(0,a.jsx)(r.HCh,{children:"GRANT SELECT ON ALL TABLES IN SCHEMA public TO username;"}),(0,a.jsx)(r.HCh,{children:"GRANT ALL PRIVILEGES ON ALL TABLES IN SCHEMA public TO username;"})]})]})]}),{}),tags:["Discovery","Detection"],enabledFeatures:[l.j.DATA_DISCOVERY]},k={placeholder:{name:"Amazon S3",key:"s3_placeholder",connection_type:d.Rj.S3,access:d.uv.READ,created_at:""},category:n.DATA_WAREHOUSE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Overview"}),(0,a.jsx)(o.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)(c,{children:[(0,a.jsx)(o.cB,{text:"Categories"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"Object storage"}),(0,a.jsx)(r.HCh,{children:"Storage system"}),(0,a.jsx)(r.HCh,{children:"Cloud provider"}),(0,a.jsx)(r.HCh,{children:"Data detection"}),(0,a.jsx)(r.HCh,{children:"Data discovery"})]}),(0,a.jsx)(o.cB,{text:"Permissions"}),(0,a.jsx)(o.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)(o.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)(o.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)(o.cB,{text:"Permissions list"}),(0,a.jsx)(o.Z5,{children:(0,a.jsx)(r.HCh,{children:"AmazonS3ReadOnlyAccess"})})]})]}),{}),instructions:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Configuring a Fides -> Amazon S3 Integration"}),(0,a.jsx)(o.cB,{text:"Step 1: Create an IAM role in AWS"}),(0,a.jsx)(o.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)(c,{children:[(0,a.jsx)(o.cB,{text:"Step 2: Assign policies to the IAM role"}),(0,a.jsx)(o.XU,{children:"Grant the necessary permissions to the IAM role by attaching the following AWS-managed policy:"}),(0,a.jsx)(o.aG,{data:[{permission:"AmazonS3ReadOnlyAccess",description:"Provides read-only access to all buckets via the AWS Management Console."}]}),(0,a.jsx)(o.cB,{text:"Step 3: Create an IAM user for assuming a role"}),(0,a.jsxs)(o.XU,{children:["Follow the ",(0,a.jsx)(o.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)(o.cB,{text:"Step 4: Grant the IAM user permission to assume the Fides S3 Access Role"}),(0,a.jsx)(o.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)(o.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)(o.cB,{text:"Step 5: Create an access key for the IAM user"}),(0,a.jsxs)(o.vQ,{children:[(0,a.jsxs)(r.HCh,{children:["Create an access key for the IAM user under"," ",(0,a.jsx)("strong",{children:"Security credentials"}),"."]}),(0,a.jsx)(r.HCh,{children:"Select the Other use case"}),(0,a.jsx)(r.HCh,{children:"Copy the Access Key ID and Secret Access Key"})]}),(0,a.jsx)(o.cB,{text:"Step 6: Use the credentials to authenticate your integration"}),(0,a.jsxs)(o.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:[l.j.DATA_DISCOVERY]};var F=s(80388);let I={placeholder:{name:"Salesforce",key:"salesforce_placeholder",connection_type:s(88337).R.SAAS,saas_config:{fides_key:"salesforce",name:"Salesforce",type:F.m.SALESFORCE},access:d.uv.WRITE,created_at:""},category:n.CRM,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Overview"}),(0,a.jsx)(o.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)(c,{children:[(0,a.jsx)(o.cB,{text:"What this integration does"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"Discover personal data in standard Salesforce objects"}),(0,a.jsx)(r.HCh,{children:"Detect sensitive information across your Salesforce instance"}),(0,a.jsx)(r.HCh,{children:"Automate data subject access requests including data retrieval, updates, and deletions"}),(0,a.jsx)(r.HCh,{children:"Map Salesforce data to your organization's data map"}),(0,a.jsx)(r.HCh,{children:"Discover and map custom Salesforce objects (requires setting up a monitor)"})]}),(0,a.jsx)(o.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)(o.cB,{text:"Categories"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"CRM System"}),(0,a.jsx)(r.HCh,{children:"Data detection"}),(0,a.jsx)(r.HCh,{children:"Data discovery"}),(0,a.jsx)(r.HCh,{children:"DSR automation"})]}),(0,a.jsx)(o.cB,{text:"Prerequisites"}),(0,a.jsx)(o.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)(o.cB,{text:"Setup instructions"}),(0,a.jsx)(o.XU,{children:"Follow these steps to set up your Salesforce integration:"}),(0,a.jsxs)(o.vQ,{children:[(0,a.jsx)(r.HCh,{children:"Create a Connected App in Salesforce by following the Salesforce guide"}),(0,a.jsx)(r.HCh,{children:"Configure Basic Connected App Settings"}),(0,a.jsx)(r.HCh,{children:'Uncheck "Require Proof Key for Code Exchange (PKCE) Extension for Supported Authorization Flows"'}),(0,a.jsx)(r.HCh,{children:"Enable OAuth Settings for API Integration with the required scopes"}),(0,a.jsx)(r.HCh,{children:"Enter your Fides Redirect URL (typically https://fides-host.com/api/v1/oauth/callback)"})]}),(0,a.jsx)(o.cB,{text:"Required information"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"Domain: Your Salesforce URL"}),(0,a.jsx)(r.HCh,{children:"Consumer Key: Your OAuth client ID"}),(0,a.jsx)(r.HCh,{children:"Consumer Secret: Your OAuth client secret"}),(0,a.jsx)(r.HCh,{children:"Redirect URL: The Fides URL for OAuth callback"}),(0,a.jsx)(r.HCh,{children:"Token Refresh URL: The Salesforce URL for refresh tokens"})]}),(0,a.jsx)(o.cB,{text:"Required OAuth scopes"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"Manage user data via APIs (api)"}),(0,a.jsx)(r.HCh,{children:"Perform requests at any time (refresh_token, offline_access)"})]}),(0,a.jsx)(o.cB,{text:"Supported objects"}),(0,a.jsx)(o.XU,{children:"Fides supports both standard and custom Salesforce objects. The integration includes built-in support for common objects such as:"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"Contacts"}),(0,a.jsx)(r.HCh,{children:"Cases"}),(0,a.jsx)(r.HCh,{children:"Leads"}),(0,a.jsx)(r.HCh,{children:"Accounts"}),(0,a.jsx)(r.HCh,{children:"Campaign Members"}),(0,a.jsx)(r.HCh,{children:"Custom Objects"})]})]})]}),{}),tags:["API","DSR Automation","Discovery","Detection"],enabledFeatures:[l.j.DATA_DISCOVERY]},B={placeholder:{name:"Scylla",key:"scylla_placeholder",connection_type:d.Rj.SCYLLA,access:d.uv.READ,created_at:""},category:n.DATABASE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Overview"}),(0,a.jsx)(o.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)(c,{children:[(0,a.jsx)(o.cB,{text:"Categories"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"Database"}),(0,a.jsx)(r.HCh,{children:"NoSQL database"}),(0,a.jsx)(r.HCh,{children:"Storage system"}),(0,a.jsx)(r.HCh,{children:"Data detection"}),(0,a.jsx)(r.HCh,{children:"Data discovery"}),(0,a.jsx)(r.HCh,{children:"DSR automation"})]}),(0,a.jsx)(o.cB,{text:"Permissions"}),(0,a.jsx)(o.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)(o.cB,{text:"Permissions list"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"SELECT ALL KEYSPACES"}),(0,a.jsx)(r.HCh,{children:"MODIFY ALL KEYSPACES"})]})]})]}),{}),tags:["DSR Automation","Discovery","Detection"],enabledFeatures:[l.j.DATA_DISCOVERY]},O={placeholder:{name:"Snowflake",key:"snowflake_placeholder",connection_type:d.Rj.SNOWFLAKE,access:d.uv.READ,created_at:""},category:n.DATA_WAREHOUSE,overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Overview"}),(0,a.jsx)(o.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)(c,{children:[(0,a.jsx)(o.cB,{text:"Categories"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"Database"}),(0,a.jsx)(r.HCh,{children:"SQL database"}),(0,a.jsx)(r.HCh,{children:"Storage system"}),(0,a.jsx)(r.HCh,{children:"Data detection"}),(0,a.jsx)(r.HCh,{children:"Data discovery"})]}),(0,a.jsx)(o.cB,{text:"Permissions"}),(0,a.jsxs)(o.Z5,{children:[(0,a.jsx)(r.HCh,{children:"CREATE ROLE my_monitor_role;"}),(0,a.jsx)(r.HCh,{children:"GRANT USAGE ON DATABASE DATABASE_1 TO ROLE my_monitor_role;"}),(0,a.jsx)(r.HCh,{children:"GRANT USAGE ON SCHEMA DATABASE_1.TEST_SCHEMA TO ROLE my_monitor_role;"}),(0,a.jsx)(r.HCh,{children:"GRANT SELECT ON ALL TABLES IN SCHEMA DATABASE_1.TEST_SCHEMA TO ROLE my_monitor_role;"}),(0,a.jsx)(r.HCh,{children:"CREATE USER test_user PASSWORD='***';"}),(0,a.jsx)(r.HCh,{children:"GRANT ROLE my_monitor_role TO USER test_user;"})]})]})]}),{}),tags:["DSR Automation","Discovery","Detection"],enabledFeatures:[l.j.DATA_DISCOVERY]},L={placeholder:{name:"Website",key:"website_placeholder",connection_type:d.Rj.WEBSITE,access:d.uv.READ,created_at:""},category:n.WEBSITE,tags:["Consent","Discovery","Detection"],overview:(0,a.jsx)(()=>(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(o.cB,{text:"Overview"}),(0,a.jsx)(o.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:[l.j.DATA_DISCOVERY]},P=[I],N={[d.Rj.BIGQUERY]:x,[d.Rj.DATAHUB]:g,[d.Rj.DYNAMODB]:f,[d.Rj.GOOGLE_CLOUD_SQL_MYSQL]:C,[d.Rj.GOOGLE_CLOUD_SQL_POSTGRES]:S,[d.Rj.MSSQL]:b,[d.Rj.OKTA]:_,[d.Rj.RDS_MYSQL]:T,[d.Rj.RDS_POSTGRES]:H,[d.Rj.S3]:k,[d.Rj.SCYLLA]:B,[d.Rj.SNOWFLAKE]:O,[d.Rj.MYSQL]:D,[d.Rj.WEBSITE]:L,[d.Rj.POSTGRES]:E,[d.Rj.MANUAL_WEBHOOK]:A},M=[...Object.values(N),...P],U=[...Object.keys(N)],q={placeholder:{name:"",key:"placeholder",connection_type:d.Rj.MANUAL,access:d.uv.READ,created_at:""},category:n.DATA_WAREHOUSE,tags:[],enabledFeatures:[]};var z=(e,t)=>{if(!e)return q;if(e===d.Rj.SAAS&&t){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!==d.Rj.SAAS){let t=N[e];if(t)return t}return q}},93633:function(e,t,s){"use strict";s.d(t,{z:function(){return r}});var i=s(14047),n=s(62051),a=s(14207);let r=e=>{let{connection:t,connectionOption:s,testData:r}=e,[o]=(0,a.rO)(),{handleError:c}=(0,i.H)();return{handleAuthorize:async()=>{if(!(null==t?void 0:t.key)){n.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 i=s(27378),n=s(20682),a=s(88337);t.Z=(e,t)=>{let{data:s}=(0,n.$I)({});return(0,i.useMemo)(()=>e===a.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])}},11013:function(e,t,s){"use strict";s.d(t,{$y:function(){return a},eV:function(){return i},m5:function(){return o},ww:function(){return r}});let{useGetSharedMonitorConfigsQuery:i,useGetSharedMonitorConfigByIdQuery:n,useCreateSharedMonitorConfigMutation:a,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"]})})})},31883:function(e,t,s){"use strict";s.d(t,{Bw:function(){return i.Bw},D4:function(){return i.D4}});var i=s(19043)},72707:function(e){e.exports={option:"TaxonomySelect_option__vY6v2"}}}]);
@@ -1 +1 @@
1
- self.__BUILD_MANIFEST=function(s,e,t,a,c,n,i,d,o,r,p,u,g,f,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){return{__rewrites:{afterFiles:[],beforeFiles:[],fallback:[]},"/":[_,"static/chunks/pages/index-1adb6bcb71701ac2.js"],"/404":["static/chunks/pages/404-ac2f0844e5c4b4cd.js"],"/_error":["static/chunks/pages/_error-bede3a8288930dcf.js"],"/add-systems":[e,_,"static/chunks/pages/add-systems-587e21d14e0a5196.js"],"/add-systems/manual":[s,t,c,n,i,o,b,e,a,d,u,j,l,U,w,"static/chunks/pages/add-systems/manual-0a5f2310ce6b1059.js"],"/add-systems/multiple":[s,t,e,a,u,k,q,"static/chunks/pages/add-systems/multiple-00cb904825aad7e3.js"],"/consent":["static/chunks/pages/consent-4d5ea70a77df1bb8.js"],"/consent/configure":[s,t,e,a,u,k,"static/chunks/pages/consent/configure-f140ec9d8e8a0f7a.js"],"/consent/configure/add-vendors":[s,t,e,a,u,k,q,"static/chunks/pages/consent/configure/add-vendors-fa7305b88c1afd20.js"],"/consent/privacy-experience":[s,t,b,e,a,N,"static/chunks/pages/consent/privacy-experience-d8d926f0735a2546.js"],"/consent/privacy-experience/new":[c,n,g,A,r,h,S,"static/chunks/pages/consent/privacy-experience/new-a0039f216fb3eb93.js"],"/consent/privacy-experience/[id]":[c,n,g,A,r,h,S,"static/chunks/pages/consent/privacy-experience/[id]-0edb7c92518e7d21.js"],"/consent/privacy-notices":[s,t,e,a,N,"static/chunks/pages/consent/privacy-notices-1135ad8924d32c36.js"],"/consent/privacy-notices/new":[c,n,g,B,r,h,C,"static/chunks/pages/consent/privacy-notices/new-130155cfb4a0bcc7.js"],"/consent/privacy-notices/[id]":[c,n,g,B,r,h,C,"static/chunks/pages/consent/privacy-notices/[id]-5c949f2e3cef2398.js"],"/consent/properties":[s,t,e,a,z,"static/chunks/pages/consent/properties-776855e370414beb.js"],"/consent/reporting":[s,t,c,e,a,"static/chunks/pages/consent/reporting-21c23f75ff1135d9.js"],"/data-catalog":[s,t,c,n,i,e,a,d,"static/css/95ac327e5d70148d.css","static/chunks/pages/data-catalog-7b5aec33da578745.js"],"/data-catalog/[systemId]/projects":[s,t,c,n,i,e,a,d,v,p,"static/chunks/pages/data-catalog/[systemId]/projects-cfac259a30641e68.js"],"/data-catalog/[systemId]/projects/[projectUrn]":[s,t,e,a,D,"static/chunks/pages/data-catalog/[systemId]/projects/[projectUrn]-030ee304cbe5e530.js"],"/data-catalog/[systemId]/projects/[projectUrn]/[resourceUrn]":[s,t,c,n,i,e,a,d,v,E,p,"static/chunks/pages/data-catalog/[systemId]/projects/[projectUrn]/[resourceUrn]-c623d6f1a61c8ea9.js"],"/data-catalog/[systemId]/resources":[s,t,e,a,D,"static/chunks/pages/data-catalog/[systemId]/resources-51d99174c8006eb5.js"],"/data-catalog/[systemId]/resources/[resourceUrn]":[s,t,c,n,i,e,a,d,v,E,p,"static/chunks/pages/data-catalog/[systemId]/resources/[resourceUrn]-57bd5cdf784f059f.js"],"/data-discovery/action-center":[s,t,e,a,"static/chunks/pages/data-discovery/action-center-27205f8457a1ecb0.js"],"/data-discovery/action-center/[monitorId]":[s,t,c,n,i,e,a,I,"static/chunks/pages/data-discovery/action-center/[monitorId]-333f53caab751428.js"],"/data-discovery/action-center/[monitorId]/[systemId]":[s,t,c,n,i,e,a,d,u,l,"static/css/81642473e38c67a5.css","static/chunks/pages/data-discovery/action-center/[monitorId]/[systemId]-c948f93c833d4358.js"],"/data-discovery/activity":[s,t,e,a,m,"static/chunks/pages/data-discovery/activity-20a1043f6a06198f.js"],"/data-discovery/detection":[s,t,e,a,m,L,"static/chunks/pages/data-discovery/detection-faf326a6200637d0.js"],"/data-discovery/detection/[resourceUrn]":[s,t,e,a,m,L,"static/chunks/pages/data-discovery/detection/[resourceUrn]-06edce289876dea1.js"],"/data-discovery/discovery":[s,t,c,n,i,e,a,d,m,M,p,"static/chunks/pages/data-discovery/discovery-8c3e4be6d36da66d.js"],"/data-discovery/discovery/[resourceUrn]":[s,t,c,n,i,e,a,d,m,M,p,"static/chunks/pages/data-discovery/discovery/[resourceUrn]-64acf269256ee74f.js"],"/datamap":[s,t,"static/chunks/255-7db55b0e3a0f9dea.js",e,a,j,T,"static/chunks/pages/datamap-fb50de22f83edd4a.js"],"/dataset":[s,t,f,e,a,y,"static/chunks/pages/dataset-8f7d16bc5e9229c8.js"],"/dataset/new":[f,y,"static/chunks/pages/dataset/new-d4e31a1c4a58800e.js"],"/dataset/[datasetId]":[s,t,"static/chunks/9729-fcf6ff4e3534e4a8.js",e,a,F,"static/chunks/pages/dataset/[datasetId]-904d43e31157aa55.js"],"/dataset/[datasetId]/[collectionName]":[s,t,c,n,i,o,e,a,d,F,p,"static/chunks/pages/dataset/[datasetId]/[collectionName]-6e2caba24b3e78c2.js"],"/dataset/[datasetId]/[collectionName]/[...subfieldNames]":[s,t,c,n,i,o,e,a,d,F,p,"static/chunks/pages/dataset/[datasetId]/[collectionName]/[...subfieldNames]-41ab27c4195cfa93.js"],"/datastore-connection":["static/css/5f393dea1c0d031c.css","static/chunks/pages/datastore-connection-8f9b8890018e1ea5.js"],"/datastore-connection/new":[c,o,f,b,P,y,G,"static/chunks/pages/datastore-connection/new-e88509346b2d2851.js"],"/datastore-connection/[id]":[c,o,f,P,y,G,"static/chunks/pages/datastore-connection/[id]-4a33dd0371dbaebc.js"],"/fides-js-docs":["static/chunks/2fbcc6de-a6c61724c327e9fa.js","static/chunks/e3251fe7-5777b5d778e6fffa.js",c,n,i,o,f,H,"static/css/ab65b8cc3144bfc8.css","static/chunks/905-742074a074be1055.js","static/chunks/pages/fides-js-docs-5d8fd1af75f19e2f.js"],"/integrations":[s,t,c,n,i,o,g,J,e,a,K,p,"static/chunks/pages/integrations-adc286ff254e7f41.js"],"/integrations/[id]":[s,t,c,n,i,o,g,J,e,a,K,"static/css/e458b5f1afdbb7fc.css","static/chunks/pages/integrations/[id]-fdc2964fa7d1d8fd.js"],"/login":["static/chunks/pages/login-0cb0eb44bf2dd24c.js"],"/login/[provider]":["static/chunks/pages/login/[provider]-c58beef131c3a82d.js"],"/messaging":[s,t,c,n,i,e,a,"static/chunks/pages/messaging-aa744ae8b61e5ff2.js"],"/messaging/add-template":[r,O,"static/chunks/pages/messaging/add-template-f8fd4795e260887c.js"],"/messaging/[id]":[r,O,"static/chunks/pages/messaging/[id]-9b4d1d61c7c97509.js"],"/poc/ant-components":["static/chunks/pages/poc/ant-components-3407158757fb3627.js"],"/poc/form-experiments/AntForm":["static/chunks/pages/poc/form-experiments/AntForm-47e947c02ae90fd0.js"],"/poc/form-experiments/FormikAntFormItem":["static/chunks/pages/poc/form-experiments/FormikAntFormItem-24f9a44512ce8827.js"],"/poc/form-experiments/FormikControlled":["static/chunks/pages/poc/form-experiments/FormikControlled-e567a69f8c37fb9a.js"],"/poc/form-experiments/FormikField":["static/chunks/pages/poc/form-experiments/FormikField-35a33f9c7def2220.js"],"/poc/form-experiments/FormikSpreadField":[Q,"static/chunks/pages/poc/form-experiments/FormikSpreadField-af097d661f6abcf4.js"],"/poc/forms":[Q,"static/chunks/pages/poc/forms-780e18dde8e38099.js"],"/poc/table-migration":[u,k,"static/chunks/pages/poc/table-migration-7a17dffa515e5560.js"],"/privacy-requests":[s,t,e,a,R,"static/chunks/pages/privacy-requests-c4e1b69fb5bab61a.js"],"/privacy-requests/configure":["static/chunks/pages/privacy-requests/configure-1a1aa83a3f88844c.js"],"/privacy-requests/configure/messaging":["static/chunks/pages/privacy-requests/configure/messaging-b01cbbaac34dadbc.js"],"/privacy-requests/configure/storage":["static/chunks/pages/privacy-requests/configure/storage-a15410de7f1d0f84.js"],"/privacy-requests/[id]":[R,"static/css/5ded47c57dae5baf.css","static/chunks/pages/privacy-requests/[id]-91dd0039cc2b70bc.js"],"/properties":[s,t,e,a,z,"static/chunks/pages/properties-3a1037a2e036212a.js"],"/properties/add-property":[r,V,"static/chunks/pages/properties/add-property-9ccb295110feee20.js"],"/properties/[id]":[r,V,"static/chunks/pages/properties/[id]-19737d4f21aadbee.js"],"/reporting/datamap":[s,t,c,n,i,H,e,a,j,T,"static/chunks/pages/reporting/datamap-4cdbbb8cd1d8698e.js"],"/settings/about":["static/chunks/pages/settings/about-0e1c381d488a7ada.js"],"/settings/about/alpha":["static/chunks/pages/settings/about/alpha-965cc21889b25e44.js"],"/settings/consent":["static/chunks/pages/settings/consent-7796fbf458f8f159.js"],"/settings/consent/[configuration_id]/[purpose_id]":[s,t,e,a,"static/chunks/pages/settings/consent/[configuration_id]/[purpose_id]-d0e350d2a2667883.js"],"/settings/custom-fields":[s,t,e,a,"static/chunks/pages/settings/custom-fields-6f866bc799a5f67f.js"],"/settings/domain-records":[s,t,e,a,"static/chunks/pages/settings/domain-records-0b44b2b224077dcd.js"],"/settings/domains":["static/chunks/pages/settings/domains-5d00e1155bd11178.js"],"/settings/email-templates":["static/chunks/pages/settings/email-templates-d2cdbe770683e9df.js"],"/settings/locations":[s,W,I,"static/chunks/pages/settings/locations-811dadb489f23d7d.js"],"/settings/organization":["static/chunks/pages/settings/organization-24108f615ff5e1e7.js"],"/settings/regulations":[s,W,I,"static/chunks/pages/settings/regulations-54f142bc3e4c95ba.js"],"/systems":[s,t,e,a,"static/chunks/pages/systems-7b71274334c559a4.js"],"/systems/configure/[id]":[s,t,c,n,i,o,b,e,a,d,u,j,l,U,w,"static/chunks/pages/systems/configure/[id]-6eb886e7b7e6785b.js"],"/systems/configure/[id]/test-datasets":[f,"static/chunks/pages/systems/configure/[id]/test-datasets-fef247a87baeb080.js"],"/taxonomy":["static/chunks/678d4732-50255cc09048e643.js",c,n,i,g,"static/chunks/3983-17ae9c232bddc413.js","static/css/34a7eb08b86ddb57.css","static/chunks/pages/taxonomy-18534d2a79a3850b.js"],"/user-management":[x,"static/chunks/pages/user-management-dd43755b687c09a7.js"],"/user-management/new":[x,X,"static/chunks/pages/user-management/new-b124cc24b930c9e1.js"],"/user-management/profile/[id]":[x,X,"static/chunks/pages/user-management/profile/[id]-75d41fde668b9025.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/messaging","/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/organization","/settings/regulations","/systems","/systems/configure/[id]","/systems/configure/[id]/test-datasets","/taxonomy","/user-management","/user-management/new","/user-management/profile/[id]"]}}("static/chunks/c78d26b1-88a3e1bacb2a03c2.js","static/chunks/7553-a95939c32d54b5b7.js","static/chunks/6060-cb1ab5be7067bf7b.js","static/chunks/4481-f597a7cf03f8c9e1.js","static/chunks/2858-0b44609b6be7850b.js","static/chunks/2866-a73888c17a195cbe.js","static/chunks/9278-9b1b5970f0702668.js","static/chunks/409-037cfc3f096150f0.js","static/chunks/699-8ca44b0de9fa20f0.js","static/chunks/69-6889d6674c95e7b5.js","static/css/d2d4e9a6923e6730.css","static/chunks/401-fceaae662cfca5a5.js","static/chunks/3662-f6a1ddca5ee42076.js","static/chunks/6527-0eed08abe252a918.js","static/chunks/431-f72599f01b98f07d.js","static/chunks/5277-e8a036319456127f.js","static/chunks/9951-f9ab5cac7e2c05ab.js","static/chunks/3923-5d580fbb1dd6ae01.js","static/chunks/6277-3fb4c7fc790a6d20.js","static/chunks/5574-3cd33b3a6c937899.js","static/chunks/1040-630c7f4284dc6f70.js","static/chunks/6882-3cc73d407a088d7d.js","static/css/eb46b504bb5d980d.css","static/chunks/9226-ba6587e46ec7659a.js","static/chunks/3513-8677ee280eaef0da.js","static/css/972dc7eef106ee7c.css","static/chunks/3450-bdaeb35442d810b4.js","static/css/92fc10cc7ed1aba3.css","static/chunks/796-9a6b13c838e25538.js","static/chunks/6853-a4097260e402980e.js","static/chunks/3670-2abd9b2f17770872.js","static/chunks/1817-b4688ba5042ec687.js","static/chunks/6659-b2088f525bf13c17.js","static/chunks/6954-13a25cef3a8fdd76.js","static/chunks/79-5670e31eb65d0a53.js","static/chunks/3872-ffa16c2df7ef0ab6.js","static/chunks/3855-0dec3e7d9e886550.js","static/chunks/5309-4511df9708d5a63c.js","static/chunks/9046-fdf53cc7e926a8c1.js","static/chunks/4230-1cdb7ea1be370ed3.js","static/chunks/2430-b480401d44c55416.js","static/chunks/9767-e49b065d03ce4e80.js","static/chunks/2599-6c4d22e75028d8b6.js","static/chunks/1316-6cc72a45ebf7ff81.js","static/chunks/6662-cb11881dcaabe5e2.js","static/chunks/1100-d43cb04522a6505c.js","static/chunks/2921-aabf41bf3d7573f9.js","static/chunks/8433-adb1fcb29d82f1b7.js","static/chunks/4060-71cd041e5a57ca5a.js","static/chunks/3505-a79256cd851dfab4.js","static/chunks/4121-78a76e980acbd539.js"),self.__BUILD_MANIFEST_CB&&self.__BUILD_MANIFEST_CB();
1
+ self.__BUILD_MANIFEST=function(s,e,t,a,c,n,i,d,o,r,p,u,g,f,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){return{__rewrites:{afterFiles:[],beforeFiles:[],fallback:[]},"/":[_,"static/chunks/pages/index-1adb6bcb71701ac2.js"],"/404":["static/chunks/pages/404-ac2f0844e5c4b4cd.js"],"/_error":["static/chunks/pages/_error-bede3a8288930dcf.js"],"/add-systems":[e,_,"static/chunks/pages/add-systems-587e21d14e0a5196.js"],"/add-systems/manual":[s,t,c,n,i,o,b,e,a,d,u,j,l,U,w,"static/chunks/pages/add-systems/manual-0a5f2310ce6b1059.js"],"/add-systems/multiple":[s,t,e,a,u,k,q,"static/chunks/pages/add-systems/multiple-00cb904825aad7e3.js"],"/consent":["static/chunks/pages/consent-4d5ea70a77df1bb8.js"],"/consent/configure":[s,t,e,a,u,k,"static/chunks/pages/consent/configure-f140ec9d8e8a0f7a.js"],"/consent/configure/add-vendors":[s,t,e,a,u,k,q,"static/chunks/pages/consent/configure/add-vendors-fa7305b88c1afd20.js"],"/consent/privacy-experience":[s,t,b,e,a,N,"static/chunks/pages/consent/privacy-experience-d8d926f0735a2546.js"],"/consent/privacy-experience/new":[c,n,g,A,r,h,S,"static/chunks/pages/consent/privacy-experience/new-a0039f216fb3eb93.js"],"/consent/privacy-experience/[id]":[c,n,g,A,r,h,S,"static/chunks/pages/consent/privacy-experience/[id]-0edb7c92518e7d21.js"],"/consent/privacy-notices":[s,t,e,a,N,"static/chunks/pages/consent/privacy-notices-1135ad8924d32c36.js"],"/consent/privacy-notices/new":[c,n,g,B,r,h,C,"static/chunks/pages/consent/privacy-notices/new-130155cfb4a0bcc7.js"],"/consent/privacy-notices/[id]":[c,n,g,B,r,h,C,"static/chunks/pages/consent/privacy-notices/[id]-5c949f2e3cef2398.js"],"/consent/properties":[s,t,e,a,z,"static/chunks/pages/consent/properties-776855e370414beb.js"],"/consent/reporting":[s,t,c,e,a,"static/chunks/pages/consent/reporting-21c23f75ff1135d9.js"],"/data-catalog":[s,t,c,n,i,e,a,d,"static/css/95ac327e5d70148d.css","static/chunks/pages/data-catalog-7b5aec33da578745.js"],"/data-catalog/[systemId]/projects":[s,t,c,n,i,e,a,d,v,p,"static/chunks/pages/data-catalog/[systemId]/projects-cfac259a30641e68.js"],"/data-catalog/[systemId]/projects/[projectUrn]":[s,t,e,a,D,"static/chunks/pages/data-catalog/[systemId]/projects/[projectUrn]-030ee304cbe5e530.js"],"/data-catalog/[systemId]/projects/[projectUrn]/[resourceUrn]":[s,t,c,n,i,e,a,d,v,E,p,"static/chunks/pages/data-catalog/[systemId]/projects/[projectUrn]/[resourceUrn]-c623d6f1a61c8ea9.js"],"/data-catalog/[systemId]/resources":[s,t,e,a,D,"static/chunks/pages/data-catalog/[systemId]/resources-51d99174c8006eb5.js"],"/data-catalog/[systemId]/resources/[resourceUrn]":[s,t,c,n,i,e,a,d,v,E,p,"static/chunks/pages/data-catalog/[systemId]/resources/[resourceUrn]-57bd5cdf784f059f.js"],"/data-discovery/action-center":[s,t,e,a,"static/chunks/pages/data-discovery/action-center-27205f8457a1ecb0.js"],"/data-discovery/action-center/[monitorId]":[s,t,c,n,i,e,a,I,"static/chunks/pages/data-discovery/action-center/[monitorId]-333f53caab751428.js"],"/data-discovery/action-center/[monitorId]/[systemId]":[s,t,c,n,i,e,a,d,u,l,"static/css/81642473e38c67a5.css","static/chunks/pages/data-discovery/action-center/[monitorId]/[systemId]-c948f93c833d4358.js"],"/data-discovery/activity":[s,t,e,a,m,"static/chunks/pages/data-discovery/activity-20a1043f6a06198f.js"],"/data-discovery/detection":[s,t,e,a,m,L,"static/chunks/pages/data-discovery/detection-faf326a6200637d0.js"],"/data-discovery/detection/[resourceUrn]":[s,t,e,a,m,L,"static/chunks/pages/data-discovery/detection/[resourceUrn]-06edce289876dea1.js"],"/data-discovery/discovery":[s,t,c,n,i,e,a,d,m,M,p,"static/chunks/pages/data-discovery/discovery-8c3e4be6d36da66d.js"],"/data-discovery/discovery/[resourceUrn]":[s,t,c,n,i,e,a,d,m,M,p,"static/chunks/pages/data-discovery/discovery/[resourceUrn]-64acf269256ee74f.js"],"/datamap":[s,t,"static/chunks/255-7db55b0e3a0f9dea.js",e,a,j,T,"static/chunks/pages/datamap-fb50de22f83edd4a.js"],"/dataset":[s,t,f,e,a,y,"static/chunks/pages/dataset-8f7d16bc5e9229c8.js"],"/dataset/new":[f,y,"static/chunks/pages/dataset/new-d4e31a1c4a58800e.js"],"/dataset/[datasetId]":[s,t,"static/chunks/9729-fcf6ff4e3534e4a8.js",e,a,F,"static/chunks/pages/dataset/[datasetId]-904d43e31157aa55.js"],"/dataset/[datasetId]/[collectionName]":[s,t,c,n,i,o,e,a,d,F,p,"static/chunks/pages/dataset/[datasetId]/[collectionName]-6e2caba24b3e78c2.js"],"/dataset/[datasetId]/[collectionName]/[...subfieldNames]":[s,t,c,n,i,o,e,a,d,F,p,"static/chunks/pages/dataset/[datasetId]/[collectionName]/[...subfieldNames]-41ab27c4195cfa93.js"],"/datastore-connection":["static/css/5f393dea1c0d031c.css","static/chunks/pages/datastore-connection-8f9b8890018e1ea5.js"],"/datastore-connection/new":[c,o,f,b,P,y,G,"static/chunks/pages/datastore-connection/new-e88509346b2d2851.js"],"/datastore-connection/[id]":[c,o,f,P,y,G,"static/chunks/pages/datastore-connection/[id]-4a33dd0371dbaebc.js"],"/fides-js-docs":["static/chunks/2fbcc6de-a6c61724c327e9fa.js","static/chunks/e3251fe7-5777b5d778e6fffa.js",c,n,i,o,f,H,"static/css/ab65b8cc3144bfc8.css","static/chunks/905-742074a074be1055.js","static/chunks/pages/fides-js-docs-5d8fd1af75f19e2f.js"],"/integrations":[s,t,c,n,i,o,g,J,e,a,K,p,"static/chunks/pages/integrations-adc286ff254e7f41.js"],"/integrations/[id]":[s,t,c,n,i,o,g,J,e,a,K,"static/css/e458b5f1afdbb7fc.css","static/chunks/pages/integrations/[id]-fdc2964fa7d1d8fd.js"],"/login":["static/chunks/pages/login-0cb0eb44bf2dd24c.js"],"/login/[provider]":["static/chunks/pages/login/[provider]-c58beef131c3a82d.js"],"/messaging":[s,t,c,n,i,e,a,"static/chunks/pages/messaging-aa744ae8b61e5ff2.js"],"/messaging/add-template":[r,O,"static/chunks/pages/messaging/add-template-f8fd4795e260887c.js"],"/messaging/[id]":[r,O,"static/chunks/pages/messaging/[id]-9b4d1d61c7c97509.js"],"/poc/ant-components":["static/chunks/pages/poc/ant-components-3407158757fb3627.js"],"/poc/form-experiments/AntForm":["static/chunks/pages/poc/form-experiments/AntForm-47e947c02ae90fd0.js"],"/poc/form-experiments/FormikAntFormItem":["static/chunks/pages/poc/form-experiments/FormikAntFormItem-24f9a44512ce8827.js"],"/poc/form-experiments/FormikControlled":["static/chunks/pages/poc/form-experiments/FormikControlled-e567a69f8c37fb9a.js"],"/poc/form-experiments/FormikField":["static/chunks/pages/poc/form-experiments/FormikField-35a33f9c7def2220.js"],"/poc/form-experiments/FormikSpreadField":[Q,"static/chunks/pages/poc/form-experiments/FormikSpreadField-af097d661f6abcf4.js"],"/poc/forms":[Q,"static/chunks/pages/poc/forms-780e18dde8e38099.js"],"/poc/table-migration":[u,k,"static/chunks/pages/poc/table-migration-7a17dffa515e5560.js"],"/privacy-requests":[s,t,e,a,R,"static/chunks/pages/privacy-requests-c4e1b69fb5bab61a.js"],"/privacy-requests/configure":["static/chunks/pages/privacy-requests/configure-1a1aa83a3f88844c.js"],"/privacy-requests/configure/messaging":["static/chunks/pages/privacy-requests/configure/messaging-b01cbbaac34dadbc.js"],"/privacy-requests/configure/storage":["static/chunks/pages/privacy-requests/configure/storage-a15410de7f1d0f84.js"],"/privacy-requests/[id]":[R,"static/css/5ded47c57dae5baf.css","static/chunks/pages/privacy-requests/[id]-91dd0039cc2b70bc.js"],"/properties":[s,t,e,a,z,"static/chunks/pages/properties-3a1037a2e036212a.js"],"/properties/add-property":[r,V,"static/chunks/pages/properties/add-property-9ccb295110feee20.js"],"/properties/[id]":[r,V,"static/chunks/pages/properties/[id]-19737d4f21aadbee.js"],"/reporting/datamap":[s,t,c,n,i,H,e,a,j,T,"static/chunks/pages/reporting/datamap-4cdbbb8cd1d8698e.js"],"/settings/about":["static/chunks/pages/settings/about-0e1c381d488a7ada.js"],"/settings/about/alpha":["static/chunks/pages/settings/about/alpha-965cc21889b25e44.js"],"/settings/consent":["static/chunks/pages/settings/consent-7796fbf458f8f159.js"],"/settings/consent/[configuration_id]/[purpose_id]":[s,t,e,a,"static/chunks/pages/settings/consent/[configuration_id]/[purpose_id]-d0e350d2a2667883.js"],"/settings/custom-fields":[s,t,e,a,"static/chunks/pages/settings/custom-fields-6f866bc799a5f67f.js"],"/settings/domain-records":[s,t,e,a,"static/chunks/pages/settings/domain-records-0b44b2b224077dcd.js"],"/settings/domains":["static/chunks/pages/settings/domains-5d00e1155bd11178.js"],"/settings/email-templates":["static/chunks/pages/settings/email-templates-d2cdbe770683e9df.js"],"/settings/locations":[s,W,I,"static/chunks/pages/settings/locations-811dadb489f23d7d.js"],"/settings/organization":["static/chunks/pages/settings/organization-24108f615ff5e1e7.js"],"/settings/regulations":[s,W,I,"static/chunks/pages/settings/regulations-54f142bc3e4c95ba.js"],"/systems":[s,t,e,a,"static/chunks/pages/systems-7b71274334c559a4.js"],"/systems/configure/[id]":[s,t,c,n,i,o,b,e,a,d,u,j,l,U,w,"static/chunks/pages/systems/configure/[id]-6eb886e7b7e6785b.js"],"/systems/configure/[id]/test-datasets":[f,"static/chunks/pages/systems/configure/[id]/test-datasets-fef247a87baeb080.js"],"/taxonomy":["static/chunks/678d4732-50255cc09048e643.js",c,n,i,g,"static/chunks/3983-17ae9c232bddc413.js","static/css/34a7eb08b86ddb57.css","static/chunks/pages/taxonomy-18534d2a79a3850b.js"],"/user-management":[x,"static/chunks/pages/user-management-dd43755b687c09a7.js"],"/user-management/new":[x,X,"static/chunks/pages/user-management/new-b124cc24b930c9e1.js"],"/user-management/profile/[id]":[x,X,"static/chunks/pages/user-management/profile/[id]-75d41fde668b9025.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/messaging","/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/organization","/settings/regulations","/systems","/systems/configure/[id]","/systems/configure/[id]/test-datasets","/taxonomy","/user-management","/user-management/new","/user-management/profile/[id]"]}}("static/chunks/c78d26b1-88a3e1bacb2a03c2.js","static/chunks/7553-a95939c32d54b5b7.js","static/chunks/6060-cb1ab5be7067bf7b.js","static/chunks/4481-f597a7cf03f8c9e1.js","static/chunks/2858-0b44609b6be7850b.js","static/chunks/2866-a73888c17a195cbe.js","static/chunks/9278-9b1b5970f0702668.js","static/chunks/409-037cfc3f096150f0.js","static/chunks/699-8ca44b0de9fa20f0.js","static/chunks/69-6889d6674c95e7b5.js","static/css/d2d4e9a6923e6730.css","static/chunks/401-fceaae662cfca5a5.js","static/chunks/3662-f6a1ddca5ee42076.js","static/chunks/6527-0eed08abe252a918.js","static/chunks/431-f72599f01b98f07d.js","static/chunks/5277-e8a036319456127f.js","static/chunks/9951-f9ab5cac7e2c05ab.js","static/chunks/3923-5d580fbb1dd6ae01.js","static/chunks/6277-3fb4c7fc790a6d20.js","static/chunks/5574-3cd33b3a6c937899.js","static/chunks/1040-630c7f4284dc6f70.js","static/chunks/6882-3cc73d407a088d7d.js","static/css/eb46b504bb5d980d.css","static/chunks/9226-ba6587e46ec7659a.js","static/chunks/3513-8677ee280eaef0da.js","static/css/972dc7eef106ee7c.css","static/chunks/3450-bdaeb35442d810b4.js","static/css/92fc10cc7ed1aba3.css","static/chunks/796-9a6b13c838e25538.js","static/chunks/6853-a4097260e402980e.js","static/chunks/3670-2abd9b2f17770872.js","static/chunks/1817-b4688ba5042ec687.js","static/chunks/6659-b2088f525bf13c17.js","static/chunks/6954-13a25cef3a8fdd76.js","static/chunks/79-5670e31eb65d0a53.js","static/chunks/3872-ffa16c2df7ef0ab6.js","static/chunks/3855-0dec3e7d9e886550.js","static/chunks/5309-4511df9708d5a63c.js","static/chunks/9046-fdf53cc7e926a8c1.js","static/chunks/4230-1cdb7ea1be370ed3.js","static/chunks/2430-b480401d44c55416.js","static/chunks/9767-e49b065d03ce4e80.js","static/chunks/2599-6c4d22e75028d8b6.js","static/chunks/1316-6cc72a45ebf7ff81.js","static/chunks/6662-6a6b90fc8f11558f.js","static/chunks/1100-d43cb04522a6505c.js","static/chunks/2921-aabf41bf3d7573f9.js","static/chunks/8433-adb1fcb29d82f1b7.js","static/chunks/4060-71cd041e5a57ca5a.js","static/chunks/3505-a79256cd851dfab4.js","static/chunks/4121-78a76e980acbd539.js"),self.__BUILD_MANIFEST_CB&&self.__BUILD_MANIFEST_CB();
@@ -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/c693338e3bc8dcc6.css" as="style"/><link rel="stylesheet" href="/_next/static/css/c693338e3bc8dcc6.css" data-n-g=""/><link rel="preload" href="/_next/static/css/92fc10cc7ed1aba3.css" as="style"/><link rel="stylesheet" href="/_next/static/css/92fc10cc7ed1aba3.css" data-n-p=""/><noscript data-n-css=""></noscript><script defer="" nomodule="" src="/_next/static/chunks/polyfills-42372ed130431b0a.js"></script><script src="/_next/static/chunks/webpack-0a61b5bd21a41fe6.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-8ec6e466f3373ac0.js" defer=""></script><script src="/_next/static/chunks/c78d26b1-88a3e1bacb2a03c2.js" defer=""></script><script src="/_next/static/chunks/6060-cb1ab5be7067bf7b.js" defer=""></script><script src="/_next/static/chunks/2858-0b44609b6be7850b.js" defer=""></script><script src="/_next/static/chunks/2866-a73888c17a195cbe.js" defer=""></script><script src="/_next/static/chunks/9278-9b1b5970f0702668.js" defer=""></script><script src="/_next/static/chunks/699-8ca44b0de9fa20f0.js" defer=""></script><script src="/_next/static/chunks/5277-e8a036319456127f.js" defer=""></script><script src="/_next/static/chunks/7553-a95939c32d54b5b7.js" defer=""></script><script src="/_next/static/chunks/4481-f597a7cf03f8c9e1.js" defer=""></script><script src="/_next/static/chunks/409-037cfc3f096150f0.js" defer=""></script><script src="/_next/static/chunks/401-fceaae662cfca5a5.js" defer=""></script><script src="/_next/static/chunks/9951-f9ab5cac7e2c05ab.js" defer=""></script><script src="/_next/static/chunks/1040-630c7f4284dc6f70.js" defer=""></script><script src="/_next/static/chunks/3450-bdaeb35442d810b4.js" defer=""></script><script src="/_next/static/chunks/pages/add-systems/manual-0a5f2310ce6b1059.js" defer=""></script><script src="/_next/static/zBkPKRGECPjwEx0G7BvHe/_buildManifest.js" defer=""></script><script src="/_next/static/zBkPKRGECPjwEx0G7BvHe/_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":"/add-systems/manual","query":{},"buildId":"zBkPKRGECPjwEx0G7BvHe","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/c693338e3bc8dcc6.css" as="style"/><link rel="stylesheet" href="/_next/static/css/c693338e3bc8dcc6.css" data-n-g=""/><link rel="preload" href="/_next/static/css/92fc10cc7ed1aba3.css" as="style"/><link rel="stylesheet" href="/_next/static/css/92fc10cc7ed1aba3.css" data-n-p=""/><noscript data-n-css=""></noscript><script defer="" nomodule="" src="/_next/static/chunks/polyfills-42372ed130431b0a.js"></script><script src="/_next/static/chunks/webpack-0a61b5bd21a41fe6.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-8ec6e466f3373ac0.js" defer=""></script><script src="/_next/static/chunks/c78d26b1-88a3e1bacb2a03c2.js" defer=""></script><script src="/_next/static/chunks/6060-cb1ab5be7067bf7b.js" defer=""></script><script src="/_next/static/chunks/2858-0b44609b6be7850b.js" defer=""></script><script src="/_next/static/chunks/2866-a73888c17a195cbe.js" defer=""></script><script src="/_next/static/chunks/9278-9b1b5970f0702668.js" defer=""></script><script src="/_next/static/chunks/699-8ca44b0de9fa20f0.js" defer=""></script><script src="/_next/static/chunks/5277-e8a036319456127f.js" defer=""></script><script src="/_next/static/chunks/7553-a95939c32d54b5b7.js" defer=""></script><script src="/_next/static/chunks/4481-f597a7cf03f8c9e1.js" defer=""></script><script src="/_next/static/chunks/409-037cfc3f096150f0.js" defer=""></script><script src="/_next/static/chunks/401-fceaae662cfca5a5.js" defer=""></script><script src="/_next/static/chunks/9951-f9ab5cac7e2c05ab.js" defer=""></script><script src="/_next/static/chunks/1040-630c7f4284dc6f70.js" defer=""></script><script src="/_next/static/chunks/3450-bdaeb35442d810b4.js" defer=""></script><script src="/_next/static/chunks/pages/add-systems/manual-0a5f2310ce6b1059.js" defer=""></script><script src="/_next/static/hCJxUAFBWobWrps6RkP0K/_buildManifest.js" defer=""></script><script src="/_next/static/hCJxUAFBWobWrps6RkP0K/_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":"/add-systems/manual","query":{},"buildId":"hCJxUAFBWobWrps6RkP0K","nextExport":true,"autoExport":true,"isFallback":false,"scriptLoader":[]}</script></body></html>
@@ -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/c693338e3bc8dcc6.css" as="style"/><link rel="stylesheet" href="/_next/static/css/c693338e3bc8dcc6.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-0a61b5bd21a41fe6.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-8ec6e466f3373ac0.js" defer=""></script><script src="/_next/static/chunks/c78d26b1-88a3e1bacb2a03c2.js" defer=""></script><script src="/_next/static/chunks/6060-cb1ab5be7067bf7b.js" defer=""></script><script src="/_next/static/chunks/7553-a95939c32d54b5b7.js" defer=""></script><script src="/_next/static/chunks/4481-f597a7cf03f8c9e1.js" defer=""></script><script src="/_next/static/chunks/401-fceaae662cfca5a5.js" defer=""></script><script src="/_next/static/chunks/3923-5d580fbb1dd6ae01.js" defer=""></script><script src="/_next/static/chunks/796-9a6b13c838e25538.js" defer=""></script><script src="/_next/static/chunks/pages/add-systems/multiple-00cb904825aad7e3.js" defer=""></script><script src="/_next/static/zBkPKRGECPjwEx0G7BvHe/_buildManifest.js" defer=""></script><script src="/_next/static/zBkPKRGECPjwEx0G7BvHe/_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":"/add-systems/multiple","query":{},"buildId":"zBkPKRGECPjwEx0G7BvHe","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/c693338e3bc8dcc6.css" as="style"/><link rel="stylesheet" href="/_next/static/css/c693338e3bc8dcc6.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-0a61b5bd21a41fe6.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-8ec6e466f3373ac0.js" defer=""></script><script src="/_next/static/chunks/c78d26b1-88a3e1bacb2a03c2.js" defer=""></script><script src="/_next/static/chunks/6060-cb1ab5be7067bf7b.js" defer=""></script><script src="/_next/static/chunks/7553-a95939c32d54b5b7.js" defer=""></script><script src="/_next/static/chunks/4481-f597a7cf03f8c9e1.js" defer=""></script><script src="/_next/static/chunks/401-fceaae662cfca5a5.js" defer=""></script><script src="/_next/static/chunks/3923-5d580fbb1dd6ae01.js" defer=""></script><script src="/_next/static/chunks/796-9a6b13c838e25538.js" defer=""></script><script src="/_next/static/chunks/pages/add-systems/multiple-00cb904825aad7e3.js" defer=""></script><script src="/_next/static/hCJxUAFBWobWrps6RkP0K/_buildManifest.js" defer=""></script><script src="/_next/static/hCJxUAFBWobWrps6RkP0K/_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":"/add-systems/multiple","query":{},"buildId":"hCJxUAFBWobWrps6RkP0K","nextExport":true,"autoExport":true,"isFallback":false,"scriptLoader":[]}</script></body></html>
@@ -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/c693338e3bc8dcc6.css" as="style"/><link rel="stylesheet" href="/_next/static/css/c693338e3bc8dcc6.css" data-n-g=""/><link rel="preload" href="/_next/static/css/972dc7eef106ee7c.css" as="style"/><link rel="stylesheet" href="/_next/static/css/972dc7eef106ee7c.css" data-n-p=""/><noscript data-n-css=""></noscript><script defer="" nomodule="" src="/_next/static/chunks/polyfills-42372ed130431b0a.js"></script><script src="/_next/static/chunks/webpack-0a61b5bd21a41fe6.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-8ec6e466f3373ac0.js" defer=""></script><script src="/_next/static/chunks/7553-a95939c32d54b5b7.js" defer=""></script><script src="/_next/static/chunks/pages/add-systems-587e21d14e0a5196.js" defer=""></script><script src="/_next/static/zBkPKRGECPjwEx0G7BvHe/_buildManifest.js" defer=""></script><script src="/_next/static/zBkPKRGECPjwEx0G7BvHe/_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":"/add-systems","query":{},"buildId":"zBkPKRGECPjwEx0G7BvHe","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/c693338e3bc8dcc6.css" as="style"/><link rel="stylesheet" href="/_next/static/css/c693338e3bc8dcc6.css" data-n-g=""/><link rel="preload" href="/_next/static/css/972dc7eef106ee7c.css" as="style"/><link rel="stylesheet" href="/_next/static/css/972dc7eef106ee7c.css" data-n-p=""/><noscript data-n-css=""></noscript><script defer="" nomodule="" src="/_next/static/chunks/polyfills-42372ed130431b0a.js"></script><script src="/_next/static/chunks/webpack-0a61b5bd21a41fe6.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-8ec6e466f3373ac0.js" defer=""></script><script src="/_next/static/chunks/7553-a95939c32d54b5b7.js" defer=""></script><script src="/_next/static/chunks/pages/add-systems-587e21d14e0a5196.js" defer=""></script><script src="/_next/static/hCJxUAFBWobWrps6RkP0K/_buildManifest.js" defer=""></script><script src="/_next/static/hCJxUAFBWobWrps6RkP0K/_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":"/add-systems","query":{},"buildId":"hCJxUAFBWobWrps6RkP0K","nextExport":true,"autoExport":true,"isFallback":false,"scriptLoader":[]}</script></body></html>
@@ -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/c693338e3bc8dcc6.css" as="style"/><link rel="stylesheet" href="/_next/static/css/c693338e3bc8dcc6.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-0a61b5bd21a41fe6.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-8ec6e466f3373ac0.js" defer=""></script><script src="/_next/static/chunks/c78d26b1-88a3e1bacb2a03c2.js" defer=""></script><script src="/_next/static/chunks/6060-cb1ab5be7067bf7b.js" defer=""></script><script src="/_next/static/chunks/7553-a95939c32d54b5b7.js" defer=""></script><script src="/_next/static/chunks/4481-f597a7cf03f8c9e1.js" defer=""></script><script src="/_next/static/chunks/401-fceaae662cfca5a5.js" defer=""></script><script src="/_next/static/chunks/3923-5d580fbb1dd6ae01.js" defer=""></script><script src="/_next/static/chunks/796-9a6b13c838e25538.js" defer=""></script><script src="/_next/static/chunks/pages/consent/configure/add-vendors-fa7305b88c1afd20.js" defer=""></script><script src="/_next/static/zBkPKRGECPjwEx0G7BvHe/_buildManifest.js" defer=""></script><script src="/_next/static/zBkPKRGECPjwEx0G7BvHe/_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":"/consent/configure/add-vendors","query":{},"buildId":"zBkPKRGECPjwEx0G7BvHe","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/c693338e3bc8dcc6.css" as="style"/><link rel="stylesheet" href="/_next/static/css/c693338e3bc8dcc6.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-0a61b5bd21a41fe6.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-8ec6e466f3373ac0.js" defer=""></script><script src="/_next/static/chunks/c78d26b1-88a3e1bacb2a03c2.js" defer=""></script><script src="/_next/static/chunks/6060-cb1ab5be7067bf7b.js" defer=""></script><script src="/_next/static/chunks/7553-a95939c32d54b5b7.js" defer=""></script><script src="/_next/static/chunks/4481-f597a7cf03f8c9e1.js" defer=""></script><script src="/_next/static/chunks/401-fceaae662cfca5a5.js" defer=""></script><script src="/_next/static/chunks/3923-5d580fbb1dd6ae01.js" defer=""></script><script src="/_next/static/chunks/796-9a6b13c838e25538.js" defer=""></script><script src="/_next/static/chunks/pages/consent/configure/add-vendors-fa7305b88c1afd20.js" defer=""></script><script src="/_next/static/hCJxUAFBWobWrps6RkP0K/_buildManifest.js" defer=""></script><script src="/_next/static/hCJxUAFBWobWrps6RkP0K/_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":"/consent/configure/add-vendors","query":{},"buildId":"hCJxUAFBWobWrps6RkP0K","nextExport":true,"autoExport":true,"isFallback":false,"scriptLoader":[]}</script></body></html>