Source code for mlflow.server.auth.client

from mlflow.server.auth.entities import ExperimentPermission, RegisteredModelPermission, User
from mlflow.server.auth.routes import (
    CREATE_EXPERIMENT_PERMISSION,
    CREATE_REGISTERED_MODEL_PERMISSION,
    CREATE_USER,
    DELETE_EXPERIMENT_PERMISSION,
    DELETE_REGISTERED_MODEL_PERMISSION,
    DELETE_USER,
    GET_EXPERIMENT_PERMISSION,
    GET_REGISTERED_MODEL_PERMISSION,
    GET_USER,
    UPDATE_EXPERIMENT_PERMISSION,
    UPDATE_REGISTERED_MODEL_PERMISSION,
    UPDATE_USER_ADMIN,
    UPDATE_USER_PASSWORD,
)
from mlflow.tracking._tracking_service.utils import _get_default_host_creds
from mlflow.utils.rest_utils import http_request_safe


[docs]class AuthServiceClient: """ Client of an MLflow Tracking Server that enabled the default basic authentication plugin. It is recommended to use :py:func:`mlflow.server.get_app_client()` to instantiate this class. See https://mlflow.org/docs/latest/auth.html for more information. """ def __init__(self, tracking_uri: str): """ :param tracking_uri: Address of local or remote tracking server. """ self.tracking_uri = tracking_uri def _request(self, endpoint, method, **kwargs): host_creds = _get_default_host_creds(self.tracking_uri) resp = http_request_safe(host_creds, endpoint, method, **kwargs) return resp.json()
[docs] def create_user(self, username: str, password: str): """ Create a new user. :param username: The username. :param password: The user's password. Must not be empty string. :return: A single :py:class:`mlflow.server.auth.entities.User` object. Raises ``RestException`` if the username is already taken. .. code-block:: python :caption: Example from mlflow.server.auth.client import AuthServiceClient client = AuthServiceClient("tracking_uri") user = client.create_user("newuser", "newpassword") print(f"user_id: {user.id}") print(f"username: {user.username}") print(f"password_hash: {user.password_hash}") print(f"is_admin: {user.is_admin}") .. code-block:: text :caption: Output user_id: 3 username: newuser password_hash: REDACTED is_admin: False """ resp = self._request( CREATE_USER, "POST", json={"username": username, "password": password}, ) return User.from_json(resp["user"])
[docs] def get_user(self, username: str): """ Get a user with a specific username. :param username: The username. :return: A single :py:class:`mlflow.server.auth.entities.User` object. Raises ``RestException`` if the user does not exist. .. code-block:: bash :caption: Example export MLFLOW_TRACKING_USERNAME=admin export MLFLOW_TRACKING_PASSWORD=password .. code-block:: python from mlflow.server.auth.client import AuthServiceClient client = AuthServiceClient("tracking_uri") client.create_user("newuser", "newpassword") user = client.get_user("newuser") print(f"user_id: {user.id}") print(f"username: {user.username}") print(f"password_hash: {user.password_hash}") print(f"is_admin: {user.is_admin}") .. code-block:: text :caption: Output user_id: 3 username: newuser password_hash: REDACTED is_admin: False """ resp = self._request( GET_USER, "GET", params={"username": username}, ) return User.from_json(resp["user"])
[docs] def update_user_password(self, username: str, password: str): """ Update the password of a specific user. :param username: The username. :param password: The new password. :return: None. Raises ``RestException`` if the user does not exist. .. code-block:: bash :caption: Example export MLFLOW_TRACKING_USERNAME=admin export MLFLOW_TRACKING_PASSWORD=password .. code-block:: python from mlflow.server.auth.client import AuthServiceClient client = AuthServiceClient("tracking_uri") client.create_user("newuser", "newpassword") client.update_user_password("newuser", "anotherpassword") """ self._request( UPDATE_USER_PASSWORD, "PATCH", json={"username": username, "password": password}, )
[docs] def update_user_admin(self, username: str, is_admin: bool): """ Update the admin status of a specific user. :param username: The username. :param is_admin: The new admin status. :return: None. Raises ``RestException`` if the user does not exist. .. code-block:: bash :caption: Example export MLFLOW_TRACKING_USERNAME=admin export MLFLOW_TRACKING_PASSWORD=password .. code-block:: python from mlflow.server.auth.client import AuthServiceClient client = AuthServiceClient("tracking_uri") client.create_user("newuser", "newpassword") client.update_user_admin("newuser", True) """ self._request( UPDATE_USER_ADMIN, "PATCH", json={"username": username, "is_admin": is_admin}, )
[docs] def delete_user(self, username: str): """ Delete a specific user. :param username: The username. :return: None. Raises ``RestException`` if the user does not exist. .. code-block:: bash :caption: Example export MLFLOW_TRACKING_USERNAME=admin export MLFLOW_TRACKING_PASSWORD=password .. code-block:: python from mlflow.server.auth.client import AuthServiceClient client = AuthServiceClient("tracking_uri") client.create_user("newuser", "newpassword") client.delete_user("newuser") """ self._request( DELETE_USER, "DELETE", json={"username": username}, )
[docs] def create_experiment_permission(self, experiment_id: str, username: str, permission: str): """ Create a permission on an experiment for a user. :param experiment_id: The id of the experiment. :param username: The username. :param permission: Permission to grant. Must be one of "READ", "EDIT", "MANAGE" and "NO_PERMISSIONS". :return: A single :py:class:`mlflow.server.auth.entities.ExperimentPermission` object. Raises ``RestException`` if the user does not exist, or a permission already exists for this experiment user pair, or if the permission is invalid. Does not require ``experiment_id`` to be an existing experiment. .. code-block:: bash :caption: Example export MLFLOW_TRACKING_USERNAME=admin export MLFLOW_TRACKING_PASSWORD=password .. code-block:: python from mlflow.server.auth.client import AuthServiceClient client = AuthServiceClient("tracking_uri") client.create_user("newuser", "newpassword") ep = client.create_experiment_permission("myexperiment", "newuser", "READ") print(f"experiment_id: {ep.experiment_id}") print(f"user_id: {ep.user_id}") print(f"permission: {ep.permission}") .. code-block:: text :caption: Output experiment_id: myexperiment user_id: 3 permission: READ """ resp = self._request( CREATE_EXPERIMENT_PERMISSION, "POST", json={"experiment_id": experiment_id, "username": username, "permission": permission}, ) return ExperimentPermission.from_json(resp["experiment_permission"])
[docs] def get_experiment_permission(self, experiment_id: str, username: str): """ Get an experiment permission for a user. :param experiment_id: The id of the experiment. :param username: The username. :return: A single :py:class:`mlflow.server.auth.entities.ExperimentPermission` object. Raises ``RestException`` if the user does not exist, or no permission exists for this experiment user pair. Note that the default permission will still be effective even if no permission exists. .. code-block:: bash :caption: Example export MLFLOW_TRACKING_USERNAME=admin export MLFLOW_TRACKING_PASSWORD=password .. code-block:: python from mlflow.server.auth.client import AuthServiceClient client = AuthServiceClient("tracking_uri") client.create_user("newuser", "newpassword") client.create_experiment_permission("myexperiment", "newuser", "READ") ep = client.get_experiment_permission("myexperiment", "newuser") print(f"experiment_id: {ep.experiment_id}") print(f"user_id: {ep.user_id}") print(f"permission: {ep.permission}") .. code-block:: text :caption: Output experiment_id: myexperiment user_id: 3 permission: READ """ resp = self._request( GET_EXPERIMENT_PERMISSION, "GET", params={"experiment_id": experiment_id, "username": username}, ) return ExperimentPermission.from_json(resp["experiment_permission"])
[docs] def update_experiment_permission(self, experiment_id: str, username: str, permission: str): """ Update an existing experiment permission for a user. :param experiment_id: The id of the experiment. :param username: The username. :param permission: New permission to grant. Must be one of "READ", "EDIT", "MANAGE" and "NO_PERMISSIONS". :return: None. Raises ``RestException`` if the user does not exist, or no permission exists for this experiment user pair, or if the permission is invalid. .. code-block:: bash :caption: Example export MLFLOW_TRACKING_USERNAME=admin export MLFLOW_TRACKING_PASSWORD=password .. code-block:: python from mlflow.server.auth.client import AuthServiceClient client = AuthServiceClient("tracking_uri") client.create_user("newuser", "newpassword") client.create_experiment_permission("myexperiment", "newuser", "READ") client.update_experiment_permission("myexperiment", "newuser", "EDIT") """ self._request( UPDATE_EXPERIMENT_PERMISSION, "PATCH", json={"experiment_id": experiment_id, "username": username, "permission": permission}, )
[docs] def delete_experiment_permission(self, experiment_id: str, username: str): """ Delete an existing experiment permission for a user. :param experiment_id: The id of the experiment. :param username: The username. :return: None. Raises ``RestException`` if the user does not exist, or no permission exists for this experiment user pair, or if the permission is invalid. Note that the default permission will still be effective even after the permission has been deleted. .. code-block:: bash :caption: Example export MLFLOW_TRACKING_USERNAME=admin export MLFLOW_TRACKING_PASSWORD=password .. code-block:: python from mlflow.server.auth.client import AuthServiceClient client = AuthServiceClient("tracking_uri") client.create_user("newuser", "newpassword") client.create_experiment_permission("myexperiment", "newuser", "READ") client.delete_experiment_permission("myexperiment", "newuser") """ self._request( DELETE_EXPERIMENT_PERMISSION, "DELETE", json={"experiment_id": experiment_id, "username": username}, )
[docs] def create_registered_model_permission(self, name: str, username: str, permission: str): """ Create a permission on an registered model for a user. :param name: The name of the registered model. :param username: The username. :param permission: Permission to grant. Must be one of "READ", "EDIT", "MANAGE" and "NO_PERMISSIONS". :return: A single :py:class:`mlflow.server.auth.entities.RegisteredModelPermission` object. Raises ``RestException`` if the user does not exist, or a permission already exists for this registered model user pair, or if the permission is invalid. Does not require ``name`` to be an existing registered model. .. code-block:: bash :caption: Example export MLFLOW_TRACKING_USERNAME=admin export MLFLOW_TRACKING_PASSWORD=password .. code-block:: python from mlflow.server.auth.client import AuthServiceClient client = AuthServiceClient("tracking_uri") client.create_user("newuser", "newpassword") rmp = client.create_registered_model_permission("myregisteredmodel", "newuser", "READ") print(f"name: {rmp.name}") print(f"user_id: {rmp.user_id}") print(f"permission: {rmp.permission}") .. code-block:: text :caption: Output name: myregisteredmodel user_id: 3 permission: READ """ resp = self._request( CREATE_REGISTERED_MODEL_PERMISSION, "POST", json={"name": name, "username": username, "permission": permission}, ) return RegisteredModelPermission.from_json(resp["registered_model_permission"])
[docs] def get_registered_model_permission(self, name: str, username: str): """ Get an registered model permission for a user. :param name: The name of the registered model. :param username: The username. :return: A single :py:class:`mlflow.server.auth.entities.RegisteredModelPermission` object. Raises ``RestException`` if the user does not exist, or no permission exists for this registered model user pair. Note that the default permission will still be effective even if no permission exists. .. code-block:: bash :caption: Example export MLFLOW_TRACKING_USERNAME=admin export MLFLOW_TRACKING_PASSWORD=password .. code-block:: python from mlflow.server.auth.client import AuthServiceClient client = AuthServiceClient("tracking_uri") client.create_user("newuser", "newpassword") client.create_registered_model_permission("myregisteredmodel", "newuser", "READ") rmp = client.get_registered_model_permission("myregisteredmodel", "newuser") print(f"name: {rmp.name}") print(f"user_id: {rmp.user_id}") print(f"permission: {rmp.permission}") .. code-block:: text :caption: Output name: myregisteredmodel user_id: 3 permission: READ """ resp = self._request( GET_REGISTERED_MODEL_PERMISSION, "GET", params={"name": name, "username": username}, ) return RegisteredModelPermission.from_json(resp["registered_model_permission"])
[docs] def update_registered_model_permission(self, name: str, username: str, permission: str): """ Update an existing registered model permission for a user. :param name: The name of the registered model. :param username: The username. :param permission: New permission to grant. Must be one of "READ", "EDIT", "MANAGE" and "NO_PERMISSIONS". :return: None. Raises ``RestException`` if the user does not exist, or no permission exists for this registered model user pair, or if the permission is invalid. .. code-block:: bash :caption: Example export MLFLOW_TRACKING_USERNAME=admin export MLFLOW_TRACKING_PASSWORD=password .. code-block:: python from mlflow.server.auth.client import AuthServiceClient client = AuthServiceClient("tracking_uri") client.create_user("newuser", "newpassword") client.create_registered_model_permission("myregisteredmodel", "newuser", "READ") client.update_registered_model_permission("myregisteredmodel", "newuser", "EDIT") """ self._request( UPDATE_REGISTERED_MODEL_PERMISSION, "PATCH", json={"name": name, "username": username, "permission": permission}, )
[docs] def delete_registered_model_permission(self, name: str, username: str): """ Delete an existing registered model permission for a user. :param name: The name of the registered model. :param username: The username. :return: None. Raises ``RestException`` if the user does not exist, or no permission exists for this registered model user pair, or if the permission is invalid. Note that the default permission will still be effective even after the permission has been deleted. .. code-block:: bash :caption: Example export MLFLOW_TRACKING_USERNAME=admin export MLFLOW_TRACKING_PASSWORD=password .. code-block:: python from mlflow.server.auth.client import AuthServiceClient client = AuthServiceClient("tracking_uri") client.create_user("newuser", "newpassword") client.create_registered_model_permission("myregisteredmodel", "newuser", "READ") client.delete_registered_model_permission("myregisteredmodel", "newuser") """ self._request( DELETE_REGISTERED_MODEL_PERMISSION, "DELETE", json={"name": name, "username": username}, )