Skip to content

Commit

Permalink
feat(application-system): On delete template api (#16605)
Browse files Browse the repository at this point in the history
* on delete

* fix if block

---------

Co-authored-by: kodiakhq[bot] <49736102+kodiakhq[bot]@users.noreply.github.com>
  • Loading branch information
obmagnusson and kodiakhq[bot] authored Oct 29, 2024
1 parent b86cd04 commit e50ded3
Show file tree
Hide file tree
Showing 5 changed files with 78 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -1079,6 +1079,7 @@ export class ApplicationController {
async delete(
@Param('id', new ParseUUIDPipe()) id: string,
@CurrentUser() user: User,
@CurrentLocale() locale: Locale,
) {
const { nationalId } = user
const existingApplication =
Expand All @@ -1097,6 +1098,53 @@ export class ApplicationController {
)
}

const template = await getApplicationTemplateByTypeId(
existingApplication.typeId,
)
if (template === null) {
throw new BadRequestException(
`No application template exists for type: ${existingApplication.typeId}`,
)
}

let onDeleteActions = new ApplicationTemplateHelper(
existingApplication,
template,
).getOnDeleteStateAPIAction()
if (onDeleteActions) {
const namespaces = await getApplicationTranslationNamespaces(
existingApplication,
)
if (!Array.isArray(onDeleteActions)) {
onDeleteActions = [onDeleteActions]
}

const intl = await this.intlService.useIntl(namespaces, locale)
const deletingApplication = await this.templateApiActionRunner.run(
existingApplication,
onDeleteActions,
user,
locale,
intl.formatMessage,
)

for (const api of onDeleteActions) {
const result =
deletingApplication.externalData[api.externalDataId || api.action]

this.logger.debug(
`Performing action ${api.action} on ${JSON.stringify(
template.name,
)} ended with ${result.status}`,
)

if (result.status === 'failure' && api.throwOnError) {
const reason = result.reason ?? 'Unknown error'
throw new TemplateApiError(reason, 500)
}
}
}

// delete charge in FJS
await this.applicationChargeService.deleteCharge(existingApplication)

Expand All @@ -1111,5 +1159,12 @@ export class ApplicationController {
)

await this.applicationService.delete(existingApplication.id)

this.auditService.audit({
auth: user,
action: 'delete',
resources: existingApplication.id,
meta: { type: existingApplication.typeId },
})
}
}
9 changes: 9 additions & 0 deletions libs/application/core/src/lib/ApplicationTemplateHelper.ts
Original file line number Diff line number Diff line change
Expand Up @@ -118,6 +118,15 @@ export class ApplicationTemplateHelper<
return this.getTemplateAPIAction(action)
}

getOnDeleteStateAPIAction(
stateKey: string = this.application.state,
): TemplateApi | TemplateApi[] | null {
const action =
this.template.stateMachineConfig.states[stateKey]?.meta?.onDelete ?? null

return this.getTemplateAPIAction(action)
}

getApplicationStateInformation(
stateKey: string = this.application.state,
): ApplicationStateMeta<TEvents> | undefined {
Expand Down
1 change: 1 addition & 0 deletions libs/application/types/src/lib/StateMachine.ts
Original file line number Diff line number Diff line change
Expand Up @@ -131,6 +131,7 @@ export interface ApplicationStateMeta<
roles?: RoleInState<T>[]
onExit?: TemplateApi<R>[] | TemplateApi<R>
onEntry?: TemplateApi<R>[] | TemplateApi<R>
onDelete?: TemplateApi<R>[] | TemplateApi<R>
}

export interface ApplicationStateSchema<T extends EventObject = AnyEventObject>
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,10 @@
import React, { useCallback, useState } from 'react'
import { Box, Pagination, Stack } from '@island.is/island-ui/core'
import {
Box,
Pagination,
Stack,
ToastContainer,
} from '@island.is/island-ui/core'
import {
Application,
ApplicationTypes,
Expand Down Expand Up @@ -95,6 +100,7 @@ const ApplicationList = ({
/>
</Box>
) : null}
<ToastContainer hideProgressBar closeButton useKeyframeStyles={false} />
</>
)
}
Expand Down
Original file line number Diff line number Diff line change
@@ -1,13 +1,19 @@
import { useMutation } from '@apollo/client'
import { DELETE_APPLICATION } from '@island.is/application/graphql'
import { handleServerError } from '../utilities/handleServerError'
import { useLocale } from '@island.is/localization'

export const useDeleteApplication = (refetch?: (() => void) | undefined) => {
const { formatMessage } = useLocale()
const [deleteApplicationMutation, { error, loading }] = useMutation(
DELETE_APPLICATION,
{
onCompleted: () => {
refetch?.()
},
onError: (error) => {
handleServerError(error, formatMessage)
},
},
)

Expand Down

0 comments on commit e50ded3

Please sign in to comment.