| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293 | 
							- /*=========================================================================
 
-   Library:   CTK
 
-  
 
-   Copyright (c) 2010  Kitware Inc.
 
-   Licensed under the Apache License, Version 2.0 (the "License");
 
-   you may not use this file except in compliance with the License.
 
-   You may obtain a copy of the License at
 
-       http://www.commontk.org/LICENSE
 
-   Unless required by applicable law or agreed to in writing, software
 
-   distributed under the License is distributed on an "AS IS" BASIS,
 
-   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 
-   See the License for the specific language governing permissions and
 
-   limitations under the License.
 
-  
 
- =========================================================================*/
 
- // Qt includes
 
- #include <QSqlQuery>
 
- #include <QSqlRecord>
 
- #include <QVariant>
 
- #include <QDate>
 
- #include <QStringList>
 
- #include <QSet>
 
- #include <QFile>
 
- #include <QDirIterator>
 
- #include <QFileInfo>
 
- #include <QDebug>
 
- // ctkDICOM includes
 
- #include "ctkDICOMQuery.h"
 
- #include "ctkLogger.h"
 
- // DCMTK includes
 
- #ifndef WIN32
 
-   #define HAVE_CONFIG_H 
 
- #endif
 
- #include "dcmtk/dcmnet/dimse.h"
 
- #include "dcmtk/dcmnet/diutil.h"
 
- #include <dcmtk/dcmdata/dcfilefo.h>
 
- #include <dcmtk/dcmdata/dcfilefo.h>
 
- #include <dcmtk/dcmdata/dcdeftag.h>
 
- #include <dcmtk/dcmdata/dcdatset.h>
 
- #include <dcmtk/ofstd/ofcond.h>
 
- #include <dcmtk/ofstd/ofstring.h>
 
- #include <dcmtk/ofstd/ofstd.h>        /* for class OFStandard */
 
- #include <dcmtk/dcmdata/dcddirif.h>   /* for class DicomDirInterface */
 
- #include <dcmtk/dcmnet/scu.h>
 
- static ctkLogger logger ( "org.commontk.dicom.DICOMQuery" );
 
- //------------------------------------------------------------------------------
 
- class ctkDICOMQueryPrivate: public ctkPrivate<ctkDICOMQuery>
 
- {
 
- public:
 
-   ctkDICOMQueryPrivate();
 
-   ~ctkDICOMQueryPrivate();
 
-   QString CallingAETitle;
 
-   QString CalledAETitle;
 
-   QString Host;
 
-   int Port;
 
-   DcmSCU SCU;
 
-   DcmDataset* query;
 
-   QStringList StudyInstanceUIDList;
 
- };
 
- //------------------------------------------------------------------------------
 
- // ctkDICOMQueryPrivate methods
 
- //------------------------------------------------------------------------------
 
- ctkDICOMQueryPrivate::ctkDICOMQueryPrivate()
 
- {
 
-   query = new DcmDataset();
 
- }
 
- //------------------------------------------------------------------------------
 
- ctkDICOMQueryPrivate::~ctkDICOMQueryPrivate()
 
- {
 
-   delete query;
 
- }
 
- //------------------------------------------------------------------------------
 
- // ctkDICOMQuery methods
 
- //------------------------------------------------------------------------------
 
- ctkDICOMQuery::ctkDICOMQuery()
 
- {
 
- }
 
- //------------------------------------------------------------------------------
 
- ctkDICOMQuery::~ctkDICOMQuery()
 
- {
 
- }
 
- void ctkDICOMQuery::addStudyInstanceUID ( QString s )
 
- {
 
-   CTK_D(ctkDICOMQuery);
 
-   d->StudyInstanceUIDList.append ( s );
 
- }
 
- /// Set methods for connectivity
 
- void ctkDICOMQuery::setCallingAETitle ( QString callingAETitle )
 
- {
 
-   CTK_D(ctkDICOMQuery);
 
-   d->CallingAETitle = callingAETitle;
 
- }
 
- const QString& ctkDICOMQuery::callingAETitle() 
 
- {
 
-   CTK_D(ctkDICOMQuery);
 
-   return d->CallingAETitle;
 
- }
 
- void ctkDICOMQuery::setCalledAETitle ( QString calledAETitle )
 
