Source code for airflow.providers.cncf.kubernetes.backcompat.volume

# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements.  See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership.  The ASF licenses this file
# to you 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.
"""This module is deprecated. Please use :mod:`kubernetes.client.models.V1Volume`."""

import warnings

from kubernetes.client import models as k8s

warnings.warn(
    "This module is deprecated. Please use `kubernetes.client.models.V1Volume`.",
    DeprecationWarning,
    stacklevel=2,
)


[docs]class Volume: """Backward compatible Volume""" def __init__(self, name, configs): """Adds Kubernetes Volume to pod. allows pod to access features like ConfigMaps and Persistent Volumes :param name: the name of the volume mount :type name: str :param configs: dictionary of any features needed for volume. We purposely keep this vague since there are multiple volume types with changing configs. :type configs: dict """ self.name = name self.configs = configs
[docs] def to_k8s_client_obj(self) -> k8s.V1Volume: """ Converts to k8s object. :return: Volume Mount k8s object """ resp = k8s.V1Volume(name=self.name) for k, v in self.configs.items(): snake_key = Volume._convert_to_snake_case(k) if hasattr(resp, snake_key): setattr(resp, snake_key, v) else: raise AttributeError(f"V1Volume does not have attribute {k}") return resp
# source: https://www.geeksforgeeks.org/python-program-to-convert-camel-case-string-to-snake-case/ @staticmethod
[docs] def _convert_to_snake_case(input_string): return ''.join('_' + i.lower() if i.isupper() else i for i in input_string).lstrip('_')

Was this entry helpful?