File: //proc/self/root/lib/mysqlsh/lib/python3.8/site-packages/oci/os_management_hub/models/erratum.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: 20220901
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 Erratum(object):
"""
An object that defines an erratum..
"""
#: A constant which can be used with the classification_type property of a Erratum.
#: This constant has a value of "SECURITY"
CLASSIFICATION_TYPE_SECURITY = "SECURITY"
#: A constant which can be used with the classification_type property of a Erratum.
#: This constant has a value of "BUGFIX"
CLASSIFICATION_TYPE_BUGFIX = "BUGFIX"
#: A constant which can be used with the classification_type property of a Erratum.
#: This constant has a value of "ENHANCEMENT"
CLASSIFICATION_TYPE_ENHANCEMENT = "ENHANCEMENT"
#: A constant which can be used with the classification_type property of a Erratum.
#: This constant has a value of "OTHER"
CLASSIFICATION_TYPE_OTHER = "OTHER"
#: A constant which can be used with the advisory_type property of a Erratum.
#: This constant has a value of "SECURITY"
ADVISORY_TYPE_SECURITY = "SECURITY"
#: A constant which can be used with the advisory_type property of a Erratum.
#: This constant has a value of "BUGFIX"
ADVISORY_TYPE_BUGFIX = "BUGFIX"
#: A constant which can be used with the advisory_type property of a Erratum.
#: This constant has a value of "ENHANCEMENT"
ADVISORY_TYPE_ENHANCEMENT = "ENHANCEMENT"
#: A constant which can be used with the advisory_severity property of a Erratum.
#: This constant has a value of "LOW"
ADVISORY_SEVERITY_LOW = "LOW"
#: A constant which can be used with the advisory_severity property of a Erratum.
#: This constant has a value of "MODERATE"
ADVISORY_SEVERITY_MODERATE = "MODERATE"
#: A constant which can be used with the advisory_severity property of a Erratum.
#: This constant has a value of "IMPORTANT"
ADVISORY_SEVERITY_IMPORTANT = "IMPORTANT"
#: A constant which can be used with the advisory_severity property of a Erratum.
#: This constant has a value of "CRITICAL"
ADVISORY_SEVERITY_CRITICAL = "CRITICAL"
def __init__(self, **kwargs):
"""
Initializes a new Erratum object with values from keyword arguments.
The following keyword arguments are supported (corresponding to the getters/setters of this class):
:param name:
The value to assign to the name property of this Erratum.
:type name: str
:param synopsis:
The value to assign to the synopsis property of this Erratum.
:type synopsis: str
:param time_issued:
The value to assign to the time_issued property of this Erratum.
:type time_issued: datetime
:param description:
The value to assign to the description property of this Erratum.
:type description: str
:param time_updated:
The value to assign to the time_updated property of this Erratum.
:type time_updated: datetime
:param classification_type:
The value to assign to the classification_type property of this Erratum.
Allowed values for this property are: "SECURITY", "BUGFIX", "ENHANCEMENT", "OTHER", 'UNKNOWN_ENUM_VALUE'.
Any unrecognized values returned by a service will be mapped to 'UNKNOWN_ENUM_VALUE'.
:type classification_type: str
:param advisory_type:
The value to assign to the advisory_type property of this Erratum.
Allowed values for this property are: "SECURITY", "BUGFIX", "ENHANCEMENT", 'UNKNOWN_ENUM_VALUE'.
Any unrecognized values returned by a service will be mapped to 'UNKNOWN_ENUM_VALUE'.
:type advisory_type: str
:param _from:
The value to assign to the _from property of this Erratum.
:type _from: str
:param solution:
The value to assign to the solution property of this Erratum.
:type solution: str
:param references:
The value to assign to the references property of this Erratum.
:type references: str
:param related_cves:
The value to assign to the related_cves property of this Erratum.
:type related_cves: list[str]
:param repositories:
The value to assign to the repositories property of this Erratum.
:type repositories: list[str]
:param packages:
The value to assign to the packages property of this Erratum.
:type packages: list[oci.os_management_hub.models.SoftwarePackageSummary]
:param os_families:
The value to assign to the os_families property of this Erratum.
:type os_families: list[oci.os_management_hub.models.OsFamily]
:param advisory_severity:
The value to assign to the advisory_severity property of this Erratum.
Allowed values for this property are: "LOW", "MODERATE", "IMPORTANT", "CRITICAL", 'UNKNOWN_ENUM_VALUE'.
Any unrecognized values returned by a service will be mapped to 'UNKNOWN_ENUM_VALUE'.
:type advisory_severity: str
"""
self.swagger_types = {
'name': 'str',
'synopsis': 'str',
'time_issued': 'datetime',
'description': 'str',
'time_updated': 'datetime',
'classification_type': 'str',
'advisory_type': 'str',
'_from': 'str',
'solution': 'str',
'references': 'str',
'related_cves': 'list[str]',
'repositories': 'list[str]',
'packages': 'list[SoftwarePackageSummary]',
'os_families': 'list[OsFamily]',
'advisory_severity': 'str'
}
self.attribute_map = {
'name': 'name',
'synopsis': 'synopsis',
'time_issued': 'timeIssued',
'description': 'description',
'time_updated': 'timeUpdated',
'classification_type': 'classificationType',
'advisory_type': 'advisoryType',
'_from': 'from',
'solution': 'solution',
'references': 'references',
'related_cves': 'relatedCves',
'repositories': 'repositories',
'packages': 'packages',
'os_families': 'osFamilies',
'advisory_severity': 'advisorySeverity'
}
self._name = None
self._synopsis = None
self._time_issued = None
self._description = None
self._time_updated = None
self._classification_type = None
self._advisory_type = None
self.__from = None
self._solution = None
self._references = None
self._related_cves = None
self._repositories = None
self._packages = None
self._os_families = None
self._advisory_severity = None
@property
def name(self):
"""
**[Required]** Gets the name of this Erratum.
Advisory name.
:return: The name of this Erratum.
:rtype: str
"""
return self._name
@name.setter
def name(self, name):
"""
Sets the name of this Erratum.
Advisory name.
:param name: The name of this Erratum.
:type: str
"""
self._name = name
@property
def synopsis(self):
"""
Gets the synopsis of this Erratum.
Summary description of the erratum.
:return: The synopsis of this Erratum.
:rtype: str
"""
return self._synopsis
@synopsis.setter
def synopsis(self, synopsis):
"""
Sets the synopsis of this Erratum.
Summary description of the erratum.
:param synopsis: The synopsis of this Erratum.
:type: str
"""
self._synopsis = synopsis
@property
def time_issued(self):
"""
Gets the time_issued of this Erratum.
The date and time the erratum was issued (in `RFC 3339`__ format).
__ https://tools.ietf.org/rfc/rfc3339
:return: The time_issued of this Erratum.
:rtype: datetime
"""
return self._time_issued
@time_issued.setter
def time_issued(self, time_issued):
"""
Sets the time_issued of this Erratum.
The date and time the erratum was issued (in `RFC 3339`__ format).
__ https://tools.ietf.org/rfc/rfc3339
:param time_issued: The time_issued of this Erratum.
:type: datetime
"""
self._time_issued = time_issued
@property
def description(self):
"""
Gets the description of this Erratum.
Details describing the erratum.
:return: The description of this Erratum.
:rtype: str
"""
return self._description
@description.setter
def description(self, description):
"""
Sets the description of this Erratum.
Details describing the erratum.
:param description: The description of this Erratum.
:type: str
"""
self._description = description
@property
def time_updated(self):
"""
Gets the time_updated of this Erratum.
The date and time the erratum was updated (in `RFC 3339`__ format).
__ https://tools.ietf.org/rfc/rfc3339
:return: The time_updated of this Erratum.
:rtype: datetime
"""
return self._time_updated
@time_updated.setter
def time_updated(self, time_updated):
"""
Sets the time_updated of this Erratum.
The date and time the erratum was updated (in `RFC 3339`__ format).
__ https://tools.ietf.org/rfc/rfc3339
:param time_updated: The time_updated of this Erratum.
:type: datetime
"""
self._time_updated = time_updated
@property
def classification_type(self):
"""
Gets the classification_type of this Erratum.
Type of the erratum. This property is deprecated and it will be removed in a future API release. Please refer to the advisoryType property instead.
Allowed values for this property are: "SECURITY", "BUGFIX", "ENHANCEMENT", "OTHER", 'UNKNOWN_ENUM_VALUE'.
Any unrecognized values returned by a service will be mapped to 'UNKNOWN_ENUM_VALUE'.
:return: The classification_type of this Erratum.
:rtype: str
"""
return self._classification_type
@classification_type.setter
def classification_type(self, classification_type):
"""
Sets the classification_type of this Erratum.
Type of the erratum. This property is deprecated and it will be removed in a future API release. Please refer to the advisoryType property instead.
:param classification_type: The classification_type of this Erratum.
:type: str
"""
allowed_values = ["SECURITY", "BUGFIX", "ENHANCEMENT", "OTHER"]
if not value_allowed_none_or_none_sentinel(classification_type, allowed_values):
classification_type = 'UNKNOWN_ENUM_VALUE'
self._classification_type = classification_type
@property
def advisory_type(self):
"""
Gets the advisory_type of this Erratum.
The advisory type of the erratum.
Allowed values for this property are: "SECURITY", "BUGFIX", "ENHANCEMENT", 'UNKNOWN_ENUM_VALUE'.
Any unrecognized values returned by a service will be mapped to 'UNKNOWN_ENUM_VALUE'.
:return: The advisory_type of this Erratum.
:rtype: str
"""
return self._advisory_type
@advisory_type.setter
def advisory_type(self, advisory_type):
"""
Sets the advisory_type of this Erratum.
The advisory type of the erratum.
:param advisory_type: The advisory_type of this Erratum.
:type: str
"""
allowed_values = ["SECURITY", "BUGFIX", "ENHANCEMENT"]
if not value_allowed_none_or_none_sentinel(advisory_type, allowed_values):
advisory_type = 'UNKNOWN_ENUM_VALUE'
self._advisory_type = advisory_type
@property
def _from(self):
"""
Gets the _from of this Erratum.
Information specifying from where the erratum was release.
:return: The _from of this Erratum.
:rtype: str
"""
return self.__from
@_from.setter
def _from(self, _from):
"""
Sets the _from of this Erratum.
Information specifying from where the erratum was release.
:param _from: The _from of this Erratum.
:type: str
"""
self.__from = _from
@property
def solution(self):
"""
Gets the solution of this Erratum.
Information describing how the erratum can be resolved.
:return: The solution of this Erratum.
:rtype: str
"""
return self._solution
@solution.setter
def solution(self, solution):
"""
Sets the solution of this Erratum.
Information describing how the erratum can be resolved.
:param solution: The solution of this Erratum.
:type: str
"""
self._solution = solution
@property
def references(self):
"""
Gets the references of this Erratum.
Information describing how to find more information about. the erratum.
:return: The references of this Erratum.
:rtype: str
"""
return self._references
@references.setter
def references(self, references):
"""
Sets the references of this Erratum.
Information describing how to find more information about. the erratum.
:param references: The references of this Erratum.
:type: str
"""
self._references = references
@property
def related_cves(self):
"""
Gets the related_cves of this Erratum.
List of CVEs applicable to this erratum.
:return: The related_cves of this Erratum.
:rtype: list[str]
"""
return self._related_cves
@related_cves.setter
def related_cves(self, related_cves):
"""
Sets the related_cves of this Erratum.
List of CVEs applicable to this erratum.
:param related_cves: The related_cves of this Erratum.
:type: list[str]
"""
self._related_cves = related_cves
@property
def repositories(self):
"""
Gets the repositories of this Erratum.
List of repository identifiers.
:return: The repositories of this Erratum.
:rtype: list[str]
"""
return self._repositories
@repositories.setter
def repositories(self, repositories):
"""
Sets the repositories of this Erratum.
List of repository identifiers.
:param repositories: The repositories of this Erratum.
:type: list[str]
"""
self._repositories = repositories
@property
def packages(self):
"""
Gets the packages of this Erratum.
List of packages affected by this erratum.
:return: The packages of this Erratum.
:rtype: list[oci.os_management_hub.models.SoftwarePackageSummary]
"""
return self._packages
@packages.setter
def packages(self, packages):
"""
Sets the packages of this Erratum.
List of packages affected by this erratum.
:param packages: The packages of this Erratum.
:type: list[oci.os_management_hub.models.SoftwarePackageSummary]
"""
self._packages = packages
@property
def os_families(self):
"""
Gets the os_families of this Erratum.
List of affected OS families.
:return: The os_families of this Erratum.
:rtype: list[oci.os_management_hub.models.OsFamily]
"""
return self._os_families
@os_families.setter
def os_families(self, os_families):
"""
Sets the os_families of this Erratum.
List of affected OS families.
:param os_families: The os_families of this Erratum.
:type: list[oci.os_management_hub.models.OsFamily]
"""
self._os_families = os_families
@property
def advisory_severity(self):
"""
Gets the advisory_severity of this Erratum.
The severity for a security advisory, otherwise, null.
Allowed values for this property are: "LOW", "MODERATE", "IMPORTANT", "CRITICAL", 'UNKNOWN_ENUM_VALUE'.
Any unrecognized values returned by a service will be mapped to 'UNKNOWN_ENUM_VALUE'.
:return: The advisory_severity of this Erratum.
:rtype: str
"""
return self._advisory_severity
@advisory_severity.setter
def advisory_severity(self, advisory_severity):
"""
Sets the advisory_severity of this Erratum.
The severity for a security advisory, otherwise, null.
:param advisory_severity: The advisory_severity of this Erratum.
:type: str
"""
allowed_values = ["LOW", "MODERATE", "IMPORTANT", "CRITICAL"]
if not value_allowed_none_or_none_sentinel(advisory_severity, allowed_values):
advisory_severity = 'UNKNOWN_ENUM_VALUE'
self._advisory_severity = advisory_severity
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