Files
evo-ai/.venv/lib/python3.10/site-packages/vertex_ray/dashboard_sdk.py
2025-04-25 15:30:54 -03:00

80 lines
2.8 KiB
Python

# -*- coding: utf-8 -*-
# Copyright 2025 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
"""Utility to interact with Ray-on-Vertex dashboard."""
from ray.dashboard.modules import dashboard_sdk as oss_dashboard_sdk
from .util import _gapic_utils
from .util import _validation_utils
def get_job_submission_client_cluster_info(
address: str, *args, **kwargs
) -> oss_dashboard_sdk.ClusterInfo:
"""A vertex_ray implementation of get_job_submission_client_cluster_info().
Implements
https://github.com/ray-project/ray/blob/ray-2.42.0/python/ray/dashboard/modules/dashboard_sdk.py#L84
This will be called in from Ray Job API Python client.
Args:
address: Address without the module prefix `vertex_ray` but otherwise
the same format as passed to ray.init(address="vertex_ray://...").
*args: Remainder of positional args that might be passed down from
the framework.
**kwargs: Remainder of keyword args that might be passed down from
the framework.
Returns:
An instance of ClusterInfo that contains address, cookies and
metadata for SubmissionClient to use.
Raises:
RuntimeError if head_address is None.
"""
if _validation_utils.valid_dashboard_address(address):
dashboard_address = address
else:
address = _validation_utils.maybe_reconstruct_resource_name(address)
_validation_utils.valid_resource_name(address)
resource_name = address
response = _gapic_utils.get_persistent_resource(resource_name)
dashboard_address = response.resource_runtime.access_uris.get(
"RAY_DASHBOARD_URI", None
)
if dashboard_address is None:
raise RuntimeError(
"[Ray on Vertex AI]: Unable to obtain a response from the backend."
)
# If passing the dashboard uri, programmatically get headers
bearer_token = _validation_utils.get_bearer_token()
if kwargs.get("headers", None) is None:
kwargs["headers"] = {
"Content-Type": "application/json",
"Authorization": "Bearer {}".format(bearer_token),
}
return oss_dashboard_sdk.get_job_submission_client_cluster_info(
address=dashboard_address,
_use_tls=True,
*args,
**kwargs,
)