File: //lib/mysqlsh/lib/python3.8/site-packages/oci/data_integration/models/abstract_format_attribute.py
# coding: utf-8
# Copyright (c) 2016, 2025, Oracle and/or its affiliates. All rights reserved.
# This software is dual-licensed to you under the Universal Permissive License (UPL) 1.0 as shown at https://oss.oracle.com/licenses/upl or Apache License 2.0 as shown at http://www.apache.org/licenses/LICENSE-2.0. You may choose either license.
# NOTE: This class is auto generated by OracleSDKGenerator. DO NOT EDIT. API Version: 20200430
from oci.util import formatted_flat_dict, NONE_SENTINEL, value_allowed_none_or_none_sentinel # noqa: F401
from oci.decorators import init_model_state_from_kwargs
@init_model_state_from_kwargs
class AbstractFormatAttribute(object):
"""
The abstract format attribute.
"""
#: A constant which can be used with the model_type property of a AbstractFormatAttribute.
#: This constant has a value of "JSON_FORMAT"
MODEL_TYPE_JSON_FORMAT = "JSON_FORMAT"
#: A constant which can be used with the model_type property of a AbstractFormatAttribute.
#: This constant has a value of "CSV_FORMAT"
MODEL_TYPE_CSV_FORMAT = "CSV_FORMAT"
#: A constant which can be used with the model_type property of a AbstractFormatAttribute.
#: This constant has a value of "AVRO_FORMAT"
MODEL_TYPE_AVRO_FORMAT = "AVRO_FORMAT"
def __init__(self, **kwargs):
"""
Initializes a new AbstractFormatAttribute object with values from keyword arguments. This class has the following subclasses and if you are using this class as input
to a service operations then you should favor using a subclass over the base class:
* :class:`~oci.data_integration.models.AvroFormatAttribute`
* :class:`~oci.data_integration.models.JsonFormatAttribute`
* :class:`~oci.data_integration.models.CsvFormatAttribute`
* :class:`~oci.data_integration.models.ParquetFormatAttribute`
The following keyword arguments are supported (corresponding to the getters/setters of this class):
:param model_type:
The value to assign to the model_type property of this AbstractFormatAttribute.
Allowed values for this property are: "JSON_FORMAT", "CSV_FORMAT", "AVRO_FORMAT", 'UNKNOWN_ENUM_VALUE'.
Any unrecognized values returned by a service will be mapped to 'UNKNOWN_ENUM_VALUE'.
:type model_type: str
:param is_file_pattern:
The value to assign to the is_file_pattern property of this AbstractFormatAttribute.
:type is_file_pattern: bool
"""
self.swagger_types = {
'model_type': 'str',
'is_file_pattern': 'bool'
}
self.attribute_map = {
'model_type': 'modelType',
'is_file_pattern': 'isFilePattern'
}
self._model_type = None
self._is_file_pattern = None
@staticmethod
def get_subtype(object_dictionary):
"""
Given the hash representation of a subtype of this class,
use the info in the hash to return the class of the subtype.
"""
type = object_dictionary['modelType']
if type == 'AVRO_FORMAT':
return 'AvroFormatAttribute'
if type == 'JSON_FORMAT':
return 'JsonFormatAttribute'
if type == 'CSV_FORMAT':
return 'CsvFormatAttribute'
if type == 'PARQUET_FORMAT':
return 'ParquetFormatAttribute'
else:
return 'AbstractFormatAttribute'
@property
def model_type(self):
"""
**[Required]** Gets the model_type of this AbstractFormatAttribute.
The type of the format attribute.
Allowed values for this property are: "JSON_FORMAT", "CSV_FORMAT", "AVRO_FORMAT", 'UNKNOWN_ENUM_VALUE'.
Any unrecognized values returned by a service will be mapped to 'UNKNOWN_ENUM_VALUE'.
:return: The model_type of this AbstractFormatAttribute.
:rtype: str
"""
return self._model_type
@model_type.setter
def model_type(self, model_type):
"""
Sets the model_type of this AbstractFormatAttribute.
The type of the format attribute.
:param model_type: The model_type of this AbstractFormatAttribute.
:type: str
"""
allowed_values = ["JSON_FORMAT", "CSV_FORMAT", "AVRO_FORMAT"]
if not value_allowed_none_or_none_sentinel(model_type, allowed_values):
model_type = 'UNKNOWN_ENUM_VALUE'
self._model_type = model_type
@property
def is_file_pattern(self):
"""
Gets the is_file_pattern of this AbstractFormatAttribute.
Defines whether a file pattern is supported.
:return: The is_file_pattern of this AbstractFormatAttribute.
:rtype: bool
"""
return self._is_file_pattern
@is_file_pattern.setter
def is_file_pattern(self, is_file_pattern):
"""
Sets the is_file_pattern of this AbstractFormatAttribute.
Defines whether a file pattern is supported.
:param is_file_pattern: The is_file_pattern of this AbstractFormatAttribute.
:type: bool
"""
self._is_file_pattern = is_file_pattern
def __repr__(self):
return formatted_flat_dict(self)
def __eq__(self, other):
if other is None:
return False
return self.__dict__ == other.__dict__
def __ne__(self, other):
return not self == other