pybiolib 1.1.2003__tar.gz → 1.1.2011__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (113) hide show
  1. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/PKG-INFO +1 -1
  2. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/jobs/job_result.py +25 -5
  3. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/pyproject.toml +1 -1
  4. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/LICENSE +0 -0
  5. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/README.md +0 -0
  6. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/__init__.py +0 -0
  7. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/_internal/__init__.py +0 -0
  8. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/_internal/data_record/__init__.py +0 -0
  9. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/_internal/data_record/data_record.py +0 -0
  10. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/_internal/data_record/remote_storage_endpoint.py +0 -0
  11. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/_internal/fuse_mount/__init__.py +0 -0
  12. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/_internal/fuse_mount/experiment_fuse_mount.py +0 -0
  13. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/_internal/http_client.py +0 -0
  14. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/_internal/libs/__init__.py +0 -0
  15. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/_internal/libs/fusepy/__init__.py +0 -0
  16. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/_internal/push_application.py +0 -0
  17. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/_internal/runtime.py +0 -0
  18. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/_internal/utils/__init__.py +0 -0
  19. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/api/__init__.py +0 -0
  20. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/api/client.py +0 -0
  21. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/app/__init__.py +0 -0
  22. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/app/app.py +0 -0
  23. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/app/search_apps.py +0 -0
  24. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/biolib_api_client/__init__.py +0 -0
  25. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/biolib_api_client/api_client.py +0 -0
  26. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/biolib_api_client/app_types.py +0 -0
  27. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/biolib_api_client/auth.py +0 -0
  28. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/biolib_api_client/biolib_app_api.py +0 -0
  29. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/biolib_api_client/biolib_job_api.py +0 -0
  30. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/biolib_api_client/common_types.py +0 -0
  31. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/biolib_api_client/job_types.py +0 -0
  32. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/biolib_api_client/lfs_types.py +0 -0
  33. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/biolib_api_client/user_state.py +0 -0
  34. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/biolib_binary_format/__init__.py +0 -0
  35. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/biolib_binary_format/base_bbf_package.py +0 -0
  36. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/biolib_binary_format/file_in_container.py +0 -0
  37. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/biolib_binary_format/module_input.py +0 -0
  38. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/biolib_binary_format/module_output_v2.py +0 -0
  39. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/biolib_binary_format/remote_endpoints.py +0 -0
  40. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/biolib_binary_format/remote_stream_seeker.py +0 -0
  41. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/biolib_binary_format/saved_job.py +0 -0
  42. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/biolib_binary_format/stdout_and_stderr.py +0 -0
  43. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/biolib_binary_format/system_exception.py +0 -0
  44. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/biolib_binary_format/system_status_update.py +0 -0
  45. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/biolib_binary_format/utils.py +0 -0
  46. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/biolib_docker_client/__init__.py +0 -0
  47. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/biolib_download_container.py +0 -0
  48. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/biolib_errors.py +0 -0
  49. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/biolib_logging.py +0 -0
  50. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/cli/__init__.py +0 -0
  51. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/cli/auth.py +0 -0
  52. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/cli/data_record.py +0 -0
  53. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/cli/download_container.py +0 -0
  54. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/cli/init.py +0 -0
  55. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/cli/lfs.py +0 -0
  56. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/cli/push.py +0 -0
  57. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/cli/run.py +0 -0
  58. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/cli/runtime.py +0 -0
  59. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/cli/start.py +0 -0
  60. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/compute_node/.gitignore +0 -0
  61. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/compute_node/__init__.py +0 -0
  62. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/compute_node/cloud_utils/__init__.py +0 -0
  63. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/compute_node/cloud_utils/cloud_utils.py +0 -0
  64. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/compute_node/job_worker/__init__.py +0 -0
  65. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/compute_node/job_worker/cache_state.py +0 -0
  66. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/compute_node/job_worker/cache_types.py +0 -0
  67. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/compute_node/job_worker/docker_image_cache.py +0 -0
  68. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/compute_node/job_worker/executors/__init__.py +0 -0
  69. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/compute_node/job_worker/executors/docker_executor.py +0 -0
  70. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/compute_node/job_worker/executors/docker_types.py +0 -0
  71. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/compute_node/job_worker/executors/tars/__init__.py +0 -0
  72. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/compute_node/job_worker/executors/types.py +0 -0
  73. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/compute_node/job_worker/job_legacy_input_wait_timeout_thread.py +0 -0
  74. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/compute_node/job_worker/job_max_runtime_timer_thread.py +0 -0
  75. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/compute_node/job_worker/job_storage.py +0 -0
  76. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/compute_node/job_worker/job_worker.py +0 -0
  77. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/compute_node/job_worker/large_file_system.py +0 -0
  78. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/compute_node/job_worker/mappings.py +0 -0
  79. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/compute_node/job_worker/utilization_reporter_thread.py +0 -0
  80. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/compute_node/job_worker/utils.py +0 -0
  81. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/compute_node/remote_host_proxy.py +0 -0
  82. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/compute_node/socker_listener_thread.py +0 -0
  83. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/compute_node/socket_sender_thread.py +0 -0
  84. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/compute_node/utils.py +0 -0
  85. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/compute_node/webserver/__init__.py +0 -0
  86. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/compute_node/webserver/gunicorn_flask_application.py +0 -0
  87. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/compute_node/webserver/webserver.py +0 -0
  88. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/compute_node/webserver/webserver_types.py +0 -0
  89. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/compute_node/webserver/webserver_utils.py +0 -0
  90. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/compute_node/webserver/worker_thread.py +0 -0
  91. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/experiments/__init__.py +0 -0
  92. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/experiments/experiment.py +0 -0
  93. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/experiments/types.py +0 -0
  94. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/jobs/__init__.py +0 -0
  95. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/jobs/job.py +0 -0
  96. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/jobs/types.py +0 -0
  97. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/lfs/__init__.py +0 -0
  98. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/lfs/cache.py +0 -0
  99. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/lfs/utils.py +0 -0
  100. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/runtime/__init__.py +0 -0
  101. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/sdk/__init__.py +0 -0
  102. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/tables.py +0 -0
  103. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/templates/__init__.py +0 -0
  104. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/templates/example_app.py +0 -0
  105. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/typing_utils.py +0 -0
  106. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/user/__init__.py +0 -0
  107. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/user/sign_in.py +0 -0
  108. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/utils/__init__.py +0 -0
  109. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/utils/app_uri.py +0 -0
  110. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/utils/cache_state.py +0 -0
  111. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/utils/multipart_uploader.py +0 -0
  112. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/utils/seq_util.py +0 -0
  113. {pybiolib-1.1.2003 → pybiolib-1.1.2011}/biolib/utils/zip/remote_zip.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: pybiolib
