-
Notifications
You must be signed in to change notification settings - Fork 4
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
49977e2
commit 812da1b
Showing
13 changed files
with
1,351 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
name: Publish wiki | ||
on: | ||
push: | ||
branches: [main] | ||
paths: | ||
- wiki/** | ||
- .github/workflows/publish-wiki.yaml | ||
concurrency: | ||
group: publish-wiki | ||
cancel-in-progress: true | ||
permissions: | ||
contents: write | ||
jobs: | ||
publish-wiki: | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: actions/checkout@v3 | ||
- uses: Andrew-Chen-Wang/github-wiki-action@v4 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,56 @@ | ||
# DICOM Instance Test Info | ||
- This page about test info of raccoon-dicom | ||
|
||
## DICOM Instances' Info | ||
| Patient ID | Procedure Code | Modality | Series Count | Image Count | | ||
|--------------|----------------|----------|--------------|---------------| | ||
| C3L-00277 | 36643-5 | DX | 1 | 1 | | ||
| C3N-00953 | 42274-1 | CT | 3 | 11 | | ||
| TCGA-G4-6304 | 42274-1 | CT | 3 | 14 | | ||
| 123456 | | SM | 1 | 1 (Frame: 15) | | ||
|
||
## Test Search For Studies | ||
### Query By `StudyDate (0008, 0020)` | ||
#### Step 100 | ||
- StudyDate=19990101-19991231 | ||
- Expect 2 matches | ||
#### Step 110 | ||
- StudyDate=20220101-20221231 | ||
- Expect 0 match | ||
### Step 170: Query By `PatientID (0010, 0020)` | ||
- PatientID=TCGA-G4-6304 | ||
- Expect 1 match | ||
|
||
### Step 120: Query By `PatientName (0010, 0010)` & `StudyDate (0008, 0020)` | ||
- PatientName=TCGA\*&StudyDate=20100101-20101231 | ||
- Expect 0 match | ||
- PatientName=TCGA\*&StudyDate=19990101-19991231 | ||
- Expect 1 match | ||
|
||
### Step 130: Query By `PatientName (0010, 0010)` & `PatientBirthDate (0010, 0030)` | ||
- PatientName=ChestXR\*&PatientBirthDate=19590101 | ||
- Expect 0 match | ||
- PatientName=ChestXR\*&PatientBirthDate=19601218 | ||
- Expect 1 match | ||
|
||
### Step 140: Query By `PatientID (0010, 0020)` & `AccessionNumber (0008, 0050)` | ||
- PatientID=C3N-00953&AccessionNumber=4444 | ||
- Expect 0 match | ||
- PatientID=C3N-00953&AccessionNumber=2794663908550664 | ||
|
||
## Test Search For Series | ||
### Step 150 | ||
- Use StudyInstanceUID from [Query By `PatientID (0010, 0020)` & `AccessionNumber (0008, 0050)`](https://github.com/Chinlinlee/raccoon-dicom/wiki/DICOM-Instance-Test-Info#query-by-patientid-0010-0020--accessionnumber-0008-0050) to search | ||
- Expect 3 series | ||
### Step 180 | ||
- Use StudyInstanceUID from [170](https://github.com/Chinlinlee/raccoon-dicom/wiki/DICOM-Instance-Test-Info#query-by-patientid-0010-0020-170) to search | ||
- Expect 3 series | ||
|
||
## Test Search For Instances | ||
### Step 160 | ||
- Use response's SeriesInstanceUIDs from [150](https://github.com/Chinlinlee/raccoon-dicom/wiki/DICOM-Instance-Test-Info#150) | ||
- Expect 1 image, 5 images, and 5 images in 3 series, respectively | ||
|
||
## Test limit | ||
- Query limit=1 in study level | ||
- Expect 1 match |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,311 @@ | ||
# Step by Step guide to installing - Windows | ||
|
||
## Download Raccoon | ||
### Use git | ||
```bash | ||
git clone https://github.com/Chinlinlee/raccoon-dicom.git | ||
``` | ||
|
||
### Alternative, Download ZIP | ||
data:image/s3,"s3://crabby-images/50ab3/50ab31243867dd1de94a037797ca8ab91a627cbc" alt="image" | ||
|
||
> ⚠️ Please unzip by yourself | ||
## Install Environment Requirements | ||
|
||
### Environment Requirements | ||
The following is a list of requirements, we will install each software next. | ||
- [Node.js](https://nodejs.org/zh-tw/download) >= 16 | ||
- [Mongodb](https://www.mongodb.com/try/download/community) >= 4 | ||
- [Imagemagick](https://imagemagick.org/script/download.php) | ||
- openJDK >= 11 | ||
|
||
|
||
### Install Node.js 16 | ||
- [Click here to download Node.js 16 installer](https://nodejs.org/download/release/v16.20.0/node-v16.20.0-x64.msi) | ||
- Open `node-v16.20.0-x64.msi` that you downloaded | ||
|
||
data:image/s3,"s3://crabby-images/8a640/8a6402c08b1550d4733a63ac5538e55db4f9e7e7" alt="image" | ||
|
||
- **Select Install Destination** and click Next | ||
|
||
data:image/s3,"s3://crabby-images/db2a7/db2a75e1df00bc21ab65b94d669bc6695300ddc3" alt="image" | ||
|
||
- Click Install | ||
|
||
data:image/s3,"s3://crabby-images/9b355/9b3556490328624c4392b07965fc4b0e9d599f6c" alt="image" | ||
|
||
#### Verify Node.js has been installed successfully | ||
Open cmd and type `node -v`. | ||
If present v16.20.0, congratulations install successfully. | ||
|
||
data:image/s3,"s3://crabby-images/153e6/153e601a39c028a625263fd8e95df893a86297d9" alt="image" | ||
|
||
### Install MongoDB | ||
- Enter Home of MongoDB: https://www.mongodb.com/try/download/community | ||
- Select Version → `4.4.21`,`Platform` → `Windows` -> `Package` → `msi` and click Download | ||
|
||
data:image/s3,"s3://crabby-images/c0d7c/c0d7c479edf1160510a14c64aab3cb3f43f5b5de" alt="image" | ||
|
||
- Open `mongodb-windows-x86_64-4.4.21-signed.msi` that you downloaded | ||
|
||
data:image/s3,"s3://crabby-images/ea88a/ea88a35a1aed4b3786b46ded69259c9fdf5e4c68" alt="image" | ||
|
||
- Select Complete | ||
|
||
data:image/s3,"s3://crabby-images/2c401/2c401e63ef0d05402c559b2eeeb8643413f14702" alt="image" | ||
|
||
- Set Data Directory and Log Directory and then click Next | ||
|
||
data:image/s3,"s3://crabby-images/e8d11/e8d112deeff87f4c525a22bbee1319564d3f43d8" alt="image" | ||
|
||
- Install MongoDB Compass | ||
|
||
data:image/s3,"s3://crabby-images/ee052/ee052204af16e45651aba8e16839cae29565b930" alt="image" | ||
|
||
- Click Install | ||
|
||
data:image/s3,"s3://crabby-images/7f496/7f496a15d1b83a82d136692fa2463394a220f006" alt="image" | ||
|
||
- Installation Completed! | ||
|
||
data:image/s3,"s3://crabby-images/8f3d3/8f3d322f0dd4375d13fd5fcf6bf7c1d758d9940a" alt="image" | ||
|
||
#### Create User in MongoDB | ||
Since the MongoDB connection with Raccoon-DICOM requires username and password. | ||
You need to create a user in the MongoDB to use Raccoon-DICOM. | ||
- Open MongoDB Compass | ||
- Enter the following connection string in New Connection and click Connect. | ||
|
||
```bash | ||
mongodb://localhost:27017 | ||
``` | ||
|
||
data:image/s3,"s3://crabby-images/c34ed/c34ed47acdcbc34da56bdf22c0f8d060ea7ba1f5" alt="image" | ||
|
||
- Click `>_MONGOSH` below. | ||
|
||
data:image/s3,"s3://crabby-images/88b56/88b56ae843226d62865d36432728edc92a37459a" alt="image" | ||
|
||
- Enter the following command to switch to admin database | ||
```bash | ||
use admin; | ||
``` | ||
|
||
data:image/s3,"s3://crabby-images/929a9/929a9b191121b3a4c63c24eb772edced5e416506" alt="image" | ||
|
||
- Enter the following command to create root user | ||
|
||
> **Warning** | ||
> ⚠️Please change the username and password to a secure one by yourself! | ||
```js | ||
db.createUser({ | ||
user : "root", | ||
pwd : "root" , | ||
roles : [{role : "root" , db:"admin"}] | ||
}); | ||
``` | ||
|
||
> If present { ok: 1 }, it means the creation was successful! | ||
### Install ImageMagick | ||
- Enter Download page of ImageMagick: https://imagemagick.org/script/download.php | ||
- Click `Windows Binary Release` to redirect to Windows paragraph | ||
|
||
data:image/s3,"s3://crabby-images/f5b50/f5b502c137bd71c8c36f5b7678ed2bbf2fb11c23" alt="image" | ||
|
||
- Click `ImageMagick-7.1.0-27-Q16-HDRI-x64-dll.exe` to download | ||
|
||
data:image/s3,"s3://crabby-images/a9d03/a9d0374208ec74d2f3ae0c1bc1a4a655e511974d" alt="image" | ||
|
||
- Open `ImageMagick-7.1.0-27-Q16-HDRI-x64-dll` that you downloaded | ||
|
||
data:image/s3,"s3://crabby-images/b92d2/b92d2ba3fdd581056ee51e2f8431e73e762c52f9" alt="image" | ||
|
||
- Select install destination and click Next | ||
|
||
data:image/s3,"s3://crabby-images/e2f4c/e2f4c33b27fddc9ca5b9b36ee435111448e948fe" alt="image" | ||
|
||
- Click Install | ||
|
||
data:image/s3,"s3://crabby-images/5177c/5177c83768f4997923999261c426ccd5a766c5d7" alt="image" | ||
|
||
- Click Next, and uncheck `View Index.html`, and click Finish | ||
|
||
data:image/s3,"s3://crabby-images/1b7e1/1b7e1ecee6966db5b2cbf304a1d053a26150fdcb" alt="image" | ||
data:image/s3,"s3://crabby-images/e6336/e63360e7e1207423baa54ed8b1222301dff76819" alt="image" | ||
|
||
#### Verify installation is complete | ||
Open cmd (command prompt) and enter "magick -version". If you see the following message, the installation is successful! | ||
|
||
data:image/s3,"s3://crabby-images/2ddb2/2ddb2b442f4c3e20f78221882c10ac822128529c" alt="image" | ||
|
||
### Install JAVA JDK | ||
- Go to https://adoptium.net/temurin/releases/ | ||
- Select Operating System: Windows | ||
- Architecture: x64 | ||
- Package Type: JDK | ||
- Version: 11 | ||
- Click to download | ||
|
||
data:image/s3,"s3://crabby-images/76d9f/76d9fe339435234e219d5287cb884e75427e8361" alt="image" | ||
|
||
- Open `OpenJDK11U-jdk_x64_windows_hotspot_11.0.19_7` that you downloaded one | ||
|
||
data:image/s3,"s3://crabby-images/5103a/5103ab2fa0e8e68ff86ed5a223fe54ba300cf75e" alt="image" | ||
|
||
- Select install destination and click Next | ||
|
||
data:image/s3,"s3://crabby-images/6b500/6b500fc5457bd71f7ef71e0c95561d9a62d92827" alt="image" | ||
|
||
- Click Install | ||
|
||
data:image/s3,"s3://crabby-images/4164d/4164d4552d6f584b2bf21dc454c62ac74281ff5b" alt="image" | ||
|
||
- Completed! | ||
|
||
data:image/s3,"s3://crabby-images/a856f/a856f7b78c64d6ffbf3cda55729be9e39a4d6ccc" alt="image" | ||
|
||
> ⚠️Please reboot after installation | ||
#### Verify JAVA is installed successfully | ||
- Open the command prompt and enter `javac --version` | ||
- If present version info on cmd, congrats! | ||
|
||
data:image/s3,"s3://crabby-images/d7d84/d7d84bf08bac45c6c733941c2c284ab35d69b3c2" alt="image" | ||
|
||
## Raccoon-DICOM Installation | ||
The required software has been installed, and you can now proceed with setting up Raccoon! | ||
⚠️ Note: Before the following steps, please navigate to the Raccoon project directory. | ||
### Install Node.js Packages | ||
Open the command prompt and navigate to the Raccoon project directory, then execute the following command: | ||
```bash | ||
npm i --only=production | ||
``` | ||
|
||
> **Note** | ||
> --only=production means only install dependencies in the `dependencies` block of package.json file | ||
### Configure dotenv `.env` file | ||
- Copy `.env.template` in the project root and rename it to `.env` | ||
|
||
data:image/s3,"s3://crabby-images/6e2f8/6e2f81290d65d1ee9195625ed457b07265b2d029" alt="image" | ||
|
||
- Modify `.env` | ||
```text | ||
# MongoDB | ||
MONGODB_NAME="raccoon-dicom" | ||
MONGODB_HOSTS=["mongodb"] | ||
MONGODB_PORTS=[27017] | ||
MONGODB_USER="root" | ||
MONGODB_PASSWORD="root" | ||
MONGODB_AUTH_SOURCE="admin" | ||
MONGODB_OPTIONS="" | ||
MONGODB_IS_SHARDING_MODE=false | ||
# Server | ||
SERVER_PORT=8081 | ||
SERVER_SESSION_SECRET_KEY="secret-key" | ||
# DICOM Web | ||
DICOM_STORE_ROOTPATH="/dicomFiles" | ||
DICOMWEB_HOST="{host}" | ||
DICOMWEB_PORT=8081 | ||
DICOMWEB_API="dicom-web" | ||
# DICOM DIMSE | ||
ENABLE_DIMSE=true | ||
DIMSE_AE_TITLE="RACCOONQRSCP" # default: RACCOONQRSCP | ||
DIMSE_HOSTNAME="0.0.0.0" # default: 127.0.0.1 | ||
DIMSE_PORT=11112 # default: 11112 | ||
DIMSE_MAX_PDULEN_RCV=16378 | ||
DIMSE_MAX_PDULEN_SND=16378 | ||
DIMSE_NOT_ASYNC=false | ||
DIMSE_MAX_OPS_INVOKED=0 | ||
DIMSE_MAX_OPS_PERFORMED=0 | ||
DIMSE_NOT_PACK_PDV=false | ||
DIMSE_CONNECT_TIMEOUT=0 | ||
DIMSE_REQUEST_TIMEOUT=0 | ||
DIMSE_ACCEPT_TIMEOUT=0 | ||
DIMSE_RELEASE_TIMEOUT=0 | ||
DIMSE_SEND_TIMEOUT=0 | ||
DIMSE_STORE_TIMEOUT=0 | ||
DIMSE_RESPONSE_TIMEOUT=0 | ||
DIMSE_RETRIEVE_TIMEOUT=0 | ||
DIMSE_RETRIEVE_TIMEOUT_TOTAL=0 | ||
DIMSE_IDLE_TIMEOUT=0 | ||
DIMSE_SOCLOSE_DELAY=50 | ||
DIMSE_SOSND_BUFFER=0 | ||
DIMSE_SORCV_BUFFER=0 | ||
DIMSE_TCP_DELAY=false | ||
# DIMSE TLS | ||
DIMSE_TLS=false | ||
DIMSE_TLS_NULL=false | ||
DIMSE_TLS_3DES=false | ||
DIMSE_TLS_AES=false | ||
DIMSE_TLS_CIPHER="" | ||
DIMSE_TLS13=false | ||
DIMSE_TLS12=false | ||
DIMSE_TLS11=false | ||
DIMSE_TLS1=false | ||
DIMSE_SSL3=false | ||
DIMSE_SSL2HELLO=false | ||
DIMSE_TLS_PROTOCOL="" | ||
DIMSE_TLS_EIA_HTTPS=false | ||
DIMSE_TLS_EIA_LDAPS=false | ||
DIMSE_TLS_NOAUTH=false | ||
DIMSE_KEY_STORE="./config/certs/key.p12" | ||
DIMSE_KEY_STORE_TYPE="PKCS12" | ||
DIMSE_KEY_STORE_PASS="secret" | ||
DIMSE_KEY_PASS="secret" | ||
DIMSE_TRUST_STORE="./config/certs/cacerts.p12" | ||
DIMSE_TRUST_STORE_TYPE="PKCS12" | ||
DIMSE_TRUST_STORE_PASS="secret" | ||
# FHIR | ||
SYCN_TO_FHIR_SERVER=false | ||
FHIRSERVER_BASE_URL="http://localhost:8088/fhir" | ||
``` | ||
|
||
## Deploy Raccoon-DICOM | ||
- Open command prompt and enter Raccoon project directory, then execute following command | ||
``` | ||
node server.js | ||
``` | ||
|
||
## Test Raccoon-DICOM features | ||
### Upload DICOM Instance (STOW-RS) | ||
- The following steps will use the file test/dicomFiles/jpeg2000/example-jpeg-2000.dcm for uploading test | ||
- Use curl for uploading | ||
|
||
```powershell | ||
curl --location --request POST "http://localhost:8081/dicom-web/studies" ^ | ||
--header "Accept: application/dicom+json" ^ | ||
--header "Content-Type: multipart/related; type=\"application/dicom\"" ^ | ||
--form "file=@example-jpeg-2000.dcm; type=application/dicom" | ||
``` | ||
|
||
- If present message following, congrats upload successful!! | ||
```json | ||
{"00081190":{"vr":"UT","Value":["http://localhost:8081/dicom-web/studies/1.3.46.670589.45.1.1.4993912214784.1.5436.1538560373543"]},"00081198":{"vr":"SQ","Value":[]},"00081199":{"vr":"SQ","Value":[{"00081150":{"vr":"UI","Value":["1.2.840.10008.5.1.4.1.1.77.1.6"]},"00081155":{"vr":"UI","Value":["1.3.6.1.4.1.5962.99.1.3002151337.1017604488.1540600476073.6.0"]},"00081190":{"vr":"UT","Value":["http://localhost:8081/dicom-web/studies/1.3.46.670589.45.1.1.4993912214784.1.5436.1538560373543/series/1.3.46.670589.45.1.1.4993912214784.1.5436.1538560606509.3/instances/1.3.6.1.4.1.5962.99.1.3002151337.1017604488.1540600476073.6.0"]}}]}} | ||
``` | ||
|
||
### Get Image info (QIDO-RS) | ||
- Open browser or Postman | ||
- Access http://localhost:8081/dicom-web/studies and get DICOM Json | ||
|
||
|
||
### Retrieve Image (WADO-RS) | ||
- Open browser or Postman | ||
- Access http://localhost:8081/dicom-web/studies/1.3.46.670589.45.1.1.4993912214784.1.5436.1538560373543/series/1.3.46.670589.45.1.1.4993912214784.1.5436.1538560606509.3/instances/1.3.6.1.4.1.5962.99.1.3002151337.1017604488.1540600476073.6.0/frames/1/rendered | ||
- Result: | ||
|
||
data:image/s3,"s3://crabby-images/97122/97122015f1e449afba8c5731e0224e99ee7678de" alt="image" | ||
|
||
- You can also test imagemagick is working normally:Access http://localhost:8081/dicom-web/studies/1.3.46.670589.45.1.1.4993912214784.1.5436.1538560373543/series/1.3.46.670589.45.1.1.4993912214784.1.5436.1538560606509.3/instances/1.3.6.1.4.1.5962.99.1.3002151337.1017604488.1540600476073.6.0/frames/1/rendered?iccprofile=rommrgb | ||
- Check whether the color changes | ||
|
||
data:image/s3,"s3://crabby-images/374bc/374bca13bb5fff00657aa5a98f068041c24354b9" alt="image" |
Oops, something went wrong.