ctkXnatConnection.cpp 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715
  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 projectsUri("/data/archive/projects");
  136. QUuid queryId = d->xnat->get(projectsUri);
  137. qRestResult* restResult = d->xnat->takeResult(queryId);
  138. QList<ctkXnatProject*> projects = restResult->results<ctkXnatProject>();
  139. foreach (ctkXnatProject* project, projects)
  140. {
  141. project->setUri(projectsUri + "/" + project->id());
  142. ctkXnatObject::Pointer ptr(project);
  143. ptr->d_func()->selfPtr = ptr;
  144. server->addChild(ptr);
  145. }
  146. delete restResult;
  147. }
  148. void ctkXnatConnection::fetch(const ctkXnatProject::Pointer& project)
  149. {
  150. Q_D(ctkXnatConnection);
  151. QString subjectsUri = project->uri() + "/subjects";
  152. QUuid queryId = d->xnat->get(subjectsUri);
  153. qRestResult* restResult = d->xnat->takeResult(queryId);
  154. QList<ctkXnatSubject*> subjects = restResult->results<ctkXnatSubject>();
  155. foreach (ctkXnatSubject* subject, subjects)
  156. {
  157. QString label = subject->property("label");
  158. if (label.size())
  159. {
  160. subject->setProperty("ID", label);
  161. }
  162. subject->setUri(subjectsUri + "/" + subject->id());
  163. ctkXnatObject::Pointer ptr(subject);
  164. ptr->d_func()->selfPtr = ptr;
  165. project->addChild(ptr);
  166. }
  167. delete restResult;
  168. }
  169. void ctkXnatConnection::fetch(const QSharedPointer<ctkXnatSubject>& subject)
  170. {
  171. Q_D(ctkXnatConnection);
  172. QString experimentsUri = subject->uri() + "/experiments";
  173. QUuid queryId = d->xnat->get(experimentsUri);
  174. qRestResult* restResult = d->xnat->takeResult(queryId);
  175. QList<ctkXnatExperiment*> experiments = restResult->results<ctkXnatExperiment>();
  176. foreach (ctkXnatExperiment* experiment, experiments)
  177. {
  178. QString label = experiment->property ("label");
  179. if (label.size())
  180. {
  181. experiment->setProperty ("ID", label);
  182. }
  183. experiment->setUri(experimentsUri + "/" + experiment->id());
  184. ctkXnatObject::Pointer ptr(experiment);
  185. ptr->d_func()->selfPtr = ptr;
  186. subject->addChild(ptr);
  187. }
  188. delete restResult;
  189. }
  190. void ctkXnatConnection::fetch(const QSharedPointer<ctkXnatExperiment>& experiment)
  191. {
  192. Q_D(ctkXnatConnection);
  193. QString scansUri = experiment->uri() + "/scans";
  194. QUuid scansQueryId = d->xnat->get(scansUri);
  195. qRestResult* restResult = d->xnat->takeResult(scansQueryId);
  196. QList<ctkXnatScan*> scans = restResult->results<ctkXnatScan>();
  197. if (scans.size() > 0)
  198. {
  199. ctkXnatObject::Pointer ptr = ctkXnatScanFolder::Create();
  200. ptr->setUri(scansUri);
  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. delete restResult;
  215. }
  216. void ctkXnatConnection::fetch(const QSharedPointer<ctkXnatScanFolder>& scanFolder)
  217. {
  218. Q_D(ctkXnatConnection);
  219. QString scansUri = scanFolder->uri();
  220. QUuid queryId = d->xnat->get(scansUri);
  221. qRestResult* restResult = d->xnat->takeResult(queryId);
  222. QList<ctkXnatScan*> scans = restResult->results<ctkXnatScan>();
  223. foreach (ctkXnatScan* scan, scans)
  224. {
  225. scan->setUri(scansUri + "/" + scan->id());
  226. ctkXnatObject::Pointer ptr(scan);
  227. ptr->d_func()->selfPtr = ptr;
  228. scanFolder->addChild(ptr);
  229. }
  230. delete restResult;
  231. }
  232. void ctkXnatConnection::fetch(const QSharedPointer<ctkXnatScan>& scan)
  233. {
  234. Q_D(ctkXnatConnection);
  235. QString scanResourcesUri = scan->uri() + "/resources";
  236. QUuid queryId = d->xnat->get(scanResourcesUri);
  237. qRestResult* restResult = d->xnat->takeResult(queryId);
  238. QList<ctkXnatScanResource*> scanResources = restResult->results<ctkXnatScanResource>();
  239. foreach (ctkXnatScanResource* scanResource, scanResources)
  240. {
  241. QString label = scanResource->property("label");
  242. if (label.size())
  243. {
  244. scanResource->setProperty("ID", label);
  245. }
  246. scanResource->setUri(scanResourcesUri + "/" + label);
  247. ctkXnatObject::Pointer ptr(scanResource);
  248. ptr->d_func()->selfPtr = ptr;
  249. scan->addChild(ptr);
  250. }
  251. }
  252. void ctkXnatConnection::fetch(const QSharedPointer<ctkXnatScanResource>& scanResource)
  253. {
  254. Q_D(ctkXnatConnection);
  255. QString scanResourceFilesUri = scanResource->uri() + "/files";
  256. QUuid queryId = d->xnat->get(scanResourceFilesUri);
  257. qRestResult* restResult = d->xnat->takeResult(queryId);
  258. QList<ctkXnatScanResourceFile*> scanResourceFiles = restResult->results<ctkXnatScanResourceFile>();
  259. foreach (ctkXnatScanResourceFile* scanResourceFile, scanResourceFiles)
  260. {
  261. QString uri = scanResourceFile->property("URI");
  262. if (uri.size())
  263. {
  264. scanResourceFile->setUri(uri);
  265. }
  266. QString label = scanResourceFile->property("Name");
  267. if (label.size())
  268. {
  269. scanResourceFile->setProperty("ID", label);
  270. }
  271. scanResourceFile->setUri(scanResourceFilesUri + "/" + label);
  272. ctkXnatObject::Pointer ptr(scanResourceFile);
  273. ptr->d_func()->selfPtr = ptr;
  274. scanResource->addChild(ptr);
  275. }
  276. }
  277. //void ctkXnatConnection::fetch(ctkXnatReconstructionFolder* reconstructionFolder)
  278. //{
  279. // ctkXnatObject* experiment = reconstructionFolder->getParent();
  280. // const QString& experimentName = experiment->getName();
  281. // ctkXnatObject* subject = experiment->getParent();
  282. // const QString& subjectName = subject->getName();
  283. // ctkXnatObject* project = subject->getParent();
  284. // const QString& projectName = project->getName();
  285. // Q_D(ctkXnatConnection);
  286. // QString query = QString("/REST/projects/%1/subjects/%2/experiments/%3/reconstructions").arg(projectName, subjectName, experimentName);
  287. // QList<QVariantMap> result;
  288. // bool success = d->xnat->sync(d->xnat->get(query), result);
  289. // if (!success)
  290. // {
  291. // throw ctkXnatException("Error occurred while retrieving reconstruction list from XNAT.");
  292. // }
  293. // foreach (QVariantMap map, result)
  294. // {
  295. // QString reconstructionID = map["ID"].toString();
  296. // ctkXnatReconstruction* reconstruction = new ctkXnatReconstruction(reconstructionFolder);
  297. // reconstructionFolder->addChild(reconstructionID, reconstruction);
  298. // }
  299. //}
  300. //void ctkXnatConnection::fetch(ctkXnatReconstruction* reconstruction)
  301. //{
  302. // const QString& reconstructionName = reconstruction->getName();
  303. // ctkXnatObject* experiment = reconstruction->getParent()->getParent();
  304. // const QString& experimentName = experiment->getName();
  305. // ctkXnatObject* subject = experiment->getParent();
  306. // const QString& subjectName = subject->getName();
  307. // ctkXnatObject* project = subject->getParent();
  308. // const QString& projectName = project->getName();
  309. // Q_D(ctkXnatConnection);
  310. // QString query = QString("/REST/projects/%1/subjects/%2/experiments/%3/reconstructions/%4/ALL/resources").arg(projectName, subjectName, experimentName, reconstructionName);
  311. // QList<QVariantMap> result;
  312. // bool success = d->xnat->sync(d->xnat->get(query), result);
  313. // if (!success)
  314. // {
  315. // throw ctkXnatException("Error occurred while retrieving reconstruction resource list from XNAT.");
  316. // }
  317. // foreach (QVariantMap map, result)
  318. // {
  319. // QString reconstructionResourceLabel = map["label"].toString();
  320. // ctkXnatReconstructionResource* reconstructionResource = new ctkXnatReconstructionResource(reconstruction);
  321. // reconstruction->addChild(reconstructionResourceLabel, reconstructionResource);
  322. // }
  323. //}
  324. //void ctkXnatConnection::fetch(ctkXnatReconstructionResource* reconstructionResource)
  325. //{
  326. // const QString& resourceName = reconstructionResource->getName();
  327. // ctkXnatObject* reconstruction = reconstructionResource->getParent();
  328. // const QString& reconstructionName = reconstruction->getName();
  329. // ctkXnatObject* experiment = reconstruction->getParent()->getParent();
  330. // const QString& experimentName = experiment->getName();
  331. // ctkXnatObject* subject = experiment->getParent();
  332. // const QString& subjectName = subject->getName();
  333. // ctkXnatObject* project = subject->getParent();
  334. // const QString& projectName = project->getName();
  335. // Q_D(ctkXnatConnection);
  336. // QString query = QString("/REST/projects/%1/subjects/%2/experiments/%3/reconstructions/%4/ALL/resources/%5/files").arg(projectName, subjectName, experimentName, reconstructionName, resourceName);
  337. // QList<QVariantMap> result;
  338. // bool success = d->xnat->sync(d->xnat->get(query), result);
  339. // if (!success)
  340. // {
  341. // throw ctkXnatException("Error occurred while retrieving reconstruction resource file list from XNAT.");
  342. // }
  343. // foreach (QVariantMap map, result)
  344. // {
  345. // QString reconstructionResourceFileName = map["Name"].toString();
  346. // ctkXnatReconstructionResourceFile* reconstructionResourceFile = new ctkXnatReconstructionResourceFile(reconstructionResource);
  347. // reconstructionResource->addChild(reconstructionResourceFileName, reconstructionResourceFile);
  348. // }
  349. //}
  350. //void ctkXnatConnection::create(ctkXnatProject* project)
  351. //{
  352. // const QString& projectName = project->name();
  353. // Q_D(ctkXnatConnection);
  354. // QString query = QString("/REST/projects/%1").arg(projectName);
  355. // bool success = d->xnat->sync(d->xnat->put(query));
  356. // if (!success)
  357. // {
  358. // throw ctkXnatException("Error occurred while creating the project.");
  359. // }
  360. //}
  361. //void ctkXnatConnection::remove(ctkXnatProject* project)
  362. //{
  363. // const QString& projectName = project->name();
  364. // Q_D(ctkXnatConnection);
  365. // QString query = QString("/REST/projects/%1").arg(projectName);
  366. // bool success = d->xnat->sync(d->xnat->del(query));
  367. // if (!success)
  368. // {
  369. // throw ctkXnatException("Error occurred while removing the project.");
  370. // }
  371. //}
  372. //void ctkXnatConnection::create(ctkXnatSubject* subject)
  373. //{
  374. // const QString& subjectName = subject->getName();
  375. // ctkXnatObject* project = subject->getParent();
  376. // const QString& projectName = project->getName();
  377. // Q_D(ctkXnatConnection);
  378. // QString query = QString("/REST/projects/%1/subjects/%2").arg(projectName, subjectName);
  379. // bool success = d->xnat->sync(d->xnat->put(query));
  380. // if (!success)
  381. // {
  382. // throw ctkXnatException("Error occurred while creating the subject.");
  383. // }
  384. //}
  385. //void ctkXnatConnection::downloadScanFiles(ctkXnatExperiment* experiment, const QString& fileName)
  386. //{
  387. //// qDebug() << "ctkXnatConnection::downloadScanFiles(ctkXnatExperiment* experiment, const QString& zipFilename)";
  388. // const QString& experimentName = experiment->getName();
  389. // ctkXnatObject* subject = experiment->getParent();
  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/experiments/%3/scans/ALL/files").arg(projectName, subjectName, experimentName);
  395. // qRestAPI::Parameters parameters;
  396. // parameters["format"] = "zip";
  397. // QUuid queryId = d->xnat->download(fileName, query, parameters);
  398. // d->xnat->sync(queryId);
  399. //}
  400. //void ctkXnatConnection::downloadReconstructionFiles(ctkXnatExperiment* experiment, const QString& fileName)
  401. //{
  402. // const QString& experimentName = experiment->getName();
  403. // ctkXnatObject* subject = experiment->getParent();
  404. // const QString& subjectName = subject->getName();
  405. // ctkXnatObject* project = subject->getParent();
  406. // const QString& projectName = project->getName();
  407. // Q_D(ctkXnatConnection);
  408. // QString query = QString("/REST/projects/%1/subjects/%2/experiments/%3/reconstructions/ALL/files").arg(projectName, subjectName, experimentName);
  409. // qRestAPI::Parameters parameters;
  410. // parameters["format"] = "zip";
  411. // QUuid queryId = d->xnat->download(fileName, query, parameters);
  412. // d->xnat->sync(queryId);
  413. //}
  414. //void ctkXnatConnection::addReconstruction(ctkXnatExperiment* /*experiment*/, const QString& /*reconstruction*/)
  415. //{
  416. //// const QString& experimentName = experiment->getName();
  417. //// ctkXnatObject* subject = experiment->getParent();
  418. //// const QString& subjectName = subject->getName();
  419. //// ctkXnatObject* project = subject->getParent();
  420. //// const QString& projectName = project->getName();
  421. // // TODO
  422. //}
  423. //void ctkXnatConnection::downloadReconstruction(ctkXnatReconstruction* reconstruction, const QString& fileName)
  424. //{
  425. // const QString& reconstructionName = reconstruction->getName();
  426. // ctkXnatObject* experiment = reconstruction->getParent();
  427. // const QString& experimentName = experiment->getName();
  428. // ctkXnatObject* subject = experiment->getParent();
  429. // const QString& subjectName = subject->getName();
  430. // ctkXnatObject* project = subject->getParent();
  431. // const QString& projectName = project->getName();
  432. // Q_D(ctkXnatConnection);
  433. // QString query = QString("/REST/projects/%1/subjects/%2/experiments/%3/reconstructions/%4/ALL/files").arg(projectName, subjectName, experimentName, reconstructionName);
  434. // qRestAPI::Parameters parameters;
  435. // parameters["format"] = "zip";
  436. // QUuid queryId = d->xnat->download(fileName, query, parameters);
  437. // d->xnat->sync(queryId);
  438. //}
  439. //void ctkXnatConnection::addReconstructionResource(ctkXnatReconstruction* /*reconstruction*/, const QString& /*resourceName*/)
  440. //{
  441. //// const QString& reconstructionName = reconstruction->getName();
  442. //// ctkXnatObject* experiment = reconstruction->getParent()->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. // // TODO
  449. //}
  450. //void ctkXnatConnection::removeReconstruction(ctkXnatReconstruction* /*reconstruction*/)
  451. //{
  452. //// const QString& reconstructionName = reconstruction->getName();
  453. //// ctkXnatObject* experiment = reconstruction->getParent()->getParent();
  454. //// const QString& experimentName = experiment->getName();
  455. //// ctkXnatObject* subject = experiment->getParent();
  456. //// const QString& subjectName = subject->getName();
  457. //// ctkXnatObject* project = subject->getParent();
  458. //// const QString& projectName = project->getName();
  459. // // TODO
  460. //}
  461. //void ctkXnatConnection::downloadReconstructionResourceFiles(ctkXnatReconstructionResource* reconstructionResource, const QString& fileName)
  462. //{
  463. // const QString& reconstructionResourceName = reconstructionResource->getName();
  464. // ctkXnatObject* reconstruction = reconstructionResource->getParent();
  465. // const QString& reconstructionName = reconstruction->getName();
  466. // ctkXnatObject* experiment = reconstruction->getParent()->getParent();
  467. // const QString& experimentName = experiment->getName();
  468. // ctkXnatObject* subject = experiment->getParent();
  469. // const QString& subjectName = subject->getName();
  470. // ctkXnatObject* project = subject->getParent();
  471. // const QString& projectName = project->getName();
  472. // Q_D(ctkXnatConnection);
  473. // QString query = QString("/REST/projects/%1/subjects/%2/experiments/%3/reconstructions/%4/ALL/resources/%5/files").arg(projectName, subjectName, experimentName, reconstructionName, reconstructionResourceName);
  474. // qRestAPI::Parameters parameters;
  475. // parameters["format"] = "zip";
  476. // QUuid queryId = d->xnat->download(fileName, query, parameters);
  477. // d->xnat->sync(queryId);
  478. //}
  479. //void ctkXnatConnection::uploadReconstructionResourceFiles(ctkXnatReconstructionResource* /*reconstructionResource*/, const QString& /*zipFilename*/)
  480. //{
  481. //// const QString& resourceName = reconstructionResource->getName();
  482. //// ctkXnatObject* reconstruction = reconstructionResource->getParent();
  483. //// const QString& reconstructionName = reconstruction->getName();
  484. //// ctkXnatObject* experiment = reconstruction->getParent()->getParent();
  485. //// const QString& experimentName = experiment->getName();
  486. //// ctkXnatObject* subject = experiment->getParent();
  487. //// const QString& subjectName = subject->getName();
  488. //// ctkXnatObject* project = subject->getParent();
  489. //// const QString& projectName = project->getName();
  490. // // TODO
  491. //}
  492. //void ctkXnatConnection::removeReconstructionResource(ctkXnatReconstructionResource* /*reconstructionResource*/)
  493. //{
  494. //// const QString& resourceName = reconstructionResource->getName();
  495. //// ctkXnatObject* reconstruction = reconstructionResource->getParent();
  496. //// const QString& reconstructionName = reconstruction->getName();
  497. //// ctkXnatObject* experiment = reconstruction->getParent()->getParent();
  498. //// const QString& experimentName = experiment->getName();
  499. //// ctkXnatObject* subject = experiment->getParent();
  500. //// const QString& subjectName = subject->getName();
  501. //// ctkXnatObject* project = subject->getParent();
  502. //// const QString& projectName = project->getName();
  503. // // TODO
  504. //}
  505. //void ctkXnatConnection::download(ctkXnatReconstructionResourceFile* reconstructionResourceFile, const QString& fileName)
  506. //{
  507. //// qDebug() << "ctkXnatConnection::download(ctkXnatReconstructionResourceFile* reconstructionResourceFile, const QString& zipFilename)";
  508. // const QString& reconstructionResourceFileName = reconstructionResourceFile->getName();
  509. // ctkXnatObject* reconstructionResource = reconstructionResourceFile->getParent();
  510. // const QString& reconstructionResourceName = 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. // Q_D(ctkXnatConnection);
  520. // QString query = QString("/REST/projects/%1/subjects/%2/experiments/%3/reconstructions/%4/resources/%5/files/%6").arg(projectName, subjectName, experimentName, reconstructionName, reconstructionResourceName, reconstructionResourceFileName);
  521. // qRestAPI::Parameters parameters;
  522. // parameters["format"] = "zip";
  523. // QUuid queryId = d->xnat->download(fileName, query, parameters);
  524. // d->xnat->sync(queryId);
  525. //}
  526. //void ctkXnatConnection::remove(ctkXnatReconstructionResourceFile* /*reconstructionResourceFile*/)
  527. //{
  528. //// const QString& filename = reconstructionResourceFile->getName();
  529. //// ctkXnatObject* reconstructionResource = reconstructionResourceFile->getParent();
  530. //// const QString& resourceName = reconstructionResource->getName();
  531. //// ctkXnatObject* reconstruction = reconstructionResource->getParent();
  532. //// const QString& reconstructionName = reconstruction->getName();
  533. //// ctkXnatObject* experiment = reconstruction->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. // // TODO
  540. //}
  541. //void ctkXnatConnection::download(ctkXnatScan* scan, const QString& fileName)
  542. //{
  543. //// qDebug() << "ctkXnatConnection::download(ctkXnatScan* scan, const QString& zipFilename)";
  544. // const QString& scanName = scan->getName();
  545. // ctkXnatObject* experiment = scan->getParent()->getParent();
  546. // const QString& experimentName = experiment->getName();
  547. // ctkXnatObject* subject = experiment->getParent();
  548. // const QString& subjectName = subject->getName();
  549. // ctkXnatObject* project = subject->getParent();
  550. // const QString& projectName = project->getName();
  551. // Q_D(ctkXnatConnection);
  552. // QString query = QString("/REST/projects/%1/subjects/%2/experiments/%3/scans/%4/files").arg(projectName, subjectName, experimentName, scanName);
  553. // qRestAPI::Parameters parameters;
  554. // parameters["format"] = "zip";
  555. // QUuid queryId = d->xnat->download(fileName, query, parameters);
  556. // d->xnat->sync(queryId);
  557. //}
  558. void ctkXnatConnection::download(ctkXnatScanResource* scanResource, const QString& fileName)
  559. {
  560. Q_D(ctkXnatConnection);
  561. QString query = scanResource->uri() + "/files";
  562. qRestAPI::Parameters parameters;
  563. parameters["format"] = "zip";
  564. QUuid queryId = d->xnat->download(fileName, query, parameters);
  565. d->xnat->sync(queryId);
  566. }
  567. void ctkXnatConnection::download(ctkXnatScanResourceFile* scanResourceFile, const QString& fileName)
  568. {
  569. Q_D(ctkXnatConnection);
  570. QString query = scanResourceFile->uri();
  571. QUuid queryId = d->xnat->download(fileName, query);
  572. d->xnat->sync(queryId);
  573. }
  574. void ctkXnatConnection::processResult(QUuid queryId, QList<QVariantMap> parameters)
  575. {
  576. Q_UNUSED(queryId)
  577. Q_UNUSED(parameters)
  578. }