cod-dicomweb-server 1.3.16 → 1.3.18
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/main.js +276 -57
- package/dist/esm/classes/CodDicomWebServer.js +2 -1
- package/dist/esm/constants/index.d.ts +3 -1
- package/dist/esm/constants/index.js +3 -2
- package/dist/esm/constants/metadata.d.ts +8 -0
- package/dist/esm/constants/metadata.js +8 -0
- package/dist/esm/metadataManager.d.ts +4 -1
- package/dist/esm/metadataManager.js +53 -8
- package/dist/esm/types/metadata.d.ts +1 -1
- package/dist/umd/563.js +1 -1
- package/dist/umd/846.js +1 -1
- package/dist/umd/main.js +4 -4
- package/dist/umd/main.js.map +1 -1
- package/package.json +5 -4
|
@@ -1,10 +1,27 @@
|
|
|
1
|
+
import { ZSTDDecoder } from 'zstddec';
|
|
1
2
|
import { CustomError } from './classes/customClasses';
|
|
2
3
|
import { createMetadataJsonUrl } from './classes/utils';
|
|
4
|
+
import { medatata } from './constants';
|
|
3
5
|
import { createMetadataFileName, getDirectoryHandle, readFile, writeFile } from './fileAccessSystemUtils';
|
|
4
6
|
class MetadataManager {
|
|
5
7
|
metadataPromises = {};
|
|
6
|
-
|
|
7
|
-
|
|
8
|
+
decoder;
|
|
9
|
+
decoderInitPromise;
|
|
10
|
+
constructor() {
|
|
11
|
+
this.decoder = null;
|
|
12
|
+
const decoder = new ZSTDDecoder();
|
|
13
|
+
this.decoderInitPromise = decoder
|
|
14
|
+
.init()
|
|
15
|
+
.then(() => {
|
|
16
|
+
this.decoder = decoder;
|
|
17
|
+
return true;
|
|
18
|
+
})
|
|
19
|
+
.catch((error) => {
|
|
20
|
+
console.error('Failed to initialize ZSTD WASM module:', error);
|
|
21
|
+
return false;
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
async addDeidMetadata(jsonMetadata, url) {
|
|
8
25
|
const { cod } = jsonMetadata;
|
|
9
26
|
const [studyUID, _, seriesUID] = url.match(/studies\/(.*?)\/metadata/)?.[1].split('/') || [];
|
|
10
27
|
if (!cod || !studyUID || !seriesUID) {
|
|
@@ -13,9 +30,18 @@ class MetadataManager {
|
|
|
13
30
|
}
|
|
14
31
|
for (const sopUID in cod.instances) {
|
|
15
32
|
const instance = cod.instances[sopUID];
|
|
16
|
-
|
|
17
|
-
instance.
|
|
18
|
-
|
|
33
|
+
// For V2, convert the metadata to InstanceMetadata format.
|
|
34
|
+
if (instance.version === medatata.METADATA_VERSION.V2 && typeof instance.metadata === 'string') {
|
|
35
|
+
const parsedMetadata = await this.decodeDecompressAndParse(instance.metadata);
|
|
36
|
+
if (!parsedMetadata) {
|
|
37
|
+
throw new Error('Failed to decode, decompress, or parse JSON');
|
|
38
|
+
}
|
|
39
|
+
instance.metadata = parsedMetadata;
|
|
40
|
+
}
|
|
41
|
+
const instanceMetadata = instance.metadata;
|
|
42
|
+
instanceMetadata.DeidStudyInstanceUID = { Value: [studyUID] };
|
|
43
|
+
instanceMetadata.DeidSeriesInstanceUID = { Value: [seriesUID] };
|
|
44
|
+
instanceMetadata.DeidSopInstanceUID = { Value: [sopUID] };
|
|
19
45
|
}
|
|
20
46
|
}
|
|
21
47
|
getMetadataFromCache(url) {
|
|
@@ -44,9 +70,10 @@ class MetadataManager {
|
|
|
44
70
|
}
|
|
45
71
|
return response.json();
|
|
46
72
|
})
|
|
47
|
-
.then((data) => {
|
|
48
|
-
this.addDeidMetadata(data, url);
|
|
49
|
-
|
|
73
|
+
.then(async (data) => {
|
|
74
|
+
await this.addDeidMetadata(data, url);
|
|
75
|
+
await writeFile(directoryHandle, fileName, data, true);
|
|
76
|
+
return data;
|
|
50
77
|
});
|
|
51
78
|
return await this.metadataPromises[url];
|
|
52
79
|
}
|
|
@@ -55,5 +82,23 @@ class MetadataManager {
|
|
|
55
82
|
throw error;
|
|
56
83
|
}
|
|
57
84
|
}
|
|
85
|
+
async decodeDecompressAndParse(base64String) {
|
|
86
|
+
if (!base64String) {
|
|
87
|
+
return null;
|
|
88
|
+
}
|
|
89
|
+
try {
|
|
90
|
+
if (!(await this.decoderInitPromise)) {
|
|
91
|
+
throw new Error('WASM Decoder is not initialized. Cannot decompress data.');
|
|
92
|
+
}
|
|
93
|
+
const compressedBytes = Uint8Array.from(atob(base64String), (c) => c.charCodeAt(0));
|
|
94
|
+
const decompressedBytes = this.decoder.decode(compressedBytes);
|
|
95
|
+
const jsonString = new TextDecoder().decode(decompressedBytes);
|
|
96
|
+
return JSON.parse(jsonString);
|
|
97
|
+
}
|
|
98
|
+
catch (error) {
|
|
99
|
+
console.error('Failed to decode, decompress, or parse JSON:', error);
|
|
100
|
+
return null;
|
|
101
|
+
}
|
|
102
|
+
}
|
|
58
103
|
}
|
|
59
104
|
export default MetadataManager;
|
package/dist/umd/563.js
CHANGED