pybioos 0.0.12__py3-none-any.whl → 0.0.14__py3-none-any.whl

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.
bioos/__about__.py CHANGED
@@ -1,4 +1,4 @@
1
1
  # coding:utf-8
2
2
 
3
3
  # Package version
4
- __version__ = "0.0.12"
4
+ __version__ = "0.0.14"
bioos/bioos_workflow.py CHANGED
@@ -277,8 +277,13 @@ class Bioos_workflow:
277
277
  self.logger.info("Download finish.")
278
278
 
279
279
  def submit_workflow_bioosapi(self):
280
+ """Submit workflow using Bio-OS API"""
280
281
  self.runs = self.wf.submit(**self.params_submit)
281
- self.logger.info("Submit workflow run successfully.")
282
+ submission_id = self.runs[0].submission
283
+ run_id = self.runs[0].id
284
+ self.logger.info(
285
+ f"Submit workflow run successfully. Submission ID: {submission_id}, Run ID: {run_id}"
286
+ )
282
287
  return self.runs
283
288
 
284
289
  def monitor_workflow(self):
bioos/bw_import.py CHANGED
@@ -145,7 +145,8 @@ def bioos_workflow_import():
145
145
  else:
146
146
  # 如果没有设置monitor参数,直接退出
147
147
  logger.info(
148
- f"Workflow {args.workflow_name} submitted successfully")
148
+ f"Workflow {args.workflow_name} is still validating, {result}, please wait and check the status later."
149
+ )
149
150
  sys.exit(0)
150
151
 
151
152
  except Exception as e:
