New Research: Supply Chain Attack on Axios Pulls Malicious Dependency from npm.Details →
Socket
Book a DemoSign in
Socket

dicom

Package Overview
Dependencies
Maintainers
1
Versions
8
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

dicom

DICOM for node-js

latest
Source
npmnpm
Version
0.4.4
Version published
Maintainers
1
Created
Source

Node.js DICOM

Build Status

The package provides the following:

  • Data dictionary according to the 2014a standard.
  • Streaming DICOM Decoder that reads a DICOM stream and emits DicomEvent instances.
  • Streaming JSON Encoder that turns a DicomEvent stream into a DICOM JSON Model
  • JSON Sink that consumes the JSON Model stream and produces an in-memory JSON Object.

Limitations:

  • ISO 2022 character sets are not in iconv-lite, this means the decoder does not currently support ISO 2022 encodings, multi-valued (0008,0005) Specific Character Set and DICOM characterset extensions.
  • Dicom Elements with a value length above a configurable threshold are not constructed in-memory, but emitted as start_element, a sequence of raw events with the encoded value and an end_element event. The JSON Encoder emits these as bulkdata URLs, but currently there is no way to use these urls (except parsing the url and extracting the bulkdata using offset and length from the url).
  • Other DICOM VRs (OB, OW, OF, OD, UN) do not provide a way to interpret the data, i.e. it's just passed on as a byte array, unchanged.

Documentation:

There is documentation for the various pieces in the doc directory. Most notably:

Examples:

Read a DICOM file, produce JSON Model, and print some data:

dicom = require "dicom"

decoder = dicom.decoder {guess_header: true}
encoder = new dicom.json.JsonEncoder()
sink = new dicom.json.JsonSink (err, json) ->
  if err
    console.log "Error:", err
    process.exit 10
  print_element json, dicom.tags.PatientID
  print_element json, dicom.tags.IssuerOfPatientID
  print_element json, dicom.tags.StudyInstanceUID
  print_element json, dicom.tags.AccessionNumber

print_element = (json, path...) ->
  console.log dicom.json.get_value(json, path...)

require("fs").createReadStream(process.argv[2]).pipe decoder
  .pipe encoder
  .pipe sink

And the same thing in Javascript:

"use strict";

var dicom = require("dicom");

var decoder = dicom.decoder({
    guess_header: true
});

var encoder = new dicom.json.JsonEncoder();

var print_element = function(json, elem) {
    console.log(dicom.json.get_value(json, elem));
};

var sink = new dicom.json.JsonSink(function(err, json) {
    if (err) {
      console.log("Error:", err);
      process.exit(10);
    }
    print_element(json, dicom.tags.PatientID);
    print_element(json, dicom.tags.IssuerOfPatientID);
    print_element(json, dicom.tags.StudyInstanceUID);
    print_element(json, dicom.tags.AccessionNumber);
});

require("fs").createReadStream(process.argv[2]).pipe(decoder).pipe(encoder).pipe(sink);

Keywords

DICOM

FAQs

Package last updated on 01 Mar 2019

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts