DrgRouteDistribution

class oci.core.models.DrgRouteDistribution(**kwargs)

Bases: object

A route distribution establishes how routes get imported into DRG route tables and exported through the DRG attachments.

A route distribution is a list of statements. Each statement consists of a set of matches, all of which must be True in order for the statement’s action to take place. Each statement determines which routes are propagated.

You can assign a route distribution as a route table’s import distribution. The statements in an import route distribution specify how how incoming route advertisements through a referenced attachment or all attachments of a certain type are inserted into the route table.

You can assign a route distribution as a DRG attachment’s export distribution unless the attachment has the type VCN. Exporting routes through a VCN attachment is unsupported. Export route distribution statements specify how routes in a DRG attachment’s assigned table are advertised out through the attachment. When a DRG is created, a route distribution is created with a single ACCEPT statement with match criteria MATCH_ALL. By default, all DRG attachments (except for those of type VCN), are assigned this distribution.

The two auto-generated DRG route tables (one as the default for VCN attachments, and the other for all other types of attachments) are each assigned an auto generated import route distribution. The default VCN table’s import distribution has a single statement with match criteria MATCH_ALL to import routes from each DRG attachment type. The other table’s import distribution has a statement to import routes from attachments with the VCN type.

The route distribution is always in the same compartment as the DRG.

Attributes

DISTRIBUTION_TYPE_EXPORT A constant which can be used with the distribution_type property of a DrgRouteDistribution.
DISTRIBUTION_TYPE_IMPORT A constant which can be used with the distribution_type property of a DrgRouteDistribution.
LIFECYCLE_STATE_AVAILABLE A constant which can be used with the lifecycle_state property of a DrgRouteDistribution.
LIFECYCLE_STATE_PROVISIONING A constant which can be used with the lifecycle_state property of a DrgRouteDistribution.
LIFECYCLE_STATE_TERMINATED A constant which can be used with the lifecycle_state property of a DrgRouteDistribution.
LIFECYCLE_STATE_TERMINATING A constant which can be used with the lifecycle_state property of a DrgRouteDistribution.
compartment_id [Required] Gets the compartment_id of this DrgRouteDistribution.
defined_tags Gets the defined_tags of this DrgRouteDistribution.
display_name Gets the display_name of this DrgRouteDistribution.
distribution_type [Required] Gets the distribution_type of this DrgRouteDistribution.
drg_id [Required] Gets the drg_id of this DrgRouteDistribution.
freeform_tags Gets the freeform_tags of this DrgRouteDistribution.
id [Required] Gets the id of this DrgRouteDistribution.
lifecycle_state [Required] Gets the lifecycle_state of this DrgRouteDistribution.
time_created [Required] Gets the time_created of this DrgRouteDistribution.

Methods

__init__(**kwargs) Initializes a new DrgRouteDistribution object with values from keyword arguments.
DISTRIBUTION_TYPE_EXPORT = 'EXPORT'

A constant which can be used with the distribution_type property of a DrgRouteDistribution. This constant has a value of “EXPORT”

DISTRIBUTION_TYPE_IMPORT = 'IMPORT'

A constant which can be used with the distribution_type property of a DrgRouteDistribution. This constant has a value of “IMPORT”

LIFECYCLE_STATE_AVAILABLE = 'AVAILABLE'

A constant which can be used with the lifecycle_state property of a DrgRouteDistribution. This constant has a value of “AVAILABLE”

LIFECYCLE_STATE_PROVISIONING = 'PROVISIONING'

A constant which can be used with the lifecycle_state property of a DrgRouteDistribution. This constant has a value of “PROVISIONING”

LIFECYCLE_STATE_TERMINATED = 'TERMINATED'

A constant which can be used with the lifecycle_state property of a DrgRouteDistribution. This constant has a value of “TERMINATED”

LIFECYCLE_STATE_TERMINATING = 'TERMINATING'

A constant which can be used with the lifecycle_state property of a DrgRouteDistribution. This constant has a value of “TERMINATING”

__init__(**kwargs)

