diff --git a/services/common/src/components/forms/RenderFileUpload.tsx b/services/common/src/components/forms/RenderFileUpload.tsx index f38ba74cf4..d17daa9b93 100644 --- a/services/common/src/components/forms/RenderFileUpload.tsx +++ b/services/common/src/components/forms/RenderFileUpload.tsx @@ -297,7 +297,6 @@ export const FileUpload: FC = ({ metadata: { filename: file.name, filetype: file.type || APPLICATION_OCTET_STREAM, - maxfilenamelength: metadata.maxfilenamelength, }, onError: (err, uploadResult) => { setUploadResultsFor(fileId, uploadResult); @@ -326,7 +325,6 @@ export const FileUpload: FC = ({ metadata: { filename: file.name, filetype: file.type || APPLICATION_OCTET_STREAM, - maxfilenamelength: metadata.maxfilenamelength, }, onBeforeRequest: (req) => { // Set authorization header on each request to make use @@ -465,9 +463,8 @@ export const FileUpload: FC = ({ }, []); const handleFileAdd = (err, file) => { - // Add properties to file metadata so we can reference it later + // Add ID to file metadata so we can reference it later file.setMetadata("filepondid", file.id); - file.setMetadata("maxfilenamelength", maxFileNameLength); }; const getLabel = () => { diff --git a/services/common/src/components/projectSummary/__snapshots__/ProjectManagement.spec.tsx.snap b/services/common/src/components/projectSummary/__snapshots__/ProjectManagement.spec.tsx.snap index f9ac708394..ef8956ff51 100644 --- a/services/common/src/components/projectSummary/__snapshots__/ProjectManagement.spec.tsx.snap +++ b/services/common/src/components/projectSummary/__snapshots__/ProjectManagement.spec.tsx.snap @@ -480,7 +480,7 @@ exports[`Project Management renders properly 1`] = ` @@ -546,7 +546,7 @@ exports[`Project Management renders properly 1`] = ` @@ -612,7 +612,7 @@ exports[`Project Management renders properly 1`] = ` diff --git a/services/common/src/utils/fileUploadHelper.interface.ts b/services/common/src/utils/fileUploadHelper.interface.ts index e378e17ee0..870e803ead 100644 --- a/services/common/src/utils/fileUploadHelper.interface.ts +++ b/services/common/src/utils/fileUploadHelper.interface.ts @@ -6,7 +6,6 @@ export interface FileUploadHelperProps { metadata: { filename: string; filetype: string; - maxfilenamelength: string; }; uploadResults?: UploadResult[]; uploadData?: MultipartDocumentUpload; diff --git a/services/core-api/app/api/constants.py b/services/core-api/app/api/constants.py index 814489289e..598b4b36c6 100644 --- a/services/core-api/app/api/constants.py +++ b/services/core-api/app/api/constants.py @@ -183,6 +183,10 @@ def EXPLOSIVES_PERMIT_DOCUMENT_DOWNLOAD_TOKEN(token_guid): PERM_RECL_EMAIL = 'permrecl@gov.bc.ca' +MAX_DOCUMENT_NAME_LENGTHS = { + "MAJOR_PROJECTS": 50, +} + CORE_PURPLE_LOGO_BASE64_ENCODED = '' BC_GOV_LOGO_BASE64_ENCODED = '' diff --git a/services/core-api/app/api/projects/information_requirements_table/resources/information_requirements_table_document_upload.py b/services/core-api/app/api/projects/information_requirements_table/resources/information_requirements_table_document_upload.py index 476a4d8bab..8e0601c434 100644 --- a/services/core-api/app/api/projects/information_requirements_table/resources/information_requirements_table_document_upload.py +++ b/services/core-api/app/api/projects/information_requirements_table/resources/information_requirements_table_document_upload.py @@ -6,7 +6,7 @@ from app.api.projects.project.models.project import Project from app.api.mines.mine.models.mine import Mine from app.api.services.document_manager_service import DocumentManagerService - +from app.api.constants import MAX_DOCUMENT_NAME_LENGTHS class InformationRequirementsTableDocumentUploadResource(Resource, UserMixin): @api.doc( @@ -14,12 +14,14 @@ class InformationRequirementsTableDocumentUploadResource(Resource, UserMixin): params={'project_guid': 'The GUID of the project the IRT belongs to.'}) def post(self, project_guid): project = Project.find_by_project_guid(project_guid) + if not project: raise NotFound('Project not found.') + mine = Mine.find_by_mine_guid(str(project.mine_guid)) if not mine: raise NotFound('Mine not found.') return DocumentManagerService.initializeFileUploadWithDocumentManager( - request, mine, 'information_requirements_table') + request, mine, 'information_requirements_table', MAX_DOCUMENT_NAME_LENGTHS['MAJOR_PROJECTS']) diff --git a/services/core-api/app/api/projects/major_mine_application/resources/major_mine_application_document_upload.py b/services/core-api/app/api/projects/major_mine_application/resources/major_mine_application_document_upload.py index de40b04671..14092a94d1 100644 --- a/services/core-api/app/api/projects/major_mine_application/resources/major_mine_application_document_upload.py +++ b/services/core-api/app/api/projects/major_mine_application/resources/major_mine_application_document_upload.py @@ -8,6 +8,7 @@ from app.api.projects.project.models.project import Project from app.api.mines.mine.models.mine import Mine from app.api.services.document_manager_service import DocumentManagerService +from app.api.constants import MAX_DOCUMENT_NAME_LENGTHS class MajorMineApplicationDocumentUploadResource(Resource, UserMixin): @@ -30,4 +31,4 @@ def post(self, project_guid): raise NotFound('Mine not found.') return DocumentManagerService.initializeFileUploadWithDocumentManager( - request, mine, 'major_mine_application') + request, mine, 'major_mine_application', MAX_DOCUMENT_NAME_LENGTHS['MAJOR_PROJECTS']) diff --git a/services/core-api/app/api/projects/project_decision_package/resources/project_decision_package_document_upload.py b/services/core-api/app/api/projects/project_decision_package/resources/project_decision_package_document_upload.py index 5cbbcf78ec..2cf165fd6d 100644 --- a/services/core-api/app/api/projects/project_decision_package/resources/project_decision_package_document_upload.py +++ b/services/core-api/app/api/projects/project_decision_package/resources/project_decision_package_document_upload.py @@ -8,6 +8,7 @@ from app.api.projects.project.models.project import Project from app.api.mines.mine.models.mine import Mine from app.api.services.document_manager_service import DocumentManagerService +from app.api.constants import MAX_DOCUMENT_NAME_LENGTHS class ProjectDecisionPackageDocumentUploadResource(Resource, UserMixin): @@ -30,4 +31,4 @@ def post(self, project_guid): raise NotFound('Mine not found.') return DocumentManagerService.initializeFileUploadWithDocumentManager( - request, mine, 'project_decision_package') + request, mine, 'project_decision_package', MAX_DOCUMENT_NAME_LENGTHS['MAJOR_PROJECTS']) diff --git a/services/core-api/app/api/projects/project_summary/resources/project_summary_document_upload.py b/services/core-api/app/api/projects/project_summary/resources/project_summary_document_upload.py index 8d2aa1af89..48d92abfc9 100644 --- a/services/core-api/app/api/projects/project_summary/resources/project_summary_document_upload.py +++ b/services/core-api/app/api/projects/project_summary/resources/project_summary_document_upload.py @@ -9,6 +9,7 @@ from app.api.services.document_manager_service import DocumentManagerService from app.config import Config from app.api.utils.feature_flag import is_feature_enabled, Feature +from app.api.constants import MAX_DOCUMENT_NAME_LENGTHS class ProjectSummaryDocumentUploadResource(Resource, UserMixin): @api.doc( @@ -29,7 +30,8 @@ def post(self, project_guid, project_summary_guid): if is_feature_enabled(Feature.MAJOR_PROJECT_REPLACE_FILE): return DocumentManagerService.validateFileNameAndInitializeFileUploadWithDocumentManager( - request, mine, project_guid, 'project_summaries') + request, mine, project_guid, 'project_summaries', MAX_DOCUMENT_NAME_LENGTHS['MAJOR_PROJECTS']) else: - return DocumentManagerService.initializeFileUploadWithDocumentManager(request, mine, 'project_summaries') + return DocumentManagerService.initializeFileUploadWithDocumentManager( + request, mine, 'project_summaries', MAX_DOCUMENT_NAME_LENGTHS['MAJOR_PROJECTS']) \ No newline at end of file diff --git a/services/core-api/app/api/services/document_manager_service.py b/services/core-api/app/api/services/document_manager_service.py index 0ed336b57f..c00ad2b0fd 100644 --- a/services/core-api/app/api/services/document_manager_service.py +++ b/services/core-api/app/api/services/document_manager_service.py @@ -35,7 +35,8 @@ class DocumentManagerService(): document_manager_document_resource_url = f'{Config.DOCUMENT_MANAGER_URL}/documents' @classmethod - def validateFileNameAndInitializeFileUploadWithDocumentManager(cls, request, mine, project_guid, document_category): + def validateFileNameAndInitializeFileUploadWithDocumentManager( + cls, request, mine, project_guid, document_category, max_document_name_length=None): metadata = cls._parse_request_metadata(request) file_name = metadata.get('filename') @@ -44,7 +45,7 @@ def validateFileNameAndInitializeFileUploadWithDocumentManager(cls, request, min resp = None if not mine_document: # No existing file found in this application hence continuing the file uploading - resp = DocumentManagerService.initializeFileUploadWithDocumentManager(request, mine, document_category) + resp = DocumentManagerService.initializeFileUploadWithDocumentManager(request, mine, document_category, max_document_name_length) elif mine_document.is_archived: # An archived file with the same name in this application found, hence responing with 409 content = { "description" : f"Archived file already exist with the given name: {file_name}", @@ -76,15 +77,14 @@ def validateFileNameAndInitializeFileUploadWithDocumentManager(cls, request, min return resp @classmethod - def initializeFileUploadWithDocumentManager(cls, request, mine, document_category): + def initializeFileUploadWithDocumentManager(cls, request, mine, document_category, max_document_name_length=None): metadata = cls._parse_request_metadata(request) if not metadata or not metadata.get('filename'): raise Exception('Request metadata missing filename') - max_file_name_length = metadata.get('maxfilenamelength', None) file_name = ((metadata.get('filename')).rsplit('.', 1))[0] - if max_file_name_length and max_file_name_length.isdigit() and len(file_name) > int(max_file_name_length): - raise BadRequest(f'File name exceeds the {max_file_name_length} character limit') + if max_document_name_length and len(file_name) > max_document_name_length: + raise BadRequest(f'File name exceeds the {max_document_name_length} character limit') folder, pretty_folder = cls._parse_upload_folders(mine, document_category) data = { diff --git a/services/core-web/cypress/e2e/majorprojects.cy.ts b/services/core-web/cypress/e2e/majorprojects.cy.ts index fbf9c20935..55beab3c03 100644 --- a/services/core-web/cypress/e2e/majorprojects.cy.ts +++ b/services/core-web/cypress/e2e/majorprojects.cy.ts @@ -77,7 +77,7 @@ describe("Major Projects", () => { expect(interception.request.headers["upload-length"]).to.equal("16368"); expect(interception.request.headers["upload-protocol"]).to.equal("s3-multipart"); expect(interception.request.headers["upload-metadata"]).to.equal( - "filename ZHVtbXkucGRm,filetype YXBwbGljYXRpb24vcGRm,maxfilenamelength NTA=" + "filename ZHVtbXkucGRm,filetype YXBwbGljYXRpb24vcGRm" ); }); diff --git a/services/core-web/src/components/Forms/UploadProjectDecisionPackageDocumentForm.js b/services/core-web/src/components/Forms/UploadProjectDecisionPackageDocumentForm.js index 424ad7b3be..b194ce8580 100644 --- a/services/core-web/src/components/Forms/UploadProjectDecisionPackageDocumentForm.js +++ b/services/core-web/src/components/Forms/UploadProjectDecisionPackageDocumentForm.js @@ -3,9 +3,7 @@ import PropTypes from "prop-types"; import { compose } from "redux"; import { Field, reduxForm, getFormValues } from "redux-form"; import { connect } from "react-redux"; -import { Form } from "@ant-design/compatible"; -import "@ant-design/compatible/assets/index.css"; -import { Button, Col, Row, Popconfirm, Typography, Divider, Checkbox } from "antd"; +import { Button, Col, Row, Popconfirm, Typography, Divider, Checkbox, Form } from "antd"; import { resetForm } from "@common/utils/helpers"; import * as FORM from "@/constants/forms"; import ProjectDecisionPackageFileUpload from "@/components/mine/Projects/ProjectDecisionPackageFileUpload"; @@ -65,16 +63,14 @@ export const UploadProjectDecisionPackageDocumentForm = (props) => { - - - + {isDecisionPackageEligible && ( diff --git a/services/core-web/src/components/mine/Projects/ProjectDecisionPackageFileUpload.js b/services/core-web/src/components/mine/Projects/ProjectDecisionPackageFileUpload.js index 74358396a6..fa666f3c27 100644 --- a/services/core-web/src/components/mine/Projects/ProjectDecisionPackageFileUpload.js +++ b/services/core-web/src/components/mine/Projects/ProjectDecisionPackageFileUpload.js @@ -1,8 +1,6 @@ import React from "react"; import PropTypes from "prop-types"; import { Field } from "redux-form"; -import { Form } from "@ant-design/compatible"; -import "@ant-design/compatible/assets/index.css"; import { PROJECT_DECISION_PACKAGE_DOCUMENTS } from "@mds/common/constants/API"; import FileUpload from "@/components/common/FileUpload"; import { DOCUMENT, EXCEL, IMAGE, SPATIAL } from "@/constants/fileTypes"; @@ -16,22 +14,20 @@ const propTypes = { }; export const ProjectDecisionPackageFileUpload = (props) => ( - - - + ); ProjectDecisionPackageFileUpload.propTypes = propTypes; diff --git a/services/core-web/src/styles/components/MajorMineApplication.scss b/services/core-web/src/styles/components/MajorMineApplication.scss deleted file mode 100644 index ad752809d9..0000000000 --- a/services/core-web/src/styles/components/MajorMineApplication.scss +++ /dev/null @@ -1,5 +0,0 @@ -.decision-package-uploads { - .ant-form-item-label { - text-align: left; - } -} \ No newline at end of file diff --git a/services/core-web/src/styles/index.scss b/services/core-web/src/styles/index.scss index 58b893c2dc..c545c9b517 100755 --- a/services/core-web/src/styles/index.scss +++ b/services/core-web/src/styles/index.scss @@ -66,6 +66,5 @@ @import "./components/PermitConditions.scss"; @import "./components/HelpGuide.scss"; @import "./components/RichTextEditor.scss"; -@import "./components/MajorMineApplication.scss"; // UTILITIES - utilities and helper classes. This layer has the highest specificity. \ No newline at end of file diff --git a/services/core-web/src/tests/components/Forms/__snapshots__/UploadProjectDecisionPackageDocumentForm.spec.js.snap b/services/core-web/src/tests/components/Forms/__snapshots__/UploadProjectDecisionPackageDocumentForm.spec.js.snap index bd9c9a6e3d..6216510193 100644 --- a/services/core-web/src/tests/components/Forms/__snapshots__/UploadProjectDecisionPackageDocumentForm.spec.js.snap +++ b/services/core-web/src/tests/components/Forms/__snapshots__/UploadProjectDecisionPackageDocumentForm.spec.js.snap @@ -1,11 +1,8 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP exports[`UploadProjectDecisionPackageDocumentForm renders properly 1`] = ` -
- - - +
-
+ `;