ctkXnatConnection.cpp 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732
  1. /*=============================================================================
  2. Plugin: org.commontk.xnat
  3. Copyright (c) University College London,
  4. Centre for Medical Image Computing
  5. Licensed under the Apache License, Version 2.0 (the "License");
  6. you may not use this file except in compliance with the License.
  7. You may obtain a copy of the License at
  8. http://www.apache.org/licenses/LICENSE-2.0
  9. Unless required by applicable law or agreed to in writing, software
  10. distributed under the License is distributed on an "AS IS" BASIS,
  11. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. See the License for the specific language governing permissions and
  13. limitations under the License.
  14. =============================================================================*/
  15. #include "ctkXnatConnection.h"
  16. #include "ctkXnatException.h"
  17. #include "ctkXnatExperiment.h"
  18. #include "ctkXnatObject.h"
  19. #include "ctkXnatObjectPrivate.h"
  20. #include "ctkXnatProject.h"
  21. #include "ctkXnatReconstruction.h"
  22. #include "ctkXnatReconstructionFolder.h"
  23. #include "ctkXnatReconstructionResource.h"
  24. #include "ctkXnatReconstructionResourceFile.h"
  25. #include "ctkXnatScan.h"
  26. #include "ctkXnatScanFolder.h"
  27. #include "ctkXnatScanResource.h"
  28. #include "ctkXnatScanResourceFile.h"
  29. #include "ctkXnatServer.h"
  30. #include "ctkXnatSubject.h"
  31. #include <QScopedPointer>
  32. #include <QStringBuilder>
  33. #include <qXnatAPI.h>
  34. #include <qRestResult.h>
  35. class ctkXnatConnectionPrivate
  36. {
  37. public:
  38. QString profileName;
  39. QString url;
  40. QString userName;
  41. QString password;
  42. qXnatAPI* xnat;
  43. qXnatAPI::RawHeaders rawHeaders;
  44. QSharedPointer<ctkXnatServer> server;
  45. };
  46. // ctkXnatConnection class
  47. ctkXnatConnection::ctkXnatConnection()
  48. : d_ptr(new ctkXnatConnectionPrivate())
  49. {
  50. Q_D(ctkXnatConnection);
  51. d->xnat = new qXnatAPI();
  52. // TODO This is a workaround for connecting to sites with self-signed
  53. // certificate. Should be replaced with something more clever.
  54. d->xnat->setSuppressSslErrors(true);
  55. d->rawHeaders["User-Agent"] = "Qt";
  56. d->xnat->setDefaultRawHeaders(d->rawHeaders);
  57. d->server = ctkXnatServer::Create(this);
  58. createConnections();
  59. }
  60. ctkXnatConnection::~ctkXnatConnection()
  61. {
  62. Q_D(ctkXnatConnection);
  63. delete d->xnat;
  64. }
  65. void ctkXnatConnection::createConnections()
  66. {
  67. // Q_D(ctkXnatConnection);
  68. // connect(d->xnat, SIGNAL(resultReceived(QUuid,QList<QVariantMap>)),
  69. // this, SLOT(processResult(QUuid,QList<QVariantMap>)));
  70. // connect(d->xnat, SIGNAL(progress(QUuid,double)),
  71. // this, SLOT(progress(QUuid,double)));
  72. }
  73. void ctkXnatConnection::progress(QUuid queryId, double progress)
  74. {
  75. // qDebug() << "ctkXnatConnection::progress(QUuid queryId, double progress)";
  76. // qDebug() << "query id:" << queryId;
  77. // qDebug() << "progress:" << (progress * 100.0) << "%";
  78. }
  79. QString ctkXnatConnection::profileName() const
  80. {
  81. Q_D(const ctkXnatConnection);
  82. return d->profileName;
  83. }
  84. void ctkXnatConnection::setProfileName(const QString& profileName)
  85. {
  86. Q_D(ctkXnatConnection);
  87. d->profileName = profileName;
  88. d->server->setProperty("name", profileName);
  89. }
  90. QString ctkXnatConnection::url() const
  91. {
  92. Q_D(const ctkXnatConnection);
  93. return d->url;
  94. }
  95. void ctkXnatConnection::setUrl(const QString& url)
  96. {
  97. Q_D(ctkXnatConnection);
  98. d->url = url;
  99. d->xnat->setServerUrl(d->url);
  100. d->server->setProperty("ID", url);
  101. }
  102. QString ctkXnatConnection::userName() const
  103. {
  104. Q_D(const ctkXnatConnection);
  105. return d->userName;
  106. }
  107. void ctkXnatConnection::setUserName(const QString& userName)
  108. {
  109. Q_D(ctkXnatConnection);
  110. d->userName = userName;
  111. d->rawHeaders["Authorization"] = "Basic " +
  112. QByteArray(QString("%1:%2").arg(d->userName).arg(d->password).toAscii()).toBase64();
  113. d->xnat->setDefaultRawHeaders(d->rawHeaders);
  114. }
  115. QString ctkXnatConnection::password() const
  116. {
  117. Q_D(const ctkXnatConnection);
  118. return d->password;
  119. }
  120. void ctkXnatConnection::setPassword(const QString& password)
  121. {
  122. Q_D(ctkXnatConnection);
  123. d->password = password;
  124. d->rawHeaders["Authorization"] = "Basic " +
  125. QByteArray(QString("%1:%2").arg(d->userName).arg(d->password).toAscii()).toBase64();
  126. d->xnat->setDefaultRawHeaders(d->rawHeaders);
  127. }
  128. ctkXnatServer::Pointer ctkXnatConnection::server() const
  129. {
  130. Q_D(const ctkXnatConnection);
  131. return d->server;
  132. }
  133. void ctkXnatConnection::fetch(const ctkXnatServer::Pointer& server)
  134. {
  135. Q_D(ctkXnatConnection);
  136. QString projectsUri("/data/archive/projects");
  137. QUuid queryId = d->xnat->get(projectsUri);
  138. qRestResult* restResult = d->xnat->takeResult(queryId);
  139. QList<ctkXnatProject*> projects = restResult->results<ctkXnatProject>();
  140. foreach (ctkXnatProject* project, projects)
  141. {
  142. project->setUri(projectsUri + "/" + project->id());
  143. ctkXnatObject::Pointer ptr(project);
  144. ptr->d_func()->selfPtr = ptr;
  145. server->addChild(ptr);
  146. }
  147. delete restResult;
  148. }
  149. void ctkXnatConnection::fetch(const ctkXnatProject::Pointer& project)
  150. {
  151. Q_D(ctkXnatConnection);
  152. QString subjectsUri = project->uri() + "/subjects";
  153. QUuid queryId = d->xnat->get(subjectsUri);
  154. qRestResult* restResult = d->xnat->takeResult(queryId);
  155. QList<ctkXnatSubject*> subjects = restResult->results<ctkXnatSubject>();
  156. foreach (ctkXnatSubject* subject, subjects)
  157. {
  158. QString label = subject->property("label");
  159. if (label.size())
  160. {
  161. subject->setProperty("ID", label);
  162. }
  163. subject->setUri(subjectsUri + "/" + subject->id());
  164. ctkXnatObject::Pointer ptr(subject);
  165. ptr->d_func()->selfPtr = ptr;
  166. project->addChild(ptr);
  167. }
  168. delete restResult;
  169. }
  170. void ctkXnatConnection::fetch(const QSharedPointer<ctkXnatSubject>& subject)
  171. {
  172. Q_D(ctkXnatConnection);
  173. QString experimentsUri = subject->uri() + "/experiments";
  174. QUuid queryId = d->xnat->get(experimentsUri);
  175. qRestResult* restResult = d->xnat->takeResult(queryId);
  176. QList<ctkXnatExperiment*> experiments = restResult->results<ctkXnatExperiment>();
  177. foreach (ctkXnatExperiment* experiment, experiments)
  178. {
  179. QString label = experiment->property ("label");
  180. if (label.size())
  181. {
  182. experiment->setProperty ("ID", label);
  183. }
  184. experiment->setUri(experimentsUri + "/" + experiment->id());
  185. ctkXnatObject::Pointer ptr(experiment);
  186. ptr->d_func()->selfPtr = ptr;
  187. subject->addChild(ptr);
  188. }
  189. delete restResult;
  190. }
  191. void ctkXnatConnection::fetch(const QSharedPointer<ctkXnatExperiment>& experiment)
  192. {
  193. Q_D(ctkXnatConnection);
  194. QString scansUri = experiment->uri() + "/scans";
  195. QUuid scansQueryId = d->xnat->get(scansUri);
  196. qRestResult* restResult = d->xnat->takeResult(scansQueryId);
  197. QList<ctkXnatScan*> scans = restResult->results<ctkXnatScan>();
  198. if (scans.size() > 0)
  199. {
  200. ctkXnatObject::Pointer ptr = ctkXnatScanFolder::Create();
  201. ptr->setUri(scansUri);
  202. ptr->d_func()->selfPtr = ptr;
  203. experiment->addChild(ptr);
  204. }
  205. delete restResult;
  206. QString reconstructionsUri = experiment->uri() + "/reconstructions";
  207. QUuid reconstructionsQueryId = d->xnat->get(reconstructionsUri);
  208. restResult = d->xnat->takeResult(reconstructionsQueryId);
  209. QList<ctkXnatReconstruction*> reconstructions = restResult->results<ctkXnatReconstruction>();
  210. if (reconstructions.size() > 0)
  211. {
  212. ctkXnatObject::Pointer ptr = ctkXnatReconstructionFolder::Create();
  213. ptr->setUri(reconstructionsUri);
  214. ptr->d_func()->selfPtr = ptr;
  215. experiment->addChild(ptr);
  216. }
  217. delete restResult;
  218. }
  219. void ctkXnatConnection::fetch(const QSharedPointer<ctkXnatScanFolder>& scanFolder)
  220. {
  221. Q_D(ctkXnatConnection);
  222. QString scansUri = scanFolder->uri();
  223. QUuid queryId = d->xnat->get(scansUri);
  224. qRestResult* restResult = d->xnat->takeResult(queryId);
  225. QList<ctkXnatScan*> scans = restResult->results<ctkXnatScan>();
  226. foreach (ctkXnatScan* scan, scans)
  227. {
  228. scan->setUri(scansUri + "/" + scan->id());
  229. ctkXnatObject::Pointer ptr(scan);
  230. ptr->d_func()->selfPtr = ptr;
  231. scanFolder->addChild(ptr);
  232. }
  233. delete restResult;
  234. }
  235. void ctkXnatConnection::fetch(const QSharedPointer<ctkXnatScan>& scan)
  236. {
  237. Q_D(ctkXnatConnection);
  238. QString scanResourcesUri = scan->uri() + "/resources";
  239. QUuid queryId = d->xnat->get(scanResourcesUri);
  240. qRestResult* restResult = d->xnat->takeResult(queryId);
  241. QList<ctkXnatScanResource*> scanResources = restResult->results<ctkXnatScanResource>();
  242. foreach (ctkXnatScanResource* scanResource, scanResources)
  243. {
  244. QString label = scanResource->property("label");
  245. if (label.size())
  246. {
  247. scanResource->setProperty("ID", label);
  248. }
  249. scanResource->setUri(scanResourcesUri + "/" + label);
  250. ctkXnatObject::Pointer ptr(scanResource);
  251. ptr->d_func()->selfPtr = ptr;
  252. scan->addChild(ptr);
  253. }
  254. }
  255. void ctkXnatConnection::fetch(const QSharedPointer<ctkXnatScanResource>& scanResource)
  256. {
  257. Q_D(ctkXnatConnection);
  258. QString scanResourceFilesUri = scanResource->uri() + "/files";
  259. QUuid queryId = d->xnat->get(scanResourceFilesUri);
  260. qRestResult* restResult = d->xnat->takeResult(queryId);
  261. QList<ctkXnatScanResourceFile*> scanResourceFiles = restResult->results<ctkXnatScanResourceFile>();
  262. foreach (ctkXnatScanResourceFile* scanResourceFile, scanResourceFiles)
  263. {
  264. QString uri = scanResourceFile->property("URI");
  265. if (uri.size())
  266. {
  267. scanResourceFile->setUri(uri);
  268. }
  269. QString label = scanResourceFile->property("Name");
  270. if (label.size())
  271. {
  272. scanResourceFile->setProperty("ID", label);
  273. }
  274. scanResourceFile->setUri(scanResourceFilesUri + "/" + label);
  275. ctkXnatObject::Pointer ptr(scanResourceFile);
  276. ptr->d_func()->selfPtr = ptr;
  277. scanResource->addChild(ptr);
  278. }
  279. }
  280. void ctkXnatConnection::fetch(const QSharedPointer<ctkXnatReconstructionFolder>& reconstructionFolder)
  281. {
  282. Q_D(ctkXnatConnection);
  283. QString reconstructionsUri = reconstructionFolder->uri();
  284. QUuid queryId = d->xnat->get(reconstructionsUri);
  285. qRestResult* restResult = d->xnat->takeResult(queryId);
  286. QList<ctkXnatReconstruction*> reconstructions = restResult->results<ctkXnatReconstruction>();
  287. foreach (ctkXnatReconstruction* reconstruction, reconstructions)
  288. {
  289. reconstruction->setUri(reconstructionsUri + "/" + reconstruction->id());
  290. ctkXnatObject::Pointer ptr(reconstruction);
  291. ptr->d_func()->selfPtr = ptr;
  292. reconstructionFolder->addChild(ptr);
  293. }
  294. delete restResult;
  295. }
  296. void ctkXnatConnection::fetch(const QSharedPointer<ctkXnatReconstruction>& reconstruction)
  297. {
  298. Q_D(ctkXnatConnection);
  299. QString reconstructionResourcesUri = reconstruction->uri() + "/resources";
  300. QUuid queryId = d->xnat->get(reconstructionResourcesUri);
  301. qRestResult* restResult = d->xnat->takeResult(queryId);
  302. QList<ctkXnatReconstructionResource*> reconstructionResources = restResult->results<ctkXnatReconstructionResource>();
  303. foreach (ctkXnatReconstructionResource* reconstructionResource, reconstructionResources)
  304. {
  305. QString label = reconstructionResource->property("label");
  306. if (label.size())
  307. {
  308. reconstructionResource->setProperty("ID", label);
  309. }
  310. reconstructionResource->setUri(reconstructionResourcesUri + "/" + label);
  311. ctkXnatObject::Pointer ptr(reconstructionResource);
  312. ptr->d_func()->selfPtr = ptr;
  313. reconstruction->addChild(ptr);
  314. }
  315. }
  316. void ctkXnatConnection::fetch(const QSharedPointer<ctkXnatReconstructionResource>& reconstructionResource)
  317. {
  318. Q_D(ctkXnatConnection);
  319. QString reconstructionResourceFilesUri = reconstructionResource->uri() + "/files";
  320. QUuid queryId = d->xnat->get(reconstructionResourceFilesUri);
  321. qRestResult* restResult = d->xnat->takeResult(queryId);
  322. QList<ctkXnatReconstructionResourceFile*> reconstructionResourceFiles = restResult->results<ctkXnatReconstructionResourceFile>();
  323. foreach (ctkXnatReconstructionResourceFile* reconstructionResourceFile, reconstructionResourceFiles)
  324. {
  325. QString uri = reconstructionResourceFile->property("URI");
  326. if (uri.size())
  327. {
  328. reconstructionResourceFile->setUri(uri);
  329. }
  330. QString label = reconstructionResourceFile->property("Name");
  331. if (label.size())
  332. {
  333. reconstructionResourceFile->setProperty("ID", label);
  334. }
  335. reconstructionResourceFile->setUri(reconstructionResourceFilesUri + "/" + label);
  336. ctkXnatObject::Pointer ptr(reconstructionResourceFile);
  337. ptr->d_func()->selfPtr = ptr;
  338. reconstructionResource->addChild(ptr);
  339. }
  340. }
  341. //void ctkXnatConnection::create(ctkXnatProject* project)
  342. //{
  343. // const QString& projectName = project->name();
  344. // Q_D(ctkXnatConnection);
  345. // QString query = QString("/REST/projects/%1").arg(projectName);
  346. // bool success = d->xnat->sync(d->xnat->put(query));
  347. // if (!success)
  348. // {
  349. // throw ctkXnatException("Error occurred while creating the project.");
  350. // }
  351. //}
  352. //void ctkXnatConnection::remove(ctkXnatProject* project)
  353. //{
  354. // const QString& projectName = project->name();
  355. // Q_D(ctkXnatConnection);
  356. // QString query = QString("/REST/projects/%1").arg(projectName);
  357. // bool success = d->xnat->sync(d->xnat->del(query));
  358. // if (!success)
  359. // {
  360. // throw ctkXnatException("Error occurred while removing the project.");
  361. // }
  362. //}
  363. //void ctkXnatConnection::create(ctkXnatSubject* subject)
  364. //{
  365. // const QString& subjectName = subject->getName();
  366. // ctkXnatObject* project = subject->getParent();
  367. // const QString& projectName = project->getName();
  368. // Q_D(ctkXnatConnection);
  369. // QString query = QString("/REST/projects/%1/subjects/%2").arg(projectName, subjectName);
  370. // bool success = d->xnat->sync(d->xnat->put(query));
  371. // if (!success)
  372. // {
  373. // throw ctkXnatException("Error occurred while creating the subject.");
  374. // }
  375. //}
  376. //void ctkXnatConnection::downloadScanFiles(ctkXnatExperiment* experiment, const QString& fileName)
  377. //{
  378. // const QString& experimentName = experiment->getName();
  379. // ctkXnatObject* subject = experiment->getParent();
  380. // const QString& subjectName = subject->getName();
  381. // ctkXnatObject* project = subject->getParent();
  382. // const QString& projectName = project->getName();
  383. // Q_D(ctkXnatConnection);
  384. // QString query = QString("/REST/projects/%1/subjects/%2/experiments/%3/scans/ALL/files").arg(projectName, subjectName, experimentName);
  385. // qRestAPI::Parameters parameters;
  386. // parameters["format"] = "zip";
  387. // QUuid queryId = d->xnat->download(fileName, query, parameters);
  388. // d->xnat->sync(queryId);
  389. //}
  390. //void ctkXnatConnection::downloadReconstructionFiles(ctkXnatExperiment* experiment, const QString& fileName)
  391. //{
  392. // const QString& experimentName = experiment->getName();
  393. // ctkXnatObject* subject = experiment->getParent();
  394. // const QString& subjectName = subject->getName();
  395. // ctkXnatObject* project = subject->getParent();
  396. // const QString& projectName = project->getName();
  397. // Q_D(ctkXnatConnection);
  398. // QString query = QString("/REST/projects/%1/subjects/%2/experiments/%3/reconstructions/ALL/files").arg(projectName, subjectName, experimentName);
  399. // qRestAPI::Parameters parameters;
  400. // parameters["format"] = "zip";
  401. // QUuid queryId = d->xnat->download(fileName, query, parameters);
  402. // d->xnat->sync(queryId);
  403. //}
  404. //void ctkXnatConnection::addReconstruction(ctkXnatExperiment* /*experiment*/, const QString& /*reconstruction*/)
  405. //{
  406. //// const QString& experimentName = experiment->getName();
  407. //// ctkXnatObject* subject = experiment->getParent();
  408. //// const QString& subjectName = subject->getName();
  409. //// ctkXnatObject* project = subject->getParent();
  410. //// const QString& projectName = project->getName();
  411. // // TODO
  412. //}
  413. //void ctkXnatConnection::downloadReconstruction(ctkXnatReconstruction* reconstruction, const QString& fileName)
  414. //{
  415. // const QString& reconstructionName = reconstruction->getName();
  416. // ctkXnatObject* experiment = reconstruction->getParent();
  417. // const QString& experimentName = experiment->getName();
  418. // ctkXnatObject* subject = experiment->getParent();
  419. // const QString& subjectName = subject->getName();
  420. // ctkXnatObject* project = subject->getParent();
  421. // const QString& projectName = project->getName();
  422. // Q_D(ctkXnatConnection);
  423. // QString query = QString("/REST/projects/%1/subjects/%2/experiments/%3/reconstructions/%4/ALL/files").arg(projectName, subjectName, experimentName, reconstructionName);
  424. // qRestAPI::Parameters parameters;
  425. // parameters["format"] = "zip";
  426. // QUuid queryId = d->xnat->download(fileName, query, parameters);
  427. // d->xnat->sync(queryId);
  428. //}
  429. //void ctkXnatConnection::addReconstructionResource(ctkXnatReconstruction* /*reconstruction*/, const QString& /*resourceName*/)
  430. //{
  431. //// const QString& reconstructionName = reconstruction->getName();
  432. //// ctkXnatObject* experiment = reconstruction->getParent()->getParent();
  433. //// const QString& experimentName = experiment->getName();
  434. //// ctkXnatObject* subject = experiment->getParent();
  435. //// const QString& subjectName = subject->getName();
  436. //// ctkXnatObject* project = subject->getParent();
  437. //// const QString& projectName = project->getName();
  438. // // TODO
  439. //}
  440. //void ctkXnatConnection::removeReconstruction(ctkXnatReconstruction* /*reconstruction*/)
  441. //{
  442. //// const QString& reconstructionName = reconstruction->getName();
  443. //// ctkXnatObject* experiment = reconstruction->getParent()->getParent();
  444. //// const QString& experimentName = experiment->getName();
  445. //// ctkXnatObject* subject = experiment->getParent();
  446. //// const QString& subjectName = subject->getName();
  447. //// ctkXnatObject* project = subject->getParent();
  448. //// const QString& projectName = project->getName();
  449. // // TODO
  450. //}
  451. //void ctkXnatConnection::downloadReconstructionResourceFiles(ctkXnatReconstructionResource* reconstructionResource, const QString& fileName)
  452. //{
  453. // const QString& reconstructionResourceName = reconstructionResource->getName();
  454. // ctkXnatObject* reconstruction = reconstructionResource->getParent();
  455. // const QString& reconstructionName = reconstruction->getName();
  456. // ctkXnatObject* experiment = reconstruction->getParent()->getParent();
  457. // const QString& experimentName = experiment->getName();
  458. // ctkXnatObject* subject = experiment->getParent();
  459. // const QString& subjectName = subject->getName();
  460. // ctkXnatObject* project = subject->getParent();
  461. // const QString& projectName = project->getName();
  462. // Q_D(ctkXnatConnection);
  463. // QString query = QString("/REST/projects/%1/subjects/%2/experiments/%3/reconstructions/%4/ALL/resources/%5/files").arg(projectName, subjectName, experimentName, reconstructionName, reconstructionResourceName);
  464. // qRestAPI::Parameters parameters;
  465. // parameters["format"] = "zip";
  466. // QUuid queryId = d->xnat->download(fileName, query, parameters);
  467. // d->xnat->sync(queryId);
  468. //}
  469. //void ctkXnatConnection::uploadReconstructionResourceFiles(ctkXnatReconstructionResource* /*reconstructionResource*/, const QString& /*zipFilename*/)
  470. //{
  471. //// const QString& resourceName = reconstructionResource->getName();
  472. //// ctkXnatObject* reconstruction = reconstructionResource->getParent();
  473. //// const QString& reconstructionName = reconstruction->getName();
  474. //// ctkXnatObject* experiment = reconstruction->getParent()->getParent();
  475. //// const QString& experimentName = experiment->getName();
  476. //// ctkXnatObject* subject = experiment->getParent();
  477. //// const QString& subjectName = subject->getName();
  478. //// ctkXnatObject* project = subject->getParent();
  479. //// const QString& projectName = project->getName();
  480. // // TODO
  481. //}
  482. //void ctkXnatConnection::removeReconstructionResource(ctkXnatReconstructionResource* /*reconstructionResource*/)
  483. //{
  484. //// const QString& resourceName = reconstructionResource->getName();
  485. //// ctkXnatObject* reconstruction = reconstructionResource->getParent();
  486. //// const QString& reconstructionName = reconstruction->getName();
  487. //// ctkXnatObject* experiment = reconstruction->getParent()->getParent();
  488. //// const QString& experimentName = experiment->getName();
  489. //// ctkXnatObject* subject = experiment->getParent();
  490. //// const QString& subjectName = subject->getName();
  491. //// ctkXnatObject* project = subject->getParent();
  492. //// const QString& projectName = project->getName();
  493. // // TODO
  494. //}
  495. //void ctkXnatConnection::download(ctkXnatReconstructionResourceFile* reconstructionResourceFile, const QString& fileName)
  496. //{
  497. // const QString& reconstructionResourceFileName = reconstructionResourceFile->getName();
  498. // ctkXnatObject* reconstructionResource = reconstructionResourceFile->getParent();
  499. // const QString& reconstructionResourceName = reconstructionResource->getName();
  500. // ctkXnatObject* reconstruction = reconstructionResource->getParent();
  501. // const QString& reconstructionName = reconstruction->getName();
  502. // ctkXnatObject* experiment = reconstruction->getParent()->getParent();
  503. // const QString& experimentName = experiment->getName();
  504. // ctkXnatObject* subject = experiment->getParent();
  505. // const QString& subjectName = subject->getName();
  506. // ctkXnatObject* project = subject->getParent();
  507. // const QString& projectName = project->getName();
  508. // Q_D(ctkXnatConnection);
  509. // QString query = QString("/REST/projects/%1/subjects/%2/experiments/%3/reconstructions/%4/resources/%5/files/%6").arg(projectName, subjectName, experimentName, reconstructionName, reconstructionResourceName, reconstructionResourceFileName);
  510. // qRestAPI::Parameters parameters;
  511. // parameters["format"] = "zip";
  512. // QUuid queryId = d->xnat->download(fileName, query, parameters);
  513. // d->xnat->sync(queryId);
  514. //}
  515. //void ctkXnatConnection::remove(ctkXnatReconstructionResourceFile* /*reconstructionResourceFile*/)
  516. //{
  517. //// const QString& filename = reconstructionResourceFile->getName();
  518. //// ctkXnatObject* reconstructionResource = reconstructionResourceFile->getParent();
  519. //// const QString& resourceName = reconstructionResource->getName();
  520. //// ctkXnatObject* reconstruction = reconstructionResource->getParent();
  521. //// const QString& reconstructionName = reconstruction->getName();
  522. //// ctkXnatObject* experiment = reconstruction->getParent()->getParent();
  523. //// const QString& experimentName = experiment->getName();
  524. //// ctkXnatObject* subject = experiment->getParent();
  525. //// const QString& subjectName = subject->getName();
  526. //// ctkXnatObject* project = subject->getParent();
  527. //// const QString& projectName = project->getName();
  528. // // TODO
  529. //}
  530. //void ctkXnatConnection::download(ctkXnatScan* scan, const QString& fileName)
  531. //{
  532. // const QString& scanName = scan->getName();
  533. // ctkXnatObject* experiment = scan->getParent()->getParent();
  534. // const QString& experimentName = experiment->getName();
  535. // ctkXnatObject* subject = experiment->getParent();
  536. // const QString& subjectName = subject->getName();
  537. // ctkXnatObject* project = subject->getParent();
  538. // const QString& projectName = project->getName();
  539. // Q_D(ctkXnatConnection);
  540. // QString query = QString("/REST/projects/%1/subjects/%2/experiments/%3/scans/%4/files").arg(projectName, subjectName, experimentName, scanName);
  541. // qRestAPI::Parameters parameters;
  542. // parameters["format"] = "zip";
  543. // QUuid queryId = d->xnat->download(fileName, query, parameters);
  544. // d->xnat->sync(queryId);
  545. //}
  546. void ctkXnatConnection::download(ctkXnatScanResource* scanResource, const QString& fileName)
  547. {
  548. Q_D(ctkXnatConnection);
  549. QString query = scanResource->uri() + "/files";
  550. qRestAPI::Parameters parameters;
  551. parameters["format"] = "zip";
  552. QUuid queryId = d->xnat->download(fileName, query, parameters);
  553. d->xnat->sync(queryId);
  554. }
  555. void ctkXnatConnection::download(ctkXnatScanResourceFile* scanResourceFile, const QString& fileName)
  556. {
  557. Q_D(ctkXnatConnection);
  558. QString query = scanResourceFile->uri();
  559. QUuid queryId = d->xnat->download(fileName, query);
  560. d->xnat->sync(queryId);
  561. }
  562. void ctkXnatConnection::download(ctkXnatReconstructionResource* reconstructionResource, const QString& fileName)
  563. {
  564. Q_D(ctkXnatConnection);
  565. QString query = reconstructionResource->uri() + "/files";
  566. qRestAPI::Parameters parameters;
  567. parameters["format"] = "zip";
  568. QUuid queryId = d->xnat->download(fileName, query, parameters);
  569. d->xnat->sync(queryId);
  570. }
  571. void ctkXnatConnection::download(ctkXnatReconstructionResourceFile* reconstructionResourceFile, const QString& fileName)
  572. {
  573. Q_D(ctkXnatConnection);
  574. QString query = reconstructionResourceFile->uri();
  575. QUuid queryId = d->xnat->download(fileName, query);
  576. d->xnat->sync(queryId);
  577. }
  578. void ctkXnatConnection::processResult(QUuid queryId, QList<QVariantMap> parameters)
  579. {
  580. Q_UNUSED(queryId)
  581. Q_UNUSED(parameters)
  582. }