qbraid-cli 0.9.1__py3-none-any.whl → 0.9.3__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.

Potentially problematic release.


This version of qbraid-cli might be problematic. Click here for more details.

qbraid_cli/_version.py CHANGED
@@ -12,5 +12,5 @@ __version__: str
12
12
  __version_tuple__: VERSION_TUPLE
13
13
  version_tuple: VERSION_TUPLE
14
14
 
15
- __version__ = version = '0.9.1'
16
- __version_tuple__ = version_tuple = (0, 9, 1)
15
+ __version__ = version = '0.9.3'
16
+ __version_tuple__ = version_tuple = (0, 9, 3)
qbraid_cli/account/app.py CHANGED
@@ -13,7 +13,7 @@ import typer
13
13
 
14
14
  from qbraid_cli.handlers import run_progress_task
15
15
 
16
- account_app = typer.Typer(help="Manage qBraid account.")
16
+ account_app = typer.Typer(help="Manage qBraid account.", no_args_is_help=True)
17
17
 
18
18
 
19
19
  @account_app.command(name="credits")
qbraid_cli/admin/app.py CHANGED
@@ -14,7 +14,9 @@ from qbraid_cli.admin.headers import check_and_fix_headers
14
14
  from qbraid_cli.admin.validation import validate_header_type, validate_paths_exist
15
15
 
16
16
  admin_app = typer.Typer(
17
- help="CI/CD commands for qBraid maintainers.", pretty_exceptions_show_locals=False
17
+ help="CI/CD commands for qBraid maintainers.",
18
+ pretty_exceptions_show_locals=False,
19
+ no_args_is_help=True,
18
20
  )
19
21
 
20
22
 
@@ -6,6 +6,6 @@ Module defining the qbraid chat namespace
6
6
 
7
7
  """
8
8
 
9
- from .app import chat_app
9
+ from .app import ChatFormat, list_models_callback, prompt_callback
10
10
 
11
- __all__ = ["chat_app"]
11
+ __all__ = ["list_models_callback", "prompt_callback", "ChatFormat"]
qbraid_cli/chat/app.py CHANGED
@@ -7,16 +7,11 @@ Module defining commands in the 'qbraid chat' namespace.
7
7
  """
8
8
  from enum import Enum
9
9
 
10
- import typer
11
10
  from rich.console import Console
12
11
  from rich.table import Table
13
12
 
14
13
  from qbraid_cli.handlers import handle_error, run_progress_task
15
14
 
16
- chat_app = typer.Typer(
17
- help="Interact with qBraid AI chat service.", pretty_exceptions_show_locals=False
18
- )
19
-
20
15
 
21
16
  class ChatFormat(str, Enum):
22
17
  """Format of the response from the chat service."""
@@ -25,47 +20,7 @@ class ChatFormat(str, Enum):
25
20
  code = "code" # pylint: disable=invalid-name
26
21
 
27
22
 
28
- @chat_app.command("send")
29
- def chat_send(
30
- prompt: str = typer.Argument(..., help="The prompt to send to the chat service."),
31
- model: str = typer.Option(None, "--model", "-m", help="The model to use for the chat service."),
32
- response_format: ChatFormat = typer.Option(
33
- ChatFormat.text, "--format", "-f", help="The format of the response."
34
- ),
35
- stream: bool = typer.Option(False, "--stream", "-s", help="Stream the response."),
36
- ):
37
- """
38
- Interact with qBraid AI chat service.
39
-
40
- """
41
- # pylint: disable-next=import-outside-toplevel
42
- from qbraid_core.services.chat import ChatClient, ChatServiceRequestError
43
-
44
- client = ChatClient()
45
-
46
- if response_format == ChatFormat.code:
47
- prompt += " Return only raw code. Do not include any text outside of code blocks."
48
-
49
- if stream:
50
- try:
51
- for chunk in client.chat_stream(prompt, model, response_format):
52
- print(chunk, end="")
53
- except ChatServiceRequestError as err:
54
- handle_error(message=str(err), include_traceback=False)
55
- else:
56
- content = run_progress_task(
57
- client.chat,
58
- prompt,
59
- model,
60
- response_format,
61
- description="Connecting to chat service...",
62
- include_error_traceback=False,
63
- )
64
- print(content)
65
-
66
-
67
- @chat_app.command(name="models")
68
- def chat_models():
23
+ def list_models_callback():
69
24
  """List available chat models."""
70
25
  # pylint: disable-next=import-outside-toplevel
