| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235 | 
							- /*=============================================================================
 
-   Library: XNAT/Core
 
-   Copyright (c) University College London,
 
-     Centre for Medical Image Computing
 
-   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.apache.org/licenses/LICENSE-2.0
 
-   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.
 
- =============================================================================*/
 
- #include "ctkXnatExperiment.h"
 
- #include "ctkXnatSession.h"
 
- #include "ctkXnatObjectPrivate.h"
 
- #include "ctkXnatSubject.h"
 
- #include "ctkXnatScan.h"
 
- #include "ctkXnatReconstruction.h"
 
- #include "ctkXnatAssessor.h"
 
- #include "ctkXnatScanFolder.h"
 
- #include "ctkXnatReconstructionFolder.h"
 
- #include "ctkXnatAssessorFolder.h"
 
- #include "ctkXnatDefaultSchemaTypes.h"
 
- #include <QDebug>
 
- const QString ctkXnatExperiment::DATE_OF_ACQUISITION = "date";
 
- const QString ctkXnatExperiment::TIME_OF_ACQUISITION = "time";
 
- const QString ctkXnatExperiment::SCANNER_TYPE = "scanner";
 
- const QString ctkXnatExperiment::IMAGE_MODALITY = "modality";
 
- //----------------------------------------------------------------------------
 
- class ctkXnatExperimentPrivate : public ctkXnatObjectPrivate
 
- {
 
- public:
 
-   ctkXnatExperimentPrivate()
 
-   : ctkXnatObjectPrivate()
 
-   {
 
-   }
 
-   void reset()
 
-   {
 
- //    uri.clear();
 
-   }
 
- //  QString uri;
 
- };
 
- //----------------------------------------------------------------------------
 
- ctkXnatExperiment::ctkXnatExperiment(ctkXnatObject* parent, const QString& schemaType)
 
- : ctkXnatObject(*new ctkXnatExperimentPrivate(), parent, schemaType)
 
- {
 
- }
 
- //----------------------------------------------------------------------------
 
- ctkXnatExperiment::~ctkXnatExperiment()
 
- {
 
- }
 
- //----------------------------------------------------------------------------
 
- QString ctkXnatExperiment::resourceUri() const
 
- {
 
-   if (this->id().isEmpty())
 
-   {
 
-     return QString("%1/experiments/%2").arg(parent()->resourceUri(), this->label());
 
-   }
 
-   return QString("%1/experiments/%2").arg(parent()->resourceUri(), this->id());
 
- }
 
- //----------------------------------------------------------------------------
 
- QString ctkXnatExperiment::name() const
 
- {
 
-   return this->label();
 
- }
 
- //----------------------------------------------------------------------------
 
- void ctkXnatExperiment::setName(const QString &name)
 
- {
 
-   this->setLabel(name);
 
- }
 
- //----------------------------------------------------------------------------
 
- QString ctkXnatExperiment::label() const
 
- {
 
-   return this->property(LABEL);
 
- }
 
- //----------------------------------------------------------------------------
 
- void ctkXnatExperiment::setLabel(const QString &label)
 
- {
 
-   this->setProperty(LABEL, label);
 
- }
 
- //----------------------------------------------------------------------------
 
- QString ctkXnatExperiment::dateOfAcquisition() const
 
- {
 
-   return this->property(DATE_OF_ACQUISITION);
 
- }
 
- //----------------------------------------------------------------------------
 
- void ctkXnatExperiment::setDateOfAcquisition(const QString &dateOfAcquisition)
 
- {
 
-   this->setProperty(DATE_OF_ACQUISITION, dateOfAcquisition);
 
- }
 
- //----------------------------------------------------------------------------
 
- QString ctkXnatExperiment::timeOfAcquisition() const
 
- {
 
-   return this->property(TIME_OF_ACQUISITION);
 
- }
 
- //----------------------------------------------------------------------------
 
- void ctkXnatExperiment::setTimeOfAcquisition(const QString &timeOfAcquisition)
 