3
- Version: 1.1.2003
3
+ Version: 1.1.2011
4
4
  Summary: BioLib Python Client
5
5
  Home-page: https://github.com/biolib
6
6
  License: MIT
@@ -34,7 +34,9 @@ class JobResult:
34
34
  def get_exit_code(self) -> int:
35
35
  return self._get_module_output().get_exit_code()
36
36
 
37
- def save_files(self, output_dir: str, path_filter: Optional[PathFilter] = None) -> None:
37
+ def save_files(
38
+ self, output_dir: str, path_filter: Optional[PathFilter] = None, skip_file_if_exists: Optional[bool] = None
39
+ ) -> None:
38
40
  module_output = self._get_module_output()
39
41
  output_files = module_output.get_files()
40
42
  filtered_output_files = self._get_filtered_files(output_files, path_filter) if path_filter else output_files
@@ -60,15 +62,33 @@ class JobResult:
60
62
  # Remove leading slash of file_path
61
63
  destination_file_path = Path(output_dir) / Path(file.path.lstrip('/'))
62
64
  if destination_file_path.exists():
63
- destination_file_path.rename(f'{destination_file_path}.biolib-renamed.{time.strftime("%Y%m%d%H%M%S")}')
65
+ if skip_file_if_exists:
66
+ print(f'Skipping {destination_file_path} as a file with that name already exists locally.')
67
+ continue
68
+ else:
69
+ destination_file_path.rename(
70
+ f'{destination_file_path}.biolib-renamed.{time.strftime("%Y%m%d%H%M%S")}'
71
+ )
64
72
 
65
73
  dir_path = destination_file_path.parent
66
74
  if dir_path:
67
75
  dir_path.mkdir(parents=True, exist_ok=True)
68
76
 
69
- with open(destination_file_path, mode='wb') as destination_file:
70
- for chunk in stream_seeker.seek_and_read(file_start=file.start, file_length=file.length):
71
- destination_file.write(chunk)
77
+ # write content to temporary (partial) file
78
+ partial_path = destination_file_path.with_suffix(f'.{self._job_uuid}.partial_biolib_download')
79
+ file_start = file.start
80
+ data_to_download = file.length
81
+ if partial_path.exists():
82
+ data_already_downloaded = partial_path.stat().st_size
83
+ file_start += data_already_downloaded
84
+ data_to_download -= data_already_downloaded
85
+
86
+ with open(partial_path, mode='ab') as partial_file:
87
+ for chunk in stream_seeker.seek_and_read(file_start=file_start, file_length=data_to_download):
88
+ partial_file.write(chunk)
89
+
90
+ # rename partial file to actual file name
91
+ partial_path.rename(destination_file_path)
72
92
 
73
93
  def get_output_file(self, filename) -> LazyLoadedFile:
74
94
  files = self._get_module_output().get_files()
@@ -1,6 +1,6 @@
1
1
  [tool.poetry]
2
2
  name = "pybiolib"
3
- version = "1.1.2003"
3
+ version = "1.1.2011"
4
4
  description = "BioLib Python Client"
5
5
  readme = "README.md"
6
6
  license = "MIT"
File without changes
File without changes