# Copyright 2024 The Kubeflow Authors## 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."""Pipeline-level config options."""importrefromtypingimportAny,Dict,Optional# Workspace size validation regex_SIZE_REGEX=re.compile(r'^(?:(?:0|[1-9]\d*)(?:\.\d+)?)(?:Ki|Mi|Gi|Ti|Pi|Ei|K|M|G|T|P|E)?$')def_is_valid_workspace_size(value:str)->bool:"""Returns True if size is a valid Kubernetes resource quantity string."""ifnotisinstance(value,str):returnFalsesize=value.strip()return_SIZE_REGEX.match(size)isnotNone
[docs]classKubernetesWorkspaceConfig:"""Configuration for Kubernetes-specific workspace settings. Use this to override the default PersistentVolumeClaim (PVC) configuration used when running pipelines on a Kubernetes cluster. Attributes: pvcSpecPatch: A dictionary of fields to patch onto the default PVC spec (e.g., 'storageClassName', 'accessModes'). """def__init__(self,pvcSpecPatch:Optional[Dict[str,Any]]=None):self.pvcSpecPatch=pvcSpecPatchor{}
[docs]classWorkspaceConfig:"""Configuration for a shared workspace that persists during the pipeline run. Attributes: size (str): The size of the workspace (e.g., '250Gi'). This is a required field. See https://kubernetes.io/docs/reference/kubernetes-api/common-definitions/quantity/ for valid quantity formats. kubernetes: (Optional) Kubernetes-specific configuration for the underlying PVC. """def__init__(self,size:str,kubernetes:Optional[KubernetesWorkspaceConfig]=None):self.size=sizeself.kubernetes=kubernetesorKubernetesWorkspaceConfig()@propertydefsize(self)->str:returnself._size@size.setterdefsize(self,size:str)->None:ifnotsizeornotstr(size).strip():raiseValueError('Workspace size is required and cannot be empty')ifnot_is_valid_workspace_size(str(size)):raiseValueError(f'Workspace size "{size}" is invalid. Must be a valid Kubernetes resource quantity ''(e.g., "10Gi", "500Mi", "1Ti")')self._size=str(size).strip()