mirror of
https://github.com/Stirling-Tools/Stirling-PDF.git
synced 2025-08-26 14:19:24 +00:00

* automate feature * Moved all providers to app level to simplify homepage * Circular dependency fixes * You will see that now toolRegistry gets a tool config and a tool settings object. These enable automate to run the tools using as much static code as possible. --------- Co-authored-by: Connor Yoh <connor@stirlingpdf.com>
41 lines
1.7 KiB
TypeScript
41 lines
1.7 KiB
TypeScript
import { useTranslation } from 'react-i18next';
|
|
import { useToolOperation } from '../shared/useToolOperation';
|
|
import { createStandardErrorHandler } from '../../../utils/toolErrorHandler';
|
|
import { SanitizeParameters, defaultParameters } from './useSanitizeParameters';
|
|
|
|
// Static function that can be used by both the hook and automation executor
|
|
export const buildSanitizeFormData = (parameters: SanitizeParameters, file: File): FormData => {
|
|
const formData = new FormData();
|
|
formData.append('fileInput', file);
|
|
|
|
// Add parameters
|
|
formData.append('removeJavaScript', parameters.removeJavaScript.toString());
|
|
formData.append('removeEmbeddedFiles', parameters.removeEmbeddedFiles.toString());
|
|
formData.append('removeXMPMetadata', parameters.removeXMPMetadata.toString());
|
|
formData.append('removeMetadata', parameters.removeMetadata.toString());
|
|
formData.append('removeLinks', parameters.removeLinks.toString());
|
|
formData.append('removeFonts', parameters.removeFonts.toString());
|
|
|
|
return formData;
|
|
};
|
|
|
|
// Static configuration object
|
|
export const sanitizeOperationConfig = {
|
|
operationType: 'sanitize',
|
|
endpoint: '/api/v1/security/sanitize-pdf',
|
|
buildFormData: buildSanitizeFormData,
|
|
filePrefix: 'sanitized_', // Will be overridden in hook with translation
|
|
multiFileEndpoint: false,
|
|
defaultParameters,
|
|
} as const;
|
|
|
|
export const useSanitizeOperation = () => {
|
|
const { t } = useTranslation();
|
|
|
|
return useToolOperation<SanitizeParameters>({
|
|
...sanitizeOperationConfig,
|
|
filePrefix: t('sanitize.filenamePrefix', 'sanitized') + '_',
|
|
getErrorMessage: createStandardErrorHandler(t('sanitize.error.failed', 'An error occurred while sanitising the PDF.'))
|
|
});
|
|
};
|