Initializes a new DrgRouteDistribution object with values from keyword arguments. The following keyword arguments are supported (corresponding to the getters/setters of this class):

Parameters:
  • drg_id (str) – The value to assign to the drg_id property of this DrgRouteDistribution.
  • compartment_id (str) – The value to assign to the compartment_id property of this DrgRouteDistribution.
  • defined_tags (dict(str, dict(str, object))) – The value to assign to the defined_tags property of this DrgRouteDistribution.
  • display_name (str) – The value to assign to the display_name property of this DrgRouteDistribution.
  • freeform_tags (dict(str, str)) – The value to assign to the freeform_tags property of this DrgRouteDistribution.
  • id (str) – The value to assign to the id property of this DrgRouteDistribution.
  • lifecycle_state (str) – The value to assign to the lifecycle_state property of this DrgRouteDistribution. Allowed values for this property are: “PROVISIONING”, “AVAILABLE”, “TERMINATING”, “TERMINATED”, ‘UNKNOWN_ENUM_VALUE’. Any unrecognized values returned by a service will be mapped to ‘UNKNOWN_ENUM_VALUE’.
  • time_created (datetime) – The value to assign to the time_created property of this DrgRouteDistribution.
  • distribution_type (str) – The value to assign to the distribution_type property of this DrgRouteDistribution. Allowed values for this property are: “IMPORT”, “EXPORT”, ‘UNKNOWN_ENUM_VALUE’. Any unrecognized values returned by a service will be mapped to ‘UNKNOWN_ENUM_VALUE’.
compartment_id

[Required] Gets the compartment_id of this DrgRouteDistribution. The OCID of the compartment containing the route distribution.

Returns:The compartment_id of this DrgRouteDistribution.
Return type:str
defined_tags

Gets the defined_tags of this DrgRouteDistribution. Defined tags for this resource. Each key is predefined and scoped to a namespace. For more information, see Resource Tags.

Example: {“Operations”: {“CostCenter”: “42”}}

Returns:The defined_tags of this DrgRouteDistribution.
Return type:dict(str, dict(str, object))
display_name

Gets the display_name of this DrgRouteDistribution. A user-friendly name. Does not have to be unique, and it’s changeable. Avoid entering confidential information.

Returns:The display_name of this DrgRouteDistribution.
Return type:str
distribution_type

[Required] Gets the distribution_type of this DrgRouteDistribution. Whether this distribution defines how routes get imported into route tables or exported through DRG attachments.

Allowed values for this property are: “IMPORT”, “EXPORT”, ‘UNKNOWN_ENUM_VALUE’. Any unrecognized values returned by a service will be mapped to ‘UNKNOWN_ENUM_VALUE’.

Returns:The distribution_type of this DrgRouteDistribution.
Return type:str
drg_id

[Required] Gets the drg_id of this DrgRouteDistribution. The OCID of the DRG that contains this route distribution.

Returns:The drg_id of this DrgRouteDistribution.
Return type:str
freeform_tags

Gets the freeform_tags of this DrgRouteDistribution. Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace. For more information, see Resource Tags.

Example: {“Department”: “Finance”}

Returns:The freeform_tags of this DrgRouteDistribution.
Return type:dict(str, str)
id

[Required] Gets the id of this DrgRouteDistribution. The route distribution’s Oracle ID (OCID).

Returns:The id of this DrgRouteDistribution.
Return type:str
lifecycle_state

[Required] Gets the lifecycle_state of this DrgRouteDistribution. The route distribution’s current state.

Allowed values for this property are: “PROVISIONING”, “AVAILABLE”, “TERMINATING”, “TERMINATED”, ‘UNKNOWN_ENUM_VALUE’. Any unrecognized values returned by a service will be mapped to ‘UNKNOWN_ENUM_VALUE’.

Returns:The lifecycle_state of this DrgRouteDistribution.
Return type:str
time_created

[Required] Gets the time_created of this DrgRouteDistribution. The date and time the route distribution was created, in the format defined by RFC3339.

Example: 2016-08-25T21:10:29.600Z

Returns:The time_created of this DrgRouteDistribution.
Return type:datetime