IF YOU WOULD LIKE TO GET AN ACCOUNT, please write an email to s dot adaszewski at gmail dot com. User accounts are meant only to report issues and/or generate pull requests. This is a purpose-specific Git hosting for ADARED projects. Thank you for your understanding!
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

107 lines
3.4KB

  1. import { h, Component } from 'preact';
  2. import WBNavbarCommon from 'wb-navbar-common';
  3. import WBArvadosCrumbs from 'wb-arvados-crumbs';
  4. import makeArvadosRequest from 'make-arvados-request';
  5. import detectUuids from 'detect-uuids';
  6. import arvadosTypeName from 'arvados-type-name';
  7. import urlForObject from 'url-for-object';
  8. import detectHashes from 'detect-hashes';
  9. import WBCommonFields from 'wb-common-fields';
  10. class WBProcessView extends Component {
  11. constructor(...args) {
  12. super(...args);
  13. this.state.objectUrls = [];
  14. }
  15. componentDidMount() {
  16. let { arvHost, arvToken } = this.props.app.state;
  17. let prom = makeArvadosRequest(arvHost, arvToken,
  18. '/arvados/v1/container_requests/' + this.props.uuid);
  19. let req;
  20. let cont;
  21. prom = prom.then(xhr => {
  22. req = xhr.response;
  23. if (req.container_uuid) {
  24. let prom_1 = makeArvadosRequest(arvHost, arvToken,
  25. '/arvados/v1/containers/' + req.container_uuid);
  26. prom_1 = prom_1.then(xhr => (cont = xhr.response));
  27. return prom_1;
  28. }
  29. });
  30. //prom = prom.then(xhr => (cont = xhr.response));
  31. prom = prom.then(() => {
  32. let hashes = detectHashes([ req, cont ]);
  33. let filters = [
  34. [ 'portable_data_hash', 'in', hashes ]
  35. ];
  36. return makeArvadosRequest(arvHost, arvToken,
  37. '/arvados/v1/collections?filters=' +
  38. encodeURIComponent(JSON.stringify(filters)));
  39. });
  40. prom = prom.then(xhr => {
  41. let colUuids = xhr.response['items'].map(item => item.uuid);
  42. let uuids = detectUuids([ req, cont ]);
  43. let dict = {};
  44. colUuids.map(u => (dict[u] = true));
  45. uuids.map(u => (dict[u] = true));
  46. return Object.keys(dict);
  47. });
  48. prom = prom.then(uuids => {
  49. // let uuids = detectUuids([ req, cont ]);
  50. let objectTypes = uuids.map(u => arvadosTypeName(u.split('-')[1]) + 's');
  51. let objQueries = {};
  52. objectTypes.map(t => (objQueries[t] = []));
  53. uuids.map((u, idx) => (objQueries[objectTypes[idx]].push(u)));
  54. let prom_1 = new Promise(accept => accept());
  55. let objects = [];
  56. // delete objQueries['users'];
  57. delete objQueries['api_clients'];
  58. for (let k in objQueries) {
  59. let filters = [
  60. ['uuid', 'in', objQueries[k]]
  61. ];
  62. prom_1 = prom_1.then(() => makeArvadosRequest(arvHost, arvToken,
  63. '/arvados/v1/' + k + '?filters=' +
  64. encodeURIComponent(JSON.stringify(filters))));
  65. prom_1 = prom_1.then(xhr => (objects = objects.concat(xhr.response['items'])));
  66. }
  67. prom_1 = prom_1.then(() => objects);
  68. return prom_1;
  69. });
  70. prom = prom.then(objects => {
  71. let objDict = {};
  72. objects.map(o => (objDict[o['uuid']] = o));
  73. let urls = objects.map(o => urlForObject(o));
  74. this.setState({ 'objectUrls': urls });
  75. });
  76. }
  77. render({ app, uuid }, { objectUrls }) {
  78. return (
  79. <div>
  80. <WBNavbarCommon app={ app } />
  81. <WBArvadosCrumbs app={ app } uuid={ uuid } />
  82. <div class="my-2">
  83. This is the process view for { uuid }
  84. </div>
  85. <WBCommonFields app={ app } uuid={ uuid } />
  86. <div>
  87. <a href="/browse">Click here</a>
  88. </div>
  89. <ul>
  90. { objectUrls.map(url => (
  91. <li><a href={ url }>{ url }</a></li>
  92. )) }
  93. </ul>
  94. </div>
  95. );
  96. }
  97. }
  98. export default WBProcessView;