Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Minor changes #5

Open
wants to merge 4 commits into
base: master
Choose a base branch
from
Open
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
49 changes: 47 additions & 2 deletions src/Anon.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import policy from './DefaultPolicy';
import sjcl from './sjcl.sha512'
import sjcl from './sjcl.sha512';
// Prefix from Medical Connections
const UIDPREFIX = "1.2.826.0.1.3680043.10.341.";
// We want to keep the hash algorithm the same to preserve references.
Expand All @@ -26,14 +26,59 @@ function randomUid() {
return UIDPREFIX + "777." + rando;
};

//CMHM new function to check that what is in fields is proper
//below are fields that are kept
// the psuedocode fot what I am going to add is this:
// if a field, for exmaple "00080060" contains ("CT" or "MRI" or "Xray" or "flouro" or "US" or "ultrasound" in the DICOM language- must check:
// "action":"keep"
// else
// // "action":"remove"
// OBVIOUSLY I NEED TO CHECK that CT and MRI are not hashed or encoded or entered as Numbers or , or or,or
// // "00080016": {"action":"keep", "description":"SOP Class UID"},
// The following are additional fields to check:
// "00080060": { "description":"Modality"},
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is listed in the default set of policies at https://github.com/radiopaedia/dicomanon/blob/master/src/DefaultPolicy.ts#L9

// "00080008": { "description":"Image Type"},
// "00080005": {"description":"Specific Character Set"},
// "00180095": { "description":"Pixel Bandwidth"},
// "00280002": { "description":"Samples per Pixel"},
// "00280004": { "description":"Photometric Interpretation"},
// "00280010": { "description":"Rows"},
// "00280011": { "description":"Columns"},
// "00280030": { "description":"Pixel Spacing"},
// "00280100": {"description":"Bits Allocated"},
// "00280101": { "description":"Bits Stored"},
// "00280103": {"description":"Pixel Representation"},
// "00280106": {"description":"Smallest Image Pixel Value"},
// "00280107": {" "description":"Largest Image Pixel Value"},
// "00281050": {"description":"Window Center"},
// "00281051": {"description":"Window Width"},
// "00281052": {"description":"Rescale Intercept"},
// "00281053": { "description":"Rescale Slope"},
// "00281055": { "description":"Window Center & Width Explanation"},
// "00180015": { "description":"Body Part Examined"},
// "00180020": { "description":"Scanning Sequence"},
// "00180021": { "description":"Sequence Variant"},
// "00180022": { "description":"Scan Options"},
// "00180050": { "description":"Slice Thickness"},
// "00185100": { "description":"Patient Position"},
// "00200032": { "description":"Image Position (Patient)"},
// "00201041": { "description":"Slice Location"},
// // and also lt's check about the actual pixel data. perhaps even in later versions for steganography
// "00280102": { "description":"High Bit, required to decode pixel data"},
// "7FE00010": { "description":"Pixel Data"},
//
// TODO: Test that there's no personal data stored outside the "Value" for a
// given tag. This should be the case, and we're making the assumption that the
// user is not maliciously trying to hide data.


export default function anonymize(dict) {
var newDict = {};
var rule = policy["default"];
for(const key of Object.keys(dict)) {
// Use default action or action specified in policy
var rule = policy["default"];

// What happens if key is not in policy? ??? (CMHM)
if (key in policy) { rule = policy[key]; }
var action = rule["action"];
// For keep actions we can just pass the tag accross...
Expand Down