71
26
  from qbraid_core.services.chat import ChatClient
@@ -94,3 +49,28 @@ def chat_models():
94
49
  )
95
50
 
96
51
  console.print(table)
52
+
53
+
54
+ def prompt_callback(prompt: str, model: str, response_format: ChatFormat, stream: bool):
55
+ """Send a chat prompt to the chat service."""
56
+ # pylint: disable-next=import-outside-toplevel
57
+ from qbraid_core.services.chat import ChatClient, ChatServiceRequestError
58
+
59
+ client = ChatClient()
60
+
61
+ if stream:
62
+ try:
63
+ for chunk in client.chat_stream(prompt, model, response_format):
64
+ print(chunk, end="")
65
+ except ChatServiceRequestError as err:
66
+ handle_error(message=str(err), include_traceback=False)
67
+ else:
68
+ content = run_progress_task(
69
+ client.chat,
70
+ prompt,
71
+ model,
72
+ response_format,
73
+ description="Connecting to chat service...",
74
+ include_error_traceback=False,
75
+ )
76
+ print(content)
qbraid_cli/devices/app.py CHANGED
@@ -14,7 +14,7 @@ from rich.console import Console
14
14
  from qbraid_cli.devices.validation import validate_provider, validate_status, validate_type
15
15
  from qbraid_cli.handlers import run_progress_task
16
16
 
17
- devices_app = typer.Typer(help="Manage qBraid quantum devices.")
17
+ devices_app = typer.Typer(help="Manage qBraid quantum devices.", no_args_is_help=True)
18
18
 
19
19
 
20
20
  @devices_app.command(name="list")
qbraid_cli/envs/app.py CHANGED
@@ -23,7 +23,7 @@ from qbraid_cli.handlers import QbraidException, run_progress_task
23
23
  if TYPE_CHECKING:
24
24
  from qbraid_core.services.environments.client import EnvironmentManagerClient as EMC
25
25
 
26
- envs_app = typer.Typer(help="Manage qBraid environments.")
26
+ envs_app = typer.Typer(help="Manage qBraid environments.", no_args_is_help=True)
27
27
 
28
28
 
29
29
  @envs_app.command(name="create")
@@ -0,0 +1,11 @@
1
+ # Copyright (c) 2024, qBraid Development Team
2
+ # All rights reserved.
3
+
4
+ """
5
+ Module defining the qbraid files namespace
6
+
7
+ """
8
+
9
+ from .app import files_app
10
+
11
+ __all__ = ["files_app"]
@@ -0,0 +1,118 @@
1
+ # Copyright (c) 2024, qBraid Development Team
2
+ # All rights reserved.
3
+
4
+ """
5
+ Module defining commands in the 'qbraid files' namespace.
6
+
7
+ """
8
+
9
+ from pathlib import Path
10
+ from typing import Any
11
+
12
+ import rich
13
+ import typer
14
+
15
+ from qbraid_cli.handlers import run_progress_task
16
+
17
+ files_app = typer.Typer(help="Manage qBraid cloud storage files.", no_args_is_help=True)
18
+
19
+
20
+ @files_app.command(name="upload")
21
+ def files_upload(
22
+ filepath: Path = typer.Argument(
23
+ ...,
24
+ exists=True,
25
+ dir_okay=False,
26
+ resolve_path=True,
27
+ help="Local path to the file to upload.",
28
+ ),
29
+ namespace: str = typer.Option(
30
+ "user",
31
+ "--namespace",
32
+ "-n",
33
+ help="Target qBraid namespace for the upload.",
34
+ ),
35
+ object_path: str = typer.Option(
36
+ None,
37
+ "--object-path",
38
+ "-p",
39
+ help=("Target object path. " "Defaults to original filename in namespace root."),
40
+ ),
41
+ overwrite: bool = typer.Option(
42
+ False,
43
+ "--overwrite",
44
+ "-o",
45
+ help="Overwrite existing file if it already exists in the target location.",
46
+ ),
47
+ ):
48
+ """Upload a local file to qBraid storage."""
49
+
50
+ def upload_file() -> dict[str, Any]:
51
+ from qbraid_core.services.files import FileManagerClient
52
+
53
+ client = FileManagerClient()
54
+ data = client.upload_file(
55
+ filepath, namespace=namespace, object_path=object_path, overwrite=overwrite
56
+ )
57
+ return data
58
+
59
+ data: dict = run_progress_task(
60
+ upload_file, description="Uploading file...", include_error_traceback=False
61
+ )
62
+
63
+ rich.print("File uploaded successfully!")
64
+ namespace = data.get("namespace")
65
+ object_path = data.get("objectPath")
66
+
67
+ if namespace and object_path:
68
+ rich.print(f"\nNamespace: '{namespace}'")
69
+ rich.print(f"Object path: '{object_path}'")
70
+
71
+
72
+ @files_app.command(name="download")
73
+ def files_download(
74
+ object_path: str = typer.Argument(
75
+ ...,
76
+ help="The folder + filename describing the file to download.",
77
+ ),
78
+ namespace: str = typer.Option(
79
+ "user",
80
+ "--namespace",
81
+ "-n",
82
+ help="Source qBraid namespace for the download.",
83
+ ),
84
+ save_path: Path = typer.Option(
85
+ Path.cwd(),
86
+ "--save-path",
87
+ "-s",
88
+ resolve_path=True,
89
+ help="Local directory to save the downloaded file.",
90
+ ),
91
+ overwrite: bool = typer.Option(
92
+ False,
93
+ "--overwrite",
94
+ "-o",
95
+ help="Overwrite existing file if it already exists in the target location.",
96
+ ),
97
+ ):
98
+ """Download a file from qBraid storage."""
99
+
100
+ def download_file() -> Path:
101
+ from qbraid_core.services.files import FileManagerClient
102
+
103
+ client = FileManagerClient()
104
+ file_path = client.download_file(
105
+ object_path, namespace=namespace, save_path=save_path, overwrite=overwrite
106
+ )
107
+ return file_path
108
+
109
+ file_path: Path = run_progress_task(
110
+ download_file, description="Downloading file...", include_error_traceback=False
111
+ )
112
+
113
+ rich.print("File downloaded successfully!")
114
+ rich.print(f"Saved to: '{str(file_path)}'")
115
+
116
+
117
+ if __name__ == "__main__":
118
+ files_app()
qbraid_cli/jobs/app.py CHANGED
@@ -15,7 +15,7 @@ from qbraid_cli.handlers import handle_error, run_progress_task
15
15
  from qbraid_cli.jobs.toggle_braket import disable_braket, enable_braket
