From a6e30b6bf819b6c64ce05c5264ac0cd6eae773d8 Mon Sep 17 00:00:00 2001
From: Michael Berntsen
Date: Wed, 17 Apr 2024 00:32:25 +0200
Subject: [PATCH 01/48] ci: add Azure Static Web Apps workflow file
on-behalf-of: @Azure opensource@microsoft.com
---
...tatic-web-apps-polite-forest-010314b03.yml | 46 +++++++++++++++++++
1 file changed, 46 insertions(+)
create mode 100644 .github/workflows/azure-static-web-apps-polite-forest-010314b03.yml
diff --git a/.github/workflows/azure-static-web-apps-polite-forest-010314b03.yml b/.github/workflows/azure-static-web-apps-polite-forest-010314b03.yml
new file mode 100644
index 000000000000..96f59ce2d7fa
--- /dev/null
+++ b/.github/workflows/azure-static-web-apps-polite-forest-010314b03.yml
@@ -0,0 +1,46 @@
+name: Azure Static Web Apps CI/CD
+
+on:
+ push:
+ branches:
+ - main
+ pull_request:
+ types: [opened, synchronize, reopened, closed]
+ branches:
+ - main
+
+jobs:
+ build_and_deploy_job:
+ if: github.event_name == 'push' || (github.event_name == 'pull_request' && github.event.action != 'closed')
+ runs-on: ubuntu-latest
+ name: Build and Deploy Job
+ steps:
+ - uses: actions/checkout@v3
+ with:
+ submodules: true
+ lfs: false
+ - name: Build And Deploy
+ id: builddeploy
+ uses: Azure/static-web-apps-deploy@v1
+ with:
+ azure_static_web_apps_api_token: ${{ secrets.AZURE_STATIC_WEB_APPS_API_TOKEN_POLITE_FOREST_010314B03 }}
+ repo_token: ${{ secrets.GITHUB_TOKEN }} # Used for Github integrations (i.e. PR comments)
+ action: "upload"
+ ###### Repository/Build Configurations - These values can be configured to match your app requirements. ######
+ # For more information regarding Static Web App workflow configurations, please visit: https://aka.ms/swaworkflowconfig
+ app_location: "/" # App source code path
+ api_location: "" # Api source code path - optional
+ output_location: "" # Built app content directory - optional
+ ###### End of Repository/Build Configurations ######
+
+ close_pull_request_job:
+ if: github.event_name == 'pull_request' && github.event.action == 'closed'
+ runs-on: ubuntu-latest
+ name: Close Pull Request Job
+ steps:
+ - name: Close Pull Request
+ id: closepullrequest
+ uses: Azure/static-web-apps-deploy@v1
+ with:
+ azure_static_web_apps_api_token: ${{ secrets.AZURE_STATIC_WEB_APPS_API_TOKEN_POLITE_FOREST_010314B03 }}
+ action: "close"
From 34e8a8d55ff01d4d7de18fd4e28a1e499bb4a1ef Mon Sep 17 00:00:00 2001
From: Michael Berntsen
Date: Thu, 15 Aug 2024 14:12:26 +0200
Subject: [PATCH 02/48] Update
azure-static-web-apps-polite-forest-010314b03.yml
---
.../azure-static-web-apps-polite-forest-010314b03.yml | 5 +----
1 file changed, 1 insertion(+), 4 deletions(-)
diff --git a/.github/workflows/azure-static-web-apps-polite-forest-010314b03.yml b/.github/workflows/azure-static-web-apps-polite-forest-010314b03.yml
index 96f59ce2d7fa..59c26e998103 100644
--- a/.github/workflows/azure-static-web-apps-polite-forest-010314b03.yml
+++ b/.github/workflows/azure-static-web-apps-polite-forest-010314b03.yml
@@ -4,10 +4,7 @@ on:
push:
branches:
- main
- pull_request:
- types: [opened, synchronize, reopened, closed]
- branches:
- - main
+
jobs:
build_and_deploy_job:
From c880aad889c50615269d8cccb1e63e6e17b3c6d8 Mon Sep 17 00:00:00 2001
From: MoltenTesseract
Date: Tue, 20 Aug 2024 09:33:27 +1000
Subject: [PATCH 03/48] Delete exchange rule confirmation fixed
Delete exchange rule confirmation text still said disable rule instead of delete.
---
src/views/email-exchange/transport/TransportRules.jsx | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/src/views/email-exchange/transport/TransportRules.jsx b/src/views/email-exchange/transport/TransportRules.jsx
index 9d534e17dee5..549f245a2ea5 100644
--- a/src/views/email-exchange/transport/TransportRules.jsx
+++ b/src/views/email-exchange/transport/TransportRules.jsx
@@ -57,7 +57,7 @@ const Offcanvas = (row, rowIndex, formatExtraData) => {
modal: true,
icon: ,
modalUrl: `/api/RemoveTransportRule?TenantFilter=${tenant.defaultDomainName}&GUID=${row.Guid}`,
- modalMessage: 'Are you sure you want to disable this rule?',
+ modalMessage: 'Are you sure you want to delete this rule?',
},
]}
placement="end"
From a00ba2fd7083336e224f10895f58eb61070caaf5 Mon Sep 17 00:00:00 2001
From: MoltenTesseract
Date: Tue, 20 Aug 2024 12:40:24 +1000
Subject: [PATCH 04/48] Fix flyout extended information and incorrect wording
Flyout extended information was pulling the incorrect columns, so all info was showing as 'undefined' .
Updated all references to "rule" and replaced with "connector".
---
.../connectors/ConnectorList.jsx | 24 ++++++++++---------
1 file changed, 13 insertions(+), 11 deletions(-)
diff --git a/src/views/email-exchange/connectors/ConnectorList.jsx b/src/views/email-exchange/connectors/ConnectorList.jsx
index 1f3829abcb1d..c5c2b2d0951a 100644
--- a/src/views/email-exchange/connectors/ConnectorList.jsx
+++ b/src/views/email-exchange/connectors/ConnectorList.jsx
@@ -20,44 +20,46 @@ const Offcanvas = (row, rowIndex, formatExtraData) => {
,
modalBody: row,
modalType: 'POST',
modalUrl: `/api/AddExConnectorTemplate`,
- modalMessage: 'Are you sure you want to create a template based on this rule?',
+ modalMessage: 'Are you sure you want to create a template based on this connector?',
},
{
- label: 'Enable Rule',
+ label: 'Enable Connector',
color: 'info',
icon: ,
modal: true,
modalUrl: `/api/EditExConnector?State=Enable&TenantFilter=${tenant.defaultDomainName}&GUID=${row.Guid}&Type=${row.cippconnectortype}`,
- modalMessage: 'Are you sure you want to enable this rule?',
+ modalMessage: 'Are you sure you want to enable this connector?',
},
{
- label: 'Disable Rule',
+ label: 'Disable Connector',
color: 'info',
icon: ,
modal: true,
modalUrl: `/api/EditExConnector?State=Disable&TenantFilter=${tenant.defaultDomainName}&GUID=${row.Guid}&Type=${row.cippconnectortype}`,
- modalMessage: 'Are you sure you want to disable this rule?',
+ modalMessage: 'Are you sure you want to disable this connector?',
},
{
- label: 'Delete Rule',
+ label: 'Delete Connector',
color: 'danger',
modal: true,
icon: ,
modalUrl: `/api/RemoveExConnector?TenantFilter=${tenant.defaultDomainName}&GUID=${row.Guid}&Type=${row.cippconnectortype}`,
- modalMessage: 'Are you sure you want to delete this rule?',
+ modalMessage: 'Are you sure you want to delete this connector?',
},
]}
placement="end"
From 2894f938faff881d468349131df01a57114d0254 Mon Sep 17 00:00:00 2001
From: Esco
Date: Sat, 17 Aug 2024 12:03:10 +0200
Subject: [PATCH 05/48] Improvements to MEMListPolicies
---
.../endpoint/intune/MEMListCompliance.jsx | 1 +
src/views/endpoint/intune/MEMListPolicies.jsx | 32 +++++++++++++++++++
2 files changed, 33 insertions(+)
diff --git a/src/views/endpoint/intune/MEMListCompliance.jsx b/src/views/endpoint/intune/MEMListCompliance.jsx
index 328a387566fd..87c2fdfabdf3 100644
--- a/src/views/endpoint/intune/MEMListCompliance.jsx
+++ b/src/views/endpoint/intune/MEMListCompliance.jsx
@@ -138,6 +138,7 @@ const ComplianceList = () => {
Endpoint: 'deviceManagement/deviceCompliancePolicies',
$orderby: 'displayName',
$count: true,
+ $expand: 'assignments',
},
columns,
reportName: `${tenant?.defaultDomainName}-MEMPolicies-List`,
diff --git a/src/views/endpoint/intune/MEMListPolicies.jsx b/src/views/endpoint/intune/MEMListPolicies.jsx
index f63db28effef..725c4cc0cd42 100644
--- a/src/views/endpoint/intune/MEMListPolicies.jsx
+++ b/src/views/endpoint/intune/MEMListPolicies.jsx
@@ -15,6 +15,7 @@ import { CippPageList } from 'src/components/layout'
import { Link } from 'react-router-dom'
import { CippActionsOffcanvas, CippCodeBlock } from 'src/components/utilities'
import { TitleButton } from 'src/components/buttons'
+import { cellBooleanFormatter, cellDateFormatter } from 'src/components/tables'
const Actions = (row, rowIndex, formatExtraData) => {
const [ocVisible, setOCVisible] = useState(false)
@@ -90,12 +91,43 @@ const columns = [
name: 'Name',
sortable: true,
exportSelector: 'displayName',
+ maxWidth: 'auto',
},
{
selector: (row) => row['PolicyTypeName'],
name: 'Profile Type',
sortable: true,
exportSelector: 'PolicyTypeName',
+ maxWidth: '300px',
+ },
+ {
+ selector: (row) => row['PolicyAssignment'],
+ name: 'Assigned',
+ sortable: true,
+ exportSelector: 'PolicyAssignment',
+ maxWidth: '300px',
+ },
+ {
+ selector: (row) => row['PolicyExclude'],
+ name: 'Excluded',
+ sortable: true,
+ exportSelector: 'PolicyExclude',
+ maxWidth: '300px',
+ },
+ {
+ selector: (row) => row['description'],
+ name: 'Description',
+ sortable: true,
+ exportSelector: 'description',
+ maxWidth: 'auto',
+ },
+ {
+ selector: (row) => row['lastModifiedDateTime'],
+ name: 'Last Modified',
+ sortable: true,
+ exportSelector: 'lastModifiedDateTime',
+ cell: cellDateFormatter({ format: 'relative' }),
+ maxWidth: '150px',
},
{
selector: (row) => row['id'],
From a1ce07dd3165310b15a854fb7099672fcbedabb5 Mon Sep 17 00:00:00 2001
From: John Duprey
Date: Wed, 21 Aug 2024 16:09:27 -0400
Subject: [PATCH 06/48] Add owner property to anonymization check
---
src/components/tables/CippDatatable.jsx | 10 ++++++----
1 file changed, 6 insertions(+), 4 deletions(-)
diff --git a/src/components/tables/CippDatatable.jsx b/src/components/tables/CippDatatable.jsx
index 125eeda3e00a..7d00d9730e82 100644
--- a/src/components/tables/CippDatatable.jsx
+++ b/src/components/tables/CippDatatable.jsx
@@ -14,16 +14,18 @@ export default function CippDatatable({ path, params, ...rest }) {
refetch,
} = useListDatatableQuery({ path, params: { $filter: graphFilter, ...params } })
- let anonimized = false // Assuming default value is false
+ let anonymized = false // Assuming default value is false
const regex = new RegExp('^[A-Z0-9]+$')
const principalNameOrUPN =
data[0]?.userPrincipalName ??
data[0]?.UPN ??
+ data[0]?.Owner ??
data.Results?.[0]?.upn ??
- data.Results?.[0]?.userPrincipalName
+ data.Results?.[0]?.userPrincipalName ??
+ data.Results?.[0]?.Owner
if (principalNameOrUPN && regex.test(principalNameOrUPN)) {
- anonimized = true
+ anonymized = true
}
var defaultFilterText = ''
@@ -32,7 +34,7 @@ export default function CippDatatable({ path, params, ...rest }) {
}
return (
<>
- {anonimized && (
+ {anonymized && (
This table might contain anonymized data. Please check this
Date: Wed, 21 Aug 2024 16:09:52 -0400
Subject: [PATCH 07/48] Extend permission builder for app approval
---
.../utilities/CippAppPermissionBuilder.jsx | 138 ++++++++++++------
1 file changed, 92 insertions(+), 46 deletions(-)
diff --git a/src/components/utilities/CippAppPermissionBuilder.jsx b/src/components/utilities/CippAppPermissionBuilder.jsx
index c986b67145f2..69d6c8c516d3 100644
--- a/src/components/utilities/CippAppPermissionBuilder.jsx
+++ b/src/components/utilities/CippAppPermissionBuilder.jsx
@@ -34,7 +34,14 @@ import { Editor } from '@monaco-editor/react'
import { useSelector } from 'react-redux'
import { CippCallout } from '../layout'
-const CippAppPermissionBuilder = ({ onSubmit, currentPermissions = {}, isSubmitting }) => {
+const CippAppPermissionBuilder = ({
+ onSubmit,
+ currentPermissions = {},
+ isSubmitting,
+ colSize = 8,
+ removePermissionConfirm = true,
+ appDisplayName = 'CIPP-SAM',
+}) => {
const [selectedApp, setSelectedApp] = useState([])
const [permissionsImported, setPermissionsImported] = useState(false)
const [newPermissions, setNewPermissions] = useState({})
@@ -42,6 +49,7 @@ const CippAppPermissionBuilder = ({ onSubmit, currentPermissions = {}, isSubmitt
const [manifestVisible, setManifestVisible] = useState(false)
const currentTheme = useSelector((state) => state.app.currentTheme)
const [calloutMessage, setCalloutMessage] = useState(null)
+ const [initialPermissions, setInitialPermissions] = useState()
const {
data: servicePrincipals = [],
@@ -59,35 +67,49 @@ const CippAppPermissionBuilder = ({ onSubmit, currentPermissions = {}, isSubmitt
var servicePrincipal = selectedApp.find((sp) => sp?.appId === appId)
var newServicePrincipals = selectedApp.filter((sp) => sp?.appId !== appId)
- ModalService.confirm({
- title: 'Remove Service Principal',
- body: `Are you sure you want to remove ${servicePrincipal.displayName}?`,
- onConfirm: () => {
- setSelectedApp(newServicePrincipals)
- var updatedPermissions = JSON.parse(JSON.stringify(newPermissions))
- delete updatedPermissions.Permissions[appId]
- setNewPermissions(updatedPermissions)
- },
- })
+ if (removePermissionConfirm) {
+ ModalService.confirm({
+ title: 'Remove Service Principal',
+ body: `Are you sure you want to remove ${servicePrincipal.displayName}?`,
+ onConfirm: () => {
+ setSelectedApp(newServicePrincipals)
+ var updatedPermissions = JSON.parse(JSON.stringify(newPermissions))
+ delete updatedPermissions.Permissions[appId]
+ setNewPermissions(updatedPermissions)
+ },
+ })
+ } else {
+ setSelectedApp(newServicePrincipals)
+ var updatedPermissions = JSON.parse(JSON.stringify(newPermissions))
+ delete updatedPermissions.Permissions[appId]
+ setNewPermissions(updatedPermissions)
+ }
}
const confirmReset = () => {
- ModalService.confirm({
- title: 'Reset to Default',
- body: 'Are you sure you want to reset all permissions to default?',
- onConfirm: () => {
- setSelectedApp([])
- setPermissionsImported(false)
- setManifestVisible(false)
- setCalloutMessage('Permissions reset to default.')
- },
- })
+ if (removePermissionConfirm) {
+ ModalService.confirm({
+ title: 'Reset to Default',
+ body: 'Are you sure you want to reset all permissions to default?',
+ onConfirm: () => {
+ setSelectedApp([])
+ setPermissionsImported(false)
+ setManifestVisible(false)
+ setCalloutMessage('Permissions reset to default.')
+ },
+ })
+ } else {
+ setSelectedApp([])
+ setPermissionsImported(false)
+ setManifestVisible(false)
+ setCalloutMessage('Permissions reset to default.')
+ }
}
const handleSubmit = (values) => {
if (onSubmit) {
var postBody = {
- Permissions: newPermissions,
+ Permissions: newPermissions.Permissions,
}
onSubmit(postBody)
}
@@ -127,30 +149,43 @@ const CippAppPermissionBuilder = ({ onSubmit, currentPermissions = {}, isSubmitt
}
const removePermissionRow = (servicePrincipal, permissionType, permissionId, permissionValue) => {
- // modal confirm
- ModalService.confirm({
- title: 'Remove Permission',
- body: `Are you sure you want to remove the permission: ${permissionValue}?`,
- onConfirm: () => {
- var updatedPermissions = JSON.parse(JSON.stringify(newPermissions))
- var currentPermission = updatedPermissions?.Permissions[servicePrincipal][permissionType]
- var newPermission = []
- if (currentPermission) {
- currentPermission.map((perm) => {
- if (perm.id !== permissionId) {
- newPermission.push(perm)
- }
- })
- }
- updatedPermissions.Permissions[servicePrincipal][permissionType] = newPermission
- setNewPermissions(updatedPermissions)
- },
- })
+ if (removePermissionConfirm) {
+ ModalService.confirm({
+ title: 'Remove Permission',
+ body: `Are you sure you want to remove the permission: ${permissionValue}?`,
+ onConfirm: () => {
+ var updatedPermissions = JSON.parse(JSON.stringify(newPermissions))
+ var currentPermission = updatedPermissions?.Permissions[servicePrincipal][permissionType]
+ var newPermission = []
+ if (currentPermission) {
+ currentPermission.map((perm) => {
+ if (perm.id !== permissionId) {
+ newPermission.push(perm)
+ }
+ })
+ }
+ updatedPermissions.Permissions[servicePrincipal][permissionType] = newPermission
+ setNewPermissions(updatedPermissions)
+ },
+ })
+ } else {
+ var updatedPermissions = JSON.parse(JSON.stringify(newPermissions))
+ var currentPermission = updatedPermissions?.Permissions[servicePrincipal][permissionType]
+ var newPermission = []
+ if (currentPermission) {
+ currentPermission.map((perm) => {
+ if (perm.id !== permissionId) {
+ newPermission.push(perm)
+ }
+ })
+ }
+ updatedPermissions.Permissions[servicePrincipal][permissionType] = newPermission
+ setNewPermissions(updatedPermissions)
+ }
}
- const generateManifest = (appDisplayName = 'CIPP-SAM', prompt = false) => {
- if (prompt) {
- // modal input form for appDisplayName
+ const generateManifest = ({ appDisplayName = 'CIPP-SAM', prompt = false }) => {
+ if (prompt || appDisplayName === '') {
ModalService.prompt({
title: 'Generate Manifest',
body: 'Please enter the display name for the application.',
@@ -337,6 +372,11 @@ const CippAppPermissionBuilder = ({ onSubmit, currentPermissions = {}, isSubmitt
},
},
})
+ } else if (spSuccess & (currentPermissions !== initialPermissions)) {
+ setSelectedApp([])
+ setNewPermissions(currentPermissions)
+ setInitialPermissions(currentPermissions)
+ setPermissionsImported(false)
} else if (spSuccess && initialAppIds.length > 0 && permissionsImported == false) {
var newApps = []
initialAppIds?.map((appId) => {
@@ -350,10 +390,12 @@ const CippAppPermissionBuilder = ({ onSubmit, currentPermissions = {}, isSubmitt
})
setSelectedApp(newApps)
setNewPermissions(currentPermissions)
+ setInitialPermissions(currentPermissions)
setPermissionsImported(true)
}
}, [
currentPermissions,
+ initialPermissions,
permissionsImported,
spSuccess,
selectedApp,
@@ -361,6 +403,7 @@ const CippAppPermissionBuilder = ({ onSubmit, currentPermissions = {}, isSubmitt
setSelectedApp,
setPermissionsImported,
setNewPermissions,
+ setInitialPermissions,
])
const ApiPermissionRow = ({ servicePrincipal = null }) => {
@@ -679,7 +722,7 @@ const CippAppPermissionBuilder = ({ onSubmit, currentPermissions = {}, isSubmitt
return (
-
+
{servicePrincipals?.Metadata?.Success && (
@@ -738,7 +781,7 @@ const CippAppPermissionBuilder = ({ onSubmit, currentPermissions = {}, isSubmitt
{
- generateManifest()
+ generateManifest({ appDisplayName: appDisplayName })
}}
className={`circular-button`}
title={'+'}
@@ -957,6 +1000,9 @@ CippAppPermissionBuilder.propTypes = {
onSubmit: PropTypes.func,
currentPermissions: PropTypes.object,
isSubmitting: PropTypes.bool,
+ colSize: PropTypes.number,
+ removePermissionConfirm: PropTypes.bool,
+ appDisplayName: PropTypes.string,
}
export default CippAppPermissionBuilder
From be79c62682621c1c145eb726c3cc5d262c8a8587 Mon Sep 17 00:00:00 2001
From: John Duprey
Date: Wed, 21 Aug 2024 16:10:08 -0400
Subject: [PATCH 08/48] approval template page
---
src/views/cipp/AppApprovalTemplates.jsx | 140 ++++++++++++++++++++++++
1 file changed, 140 insertions(+)
create mode 100644 src/views/cipp/AppApprovalTemplates.jsx
diff --git a/src/views/cipp/AppApprovalTemplates.jsx b/src/views/cipp/AppApprovalTemplates.jsx
new file mode 100644
index 000000000000..6f9159565dcd
--- /dev/null
+++ b/src/views/cipp/AppApprovalTemplates.jsx
@@ -0,0 +1,140 @@
+import React from 'react'
+import {
+ CCol,
+ CRow,
+ CCallout,
+ CSpinner,
+ CButton,
+ CFormInput,
+ CFormLabel,
+ CTooltip,
+} from '@coreui/react'
+import { Field, Form, FormSpy } from 'react-final-form'
+import { FontAwesomeIcon } from '@fortawesome/react-fontawesome'
+import { faExclamationTriangle } from '@fortawesome/free-solid-svg-icons'
+import { CippPageList, CippWizard } from 'src/components/layout'
+import { cellDateFormatter, CippTable, WizardTableField } from 'src/components/tables'
+import PropTypes from 'prop-types'
+import {
+ Condition,
+ RFFCFormCheck,
+ RFFCFormInput,
+ RFFCFormSwitch,
+ RFFSelectSearch,
+} from 'src/components/forms'
+import { useLazyGenericPostRequestQuery } from 'src/store/api/app'
+import CippButtonCard from 'src/components/contentcards/CippButtonCard'
+import { cellGenericFormatter } from 'src/components/tables/CellGenericFormat'
+import { CippOffcanvas } from 'src/components/utilities'
+import CippAppPermissionBuilder from 'src/components/utilities/CippAppPermissionBuilder'
+
+const AppApprovalTemplates = () => {
+ const [editorVisible, setEditorVisible] = React.useState(false)
+ const [selectedTemplate, setSelectedTemplate] = React.useState(null)
+ const templateNameRef = React.useRef(null)
+ const [genericPostRequest, postResults] = useLazyGenericPostRequestQuery()
+
+ const onSubmit = (values) => {
+ var body = {
+ TemplateName: templateNameRef.current.value,
+ Permissions: values.Permissions,
+ }
+ if (selectedTemplate?.TemplateId) {
+ body.TemplateId = selectedTemplate.TemplateId
+ }
+
+ console.log(body)
+ genericPostRequest({
+ path: '/api/ExecAppPermissionTemplate?Action=Save',
+ values: body,
+ }).then(() => {})
+ }
+ const titleButton = (
+ {
+ setSelectedTemplate({})
+ templateNameRef.current.value = ''
+ setEditorVisible(true)
+ }}
+ >
+ Add Template
+
+ )
+ return (
+ <>
+ row['TemplateName'],
+ sortable: true,
+ exportSelector: 'TemplateName',
+ },
+ {
+ name: 'Updated By',
+ selector: (row) => row['UpdatedBy'],
+ sortable: true,
+ exportSelector: 'UpdatedBy',
+ },
+ {
+ name: 'Updated At',
+ selector: (row) => row['Timestamp'],
+ sortable: true,
+ exportSelector: 'Timestamp',
+ cell: cellDateFormatter({ format: 'short' }),
+ },
+ {
+ name: 'Actions',
+ cell: (row) => (
+
+ {
+ setSelectedTemplate(row)
+ templateNameRef.current.value = row.TemplateName
+ setEditorVisible(true)
+ }}
+ >
+
+
+
+ ),
+ },
+ ],
+ reportName: 'AppApprovalTemplates',
+ }}
+ />
+ setEditorVisible(false)}
+ >
+ Template Name
+
+ Permissions
+
+
+ >
+ )
+}
+
+export default AppApprovalTemplates
From 8ecaf078015c56cfd83c5ef08a0c97ca81f15cf5 Mon Sep 17 00:00:00 2001
From: John Duprey
Date: Wed, 21 Aug 2024 16:41:20 -0400
Subject: [PATCH 09/48] Hide permission builder while loading
---
.../components/SettingsAppPermissions.jsx | 15 ++++++++++-----
1 file changed, 10 insertions(+), 5 deletions(-)
diff --git a/src/views/cipp/app-settings/components/SettingsAppPermissions.jsx b/src/views/cipp/app-settings/components/SettingsAppPermissions.jsx
index d36dffb0b597..55a56aea7f5e 100644
--- a/src/views/cipp/app-settings/components/SettingsAppPermissions.jsx
+++ b/src/views/cipp/app-settings/components/SettingsAppPermissions.jsx
@@ -21,6 +21,7 @@ import { useListTenantsQuery } from 'src/store/api/tenants'
import { OffcanvasListSection } from 'src/components/utilities/CippListOffcanvas'
import CippButtonCard from 'src/components/contentcards/CippButtonCard'
import CippAppPermissionBuilder from 'src/components/utilities/CippAppPermissionBuilder'
+import Skeleton from 'react-loading-skeleton'
const SettingsAppPermissions = () => {
const [genericPostRequest, postResults] = useLazyGenericPostRequestQuery()
@@ -36,6 +37,7 @@ const SettingsAppPermissions = () => {
const {
data: samAppPermissions = [],
isFetching: samAppPermissionsFetching,
+ isSuccess: samAppPermissionsSuccess,
refetch: refetchSam,
} = useGenericGetRequestQuery({
path: 'api/ExecSAMAppPermissions',
@@ -51,11 +53,14 @@ const SettingsAppPermissions = () => {
advised.
-
+ {samAppPermissionsFetching && }
+ {samAppPermissionsSuccess && (
+
+ )}
{postResults.data && (
From 8e16606ee435f2c84e5f81a70d18a141ed36d8d0 Mon Sep 17 00:00:00 2001
From: John Duprey
Date: Wed, 21 Aug 2024 18:37:02 -0400
Subject: [PATCH 10/48] Add username to BEC refresh
---
src/views/identity/administration/ViewBEC.jsx | 1 +
1 file changed, 1 insertion(+)
diff --git a/src/views/identity/administration/ViewBEC.jsx b/src/views/identity/administration/ViewBEC.jsx
index 4f1173042008..3142af80d61e 100644
--- a/src/views/identity/administration/ViewBEC.jsx
+++ b/src/views/identity/administration/ViewBEC.jsx
@@ -239,6 +239,7 @@ const ViewBec = () => {
execBecView({
tenantFilter: tenantDomain,
userId: userId,
+ userName: userName,
overwrite: true,
})
}
From 3bb85f83a000a74f4be95ffb37c956ef6d2844d5 Mon Sep 17 00:00:00 2001
From: cipptesting
Date: Wed, 21 Aug 2024 18:47:49 -0400
Subject: [PATCH 11/48] Added Anti-Phishing and Anti-Spam policies to backup
---
src/views/tenant/backup/CreateBackup.jsx | 9 +++++++++
src/views/tenant/backup/RestoreBackup.jsx | 7 +++++--
2 files changed, 14 insertions(+), 2 deletions(-)
diff --git a/src/views/tenant/backup/CreateBackup.jsx b/src/views/tenant/backup/CreateBackup.jsx
index faec25e074a3..d0dd6350219c 100644
--- a/src/views/tenant/backup/CreateBackup.jsx
+++ b/src/views/tenant/backup/CreateBackup.jsx
@@ -194,6 +194,15 @@ const CreateBackup = () => {
name="intuneprotection"
label="Intune Protection Policies"
/>
+ Email Security
+
+
CIPP
{
Conditional Access
-
-
Intune
+
+
+ Email Security
+
+
CIPP
From f690aff93493ea553b87d5d30316d009977196f3 Mon Sep 17 00:00:00 2001
From: OwenC3 <156828136+OwenC3@users.noreply.github.com>
Date: Thu, 22 Aug 2024 16:56:07 -0400
Subject: [PATCH 12/48] Update standards.json
---
src/data/standards.json | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/src/data/standards.json b/src/data/standards.json
index 45e7c0438ea1..4b12a7181b10 100644
--- a/src/data/standards.json
+++ b/src/data/standards.json
@@ -349,7 +349,7 @@
"name": "standards.TAP",
"cat": "Entra (AAD) Standards",
"tag": ["lowimpact"],
- "helpText": "Enables TAP and sets the default TAP lifetime to 1 hour. This configuration also allows you to select is a TAP is single use or multi-logon.",
+ "helpText": "Enables TAP and sets the default TAP lifetime to 1 hour. This configuration also allows you to select if a TAP is single use or multi-logon.",
"docsDescription": "Enables Temporary Password generation for the tenant.",
"addedComponent": [
{
@@ -648,7 +648,7 @@
"name": "standards.DisableEmail",
"cat": "Entra (AAD) Standards",
"tag": ["highimpact"],
- "helpText": "This blocks users from using email as an MFA method. This disables the email OTP option for guest users, and instead promts them to create a Microsoft account.",
+ "helpText": "This blocks users from using email as an MFA method. This disables the email OTP option for guest users, and instead prompts them to create a Microsoft account.",
"addedComponent": [],
"label": "Disables Email as an MFA method",
"impact": "High Impact",
From 2fd93963586bd387d32752c453ee206966d56b40 Mon Sep 17 00:00:00 2001
From: John Duprey
Date: Thu, 22 Aug 2024 17:42:52 -0400
Subject: [PATCH 13/48] Update CippAppPermissionBuilder.jsx
---
src/components/utilities/CippAppPermissionBuilder.jsx | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/src/components/utilities/CippAppPermissionBuilder.jsx b/src/components/utilities/CippAppPermissionBuilder.jsx
index 69d6c8c516d3..d270cfc4a7a7 100644
--- a/src/components/utilities/CippAppPermissionBuilder.jsx
+++ b/src/components/utilities/CippAppPermissionBuilder.jsx
@@ -807,7 +807,7 @@ const CippAppPermissionBuilder = ({
title="Import Manifest"
id="importManifest"
visible={manifestVisible}
- onHide={() => {
+ hideFunction={() => {
setManifestVisible(false)
}}
addedClass="offcanvas-large"
From 4fb3eae37824fc55945eeac306ad492253a4e845 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Kristian=20Kj=C3=A6rg=C3=A5rd?=
Date: Sat, 24 Aug 2024 15:44:51 +0200
Subject: [PATCH 14/48] Add delete rule button to mailboxrulelist
---
.../administration/MailboxRuleList.jsx | 43 +++++++++++++++++++
1 file changed, 43 insertions(+)
diff --git a/src/views/email-exchange/administration/MailboxRuleList.jsx b/src/views/email-exchange/administration/MailboxRuleList.jsx
index 34f3798900d8..53d4d57cbc6e 100644
--- a/src/views/email-exchange/administration/MailboxRuleList.jsx
+++ b/src/views/email-exchange/administration/MailboxRuleList.jsx
@@ -3,6 +3,43 @@ import { useSelector } from 'react-redux'
import { CippPageList } from 'src/components/layout'
import { CellTip } from 'src/components/tables'
import { cellGenericFormatter } from 'src/components/tables/CellGenericFormat'
+import { FontAwesomeIcon } from '@fortawesome/react-fontawesome'
+import { CButton } from '@coreui/react'
+import { faTrash } from '@fortawesome/free-solid-svg-icons'
+import { ModalService } from 'src/components/utilities'
+import { useLazyGenericGetRequestQuery } from 'src/store/api/app'
+
+const DeleteMailboxRuleButton = (ruleId, userPrincipalName, ruleName) => {
+ const tenant = useSelector((state) => state.app.currentTenant)
+ const [genericGetRequest, getResults] = useLazyGenericGetRequestQuery()
+ const handleModal = (modalMessage, modalUrl) => {
+ ModalService.confirm({
+ body: (
+
+ ),
+ title: 'Confirm',
+ onConfirm: () => genericGetRequest({ path: modalUrl }),
+ })
+ }
+ return (
+ {
+ ModalService.confirm(
+ handleModal(
+ 'Are you sure you want to remove this mailbox rule?',
+ `/api/ExecRemoveMailboxRule?TenantFilter=${tenant?.defaultDomainName}&ruleId=${ruleId}&ruleName=${ruleName}&userPrincipalName=${userPrincipalName}`,
+ ),
+ )
+ }}
+ >
+
+
+ )
+}
const MailboxRuleList = () => {
const tenant = useSelector((state) => state.app.currentTenant)
@@ -62,6 +99,12 @@ const MailboxRuleList = () => {
exportSelector: 'ForwardTo',
cell: cellGenericFormatter(),
},
+ {
+ name: 'Action',
+ maxWidth: '100px',
+ cell: (row) =>
+ DeleteMailboxRuleButton(row['Identity'], row['UserPrincipalName'], row['Name']),
+ },
]
return (
From 1f71fe93797cdce9172173347a44f1709e3f03f1 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Kristian=20Kj=C3=A6rg=C3=A5rd?=
Date: Sat, 24 Aug 2024 16:14:33 +0200
Subject: [PATCH 15/48] Add todo's
---
src/views/email-exchange/administration/MailboxRuleList.jsx | 2 ++
src/views/identity/administration/ViewUser.jsx | 3 +++
2 files changed, 5 insertions(+)
diff --git a/src/views/email-exchange/administration/MailboxRuleList.jsx b/src/views/email-exchange/administration/MailboxRuleList.jsx
index 53d4d57cbc6e..b941e501e01b 100644
--- a/src/views/email-exchange/administration/MailboxRuleList.jsx
+++ b/src/views/email-exchange/administration/MailboxRuleList.jsx
@@ -108,6 +108,8 @@ const MailboxRuleList = () => {
]
return (
+ // TODO: Add support for displaying the result of the delete operation. Currently, the delete operation is performed but the result is not displayed anywhere but the networking tab of the dev tools in the browser.
+ // All API code is in place and should return the needed HTTP status information. -Bobby
{
+ {/* // TODO: Add support for displaying the result of the delete operation. Currently, the delete operation is performed but the result is not displayed anywhere but the networking tab of the dev tools in the browser.
+ All API code is in place and should return the needed HTTP status information.
+ Possibly even remove the row in the table if the delete operation was successful? -Bobby */}
Date: Sat, 24 Aug 2024 16:15:01 +0200
Subject: [PATCH 16/48] feat: Add delete rule button to mailboxrulelist
---
.../administration/UserMailboxRuleList.jsx | 43 ++++++++++++++++++-
1 file changed, 42 insertions(+), 1 deletion(-)
diff --git a/src/views/identity/administration/UserMailboxRuleList.jsx b/src/views/identity/administration/UserMailboxRuleList.jsx
index ae2592866e85..f0a1e05a4d31 100644
--- a/src/views/identity/administration/UserMailboxRuleList.jsx
+++ b/src/views/identity/administration/UserMailboxRuleList.jsx
@@ -2,7 +2,12 @@ import React from 'react'
import PropTypes from 'prop-types'
import { CellBoolean, cellBooleanFormatter, CellTip } from 'src/components/tables'
import { DatatableContentCard } from 'src/components/contentcards'
-import { faEnvelope } from '@fortawesome/free-solid-svg-icons'
+import { faEnvelope, faTrash } from '@fortawesome/free-solid-svg-icons'
+import { cellGenericFormatter } from 'src/components/tables/CellGenericFormat'
+import { FontAwesomeIcon } from '@fortawesome/react-fontawesome'
+import { CButton } from '@coreui/react'
+import { ModalService } from 'src/components/utilities'
+import { useLazyGenericGetRequestQuery } from 'src/store/api/app'
const rowStyle = (row, rowIndex) => {
const style = {}
@@ -10,6 +15,37 @@ const rowStyle = (row, rowIndex) => {
return style
}
+const DeleteMailboxRuleButton = (tenantDomain, ruleId, userPrincipalName, ruleName) => {
+ const [genericGetRequest, getResults] = useLazyGenericGetRequestQuery()
+ const handleModal = (modalMessage, modalUrl) => {
+ ModalService.confirm({
+ body: (
+
+ ),
+ title: 'Confirm',
+ onConfirm: () => genericGetRequest({ path: modalUrl }),
+ })
+ }
+ return (
+ {
+ ModalService.confirm(
+ handleModal(
+ 'Are you sure you want to remove this mailbox rule?',
+ `/api/ExecRemoveMailboxRule?TenantFilter=${tenantDomain}&ruleId=${ruleId}&ruleName=${ruleName}&userPrincipalName=${userPrincipalName}`,
+ ),
+ )
+ }}
+ >
+
+
+ )
+}
+
export default function UserMailboxRuleList({ userId, userEmail, tenantDomain, className = null }) {
const formatter = (cell) => CellBoolean({ cell })
const columns = [
@@ -70,6 +106,11 @@ export default function UserMailboxRuleList({ userId, userEmail, tenantDomain, c
exportSelector: 'DeleteMessage',
width: '200px',
},
+ {
+ name: 'Action',
+ maxWidth: '100px',
+ cell: (row) => DeleteMailboxRuleButton(tenantDomain, row['Identity'], userEmail, row['Name']),
+ },
]
return (
Date: Sat, 24 Aug 2024 17:16:08 +0200
Subject: [PATCH 17/48] Fix angry linter
---
src/views/identity/administration/DeployJITAdmin.jsx | 1 -
1 file changed, 1 deletion(-)
diff --git a/src/views/identity/administration/DeployJITAdmin.jsx b/src/views/identity/administration/DeployJITAdmin.jsx
index 146ab7d6fef1..b8d5945f001b 100644
--- a/src/views/identity/administration/DeployJITAdmin.jsx
+++ b/src/views/identity/administration/DeployJITAdmin.jsx
@@ -23,7 +23,6 @@ import 'react-datepicker/dist/react-datepicker.css'
import { TenantSelector } from 'src/components/utilities'
import arrayMutators from 'final-form-arrays'
import DatePicker from 'react-datepicker'
-import 'react-datepicker/dist/react-datepicker.css'
import { useListUsersQuery } from 'src/store/api/users'
import GDAPRoles from 'src/data/GDAPRoles'
import { CippDatatable, cellDateFormatter } from 'src/components/tables'
From b403887bb0689b6f1edff21d44f0fc37f94db50a Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Kristian=20Kj=C3=A6rg=C3=A5rd?=
Date: Sat, 24 Aug 2024 17:17:45 +0200
Subject: [PATCH 18/48] Fix another angry linter
---
src/views/tenant/backup/CreateBackup.jsx | 10 ++--------
1 file changed, 2 insertions(+), 8 deletions(-)
diff --git a/src/views/tenant/backup/CreateBackup.jsx b/src/views/tenant/backup/CreateBackup.jsx
index d0dd6350219c..c4dbf63ba81c 100644
--- a/src/views/tenant/backup/CreateBackup.jsx
+++ b/src/views/tenant/backup/CreateBackup.jsx
@@ -195,14 +195,8 @@ const CreateBackup = () => {
label="Intune Protection Policies"
/>
Email Security
-
-
+
+
CIPP
Date: Mon, 26 Aug 2024 21:24:34 -0400
Subject: [PATCH 19/48] Quarantine messages
---
src/scss/_custom.scss | 4 ++
.../administration/QuarantineList.jsx | 52 ++++++++++++++++---
.../email-exchange/tools/MessageViewer.jsx | 2 +-
3 files changed, 51 insertions(+), 7 deletions(-)
diff --git a/src/scss/_custom.scss b/src/scss/_custom.scss
index b118641b872e..2b1e6c2aa248 100644
--- a/src/scss/_custom.scss
+++ b/src/scss/_custom.scss
@@ -257,6 +257,10 @@ h3.underline:after {
}
}
+.modal {
+ z-index: 1555 !important;
+}
+
.modal-content {
border-radius: var(--cipp-border-radius);
}
diff --git a/src/views/email-exchange/administration/QuarantineList.jsx b/src/views/email-exchange/administration/QuarantineList.jsx
index 6c5de828afec..cc3ac793ad53 100644
--- a/src/views/email-exchange/administration/QuarantineList.jsx
+++ b/src/views/email-exchange/administration/QuarantineList.jsx
@@ -1,22 +1,44 @@
import React, { useState } from 'react'
import { useSelector } from 'react-redux'
import { CippPageList } from 'src/components/layout'
-import { CButton } from '@coreui/react'
+import { CButton, CSpinner, CTooltip } from '@coreui/react'
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome'
import { faEllipsisV, faMinusCircle, faPaperPlane } from '@fortawesome/free-solid-svg-icons'
-import { CippActionsOffcanvas } from 'src/components/utilities'
+import { CippActionsOffcanvas, CippOffcanvas } from 'src/components/utilities'
import { cellDateFormatter, CellTip } from 'src/components/tables'
+import { MessageViewer } from 'src/views/email-exchange/tools/MessageViewer'
+import { ModalService } from 'src/components/utilities'
+import { useLazyGenericGetRequestQuery } from 'src/store/api/app'
+import PropTypes from 'prop-types'
const QuarantineList = () => {
const tenant = useSelector((state) => state.app.currentTenant)
-
const Offcanvas = (row, rowIndex, formatExtraData) => {
const [ocVisible, setOCVisible] = useState(false)
+ const [msgOcVisible, setMsgOcVisible] = useState(false)
+ const [getQuarantineMessage, quarantineMessage] = useLazyGenericGetRequestQuery()
return (
<>
- setOCVisible(true)}>
-
-
+
+ {
+ setMsgOcVisible(true)
+ getQuarantineMessage({
+ path: `/api/ListMailQuarantineMessage`,
+ params: { TenantFilter: tenant.defaultDomainName, Identity: row?.Identity },
+ })
+ }}
+ >
+
+
+
+
+ setOCVisible(true)}>
+
+
+
{
id={row.id}
hideFunction={() => setOCVisible(false)}
/>
+ setMsgOcVisible(false)}
+ visible={msgOcVisible}
+ placement="end"
+ >
+ <>
+ {quarantineMessage.isLoading && (
+
+ Loading message
+
+ )}
+ {quarantineMessage.isSuccess && (
+
+ )}
+ >
+
>
)
}
diff --git a/src/views/email-exchange/tools/MessageViewer.jsx b/src/views/email-exchange/tools/MessageViewer.jsx
index f010c0b37c4f..bc63e647b186 100644
--- a/src/views/email-exchange/tools/MessageViewer.jsx
+++ b/src/views/email-exchange/tools/MessageViewer.jsx
@@ -23,7 +23,7 @@ import DOMPurify from 'dompurify'
import ReactHtmlParser from 'react-html-parser'
import CippDropzone from 'src/components/utilities/CippDropzone'
-const MessageViewer = ({ emailSource }) => {
+export const MessageViewer = ({ emailSource }) => {
const [emlContent, setEmlContent] = useState(null)
const [emlError, setEmlError] = useState(false)
const [messageHtml, setMessageHtml] = useState('')
From c47696393f16ea647f3d7ef4d276a28ea4b74426 Mon Sep 17 00:00:00 2001
From: RunningFreak <156828136+OwenIbarra@users.noreply.github.com>
Date: Tue, 27 Aug 2024 12:38:28 -0400
Subject: [PATCH 20/48] Update AzureDeploymentTemplate.json
---
deployment/AzureDeploymentTemplate.json | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/deployment/AzureDeploymentTemplate.json b/deployment/AzureDeploymentTemplate.json
index ff7e9a97bada..dc3222498ec6 100644
--- a/deployment/AzureDeploymentTemplate.json
+++ b/deployment/AzureDeploymentTemplate.json
@@ -200,7 +200,7 @@
"name": "[variables('funcStorageName')]",
"location": "[resourceGroup().location]",
"tags": {
- "displayName": "funStorageName"
+ "displayName": "funcStorageName"
},
"sku": {
"name": "Standard_LRS"
From 2173e51d8e6586755842c6ad785c474eb1a3bed8 Mon Sep 17 00:00:00 2001
From: RunningFreak <156828136+OwenIbarra@users.noreply.github.com>
Date: Tue, 27 Aug 2024 12:41:33 -0400
Subject: [PATCH 21/48] Update AzureDeploymentTemplate_regionoptions.json
---
deployment/AzureDeploymentTemplate_regionoptions.json | 6 +++---
1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/deployment/AzureDeploymentTemplate_regionoptions.json b/deployment/AzureDeploymentTemplate_regionoptions.json
index bc2f24089d4d..ac6691593a0b 100644
--- a/deployment/AzureDeploymentTemplate_regionoptions.json
+++ b/deployment/AzureDeploymentTemplate_regionoptions.json
@@ -6,7 +6,7 @@
"defaultValue": "CIPP",
"type": "string",
"metadata": {
- "description": "Name use as base-template to named the resources deployed in Azure."
+ "description": "Name used as base-template to name the resources deployed in Azure."
}
},
"GithubRepository": {
@@ -20,7 +20,7 @@
"defaultValue": "GeneratedPassword",
"type": "string",
"metadata": {
- "description": "Your Github Repository token (see https://docs.microsoft.com/en-us/azure/static-web-apps/publish-azure-resource-manager?tabs=azure-cli#create-a-github-personal-access-token"
+ "description": "Your Github Repository token (see https://docs.microsoft.com/en-us/azure/static-web-apps/publish-azure-resource-manager?tabs=azure-cli#create-a-github-personal-access-token)"
}
},
"GithubAPIRepository": {
@@ -197,7 +197,7 @@
"name": "[variables('funcStorageName')]",
"location": "[resourceGroup().location]",
"tags": {
- "displayName": "funStorageName"
+ "displayName": "funcStorageName"
},
"sku": {
"name": "Standard_LRS"
From b72a4e7df56941dea5aad475790046575829355c Mon Sep 17 00:00:00 2001
From: RunningFreak <156828136+OwenIbarra@users.noreply.github.com>
Date: Tue, 27 Aug 2024 12:43:20 -0400
Subject: [PATCH 22/48] Update DevAzureDeploymentTemplate.json
---
deployment/DevAzureDeploymentTemplate.json | 6 +++---
1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/deployment/DevAzureDeploymentTemplate.json b/deployment/DevAzureDeploymentTemplate.json
index 8beefadd450c..5e6077beab41 100644
--- a/deployment/DevAzureDeploymentTemplate.json
+++ b/deployment/DevAzureDeploymentTemplate.json
@@ -6,7 +6,7 @@
"defaultValue": "CIPPDev",
"type": "string",
"metadata": {
- "description": "Name use as base-template to named the resources deployed in Azure."
+ "description": "Name used as base-template to name the resources deployed in Azure."
}
},
"TenantID": {
@@ -48,7 +48,7 @@
"defaultValue": "GeneratedPassword",
"type": "string",
"metadata": {
- "description": "Your Github Repository token (see https://docs.microsoft.com/en-us/azure/static-web-apps/publish-azure-resource-manager?tabs=azure-cli#create-a-github-personal-access-token"
+ "description": "Your Github Repository token (see https://docs.microsoft.com/en-us/azure/static-web-apps/publish-azure-resource-manager?tabs=azure-cli#create-a-github-personal-access-token)"
}
},
"GithubAPIRepository": {
@@ -250,7 +250,7 @@
"name": "[variables('funcStorageName')]",
"location": "[resourceGroup().location]",
"tags": {
- "displayName": "funStorageName"
+ "displayName": "funcStorageName"
},
"sku": {
"name": "Standard_LRS"
From 1c4d5dd313e6e51dc11a801cc7ee48aea1cd91a5 Mon Sep 17 00:00:00 2001
From: RunningFreak <156828136+OwenIbarra@users.noreply.github.com>
Date: Tue, 27 Aug 2024 12:44:08 -0400
Subject: [PATCH 23/48] Update DevAzureDeploymentTemplate_regionoptions.json
---
deployment/DevAzureDeploymentTemplate_regionoptions.json | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/deployment/DevAzureDeploymentTemplate_regionoptions.json b/deployment/DevAzureDeploymentTemplate_regionoptions.json
index 0fb300af06c9..f41e669076e5 100644
--- a/deployment/DevAzureDeploymentTemplate_regionoptions.json
+++ b/deployment/DevAzureDeploymentTemplate_regionoptions.json
@@ -6,7 +6,7 @@
"defaultValue": "CIPP",
"type": "string",
"metadata": {
- "description": "Name use as base-template to named the resources deployed in Azure."
+ "description": "Name used as base-template to name the resources deployed in Azure."
}
},
"TenantID": {
@@ -48,7 +48,7 @@
"defaultValue": "GeneratedPassword",
"type": "string",
"metadata": {
- "description": "Your Github Repository token (see https://docs.microsoft.com/en-us/azure/static-web-apps/publish-azure-resource-manager?tabs=azure-cli#create-a-github-personal-access-token"
+ "description": "Your Github Repository token (see https://docs.microsoft.com/en-us/azure/static-web-apps/publish-azure-resource-manager?tabs=azure-cli#create-a-github-personal-access-token)"
}
},
"GithubAPIRepository": {
From 608343461800e7f36d59a7223a5e0fb02f08722b Mon Sep 17 00:00:00 2001
From: RunningFreak <156828136+OwenIbarra@users.noreply.github.com>
Date: Tue, 27 Aug 2024 12:56:58 -0400
Subject: [PATCH 24/48] Update SettingsExtensionMappings.jsx
---
src/views/cipp/app-settings/SettingsExtensionMappings.jsx | 8 ++++----
1 file changed, 4 insertions(+), 4 deletions(-)
diff --git a/src/views/cipp/app-settings/SettingsExtensionMappings.jsx b/src/views/cipp/app-settings/SettingsExtensionMappings.jsx
index 6d7a63d2a3d0..4ed3362e2b59 100644
--- a/src/views/cipp/app-settings/SettingsExtensionMappings.jsx
+++ b/src/views/cipp/app-settings/SettingsExtensionMappings.jsx
@@ -169,7 +169,7 @@ export function SettingsExtensionMappings({ type }) {
>
)
}
- const halocolumns = [
+ const haloColumns = [
{
name: 'Tenant',
selector: (row) => row.Tenant?.displayName,
@@ -205,7 +205,7 @@ export function SettingsExtensionMappings({ type }) {
},
]
- const ninjacolumns = [
+ const ninjaColumns = [
{
name: 'Tenant',
selector: (row) => row.Tenant?.displayName,
@@ -286,7 +286,7 @@ export function SettingsExtensionMappings({ type }) {
@@ -439,7 +439,7 @@ export function SettingsExtensionMappings({ type }) {
From a9b88a27b81c1c20bddaba700e444502eee0e96c Mon Sep 17 00:00:00 2001
From: John Duprey
Date: Tue, 27 Aug 2024 21:18:24 -0400
Subject: [PATCH 25/48] Update QuarantineList.jsx
---
src/views/email-exchange/administration/QuarantineList.jsx | 7 ++-----
1 file changed, 2 insertions(+), 5 deletions(-)
diff --git a/src/views/email-exchange/administration/QuarantineList.jsx b/src/views/email-exchange/administration/QuarantineList.jsx
index cc3ac793ad53..87582178f38d 100644
--- a/src/views/email-exchange/administration/QuarantineList.jsx
+++ b/src/views/email-exchange/administration/QuarantineList.jsx
@@ -10,6 +10,7 @@ import { MessageViewer } from 'src/views/email-exchange/tools/MessageViewer'
import { ModalService } from 'src/components/utilities'
import { useLazyGenericGetRequestQuery } from 'src/store/api/app'
import PropTypes from 'prop-types'
+import Skeleton from 'react-loading-skeleton'
const QuarantineList = () => {
const tenant = useSelector((state) => state.app.currentTenant)
@@ -95,11 +96,7 @@ const QuarantineList = () => {
placement="end"
>
<>
- {quarantineMessage.isLoading && (
-
- Loading message
-
- )}
+ {quarantineMessage.isLoading && }
{quarantineMessage.isSuccess && (
)}
From 43491fff83809857bb19b601088a6088e7f3ffb3 Mon Sep 17 00:00:00 2001
From: RunningFreak <156828136+OwenIbarra@users.noreply.github.com>
Date: Wed, 28 Aug 2024 10:51:17 -0400
Subject: [PATCH 26/48] Typo
---
src/views/endpoint/applications/ApplicationsAddRMM.jsx | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/src/views/endpoint/applications/ApplicationsAddRMM.jsx b/src/views/endpoint/applications/ApplicationsAddRMM.jsx
index a6583e00fd4c..e90e31ff78e3 100644
--- a/src/views/endpoint/applications/ApplicationsAddRMM.jsx
+++ b/src/views/endpoint/applications/ApplicationsAddRMM.jsx
@@ -325,7 +325,7 @@ const AddRMM = () => {
From 2b4f94abdb319c70d9b2f146b67365eb629c3f96 Mon Sep 17 00:00:00 2001
From: John Duprey
Date: Wed, 28 Aug 2024 16:52:33 -0400
Subject: [PATCH 27/48] BEC prettification
---
src/store/api/users.js | 1 +
src/views/identity/administration/ViewBEC.jsx | 76 ++++++++++++-------
2 files changed, 48 insertions(+), 29 deletions(-)
diff --git a/src/store/api/users.js b/src/store/api/users.js
index 7ef16f12fdb3..552481567406 100644
--- a/src/store/api/users.js
+++ b/src/store/api/users.js
@@ -64,6 +64,7 @@ export const usersApi = baseApi.injectEndpoints({
userId: _args.userId,
tenantFilter: _args.tenantFilter,
userName: _args.userName,
+ overwrite: _args.overwrite,
},
})
if (startRequest.error) {
diff --git a/src/views/identity/administration/ViewBEC.jsx b/src/views/identity/administration/ViewBEC.jsx
index 3142af80d61e..9a4338d79b88 100644
--- a/src/views/identity/administration/ViewBEC.jsx
+++ b/src/views/identity/administration/ViewBEC.jsx
@@ -22,6 +22,7 @@ import { CippContentCard, CippMasonry, CippMasonryItem, CippPage } from 'src/com
import 'react-loading-skeleton/dist/skeleton.css'
import Skeleton from 'react-loading-skeleton'
import useConfirmModal from 'src/hooks/useConfirmModal'
+import { cellGenericFormatter } from 'src/components/tables/CellGenericFormat'
const ViewBec = () => {
let query = useQuery()
@@ -85,28 +86,33 @@ const ViewBec = () => {
const logonColumns = [
{
name: 'App',
- selector: (row) => row['AppDisplayName'],
+ selector: (row) => row['appDisplayName'],
sortable: true,
+ cell: cellGenericFormatter(),
},
{
name: 'Date Time',
- selector: (row) => row['CreatedDateTime'],
+ selector: (row) => row['createdDateTime'],
sortable: true,
+ cell: cellGenericFormatter(),
},
{
name: 'Error code',
selector: (row) => row.id,
sortable: true,
+ cell: cellGenericFormatter(),
},
{
name: 'Details',
selector: (row) => row.Status,
sortable: true,
+ cell: cellGenericFormatter(),
},
{
name: 'IP',
selector: (row) => row.IPAddress,
sortable: true,
+ cell: cellGenericFormatter(),
},
]
@@ -115,21 +121,25 @@ const ViewBec = () => {
name: 'IP',
selector: (row) => row['IPAddress'],
sortable: true,
+ cell: cellGenericFormatter(),
},
{
name: 'User',
selector: (row) => row['userPrincipalName'],
sortable: true,
+ cell: cellGenericFormatter(),
},
{
name: 'Application',
selector: (row) => row['AppDisplayName'],
sortable: true,
+ cell: cellGenericFormatter(),
},
{
name: 'Result',
selector: (row) => row['Status'],
sortable: true,
+ cell: cellGenericFormatter(),
},
]
const newUserColumns = [
@@ -137,16 +147,19 @@ const ViewBec = () => {
name: 'DisplayName',
selector: (row) => row['displayName'],
sortable: true,
+ cell: cellGenericFormatter(),
},
{
name: 'Username',
selector: (row) => row['userPrincipalName'],
sortable: true,
+ cell: cellGenericFormatter(),
},
{
name: 'Date',
- selector: (row) => row['CreatedDateTime'],
+ selector: (row) => row['createdDateTime'],
sortable: true,
+ cell: cellGenericFormatter(),
},
]
@@ -155,16 +168,19 @@ const ViewBec = () => {
name: 'displayName',
selector: (row) => row['displayName'],
sortable: true,
+ cell: cellGenericFormatter(),
},
{
name: 'Username',
selector: (row) => row['userPrincipalName'],
sortable: true,
+ cell: cellGenericFormatter(),
},
{
name: 'Date',
selector: (row) => row['lastPasswordChangeDateTime'],
sortable: true,
+ cell: cellGenericFormatter(),
},
]
@@ -173,44 +189,46 @@ const ViewBec = () => {
name: 'Operation',
selector: (row) => row['Operation'],
sortable: true,
+ cell: cellGenericFormatter(),
},
{
name: 'Executed by',
selector: (row) => row['UserKey'],
sortable: true,
+ cell: cellGenericFormatter(),
},
{
name: 'Executed on',
selector: (row) => row['ObjectId'],
sortable: true,
+ cell: cellGenericFormatter(),
},
{
name: 'Permissions',
selector: (row) => row['Permissions'],
sortable: true,
+ cell: cellGenericFormatter(),
},
]
const appColumns = [
{
- name: 'Type',
- selector: (row) => row['Operation'],
- sortable: true,
- },
- {
- name: 'User',
- selector: (row) => row['UserId'],
+ name: 'Application',
+ selector: (row) => row['appDisplayName'],
sortable: true,
+ cell: cellGenericFormatter(),
},
{
- name: 'Application',
- selector: (row) => row['ObjectId'],
+ name: 'Application ID',
+ selector: (row) => row['appId'],
sortable: true,
+ cell: cellGenericFormatter(),
},
{
- name: 'Result',
- selector: (row) => row['ResultStatus'],
+ name: 'Created',
+ selector: (row) => row['createdDateTime'],
sortable: true,
+ cell: cellGenericFormatter(),
},
]
const handleReMediate = useConfirmModal({
@@ -304,9 +322,9 @@ const ViewBec = () => {
data={alerts.SuspectUserDevices}
striped
responsive={true}
- tableProps={{ subHeaderComponent: false, pagination: false }}
+ isModal={true}
wrapperClasses="table-responsive"
- reportName="none"
+ reportName="bec-user-devices"
/>
)}
@@ -322,8 +340,8 @@ const ViewBec = () => {
data={alerts.NewRules}
striped
responsive={true}
- tableProps={{ subHeaderComponent: false }}
- reportName="none"
+ isModal={true}
+ reportName="bec-inbox-rules"
/>
)}
@@ -338,8 +356,8 @@ const ViewBec = () => {
data={alerts.LastSuspectUserLogon}
striped
responsive={true}
- tableProps={{ subHeaderComponent: false }}
- reportName="none"
+ isModal={true}
+ reportName="bec-suspect-user-logons"
/>
)}
@@ -355,9 +373,9 @@ const ViewBec = () => {
data={alerts.NewUsers}
striped
responsive={true}
- tableProps={{ subHeaderComponent: false }}
+ isModal={true}
wrapperClasses="table-responsive"
- reportName="none"
+ reportName="bec-new-users"
/>
)}
@@ -373,9 +391,9 @@ const ViewBec = () => {
data={alerts.ChangedPasswords}
striped
responsive={true}
- tableProps={{ subHeaderComponent: false }}
+ isModal={true}
wrapperClasses="table-responsive"
- reportName="none"
+ reportName="bec-changed-passwords"
/>
)}
@@ -391,9 +409,9 @@ const ViewBec = () => {
data={alerts.MailboxPermissionChanges}
striped
responsive={true}
- tableProps={{ subHeaderComponent: false }}
+ isModal={true}
wrapperClasses="table-responsive"
- reportName="none"
+ reportName="bec-mailbox-permission-changes"
/>
)}
@@ -409,9 +427,9 @@ const ViewBec = () => {
data={alerts.AddedApps}
striped
responsive={true}
- tableProps={{ subHeaderComponent: false }}
wrapperClasses="table-responsive"
- reportName="none"
+ isModal={true}
+ reportName="bec-added-apps"
/>
)}
@@ -427,7 +445,7 @@ const ViewBec = () => {
data={alerts.SuspectUserMailboxLogons}
striped
responsive={true}
- tableProps={{ subHeaderComponent: false }}
+ isModal={true}
wrapperClasses="table-responsive"
reportName="none"
/>
From 8a04e24681a08bcfb5dd5a931b030b4c13c5e9d3 Mon Sep 17 00:00:00 2001
From: John Duprey
Date: Thu, 29 Aug 2024 10:25:39 -0400
Subject: [PATCH 28/48] Update orchestration starter url
---
src/views/endpoint/applications/ListApplicationQueue.jsx | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/src/views/endpoint/applications/ListApplicationQueue.jsx b/src/views/endpoint/applications/ListApplicationQueue.jsx
index 53f1e9197d33..eb42ed86ec47 100644
--- a/src/views/endpoint/applications/ListApplicationQueue.jsx
+++ b/src/views/endpoint/applications/ListApplicationQueue.jsx
@@ -20,7 +20,7 @@ const RefreshAction = () => {
Please note: This job runs automatically every 12 hours.
),
- onConfirm: () => execStandards({ path: 'api/AddChocoApp_OrchestrationStarter' }),
+ onConfirm: () => execStandards({ path: 'api/ExecAppUpload' }),
})
return (
From fae4360d9cd5bee3db671bf5aacd95812b4e94d0 Mon Sep 17 00:00:00 2001
From: John Duprey
Date: Thu, 29 Aug 2024 10:42:36 -0400
Subject: [PATCH 29/48] Cleanup queries in Mailbox Settings
- Change forwarding to look at proxyAddresses instead of mail
- Remove extra queries
---
.../administration/EditMailboxPermissions.jsx | 21 ++++---------------
1 file changed, 4 insertions(+), 17 deletions(-)
diff --git a/src/views/email-exchange/administration/EditMailboxPermissions.jsx b/src/views/email-exchange/administration/EditMailboxPermissions.jsx
index 3f16a1e389d9..ff1e7d2b64ce 100644
--- a/src/views/email-exchange/administration/EditMailboxPermissions.jsx
+++ b/src/views/email-exchange/administration/EditMailboxPermissions.jsx
@@ -195,7 +195,7 @@ const MailboxPermissions = () => {
params: {
Endpoint: 'users',
TenantFilter: tenantDomain,
- $filter: 'assignedLicenses/$count ne 0 and accountEnabled eq true',
+ $filter: "assignedLicenses/$count ne 0 and accountEnabled eq true and userType eq 'Member'",
$count: true,
},
})
@@ -586,7 +586,7 @@ const MailboxForwarding = () => {
params: {
Endpoint: 'users',
TenantFilter: tenantDomain,
- $filter: "userType eq 'Member' and mail ge ' '", // filter out guests and users with no mailbox. #HACK "mail ne 'null'" does not work so this horrible hack is required
+ $filter: "userType eq 'Member' and proxyAddresses/$count ne 0",
},
})
useEffect(() => {
@@ -803,19 +803,6 @@ const OutOfOffice = () => {
error: userError,
} = useListMailboxPermissionsQuery({ tenantDomain, userId })
- const {
- data: users = [],
- isFetching: usersIsFetching,
- error: usersError,
- } = useGenericGetRequestQuery({
- path: '/api/ListGraphRequest',
- params: {
- Endpoint: 'users',
- TenantFilter: tenantDomain,
- $filter: 'assignedLicenses/$count ne 0 and accountEnabled eq true',
- $count: true,
- },
- })
useEffect(() => {
if (postResults.isSuccess) {
// @TODO do something here?
@@ -865,9 +852,9 @@ const OutOfOffice = () => {
)}
- {usersIsFetching && }
+ {userIsFetching && }
{userError && Error loading user}
- {!usersIsFetching && (
+ {!userIsFetching && (
+
+ setCurrentRefresh((Math.random() + 1).toString(36).substring(7))}
+ color="primary"
+ variant="ghost"
+ className="float-end"
+ >
+
+
+
)
}
+ForwardingSettings.propTypes = {
+ refresh: PropTypes.string,
+}
-const OutOfOffice = () => {
+const OutOfOffice = ({ refreshFunction }) => {
const dispatch = useDispatch()
let query = useQuery()
const userId = query.get('userId')
@@ -932,7 +996,9 @@ const OutOfOffice = () => {
ExternalMessage: values.ExternalMessage ? values.ExternalMessage : '',
}
//window.alert(JSON.stringify(shippedValues))
- genericPostRequest({ path: '/api/ExecSetOoO', values: shippedValues })
+ genericPostRequest({ path: '/api/ExecSetOoO', values: shippedValues }).then(() => {
+ refreshFunction()
+ })
}
const initialState = {
...user,
@@ -1049,18 +1115,26 @@ const OutOfOffice = () => {
)
}
-const OutOfOfficeSettings = () => {
+const OutOfOfficeSettings = ({ refresh }) => {
const query = useQuery()
const userId = query.get('userId')
const tenantDomain = query.get('tenantDomain')
const tenantFilter = tenantDomain
+ const [currentRefresh, setCurrentRefresh] = useState('')
+
+ useEffect(() => {
+ if (refresh !== currentRefresh) {
+ setCurrentRefresh(refresh)
+ }
+ }, [refresh, currentRefresh, setCurrentRefresh])
+
const {
data: details,
isFetching,
error,
} = useGenericGetRequestQuery({
path: '/api/ListOoO',
- params: { userId, tenantFilter },
+ params: { userId, tenantFilter, currentRefresh },
})
const combinedRegex = /(<([^>]+)>)|| /gi
const content = [
@@ -1087,22 +1161,42 @@ const OutOfOfficeSettings = () => {
]
return (
- {isFetching && (
-
- Loading
-
- )}
- {!isFetching && (
-
- {content.map((item, index) => (
-
-
{item.heading}
-
{item.body}
-
- ))}
-
- )}
- {error && Could not connect to API: {error.message}}
+
+ {isFetching && (
+ <>
+ {content.map((item, index) => (
+
+ ))}
+ >
+ )}
+ {!isFetching && (
+ <>
+ {content.map((item, index) => (
+
+
{item.heading}
+
{item.body}
+
+ ))}
+ >
+ )}
+
+ {error && Could not connect to API: {error.message}}
+
+
+ setCurrentRefresh((Math.random() + 1).toString(36).substring(7))}
+ color="primary"
+ variant="ghost"
+ className="float-end"
+ >
+
+
+
)
}
From 423ed7e4254b32ff9fdd89a399792f9fc0c64b83 Mon Sep 17 00:00:00 2001
From: John Duprey
Date: Thu, 29 Aug 2024 23:10:27 -0400
Subject: [PATCH 35/48] Update EditMailboxPermissions.jsx
---
.../administration/EditMailboxPermissions.jsx | 63 +++++++++----------
1 file changed, 29 insertions(+), 34 deletions(-)
diff --git a/src/views/email-exchange/administration/EditMailboxPermissions.jsx b/src/views/email-exchange/administration/EditMailboxPermissions.jsx
index bb6613f63d33..9283001ca1f3 100644
--- a/src/views/email-exchange/administration/EditMailboxPermissions.jsx
+++ b/src/views/email-exchange/administration/EditMailboxPermissions.jsx
@@ -791,7 +791,6 @@ const ForwardingSettings = ({ refresh }) => {
const userId = query.get('userId')
const tenantDomain = query.get('tenantDomain')
const [content, setContent] = useState([])
- const [showLoading, setShowLoading] = useState(false)
const [currentRefresh, setCurrentRefresh] = useState('')
const {
data: details,
@@ -799,7 +798,7 @@ const ForwardingSettings = ({ refresh }) => {
isSuccess,
error,
} = useGenericPostRequestQuery({
- path: `/api/ListExoRequest?Cmdlet=Get-Mailbox&TenantFilter=${tenantDomain}&Select=ForwardingAddress,ForwardingSmtpAddress,DeliverToMailboxAndForward&refresh=${refresh}`,
+ path: `/api/ListExoRequest?Cmdlet=Get-Mailbox&TenantFilter=${tenantDomain}&Select=ForwardingAddress,ForwardingSmtpAddress,DeliverToMailboxAndForward&refresh=${currentRefresh}`,
values: { Identity: userId },
})
@@ -821,7 +820,6 @@ const ForwardingSettings = ({ refresh }) => {
useEffect(() => {
if (refresh !== currentRefresh) {
- setShowLoading(false)
setCurrentRefresh(refresh)
}
@@ -904,42 +902,39 @@ const ForwardingSettings = ({ refresh }) => {
},
])
}
- } else if ((isFetching || usersIsFetching) && showLoading === false) {
- setContent([
- {
- heading: 'Forward and Deliver',
- body: ,
- },
- {
- heading: 'Forwarding Address',
- body: ,
- },
- ])
- setShowLoading(true)
}
- }, [
- refresh,
- currentRefresh,
- users,
- details,
- usersSuccess,
- isSuccess,
- isFetching,
- usersIsFetching,
- showLoading,
- ])
+ }, [refresh, currentRefresh, users, details, usersSuccess, isSuccess])
return (
-
- {content.map((item, index) => (
-
-
{item.heading}
-
{item.body}
-
- ))}
+
+ {isFetching || usersIsFetching ? (
+ <>
+
+
Forward and Deliver
+
+
+
+
+
+
Forwarding Address
+
+
+
+
+ >
+ ) : (
+ <>
+ {content.map((item, index) => (
+
+
{item.heading}
+
{item.body}
+
+ ))}
+ >
+ )}
-
+
setCurrentRefresh((Math.random() + 1).toString(36).substring(7))}
color="primary"
From 6495cb15b3d68fd6275ed9886557c20d65768cbd Mon Sep 17 00:00:00 2001
From: John Duprey
Date: Thu, 29 Aug 2024 23:11:43 -0400
Subject: [PATCH 36/48] add proptypes
---
.../administration/EditMailboxPermissions.jsx | 6 ++++++
1 file changed, 6 insertions(+)
diff --git a/src/views/email-exchange/administration/EditMailboxPermissions.jsx b/src/views/email-exchange/administration/EditMailboxPermissions.jsx
index 9283001ca1f3..bddce9e02628 100644
--- a/src/views/email-exchange/administration/EditMailboxPermissions.jsx
+++ b/src/views/email-exchange/administration/EditMailboxPermissions.jsx
@@ -1109,6 +1109,9 @@ const OutOfOffice = ({ refreshFunction }) => {
>
)
}
+OutOfOffice.propTypes = {
+ refreshFunction: PropTypes.func,
+}
const OutOfOfficeSettings = ({ refresh }) => {
const query = useQuery()
@@ -1195,3 +1198,6 @@ const OutOfOfficeSettings = ({ refresh }) => {
)
}
+OutOfOfficeSettings.propTypes = {
+ refresh: PropTypes.string,
+}
From 9eb600c5a1fe70bcd66a78a616a187a61bc22614 Mon Sep 17 00:00:00 2001
From: KelvinTegelaar
Date: Fri, 30 Aug 2024 13:44:07 +0200
Subject: [PATCH 37/48] added get bitlocker key
---
src/views/identity/administration/Devices.jsx | 7 +++++++
1 file changed, 7 insertions(+)
diff --git a/src/views/identity/administration/Devices.jsx b/src/views/identity/administration/Devices.jsx
index 664f7552757c..f7808c39034a 100644
--- a/src/views/identity/administration/Devices.jsx
+++ b/src/views/identity/administration/Devices.jsx
@@ -36,6 +36,13 @@ const DevicesList = () => {
modalUrl: `/api/ExecDeviceDelete?TenantFilter=${tenant.defaultDomainName}&ID=${row.id}&Action=Enable`,
modalMessage: 'Are you sure you want to enable this device.',
},
+ {
+ label: 'Retrieve Bitlocker Keys',
+ color: 'info',
+ modal: true,
+ modalUrl: `/api/ExecGetRecoveryKey?TenantFilter=${tenant.defaultDomainName}&GUID=${row.id}`,
+ modalMessage: 'Are you sure you want to retrieve the Bitlocker keys?',
+ },
{
label: 'Disable Device',
color: 'info',
From cb32a993ed4aa1e60240ab7cb09802f79cd1a1c2 Mon Sep 17 00:00:00 2001
From: John Duprey
Date: Fri, 30 Aug 2024 09:01:59 -0400
Subject: [PATCH 38/48] Move entire request to post body
---
.../administration/EditMailboxPermissions.jsx | 10 ++++++++--
1 file changed, 8 insertions(+), 2 deletions(-)
diff --git a/src/views/email-exchange/administration/EditMailboxPermissions.jsx b/src/views/email-exchange/administration/EditMailboxPermissions.jsx
index bddce9e02628..740aa2417455 100644
--- a/src/views/email-exchange/administration/EditMailboxPermissions.jsx
+++ b/src/views/email-exchange/administration/EditMailboxPermissions.jsx
@@ -798,8 +798,14 @@ const ForwardingSettings = ({ refresh }) => {
isSuccess,
error,
} = useGenericPostRequestQuery({
- path: `/api/ListExoRequest?Cmdlet=Get-Mailbox&TenantFilter=${tenantDomain}&Select=ForwardingAddress,ForwardingSmtpAddress,DeliverToMailboxAndForward&refresh=${currentRefresh}`,
- values: { Identity: userId },
+ path: `/api/ListExoRequest`,
+ values: {
+ TenantFilter: tenantDomain,
+ Cmdlet: 'Get-Mailbox',
+ cmdParams: { Identity: userId },
+ Select: 'ForwardingAddress,ForwardingSmtpAddress,DeliverToMailboxAndForward',
+ refresh: currentRefresh,
+ },
})
const {
From 2e15063054f1c58f386cb1bf1d3e8cac7516386a Mon Sep 17 00:00:00 2001
From: KelvinTegelaar
Date: Fri, 30 Aug 2024 15:47:46 +0200
Subject: [PATCH 39/48] Right of Boom logo
---
public/img/RoB-light.svg | 17 +++++++++++++++++
public/img/RoB.svg | 25 +++++++++++++++++++++++++
public/img/datto.png | Bin 15316 -> 0 bytes
src/components/layout/AppFooter.jsx | 10 +++++++---
4 files changed, 49 insertions(+), 3 deletions(-)
create mode 100644 public/img/RoB-light.svg
create mode 100644 public/img/RoB.svg
delete mode 100644 public/img/datto.png
diff --git a/public/img/RoB-light.svg b/public/img/RoB-light.svg
new file mode 100644
index 000000000000..0673b2a8a449
--- /dev/null
+++ b/public/img/RoB-light.svg
@@ -0,0 +1,17 @@
+
\ No newline at end of file
diff --git a/public/img/RoB.svg b/public/img/RoB.svg
new file mode 100644
index 000000000000..d188e1eb541b
--- /dev/null
+++ b/public/img/RoB.svg
@@ -0,0 +1,25 @@
+
+
diff --git a/public/img/datto.png b/public/img/datto.png
deleted file mode 100644
index b0fad6f50233e46eed52acb6d6c5e037aabecfda..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001
literal 15316
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
diff --git a/src/components/layout/AppFooter.jsx b/src/components/layout/AppFooter.jsx
index c720c8f5a35b..09087af3a00e 100644
--- a/src/components/layout/AppFooter.jsx
+++ b/src/components/layout/AppFooter.jsx
@@ -10,7 +10,7 @@ const AppFooter = () => {
const isDark =
currentTheme === 'impact' || (currentTheme === 'default' && preferredTheme === 'impact')
- const datto = isDark ? '/img/datto.png' : '/img/datto.png'
+ const RoB = isDark ? '/img/RoB.svg' : '/img/RoB-light.svg'
const huntress = isDark ? '/img/huntress_teal.png' : '/img/huntress_teal.png'
const rewst = isDark ? '/img/rewst_dark.png' : '/img/rewst.png'
const ninjaone = isDark ? '/img/ninjaone_dark.png' : '/img/ninjaone.png'
@@ -24,8 +24,12 @@ const AppFooter = () => {
-
-
+
+
From 46b15c72b3b907618fe273d88e6a7188a2ae58fb Mon Sep 17 00:00:00 2001
From: KelvinTegelaar
Date: Fri, 30 Aug 2024 18:59:28 +0200
Subject: [PATCH 40/48] update version
---
package.json | 2 +-
public/version_latest.txt | 2 +-
version_latest.txt | 2 +-
3 files changed, 3 insertions(+), 3 deletions(-)
diff --git a/package.json b/package.json
index b74d149fe82e..2739d1d2801a 100644
--- a/package.json
+++ b/package.json
@@ -1,6 +1,6 @@
{
"name": "cipp",
- "version": "6.3.0",
+ "version": "6.4.0",
"description": "The CyberDrain Improved Partner Portal is a portal to help manage administration for Microsoft Partners.",
"homepage": "https://cipp.app/",
"bugs": {
diff --git a/public/version_latest.txt b/public/version_latest.txt
index 798e38995c4d..19b860c1872d 100644
--- a/public/version_latest.txt
+++ b/public/version_latest.txt
@@ -1 +1 @@
-6.3.0
+6.4.0
diff --git a/version_latest.txt b/version_latest.txt
index 798e38995c4d..19b860c1872d 100644
--- a/version_latest.txt
+++ b/version_latest.txt
@@ -1 +1 @@
-6.3.0
+6.4.0
From 557efcddba65c731f21495873513371abd491bf2 Mon Sep 17 00:00:00 2001
From: John Duprey
Date: Thu, 5 Sep 2024 08:42:29 -0400
Subject: [PATCH 41/48] Update .gitignore
---
.gitignore | 3 ++-
1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/.gitignore b/.gitignore
index 47dfb11e20c3..0c9f36fe2e8a 100644
--- a/.gitignore
+++ b/.gitignore
@@ -21,4 +21,5 @@
npm-debug.log*
yarn-debug.log*
yarn-error.log*
-__*
\ No newline at end of file
+__*
+.next/*
From b8c26ec862d6cdd9552cd5498c2b5ea6a19fbd4b Mon Sep 17 00:00:00 2001
From: John Duprey
Date: Mon, 30 Sep 2024 16:49:12 -0400
Subject: [PATCH 42/48] CippAppPermissionBuilder fixes
---
.../utilities/CippAppPermissionBuilder.jsx | 29 +++++++++++++------
1 file changed, 20 insertions(+), 9 deletions(-)
diff --git a/src/components/utilities/CippAppPermissionBuilder.jsx b/src/components/utilities/CippAppPermissionBuilder.jsx
index d270cfc4a7a7..8959b4f826fa 100644
--- a/src/components/utilities/CippAppPermissionBuilder.jsx
+++ b/src/components/utilities/CippAppPermissionBuilder.jsx
@@ -60,7 +60,6 @@ const CippAppPermissionBuilder = ({
} = useGenericGetRequestQuery({
path: 'api/ExecServicePrincipals',
})
-
const [createServicePrincipal, createResult] = useLazyGenericGetRequestQuery()
const removeServicePrincipal = (appId) => {
@@ -407,9 +406,17 @@ const CippAppPermissionBuilder = ({
])
const ApiPermissionRow = ({ servicePrincipal = null }) => {
+ const {
+ data: servicePrincipalData = [],
+ isFetching: spFetching,
+ isSuccess: spIdSuccess,
+ } = useGenericGetRequestQuery({
+ path: 'api/ExecServicePrincipals?Id=' + servicePrincipal.id,
+ })
+
return (
<>
- {spSuccess && servicePrincipal !== null && (
+ {spSuccess && servicePrincipal !== null && spIdSuccess && (
@@ -457,7 +464,7 @@ const CippAppPermissionBuilder = ({
'.applicationPermissions'
}
label="Application Permissions"
- values={servicePrincipal?.appRoles
+ values={servicePrincipalData?.Results?.appRoles
?.filter((role) => {
return newPermissions?.Permissions[
servicePrincipal.appId
@@ -524,8 +531,9 @@ const CippAppPermissionBuilder = ({
},
{
selector: (row) =>
- servicePrincipal.appRoles.find((role) => role.id === row.id)
- .description,
+ servicePrincipalData?.Results?.appRoles.find(
+ (role) => role.id === row.id,
+ ).description,
name: 'Description',
cell: cellGenericFormatter({ wrap: true }),
maxWidth: '60%',
@@ -577,7 +585,7 @@ const CippAppPermissionBuilder = ({
- {servicePrincipal?.publishedPermissionScopes?.length == 0 && (
+ {servicePrincipalData?.Results?.publishedPermissionScopes?.length == 0 && (
No Published Delegated Permissions found.
@@ -594,8 +602,8 @@ const CippAppPermissionBuilder = ({
}
label="Delegated Permissions"
values={
- servicePrincipal?.publishedPermissionScopes?.length > 0
- ? servicePrincipal?.publishedPermissionScopes
+ servicePrincipalData?.Results?.publishedPermissionScopes?.length > 0
+ ? servicePrincipalData?.Results?.publishedPermissionScopes
.filter((scopes) => {
return newPermissions?.Permissions[
servicePrincipal.appId
@@ -664,7 +672,7 @@ const CippAppPermissionBuilder = ({
},
{
selector: (row) =>
- servicePrincipal.publishedPermissionScopes.find(
+ servicePrincipalData?.Results?.publishedPermissionScopes.find(
(scope) => scope?.id === row?.id,
)?.userConsentDescription ?? 'No Description',
name: 'Description',
@@ -921,6 +929,9 @@ const CippAppPermissionBuilder = ({
Object.keys(
newPermissions?.MissingPermissions[perm],
).map((type) => {
+ if (!updatedPermissions.Permissions[perm][type]) {
+ updatedPermissions.Permissions[perm][type] = []
+ }
newPermissions?.MissingPermissions[perm][type].map(
(p) => {
updatedPermissions.Permissions[perm][type].push(p)
From 3b87108c37caa7715f47a8f32b9fc296dbf05620 Mon Sep 17 00:00:00 2001
From: John Duprey
Date: Fri, 4 Oct 2024 16:55:05 -0400
Subject: [PATCH 43/48] Add zipdeploy
---
deployment/AzureDeploymentTemplate.json | 53 +++++++------------
...AzureDeploymentTemplate_regionoptions.json | 50 +++++++----------
2 files changed, 36 insertions(+), 67 deletions(-)
diff --git a/deployment/AzureDeploymentTemplate.json b/deployment/AzureDeploymentTemplate.json
index dc3222498ec6..8bc7b610d9e3 100644
--- a/deployment/AzureDeploymentTemplate.json
+++ b/deployment/AzureDeploymentTemplate.json
@@ -57,7 +57,7 @@
"objectId": "[reference(resourceId('Microsoft.Web/sites', variables('funcAppName')),'2019-08-01', 'full').identity.principalId]",
"permissions": {
"keys": [],
- "secrets": ["all"],
+ "secrets": [ "all" ],
"certificates": []
}
}
@@ -116,7 +116,7 @@
]
}
],
- "dependsOn": ["[resourceId('Microsoft.Web/sites', variables('funcAppName'))]"]
+ "dependsOn": [ "[resourceId('Microsoft.Web/sites', variables('funcAppName'))]" ]
},
{
"apiVersion": "2015-08-01",
@@ -135,7 +135,7 @@
"serverFarmId": "[resourceId('Microsoft.Web/serverfarms', variables('serverFarmName'))]",
"siteConfig": {
"Use32BitWorkerProcess": false,
- "powerShellVersion": "7.2",
+ "powerShellVersion": "7.4",
"appSettings": [
{
"name": "AzureWebJobsStorage",
@@ -154,20 +154,8 @@
"value": "~4"
},
{
- "name": "ApplicationID",
- "value": "[concat('@Microsoft.KeyVault(SecretUri=https://',variables('uniqueResourceNameBase'), '.vault.azure.net/secrets/ApplicationId)')]"
- },
- {
- "name": "ApplicationSecret",
- "value": "[concat('@Microsoft.KeyVault(SecretUri=https://',variables('uniqueResourceNameBase'), '.vault.azure.net/secrets/ApplicationSecret)')]"
- },
- {
- "name": "RefreshToken",
- "value": "[concat('@Microsoft.KeyVault(SecretUri=https://',variables('uniqueResourceNameBase'), '.vault.azure.net/secrets/RefreshToken)')]"
- },
- {
- "name": "TenantID",
- "value": "[concat('@Microsoft.KeyVault(SecretUri=https://',variables('uniqueResourceNameBase'), '.vault.azure.net/secrets/tenantid)')]"
+ "name": "WEBSITE_RUN_FROM_PACKAGE",
+ "value": "1"
},
{
"name": "FUNCTIONS_WORKER_RUNTIME",
@@ -175,24 +163,19 @@
}
]
}
- },
- "resources": [
- {
- "apiVersion": "2015-08-01",
- "name": "web",
- "type": "sourcecontrols",
- "dependsOn": ["[resourceId('Microsoft.Web/sites/', variables('funcAppName'))]"],
- "properties": {
- "RepoUrl": "[parameters('GithubAPIRepository')]",
- "repositoryToken": "[parameters('GithubToken')]",
- "token": "[parameters('GithubToken')]",
-
- "branch": "master",
- "publishRunbook": true,
- "IsManualIntegration": true
- }
- }
- ]
+ }
+ },
+ {
+ "name": "[concat(variables('funcAppName'), '/ZipDeploy')]",
+ "type": "Microsoft.Web/sites/extensions",
+ "apiVersion": "2021-02-01",
+ "location": "[resourceGroup().location]",
+ "dependsOn": [
+ "[resourceId('Microsoft.Web/sites', variables('funcAppName'))]"
+ ],
+ "properties": {
+ "packageUri": "https://cippreleases.blob.core.windows.net/cipp-api/latest.zip"
+ }
},
{
"type": "Microsoft.Storage/storageAccounts",
diff --git a/deployment/AzureDeploymentTemplate_regionoptions.json b/deployment/AzureDeploymentTemplate_regionoptions.json
index ac6691593a0b..ff4d9331da35 100644
--- a/deployment/AzureDeploymentTemplate_regionoptions.json
+++ b/deployment/AzureDeploymentTemplate_regionoptions.json
@@ -57,7 +57,7 @@
"objectId": "[reference(resourceId('Microsoft.Web/sites', variables('funcAppName')),'2019-08-01', 'full').identity.principalId]",
"permissions": {
"keys": [],
- "secrets": ["all"],
+ "secrets": [ "all" ],
"certificates": []
}
}
@@ -116,7 +116,7 @@
]
}
],
- "dependsOn": ["[resourceId('Microsoft.Web/sites', variables('funcAppName'))]"]
+ "dependsOn": [ "[resourceId('Microsoft.Web/sites', variables('funcAppName'))]" ]
},
{
"apiVersion": "2015-08-01",
@@ -135,7 +135,7 @@
"serverFarmId": "[resourceId('Microsoft.Web/serverfarms', variables('serverFarmName'))]",
"siteConfig": {
"Use32BitWorkerProcess": false,
- "powerShellVersion": "7.2",
+ "powerShellVersion": "7.4",
"appSettings": [
{
"name": "AzureWebJobsStorage",
@@ -154,20 +154,8 @@
"value": "~4"
},
{
- "name": "ApplicationID",
- "value": "[concat('@Microsoft.KeyVault(SecretUri=https://',variables('uniqueResourceNameBase'), '.vault.azure.net/secrets/ApplicationId)')]"
- },
- {
- "name": "ApplicationSecret",
- "value": "[concat('@Microsoft.KeyVault(SecretUri=https://',variables('uniqueResourceNameBase'), '.vault.azure.net/secrets/ApplicationSecret)')]"
- },
- {
- "name": "RefreshToken",
- "value": "[concat('@Microsoft.KeyVault(SecretUri=https://',variables('uniqueResourceNameBase'), '.vault.azure.net/secrets/RefreshToken)')]"
- },
- {
- "name": "TenantID",
- "value": "[concat('@Microsoft.KeyVault(SecretUri=https://',variables('uniqueResourceNameBase'), '.vault.azure.net/secrets/tenantid)')]"
+ "name": "WEBSITE_RUN_FROM_PACKAGE",
+ "value": "1"
},
{
"name": "FUNCTIONS_WORKER_RUNTIME",
@@ -175,21 +163,19 @@
}
]
}
- },
- "resources": [
- {
- "apiVersion": "2015-08-01",
- "name": "web",
- "type": "sourcecontrols",
- "dependsOn": ["[resourceId('Microsoft.Web/sites/', variables('funcAppName'))]"],
- "properties": {
- "RepoUrl": "[parameters('GithubAPIRepository')]",
- "branch": "master",
- "publishRunbook": true,
- "IsManualIntegration": true
- }
- }
- ]
+ }
+ },
+ {
+ "name": "[concat(variables('funcAppName'), '/ZipDeploy')]",
+ "type": "Microsoft.Web/sites/extensions",
+ "apiVersion": "2021-02-01",
+ "location": "[resourceGroup().location]",
+ "dependsOn": [
+ "[resourceId('Microsoft.Web/sites', variables('funcAppName'))]"
+ ],
+ "properties": {
+ "packageUri": "https://cippreleases.blob.core.windows.net/cipp-api/latest.zip"
+ }
},
{
"type": "Microsoft.Storage/storageAccounts",
From 37fb0e6eaff8b652ac2600d37b3a741ca4f61e90 Mon Sep 17 00:00:00 2001
From: John Duprey
Date: Fri, 4 Oct 2024 16:58:45 -0400
Subject: [PATCH 44/48] Cleanup api reference
---
deployment/AzureDeploymentTemplate.json | 7 -------
deployment/AzureDeploymentTemplate_regionoptions.json | 7 -------
2 files changed, 14 deletions(-)
diff --git a/deployment/AzureDeploymentTemplate.json b/deployment/AzureDeploymentTemplate.json
index 8bc7b610d9e3..aa445e3fd6c8 100644
--- a/deployment/AzureDeploymentTemplate.json
+++ b/deployment/AzureDeploymentTemplate.json
@@ -22,13 +22,6 @@
"metadata": {
"description": "Your Github Repository token (see https://docs.microsoft.com/en-us/azure/static-web-apps/publish-azure-resource-manager?tabs=azure-cli#create-a-github-personal-access-token"
}
- },
- "GithubAPIRepository": {
- "defaultValue": "https://github.com/KelvinTegelaar/CIPP-API",
- "type": "string",
- "metadata": {
- "description": "URL to your Github backend fork."
- }
}
},
"variables": {
diff --git a/deployment/AzureDeploymentTemplate_regionoptions.json b/deployment/AzureDeploymentTemplate_regionoptions.json
index ff4d9331da35..1abff7bcc162 100644
--- a/deployment/AzureDeploymentTemplate_regionoptions.json
+++ b/deployment/AzureDeploymentTemplate_regionoptions.json
@@ -22,13 +22,6 @@
"metadata": {
"description": "Your Github Repository token (see https://docs.microsoft.com/en-us/azure/static-web-apps/publish-azure-resource-manager?tabs=azure-cli#create-a-github-personal-access-token)"
}
- },
- "GithubAPIRepository": {
- "defaultValue": "https://github.com/KelvinTegelaar/CIPP-API",
- "type": "string",
- "metadata": {
- "description": "URL to your Github backend fork."
- }
}
},
"variables": {
From f3862a240db2f77359712af2df1057380d282448 Mon Sep 17 00:00:00 2001
From: John Duprey
Date: Fri, 4 Oct 2024 19:08:41 -0400
Subject: [PATCH 45/48] up version
---
package.json | 2 +-
public/version_latest.txt | 2 +-
version_latest.txt | 2 +-
3 files changed, 3 insertions(+), 3 deletions(-)
diff --git a/package.json b/package.json
index 2739d1d2801a..1c73c05ffb68 100644
--- a/package.json
+++ b/package.json
@@ -1,6 +1,6 @@
{
"name": "cipp",
- "version": "6.4.0",
+ "version": "6.4.1",
"description": "The CyberDrain Improved Partner Portal is a portal to help manage administration for Microsoft Partners.",
"homepage": "https://cipp.app/",
"bugs": {
diff --git a/public/version_latest.txt b/public/version_latest.txt
index 19b860c1872d..4c77920fd2c5 100644
--- a/public/version_latest.txt
+++ b/public/version_latest.txt
@@ -1 +1 @@
-6.4.0
+6.4.1
diff --git a/version_latest.txt b/version_latest.txt
index 19b860c1872d..4c77920fd2c5 100644
--- a/version_latest.txt
+++ b/version_latest.txt
@@ -1 +1 @@
-6.4.0
+6.4.1
From 6fcf6138b7da6106f9c0ee5210f6bbd41b9a87f1 Mon Sep 17 00:00:00 2001
From: KelvinTegelaar <49186168+KelvinTegelaar@users.noreply.github.com>
Date: Thu, 5 Dec 2024 20:25:39 +0100
Subject: [PATCH 46/48] updated extensions
---
.vscode/extensions.json | 1 -
1 file changed, 1 deletion(-)
diff --git a/.vscode/extensions.json b/.vscode/extensions.json
index c21abba6989f..38b71fec4e7f 100644
--- a/.vscode/extensions.json
+++ b/.vscode/extensions.json
@@ -2,7 +2,6 @@
"recommendations": [
"github.vscode-codeql",
"dbaeumer.vscode-eslint",
- "eg2.vscode-npm-script",
"christian-kohler.npm-intellisense",
"esbenp.prettier-vscode",
"stylelint.vscode-stylelint",
From f624f90eff52e1eaa86d643596fdd204d06b8d55 Mon Sep 17 00:00:00 2001
From: KelvinTegelaar <49186168+KelvinTegelaar@users.noreply.github.com>
Date: Wed, 18 Dec 2024 13:03:34 +0100
Subject: [PATCH 47/48] Update package.json
---
package.json | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/package.json b/package.json
index 1c73c05ffb68..4fa734663e0b 100644
--- a/package.json
+++ b/package.json
@@ -120,7 +120,7 @@
"vite-plugin-eslint": "^1.8.1"
},
"engines": {
- "node": "18",
+ "node": ">=20.17.0",
"npm": ">=8.3.0"
},
"overrides": {
From 41eea9a338deee8c904e77ec36853369f31b1f5e Mon Sep 17 00:00:00 2001
From: KelvinTegelaar <49186168+KelvinTegelaar@users.noreply.github.com>
Date: Wed, 18 Dec 2024 13:03:43 +0100
Subject: [PATCH 48/48] Update package.json
---
package.json | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/package.json b/package.json
index 4fa734663e0b..a8a975f0c44c 100644
--- a/package.json
+++ b/package.json
@@ -120,7 +120,7 @@
"vite-plugin-eslint": "^1.8.1"
},
"engines": {
- "node": ">=20.17.0",
+ "node": "20.17.0",
"npm": ">=8.3.0"
},
"overrides": {