- {
 
-   this->setProperty(TIME_OF_ACQUISITION, timeOfAcquisition);
 
- }
 
- //----------------------------------------------------------------------------
 
- QString ctkXnatExperiment::scannerType() const
 
- {
 
-   return this->property(SCANNER_TYPE);
 
- }
 
- //----------------------------------------------------------------------------
 
- void ctkXnatExperiment::setScannerType(const QString &scannerType)
 
- {
 
-   this->setProperty(SCANNER_TYPE, scannerType);
 
- }
 
- //----------------------------------------------------------------------------
 
- QString ctkXnatExperiment::imageModality() const
 
- {
 
-   return this->property(IMAGE_MODALITY);
 
- }
 
- //----------------------------------------------------------------------------
 
- void ctkXnatExperiment::setImageModality(const QString &imageModality)
 
- {
 
-   this->setProperty(IMAGE_MODALITY, imageModality);
 
- }
 
- //----------------------------------------------------------------------------
 
- void ctkXnatExperiment::reset()
 
- {
 
-   ctkXnatObject::reset();
 
- }
 
- //----------------------------------------------------------------------------
 
- void ctkXnatExperiment::fetchImpl()
 
- {
 
-   QString scansUri = this->resourceUri() + "/scans";
 
-   ctkXnatSession* const session = this->session();
 
-   QUuid scansQueryId = session->httpGet(scansUri);
 
-   QList<ctkXnatObject*> scans;
 
-   
 
-   try
 
-   {
 
-     scans = session->httpResults(scansQueryId,
 
- 				 ctkXnatDefaultSchemaTypes::XSI_SCAN);
 
-   }
 
-   catch (const ctkException& e)
 
-   {
 
-     qWarning() << QString(e.what());
 
-   }
 
-   if (!scans.isEmpty())
 
-   {
 
-     ctkXnatScanFolder* scanFolder = new ctkXnatScanFolder();
 
-     this->add(scanFolder);
 
-   }
 
-   QString reconstructionsUri = this->resourceUri() + "/reconstructions";
 
-   QUuid reconstructionsQueryId = session->httpGet(reconstructionsUri);
 
-   QList<ctkXnatObject*> reconstructions;
 
-   try
 
-   {
 
-     reconstructions = session->httpResults(reconstructionsQueryId,
 
- 					   ctkXnatDefaultSchemaTypes::XSI_RECONSTRUCTION);
 
-   }
 
-   catch (const ctkException& e)
 
-   {
 
-     qWarning() << QString(e.what());
 
-   }
 
-   
 
-   if (!reconstructions.isEmpty())
 
-   {
 
-     ctkXnatReconstructionFolder* reconstructionFolder = new ctkXnatReconstructionFolder();
 
-     this->add(reconstructionFolder);
 
-   }
 
-   QString assessorsUri = this->resourceUri() + "/assessors";
 
-   QUuid assessorsQueryId = session->httpGet(assessorsUri);
 
-   
 
-   QList<ctkXnatObject*> assessors;
 
-   
 
-   try
 
-   {
 
-     assessors = session->httpResults(assessorsQueryId,
 
- 				     ctkXnatDefaultSchemaTypes::XSI_ASSESSOR);
 
-   }
 
-   catch (const ctkException& e)
 
-   {
 
-     qWarning() << QString(e.what());
 
-   }
 
-   if (!assessors.isEmpty())
 
-   {
 
-     ctkXnatAssessorFolder* assessorFolder = new ctkXnatAssessorFolder(this);
 
-     this->add(assessorFolder);
 
-   }
 
-   this->fetchResources();
 
- }
 
- //----------------------------------------------------------------------------
 
- void ctkXnatExperiment::downloadImpl(const QString& filename)
 
- {
 
-   Q_UNUSED(filename);
 
-   qDebug() << "ctkXnatExperiment::downloadImpl(const QString& filename) not yet implemented or not available by REST API";
 
- }
 
 
  |