diff --git a/deployment/conf/supported_apps_w_extensions.json b/deployment/conf/supported_apps_w_extensions.json index a4649424..47af9b64 100644 --- a/deployment/conf/supported_apps_w_extensions.json +++ b/deployment/conf/supported_apps_w_extensions.json @@ -121,8 +121,7 @@ "csv", "tsv", "xls", - "xlsx", - "json" + "xlsx" ], "media": [ "tsv", @@ -149,6 +148,9 @@ ], "escher_map": [ "json" + ], + "dts_manifest": [ + "json" ] }, "types": { @@ -1102,31 +1104,31 @@ } ] }, - "json": { + "smbl": { "file_ext_type": [ - "JSON" + "SBML" ], "mappings": [ { - "id": "import_specification", - "title": "Import Specification", - "app_weight": 1 - }, - { - "id": "escher_map", - "title": "EscherMap", + "id": "fba_model", + "title": "FBA Model", "app_weight": 1 } ] }, - "smbl": { + "json": { "file_ext_type": [ - "SBML" + "JSON" ], "mappings": [ { - "id": "fba_model", - "title": "FBA Model", + "id": "escher_map", + "title": "EscherMap", + "app_weight": 1 + }, + { + "id": "dts_manifest", + "title": "Data Transfer Service Manifest", "app_weight": 1 } ] diff --git a/staging_service/autodetect/GenerateMappings.py b/staging_service/autodetect/GenerateMappings.py index 4d2287f7..5f0d4212 100644 --- a/staging_service/autodetect/GenerateMappings.py +++ b/staging_service/autodetect/GenerateMappings.py @@ -50,6 +50,7 @@ ZIP, assembly_id, decompress_id, + dts_manifest, escher_map_id, expression_matrix_id, extension_to_file_format_mapping, @@ -90,6 +91,7 @@ phenotype_set_id: "Phenotype Set", escher_map_id: "EscherMap", import_specification: "Import Specification", + dts_manifest: "Data Transfer Service Manifest", } file_format_to_app_mapping = {} @@ -129,7 +131,7 @@ fba_model_id, import_specification, ] -file_format_to_app_mapping[JSON] = [escher_map_id, import_specification] +file_format_to_app_mapping[JSON] = [escher_map_id, dts_manifest] file_format_to_app_mapping[SBML] = [fba_model_id] app_id_to_extensions = defaultdict(list) diff --git a/staging_service/autodetect/Mappings.py b/staging_service/autodetect/Mappings.py index af08e54c..a063eb33 100644 --- a/staging_service/autodetect/Mappings.py +++ b/staging_service/autodetect/Mappings.py @@ -51,6 +51,10 @@ # import_specification is not a "real" data type, but rather tells the narrative that the # file contains specifications for how to load one or more other staging area files. import_specification = "import_specification" +# dts_manifest is also not a real data type, but functions like import_specification as +# it tells the narrative that the file has specs for loading other staging area files +# that came from the Data Transfer Service, and that this manifest follows that spec. +dts_manifest = "dts_manifest" decompress_id = "decompress" metabolic_annotations_id = "metabolic_annotation" metabolic_annotations_bulk_id = "metabolic_annotation_bulk" diff --git a/tests/test_app.py b/tests/test_app.py index b18bf9d8..3d938d0c 100644 --- a/tests/test_app.py +++ b/tests/test_app.py @@ -1898,7 +1898,8 @@ async def test_importer_filetypes(): a2f = js["datatype_to_filetype"] assert a2f["assembly"] == ["FASTA"] assert a2f["gff_genome"] == ["FASTA", "GFF"] - assert a2f["import_specification"] == ["CSV", "EXCEL", "JSON", "TSV"] + assert a2f["import_specification"] == ["CSV", "EXCEL", "TSV"] + assert a2f["dts_manifest"] == ["JSON"] f2e = js["filetype_to_extensions"] assert f2e["FASTA"] == [