- {
 
-   CTK_D(ctkDICOMQuery);
 
-   d->CalledAETitle = calledAETitle;
 
- }
 
- const QString& ctkDICOMQuery::calledAETitle()
 
- {
 
-   CTK_D(ctkDICOMQuery);
 
-   return d->CalledAETitle;
 
- }
 
- void ctkDICOMQuery::setHost ( QString host )
 
- {
 
-   CTK_D(ctkDICOMQuery);
 
-   d->Host = host;
 
- }
 
- const QString& ctkDICOMQuery::host()
 
- {
 
-   CTK_D(ctkDICOMQuery);
 
-   return d->Host;
 
- }
 
- void ctkDICOMQuery::setPort ( int port ) 
 
- {
 
-   CTK_D(ctkDICOMQuery);
 
-   d->Port = port;
 
- }
 
- int ctkDICOMQuery::port()
 
- {
 
-   CTK_D(ctkDICOMQuery);
 
-   return d->Port;
 
- }
 
- //------------------------------------------------------------------------------
 
- void ctkDICOMQuery::query(QSqlDatabase database )
 
- {
 
-   ctkDICOMIndexerBase::setDatabase ( database );
 
-   CTK_D(ctkDICOMQuery);
 
-   if ( this->database().isOpen() )
 
-     {
 
-     logger.debug ( "DB open in Query" );
 
-     }
 
-   else
 
-     {
 
-     logger.debug ( "DB not open in Query" );
 
-     }
 
-   d->StudyInstanceUIDList.clear();
 
-   d->SCU.setAETitle ( OFString(this->callingAETitle().toStdString().c_str()) );
 
-   d->SCU.setPeerAETitle ( OFString(this->calledAETitle().toStdString().c_str()) );
 
-   d->SCU.setPeerHostName ( OFString(this->host().toStdString().c_str()) );
 
-   d->SCU.setPeerPort ( this->port() );
 
-   logger.error ( "Setting Transfer Syntaxes" );
 
-   OFList<OFString> transferSyntaxes;
 
-   transferSyntaxes.push_back ( UID_LittleEndianExplicitTransferSyntax );
 
-   transferSyntaxes.push_back ( UID_BigEndianExplicitTransferSyntax );
 
-   transferSyntaxes.push_back ( UID_LittleEndianImplicitTransferSyntax );
 
-   d->SCU.addPresentationContext ( UID_FINDStudyRootQueryRetrieveInformationModel, transferSyntaxes );
 
-   // d->SCU.addPresentationContext ( UID_VerificationSOPClass, transferSyntaxes );
 
-   if ( !d->SCU.initNetwork().good() ) 
 
-     {
 
-     std::cerr << "Error initializing the network" << std::endl;
 
-     return;
 
-     }
 
-   logger.debug ( "Negotiating Association" );
 
-   d->SCU.negotiateAssociation();
 
-   // Clear the query
 
-   unsigned long elements = d->query->card();
 
-   // Clean it out
 
-   for ( unsigned long i = 0; i < elements; i++ ) 
 
-     {
 
-     d->query->remove ( 0ul );
 
-     }
 
-   d->query->insertEmptyElement ( DCM_PatientID );
 
-   d->query->insertEmptyElement ( DCM_PatientsName );
 
-   d->query->insertEmptyElement ( DCM_PatientsBirthDate );
 
-   d->query->insertEmptyElement ( DCM_StudyID );
 
-   d->query->insertEmptyElement ( DCM_StudyInstanceUID );
 
-   d->query->insertEmptyElement ( DCM_StudyDescription );
 
-   d->query->insertEmptyElement ( DCM_StudyDate );
 
-   d->query->insertEmptyElement ( DCM_StudyID );
 
-   d->query->insertEmptyElement ( DCM_PatientID );
 
-   d->query->insertEmptyElement ( DCM_PatientsName );
 
-   d->query->insertEmptyElement ( DCM_SeriesNumber );
 
-   d->query->insertEmptyElement ( DCM_SeriesDescription );
 
-   d->query->insertEmptyElement ( DCM_StudyInstanceUID );
 
-   d->query->insertEmptyElement ( DCM_SeriesInstanceUID );
 
-   d->query->insertEmptyElement ( DCM_StudyTime );
 
-   d->query->insertEmptyElement ( DCM_SeriesDate );
 
-   d->query->insertEmptyElement ( DCM_SeriesTime );
 
-   d->query->insertEmptyElement ( DCM_Modality );
 
-   d->query->insertEmptyElement ( DCM_ModalitiesInStudy );
 
-   d->query->insertEmptyElement ( DCM_AccessionNumber );
 
-   d->query->insertEmptyElement ( DCM_NumberOfSeriesRelatedInstances ); // Number of images in the series
 
-   d->query->insertEmptyElement ( DCM_NumberOfStudyRelatedInstances ); // Number of images in the series
 
-   d->query->insertEmptyElement ( DCM_NumberOfStudyRelatedSeries ); // Number of images in the series
 
-   d->query->putAndInsertString ( DCM_QueryRetrieveLevel, "STUDY" );
 
-   FINDResponses *responses = new FINDResponses();
 
-   Uint16 presentationContex = 0;
 
-   presentationContex = d->SCU.findPresentationContextID ( UID_FINDStudyRootQueryRetrieveInformationModel, UID_LittleEndianExplicitTransferSyntax );
 
-   if ( presentationContex == 0 )
 
-     {
 
-   presentationContex = d->SCU.findPresentationContextID ( UID_FINDStudyRootQueryRetrieveInformationModel, UID_BigEndianExplicitTransferSyntax );
 
-     }
 
-   if ( presentationContex == 0 )
 
-     {
 
-     presentationContex = d->SCU.findPresentationContextID ( UID_FINDStudyRootQueryRetrieveInformationModel, UID_LittleEndianImplicitTransferSyntax );
 
-     }
 
-   if ( presentationContex == 0 )
 
-     {
 
-     logger.error ( "Failed to find acceptable presentation context" );
 
-     }
 
-   else
 
-     {
 
-     logger.info ( "Found useful presentation context" );
 
-     }
 
-   OFCondition status = d->SCU.sendFINDRequest ( presentationContex, d->query, responses );
 
-   if ( status.good() )
 
-     {
 
-     logger.debug ( "Find succeded" );
 
-     }
 
-   else
 
-     {
 
-     logger.error ( "Find failed" );
 
-     }
 
-   for ( OFListIterator(FINDResponse*) it = responses->begin(); it != responses->end(); it++ )
 
-     {
 
-     DcmDataset *dataset = (*it)->m_dataset;
 
-     if ( dataset != NULL )
 
-       {
 
-       this->insert ( dataset );
 
-       OFString StudyInstanceUID;
 
-       dataset->findAndGetOFString ( DCM_StudyInstanceUID, StudyInstanceUID );
 
-       this->addStudyInstanceUID ( QString ( StudyInstanceUID.c_str() ) );
 
-       }
 
-     }
 
-   delete responses;
 
-   // Now search each Study
 
-   d->query->putAndInsertString ( DCM_QueryRetrieveLevel, "SERIES" );
 
-   foreach ( QString StudyInstanceUID, d->StudyInstanceUIDList )
 
-     {
 
-     logger.debug ( "Starting Series C-FIND for Series: " + StudyInstanceUID );
 
-     d->query->putAndInsertString ( DCM_StudyInstanceUID, StudyInstanceUID.toStdString().c_str() );
 
-     responses = new FINDResponses();
 
-     status = d->SCU.sendFINDRequest ( 0, d->query, responses );
 
-     if ( status.good() )
 
-       {
 
-       logger.debug ( "Find succeded for Series: " + StudyInstanceUID );
 
-       for ( OFListIterator(FINDResponse*) it = responses->begin(); it != responses->end(); it++ )
 
-         {
 
-         DcmDataset *dataset = (*it)->m_dataset;
 
-         if ( dataset != NULL )
 
-           {
 
-           this->insert ( dataset );
 
-           }
 
-         }
 
-       }
 
-     else
 
-       {
 
-       logger.error ( "Find failed for Series: " + StudyInstanceUID );
 
-       }
 
-     delete responses;
 
-     }
 
-   d->SCU.closeAssociation ( DUL_PEERREQUESTEDRELEASE );
 
- }
 
 
  |