16
16
  from qbraid_cli.jobs.validation import handle_jobs_state, run_progress_get_state, validate_library
17
17
 
18
- jobs_app = typer.Typer(help="Manage qBraid quantum jobs.")
18
+ jobs_app = typer.Typer(help="Manage qBraid quantum jobs.", no_args_is_help=True)
19
19
 
20
20
 
21
21
  @jobs_app.command(name="enable")
qbraid_cli/kernels/app.py CHANGED
@@ -11,7 +11,7 @@ from rich.console import Console
11
11
 
12
12
  from qbraid_cli.handlers import handle_error
13
13
 
14
- kernels_app = typer.Typer(help="Manage qBraid kernels.")
14
+ kernels_app = typer.Typer(help="Manage qBraid kernels.", no_args_is_help=True)
15
15
 
16
16
 
17
17
  @kernels_app.command(name="list")
qbraid_cli/main.py CHANGED
@@ -6,20 +6,22 @@ Entrypoint for the qBraid CLI.
6
6
 
7
7
  """
8
8
 
9
+ import click
9
10
  import rich
10
11
  import typer
11
12
 
12
- from qbraid_cli.account.app import account_app
13
- from qbraid_cli.admin.app import admin_app
14
- from qbraid_cli.chat.app import chat_app
15
- from qbraid_cli.configure.app import configure_app
16
- from qbraid_cli.devices.app import devices_app
17
- from qbraid_cli.jobs.app import jobs_app
13
+ from qbraid_cli.account import account_app
14
+ from qbraid_cli.admin import admin_app
15
+ from qbraid_cli.chat import ChatFormat, list_models_callback, prompt_callback
16
+ from qbraid_cli.configure import configure_app
17
+ from qbraid_cli.devices import devices_app
18
+ from qbraid_cli.files import files_app
19
+ from qbraid_cli.jobs import jobs_app
18
20
 
19
21
  try:
20
- from qbraid_cli.envs.app import envs_app
21
- from qbraid_cli.kernels.app import kernels_app
22
- from qbraid_cli.pip.app import pip_app
22
+ from qbraid_cli.envs import envs_app
23
+ from qbraid_cli.kernels import kernels_app
24
+ from qbraid_cli.pip import pip_app
23
25
 
24
26
  ENVS_COMMANDS = True
25
27
  except ImportError:
@@ -28,10 +30,10 @@ except ImportError:
28
30
  app = typer.Typer(context_settings={"help_option_names": ["-h", "--help"]})
29
31
 
30
32
  app.add_typer(admin_app, name="admin")
31
- app.add_typer(chat_app, name="chat")
32
33
  app.add_typer(configure_app, name="configure")
33
34
  app.add_typer(account_app, name="account")
34
35
  app.add_typer(devices_app, name="devices")
36
+ app.add_typer(files_app, name="files")
35
37
  app.add_typer(jobs_app, name="jobs")
36
38
 
37
39
  if ENVS_COMMANDS is True:
@@ -90,5 +92,34 @@ def main(
90
92
  show_banner()
91
93
 
92
94
 
95
+ @app.command(help="Interact with qBraid AI chat service.", no_args_is_help=True)
96
+ def chat(
97
+ prompt: str = typer.Option(
98
+ None, "--prompt", "-p", help="The prompt to send to the chat service."
99
+ ),
100
+ model: str = typer.Option(None, "--model", "-m", help="The model to use for the chat service."),
101
+ response_format: ChatFormat = typer.Option(
102
+ ChatFormat.text, "--format", "-f", help="The format of the response."
103
+ ),
104
+ stream: bool = typer.Option(False, "--stream", "-s", help="Stream the response."),
105
+ list_models: bool = typer.Option(
106
+ False, "--list-models", "-l", help="List available chat models."
107
+ ),
108
+ ):
109
+ """
110
+ Interact with qBraid AI chat service.
111
+
112
+ """
113
+ if list_models:
114
+ list_models_callback()
115
+ elif prompt:
116
+ prompt_callback(prompt, model, response_format, stream)
117
+ else:
118
+ raise click.UsageError(
119
+ "Invalid command. Please provide a prompt using --prompt "
120
+ "or use --list-models to view available models."
121
+ )
122
+
123
+
93
124
  if __name__ == "__main__":
94
125
  app()
qbraid_cli/pip/app.py CHANGED
@@ -16,8 +16,7 @@ from qbraid_core.system.executables import get_active_python_path
16
16
  from qbraid_cli.handlers import handle_error
17
17
  from qbraid_cli.pip.hooks import get_env_cfg_path, safe_set_include_sys_packages
18
18
 
19
- # disable pretty_exceptions_show_locals to avoid printing sensative information in the traceback
20
- pip_app = typer.Typer(help="Run pip command in active qBraid environment.")
19
+ pip_app = typer.Typer(help="Run pip command in active qBraid environment.", no_args_is_help=True)
21
20
 
22
21
 
23
22
  @pip_app.command(
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: qbraid-cli
3
- Version: 0.9.1
3
+ Version: 0.9.3
4
4
  Summary: Command Line Interface for interacting with all parts of the qBraid platform.
5
5
  Author-email: qBraid Development Team <contact@qbraid.com>
6
6
  License: Proprietary
@@ -29,7 +29,8 @@ Description-Content-Type: text/markdown
29
29
  License-File: LICENSE
30
30
  Requires-Dist: typer>=0.12.1
31
31
  Requires-Dist: rich>=10.11.0
32
- Requires-Dist: qbraid-core>=0.1.30
32
+ Requires-Dist: click
33
+ Requires-Dist: qbraid-core>=0.1.32
33
34
  Provides-Extra: jobs
34
35
  Requires-Dist: amazon-braket-sdk>=1.48.1; extra == "jobs"
35
36
  Provides-Extra: envs
@@ -1,40 +1,42 @@
1
1
  qbraid_cli/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
2
- qbraid_cli/_version.py,sha256=_P6tBRUyis5e8UBMut-5M8NVccs2HwAQXTxErAP99SI,411
2
+ qbraid_cli/_version.py,sha256=UKt4viYNHppvoM2VUu_oFmzU2bpc5MQ2Y0-6XGFMVuM,411
3
3
  qbraid_cli/exceptions.py,sha256=KjlhYJhSHMVazaNiBjD_Ur06w4sekP8zRsFzBdyIpno,672
4
4
  qbraid_cli/handlers.py,sha256=B9H1Qw6yx8izrqp9OGR2TgSJa_mxA8KLXUkX8LB7Feg,7650
5
- qbraid_cli/main.py,sha256=Xhqbkfi9MtxulrIbEDnBK_gpfHluBGa5YluCIkJuoLg,2839
5
+ qbraid_cli/main.py,sha256=aSOQyoRRvKBJBcx8VtU4zKZ2WHvGKHhw8I-WiRwPxcE,3926
6
6
  qbraid_cli/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
7
7
  qbraid_cli/account/__init__.py,sha256=smlpUcVkM3QEbJG0norGM7i71XBJlUGQYByswTfPnmg,181
8
- qbraid_cli/account/app.py,sha256=ggvft1Q4d5IIv0lf3adbIkcz0nIYiEriJu91SPyo5_4,1821
8
+ qbraid_cli/account/app.py,sha256=1UogauwgX0Hnr7H6cBV2Qv-lT6aRpRLAimCyLi0afGI,1843
9
9
  qbraid_cli/admin/__init__.py,sha256=qcWD5mQEUCtr49mrUpZmk7eGDe0L_Gtc8RwZmzIXSwo,175
10
- qbraid_cli/admin/app.py,sha256=NGisg2aouk8qK2oFogwblFTBK0vvTiL_zJYjeanC4x0,1576
10
+ qbraid_cli/admin/app.py,sha256=V2mgts3x3Vgsx_nbRwVrKF9PgZ9SuA10b8O9cjiphYE,1607
11
11
  qbraid_cli/admin/headers.py,sha256=WqpRYp81CQcF5-Afumo_qQrf-5XCfbndBJ6I7vOADKE,7133
12
12
  qbraid_cli/admin/validation.py,sha256=U_8RFWBwRUNPe6LdjNpl-Yz8Br57PLWMoPbpR-jBS-M,979
13
- qbraid_cli/chat/__init__.py,sha256=0He19OpSsEoyCGxZLMTWey1fKAAls5mHTCFlO5-gl2Y,172
14
- qbraid_cli/chat/app.py,sha256=QQqwCi3dk-_i5XTe8labQFPN5xttFKoLf7oWIrhlmyQ,2913
13
+ qbraid_cli/chat/__init__.py,sha256=NO41vndEdfr0vDynNcmHFh-nhzWjnWqGm4M9parikck,258
14
+ qbraid_cli/chat/app.py,sha256=-YqCLGDh4ezF149xB3dfuUAQotKAklZwYp0BL3HhA90,2256
15
15
  qbraid_cli/configure/__init__.py,sha256=YaJ74Ztz2vl3eYp8_jVBucWkXscxz7EZEIzr70OfuOM,187
16
16
  qbraid_cli/configure/actions.py,sha256=-BduRmnxvf8JMNonb6VWFtdlHlcHPOPz3Bj5g8kfmBU,3197
17
17
  qbraid_cli/configure/app.py,sha256=1uRe2lkUA4TtYb5b4mbD4LH-cKCbsZGT3Wfk7fpNzX0,2414
18
18
  qbraid_cli/devices/__init__.py,sha256=hiScO-px6jCL5cJj5Hbty55EUfNejTO4bmqUZuS3aqc,181
19
- qbraid_cli/devices/app.py,sha256=K5NBtXgwncn8x0lzZlXuagb_jWCKXBBdhFMm96eDJBM,2521
19
+ qbraid_cli/devices/app.py,sha256=q8AQ8o05JXODsaFR_16_S3UtLWPzwC2qi0bVw2h7RJ8,2543
20
20
  qbraid_cli/devices/validation.py,sha256=YhShyUufgrKnx2XjXOXF-PqFJYklJT9CgeqIwKcNam4,809
21
21
  qbraid_cli/envs/__init__.py,sha256=1-cMvrATsddYxcetPJWxq6bEOqJWMktGdhoZ4qm8euA,172
22
22
  qbraid_cli/envs/activate.py,sha256=VpvVYSfQDlcmlNWJOgkLIQ2p8YXPPLG8Jbl5t8GHUDw,2140
23
- qbraid_cli/envs/app.py,sha256=2iJ0Ik39zf_5Kj0hCvkykAdU8ESdUoLodw1-tpcKXyE,8447
23
+ qbraid_cli/envs/app.py,sha256=ug1myjrtYY0ukeT0mCJBFiRmnWqaWJCY-wclHS9TvMc,8469
24
24
  qbraid_cli/envs/create.py,sha256=xudzkLCNegY34zkXN_Vfl_0zVzg_tW83LcVx9quoWfU,988
25
25
  qbraid_cli/envs/data_handling.py,sha256=Ibnp2yJoUDpivb_sNqi0suYgJZNat_LmM6Ya0Ovez5s,1288
26
+ qbraid_cli/files/__init__.py,sha256=3_yhgFoNcviEtS6B75uJBrfFFUjsrMcccCNEntJ54xU,175
27
+ qbraid_cli/files/app.py,sha256=PoJAyfd1Y2OJm9wKNjbnzbouVOmOnrYeLWforOSFwgA,3182
26
28
  qbraid_cli/jobs/__init__.py,sha256=qVLRHYIzP4XHpx_QWP_vCzd3LsCscCORaEx-Vcbx29U,172
27
- qbraid_cli/jobs/app.py,sha256=x4mF8KfP9FWyYKZLG5MkkHFQErgYO4VoYEQbtq7q_-Q,4916
29
+ qbraid_cli/jobs/app.py,sha256=LnrxALu7OWSUg1FD6FvlGsILdoH46Y-ra12eiSfiMlE,4938
28
30
  qbraid_cli/jobs/toggle_braket.py,sha256=3AEu-Z5q4avduB-fJMyMTVTuyZXuA8m-hnvi325wIv4,7444
29
31
  qbraid_cli/jobs/validation.py,sha256=KlkqVH1-vlNCHSayEpxzyXU86_TMN5prGfMFEoyBsFs,2971
30
32
  qbraid_cli/kernels/__init__.py,sha256=jORS9vV17s5laQyq8gSVB18EPBImgEIbMZ1wKC094DA,181
31
- qbraid_cli/kernels/app.py,sha256=Sl57U1JXDKWoeMQDSXJRHlKzDYSdKIbV7tSytZXo5PM,2926
33
+ qbraid_cli/kernels/app.py,sha256=n-iyWJHy7_ML6qk4pp-v_rQkGA7WfnZMG8gyiCFGO1c,2948
32
34
  qbraid_cli/pip/__init__.py,sha256=tJtU0rxn-ODogNh5Y4pp_BgDQXMN-3JY1QGj0OZHwjQ,169
33
- qbraid_cli/pip/app.py,sha256=wzvjX5NL37XIFtZ5KvTZ-nj9xwFKt8QLYZ_vGvk3tXo,1440
35
+ qbraid_cli/pip/app.py,sha256=jkk-djductrDOJIRYfHK_7WDJ12f0zOT3MMkiZp97oM,1365
34
36
  qbraid_cli/pip/hooks.py,sha256=jkIeev3cOd-cmaoJSdSqbmhTYCs6z1we84FMqa3ZoZw,2124
35
- qbraid_cli-0.9.1.dist-info/LICENSE,sha256=P1gi-ofB8lmkRt_mxDoJpcgQq9Ckq9WhRAS1oYk-G1s,2506
36
- qbraid_cli-0.9.1.dist-info/METADATA,sha256=L2lfHPXbMA5GIsg3b94GxeooGVA502ZsJknonMNJBg0,6785
37
- qbraid_cli-0.9.1.dist-info/WHEEL,sha256=PZUExdf71Ui_so67QXpySuHtCi3-J3wvF4ORK6k_S8U,91
38
- qbraid_cli-0.9.1.dist-info/entry_points.txt,sha256=c5ZJ7NjbxhDqMpou9q5F03_b_KG34HzFDijIDmEIwgQ,47
39
- qbraid_cli-0.9.1.dist-info/top_level.txt,sha256=LTYJgeYSCHo9Il8vZu0yIPuGdGyNaIw6iRy6BeoZo8o,11
40
- qbraid_cli-0.9.1.dist-info/RECORD,,
37
+ qbraid_cli-0.9.3.dist-info/LICENSE,sha256=P1gi-ofB8lmkRt_mxDoJpcgQq9Ckq9WhRAS1oYk-G1s,2506
38
+ qbraid_cli-0.9.3.dist-info/METADATA,sha256=lL-5ZjFW1IHdCRUtXmJoAxxlsf8vNSoLboFmMAfwErc,6806
39
+ qbraid_cli-0.9.3.dist-info/WHEEL,sha256=PZUExdf71Ui_so67QXpySuHtCi3-J3wvF4ORK6k_S8U,91
40
+ qbraid_cli-0.9.3.dist-info/entry_points.txt,sha256=c5ZJ7NjbxhDqMpou9q5F03_b_KG34HzFDijIDmEIwgQ,47
41
+ qbraid_cli-0.9.3.dist-info/top_level.txt,sha256=LTYJgeYSCHo9Il8vZu0yIPuGdGyNaIw6iRy6BeoZo8o,11
42
+ qbraid_cli-0.9.3.dist-info/RECORD,,