@@ -0,0 +1,91 @@
1
+ #!/usr/bin/env python3
2
+ # coding: utf-8
3
+
4
+ import argparse
5
+ import logging
6
+ import sys
7
+
8
+ from bioos import bioos
9
+ from bioos.config import Config
10
+ from bioos.resource.workflows import WorkflowResource
11
+
12
+
13
+ def get_logger():
14
+ """Setup logger"""
15
+ logger = logging.getLogger('bw_import_status_check')
16
+ if not logger.handlers:
17
+ handler = logging.StreamHandler()
18
+ formatter = logging.Formatter(
19
+ '%(asctime)s - %(levelname)s - %(message)s')
20
+ handler.setFormatter(formatter)
21
+ logger.addHandler(handler)
22
+ logger.setLevel(logging.INFO)
23
+ return logger
24
+
25
+
26
+ def bioos_workflow_status_check():
27
+ """Command line entry point for checking workflow validation status"""
28
+ parser = argparse.ArgumentParser(
29
+ description='Bio-OS Workflow Import Status Check Tool',
30
+ formatter_class=argparse.RawDescriptionHelpFormatter)
31
+
32
+ # 必需参数
33
+ parser.add_argument(
34
+ '--ak',
35
+ required=True,
36
+ help='Access key for your Bio-OS instance platform account')
37
+ parser.add_argument(
38
+ '--sk',
39
+ required=True,
40
+ help='Secret key for your Bio-OS instance platform account')
41
+ parser.add_argument('--workspace_name',
42
+ required=True,
43
+ help='Target workspace name')
44
+ parser.add_argument('--workflow_id',
45
+ required=True,
46
+ help='ID of the workflow to check')
47
+
48
+ args = parser.parse_args()
49
+ logger = get_logger()
50
+
51
+ try:
52
+ # 配置Bio-OS
53
+ Config.set_access_key(args.ak)
54
+ Config.set_secret_key(args.sk)
55
+ Config.set_endpoint("https://bio-top.miracle.ac.cn")
56
+
57
+ # 获取workspace ID
58
+ workspaces = bioos.list_workspaces()
59
+ workspace_info = workspaces.query(f"Name=='{args.workspace_name}'")
60
+ if workspace_info.empty:
61
+ logger.error(f"Workspace {args.workspace_name} not found")
62
+ sys.exit(1)
63
+ workspace_id = workspace_info["ID"].iloc[0]
64
+
65
+ # 创建WorkflowResource实例
66
+ workflow_resource = WorkflowResource(workspace_id)
67
+
68
+ # 获取工作流状态
69
+ df = workflow_resource.list()
70
+ workflow_info = df[df.ID == args.workflow_id]
71
+
72
+ if len(workflow_info) == 1:
73
+ status = workflow_info.iloc[0]["Status"]["Phase"]
74
+ message = workflow_info.iloc[0]["Status"].get("Message", "")
75
+
76
+ # 打印状态信息
77
+ print(f"Status: {status}")
78
+ if message:
79
+ print(f"Message: {message}")
80
+
81
+ else:
82
+ logger.error(f"Workflow with ID {args.workflow_id} not found")
83
+ sys.exit(1)
84
+
85
+ except Exception as e:
86
+ logger.error(f"Error: {str(e)}")
87
+ sys.exit(1)
88
+
89
+
90
+ if __name__ == '__main__':
91
+ bioos_workflow_status_check()
@@ -0,0 +1,94 @@
1
+ #!/usr/bin/env python3
2
+ # coding: utf-8
3
+
4
+ import argparse
5
+ import logging
6
+ import sys
7
+
8
+ from bioos import bioos
9
+ from bioos.config import Config
10
+ from bioos.resource.workflows import WorkflowResource
11
+
12
+
13
+ def get_logger():
14
+ """Setup logger"""
15
+ logger = logging.getLogger('bw_status_check')
16
+ if not logger.handlers:
17
+ handler = logging.StreamHandler()
18
+ formatter = logging.Formatter(
19
+ '%(asctime)s - %(levelname)s - %(message)s')
20
+ handler.setFormatter(formatter)
21
+ logger.addHandler(handler)
22
+ logger.setLevel(logging.INFO)
23
+ return logger
24
+
25
+
26
+ def bioos_workflow_status_check():
27
+ """Command line entry point for checking workflow run status"""
28
+ parser = argparse.ArgumentParser(
29
+ description='Bio-OS Workflow Run Status Check Tool',
30
+ formatter_class=argparse.RawDescriptionHelpFormatter)
31
+
32
+ # 必需参数
33
+ parser.add_argument(
34
+ '--ak',
35
+ required=True,
36
+ help='Access key for your Bio-OS instance platform account')
37
+ parser.add_argument(
38
+ '--sk',
39
+ required=True,
40
+ help='Secret key for your Bio-OS instance platform account')
41
+ parser.add_argument('--workspace_name',
42
+ required=True,
43
+ help='Target workspace name')
44
+ parser.add_argument('--submission_id',
45
+ required=True,
46
+ help='ID of the submission to check')
47
+
48
+ args = parser.parse_args()
49
+ logger = get_logger()
50
+
51
+ try:
52
+ # 配置Bio-OS
53
+ Config.set_access_key(args.ak)
54
+ Config.set_secret_key(args.sk)
55
+ Config.set_endpoint("https://bio-top.miracle.ac.cn")
56
+
57
+ # 获取workspace ID
58
+ workspaces = bioos.list_workspaces()
59
+ workspace_info = workspaces.query(f"Name=='{args.workspace_name}'")
60
+ if workspace_info.empty:
61
+ logger.error(f"Workspace {args.workspace_name} not found")
62
+ sys.exit(1)
63
+ workspace_id = workspace_info["ID"].iloc[0]
64
+
65
+ # 获取提交的运行状态
66
+ resp = Config.service().list_runs({
67
+ "SubmissionID": args.submission_id,
68
+ "WorkspaceID": workspace_id
69
+ })
70
+
71
+ if not resp.get("Items"):
72
+ logger.error(f"No runs found for submission {args.submission_id}")
73
+ sys.exit(1)
74
+
75
+ # 打印所有运行的状态
76
+ print(f"\nSubmission ID: {args.submission_id}")
77
+ print("Runs Status:")
78
+ print("-" * 60)
79
+ print(f"{'Run ID':<40} {'Status':<10} {'Message'}")
80
+ print("-" * 60)
81
+
82
+ for run in resp.get("Items"):
83
+ run_id = run.get("ID", "N/A")
84
+ status = run.get("Status", "Unknown")
85
+ message = run.get("Message", "")
86
+ print(f"{run_id:<40} {status:<10} {message}")
87
+
88
+ except Exception as e:
89
+ logger.error(f"Error: {str(e)}")
90
+ sys.exit(1)
91
+
92
+
93
+ if __name__ == '__main__':
94
+ bioos_workflow_status_check()
@@ -0,0 +1,119 @@
1
+ #!/usr/bin/env python3
2
+ # coding: utf-8
3
+
4
+ import argparse
5
+ import logging
6
+ import os
7
+ import sys
8
+
9
+ from bioos import bioos
10
+ from bioos.config import Config
11
+
12
+
13
+ def get_logger():
14
+ """Setup logger"""
15
+ logger = logging.getLogger('get_submission_logs')
16
+ if not logger.handlers:
17
+ handler = logging.StreamHandler()
18
+ formatter = logging.Formatter(
19
+ '%(asctime)s - %(levelname)s - %(message)s')
20
+ handler.setFormatter(formatter)
21
+ logger.addHandler(handler)
22
+ logger.setLevel(logging.INFO)
23
+ return logger
24
+
25
+
26
+ def get_submission_logs():
27
+ """Command line entry point for downloading workflow submission logs"""
28
+ parser = argparse.ArgumentParser(
29
+ description='Bio-OS Workflow Submission Logs Download Tool',
30
+ formatter_class=argparse.RawDescriptionHelpFormatter)
31
+
32
+ # 必需参数
33
+ parser.add_argument(
34
+ '--ak',
35
+ required=True,
36
+ help='Access key for your Bio-OS instance platform account')
37
+ parser.add_argument(
38
+ '--sk',
39
+ required=True,
40
+ help='Secret key for your Bio-OS instance platform account')
41
+ parser.add_argument('--workspace_name',
42
+ required=True,
43
+ help='Target workspace name')
44
+ parser.add_argument('--submission_id',
45
+ required=True,
46
+ help='ID of the submission to download logs')
47
+ parser.add_argument(
48
+ '--output_dir',
49
+ default='.',
50
+ help='Local directory to save the logs (default: current directory)')
51
+
52
+ args = parser.parse_args()
53
+ logger = get_logger()
54
+
55
+ try:
56
+ # 配置Bio-OS
57
+ Config.set_access_key(args.ak)
58
+ Config.set_secret_key(args.sk)
59
+ Config.set_endpoint("https://bio-top.miracle.ac.cn")
60
+
61
+ # 获取workspace ID
62
+ workspaces = bioos.list_workspaces()
63
+ workspace_info = workspaces.query(f"Name=='{args.workspace_name}'")
64
+ if workspace_info.empty:
65
+ logger.error(f"Workspace {args.workspace_name} not found")
66
+ sys.exit(1)
67
+ workspace_id = workspace_info["ID"].iloc[0]
68
+
69
+ # 获取workspace对象
70
+ ws = bioos.workspace(workspace_id)
71
+
72
+ # 列出所有文件
73
+ logger.info(f"Listing files for submission {args.submission_id}")
74
+ files_df = ws.files.list()
75
+
76
+ # 过滤出与submission相关的日志文件
77
+ log_files = []
78
+ for file in files_df.key:
79
+ if args.submission_id in file:
80
+ # 检查是否是日志文件
81
+ if (file.endswith('.log') or 'stderr' in file
82
+ or 'stdout' in file or '/log/' in file):
83
+ log_files.append(file)
84
+
85
+ if not log_files:
86
+ logger.error(
87
+ f"No log files found for submission {args.submission_id}")
88
+ sys.exit(1)
89
+
90
+ logger.info(f"Found {len(log_files)} log files")
91
+
92
+ # 创建输出目录
93
+ output_path = os.path.join(args.output_dir, args.submission_id)
94
+ os.makedirs(output_path, exist_ok=True)
95
+
96
+ # 下载文件
97
+ logger.info("Downloading log files...")
98
+ try:
99
+ ws.files.download(log_files, output_path, flatten=False)
100
+ logger.info(f"Successfully downloaded log files to {output_path}")
101
+ except Exception as e:
102
+ logger.error(f"Error downloading some files: {str(e)}")
103
+ logger.info("Continuing with successfully downloaded files...")
104
+
105
+ # 打印下载的文件列表
106
+ logger.info("\nDownloaded files:")
107
+ for root, _, files in os.walk(output_path):
108
+ for file in files:
109
+ rel_path = os.path.relpath(os.path.join(root, file),
110
+ output_path)
111
+ logger.info(f" {rel_path}")
112
+
113
+ except Exception as e:
114
+ logger.error(f"Error: {str(e)}")
115
+ sys.exit(1)
116
+
117
+
118
+ if __name__ == '__main__':
119
+ get_submission_logs()
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: pybioos
3
- Version: 0.0.12
3
+ Version: 0.0.14
4
4
  Summary: BioOS SDK for Python
5
5
  Home-page: https://github.com/GBA-BI/pybioos
6
6
  Author: Jilong Liu
@@ -1,10 +1,13 @@
1
- bioos/__about__.py,sha256=aNi-I9L-ETYKI6YggZi-kF7_uIuNnhWlJs7B17PKWaw,57
1
+ bioos/__about__.py,sha256=ev5P6FQdPx-W_Hkam384TBq5XWIMHrvDeSBRkz-p7wo,57
2
2
  bioos/__init__.py,sha256=4GZKi13lDTD25YBkGakhZyEQZWTER_OWQMNPoH_UM2c,22
3
3
  bioos/bioos.py,sha256=fHzOb1l5wYxw6NVYYZDiFcgk4V28BAgWEc3ev12reWs,2409
4
- bioos/bioos_workflow.py,sha256=LbKxK7Otzj9apJciI3jg_cfh92x9aZGlUyN5ZRAdZeU,14127
5
- bioos/bw_import.py,sha256=90wZi86nwJUTSC5z3fioBcdFOF2nH5kTtoUH1xBKW_s,5632
4
+ bioos/bioos_workflow.py,sha256=BzEPOyAjgdK7Wafbl2b1_qG_VTEdp8xDwKS68tBovjs,14327
5
+ bioos/bw_import.py,sha256=lQk_ch_tTz8l4bnWniOzWZ1IxI6ZvKlaASkNMsdDGfA,5697
6
+ bioos/bw_import_status_check.py,sha256=sJuso2SAfZWvPzypnGge25Ayv5PsSGRXqSNNwIhNu-E,2794
7
+ bioos/bw_status_check.py,sha256=FVilkawRA7GD1JXUBeaR28W1DfN9bAzYBIAjqi4JIno,2916
6
8
  bioos/config.py,sha256=CvFabYqV1BkFWO8fnr5vBf6xNtNzA8hAEVeEIbvAOm8,4307
