ctkXnatConnection.cpp 28 KB

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