ctkXnatConnection.cpp 27 KB

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