7
9
  bioos/errors.py,sha256=Lzz2rkjDOTR2X9CnVkmsmqeOgmNqbi46WAxnC6LEGm0,2459
10
+ bioos/get_submission_logs.py,sha256=jUtT8Vic8h_VOcqrqJsTBSonve64RjbKNAyp0wUtIpg,3934
8
11
  bioos/log.py,sha256=twiCvf5IgJB7uvzANwBluSlztJN8ZrxbGZUBGlZ0vps,3204
9
12
  bioos/internal/__init__.py,sha256=AbpHGcgLb-kRsJGnwFEktk7uzpZOCcBY74-YBdrKVGs,1
10
13
  bioos/internal/tos.py,sha256=0R6YN2lxjjZsuMfv0yLSkBmz_LqmzQGb8GagnUMc8EY,12264
@@ -31,9 +34,9 @@ bioos/tests/workspaces.py,sha256=LuuRrTs2XqfE5mGQyJNl9RBtuMb4NZHBJFoO8HMZVYQ,522
31
34
  bioos/utils/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
32
35
  bioos/utils/common_tools.py,sha256=fgMoE_-qZjgfQtUj_pmCTyYDtbJasyfH4Gm3VQsbgBQ,1651
33
36
  bioos/utils/workflows.py,sha256=zRbwTUigoM5V5LFOgzQPm3kwxt5Ogz95OFfefJc6Fjo,133
34
- pybioos-0.0.12.dist-info/LICENSE,sha256=cPkGXsgfPgEhIns7Lt3Avxx0Uy-VbdsoP8jvNGuj3cE,1063
35
- pybioos-0.0.12.dist-info/METADATA,sha256=7SzKHdMzKQwOhng63du_GID62jbgkc3j_RTm8lTy-ao,830
36
- pybioos-0.0.12.dist-info/WHEEL,sha256=OqRkF0eY5GHssMorFjlbTIq072vpHpF60fIQA6lS9xA,92
37
- pybioos-0.0.12.dist-info/entry_points.txt,sha256=G8eh4umiCimlV9nNNeyA3vqLyG3jfUj8uVNrgvAuhAM,110
38
- pybioos-0.0.12.dist-info/top_level.txt,sha256=llpzydkKVDSaWZgz3bsTUsQmhoQpc_JcRJg2-H-5a2U,6
39
- pybioos-0.0.12.dist-info/RECORD,,
37
+ pybioos-0.0.14.dist-info/LICENSE,sha256=cPkGXsgfPgEhIns7Lt3Avxx0Uy-VbdsoP8jvNGuj3cE,1063
38
+ pybioos-0.0.14.dist-info/METADATA,sha256=8sh0iBOI-33lr0H0_q6ZOzznns9i46p16siJFcRbnrM,830
39
+ pybioos-0.0.14.dist-info/WHEEL,sha256=OqRkF0eY5GHssMorFjlbTIq072vpHpF60fIQA6lS9xA,92
40
+ pybioos-0.0.14.dist-info/entry_points.txt,sha256=Sc5H0_X7r03Mef4Qd70bebqgdIbVAxLU7nV7qP7cKD4,328
41
+ pybioos-0.0.14.dist-info/top_level.txt,sha256=llpzydkKVDSaWZgz3bsTUsQmhoQpc_JcRJg2-H-5a2U,6
42
+ pybioos-0.0.14.dist-info/RECORD,,
@@ -0,0 +1,7 @@
1
+ [console_scripts]
2
+ bw = bioos.bioos_workflow:bioos_workflow
3
+ bw_import = bioos.bw_import:bioos_workflow_import
4
+ bw_import_status_check = bioos.bw_import_status_check:bioos_workflow_status_check
5
+ bw_status_check = bioos.bw_status_check:bioos_workflow_status_check
6
+ get_submission_logs = bioos.get_submission_logs:get_submission_logs
7
+
@@ -1,4 +0,0 @@
1
- [console_scripts]
2
- bw = bioos.bioos_workflow:bioos_workflow
3
- bw_import = bioos.bw_import:bioos_workflow_import
4
-