HEX
Server: Apache
System: Linux scp1.abinfocom.com 5.4.0-216-generic #236-Ubuntu SMP Fri Apr 11 19:53:21 UTC 2025 x86_64
User: confeduphaar (1010)
PHP: 8.1.33
Disabled: exec,passthru,shell_exec,system
Upload Files
File: //lib/mysqlsh/lib/python3.8/site-packages/oci/data_safe/models/random_digits_format_entry.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: 20181201

from .format_entry import FormatEntry
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 RandomDigitsFormatEntry(FormatEntry):
    """
    The Random Digits masking format generates random digits of length within a range.
    The length range is defined by the startLength and endLength attributes. The start
    length must be less than or equal to the end length. When masking columns with
    uniqueness constraint, ensure that the length range is sufficient enough to generate
    unique values. This masking format pads to the appropriate length in a string, but
    does not pad when used for a number column. It's a complementary type of Random Number,
    which is not padded.
    """

    def __init__(self, **kwargs):
        """
        Initializes a new RandomDigitsFormatEntry object with values from keyword arguments. The default value of the :py:attr:`~oci.data_safe.models.RandomDigitsFormatEntry.type` attribute
        of this class is ``RANDOM_DIGITS`` and it should not be changed.
        The following keyword arguments are supported (corresponding to the getters/setters of this class):

        :param type:
            The value to assign to the type property of this RandomDigitsFormatEntry.
            Allowed values for this property are: "DELETE_ROWS", "DETERMINISTIC_SUBSTITUTION", "DETERMINISTIC_ENCRYPTION", "DETERMINISTIC_ENCRYPTION_DATE", "FIXED_NUMBER", "FIXED_STRING", "LIBRARY_MASKING_FORMAT", "NULL_VALUE", "PATTERN", "POST_PROCESSING_FUNCTION", "PRESERVE_ORIGINAL_DATA", "RANDOM_DATE", "RANDOM_DECIMAL_NUMBER", "RANDOM_DIGITS", "RANDOM_LIST", "RANDOM_NUMBER", "RANDOM_STRING", "RANDOM_SUBSTITUTION", "REGULAR_EXPRESSION", "SHUFFLE", "SQL_EXPRESSION", "SUBSTRING", "TRUNCATE_TABLE", "USER_DEFINED_FUNCTION"
        :type type: str

        :param description:
            The value to assign to the description property of this RandomDigitsFormatEntry.
        :type description: str

        :param start_length:
            The value to assign to the start_length property of this RandomDigitsFormatEntry.
        :type start_length: int

        :param end_length:
            The value to assign to the end_length property of this RandomDigitsFormatEntry.
        :type end_length: int

        """
        self.swagger_types = {
            'type': 'str',
            'description': 'str',
            'start_length': 'int',
            'end_length': 'int'
        }
        self.attribute_map = {
            'type': 'type',
            'description': 'description',
            'start_length': 'startLength',
            'end_length': 'endLength'
        }
        self._type = None
        self._description = None
        self._start_length = None
        self._end_length = None
        self._type = 'RANDOM_DIGITS'

    @property
    def start_length(self):
        """
        **[Required]** Gets the start_length of this RandomDigitsFormatEntry.
        The minimum number of digits the generated values should have. It can be
        any integer greater than zero, but it must be less than or equal to the
        end length.


        :return: The start_length of this RandomDigitsFormatEntry.
        :rtype: int
        """
        return self._start_length

    @start_length.setter
    def start_length(self, start_length):
        """
        Sets the start_length of this RandomDigitsFormatEntry.
        The minimum number of digits the generated values should have. It can be
        any integer greater than zero, but it must be less than or equal to the
        end length.


        :param start_length: The start_length of this RandomDigitsFormatEntry.
        :type: int
        """
        self._start_length = start_length

    @property
    def end_length(self):
        """
        **[Required]** Gets the end_length of this RandomDigitsFormatEntry.
        The maximum number of digits the generated values should have. It can
        be any integer greater than zero, but it must be greater than or equal
        to the start length.


        :return: The end_length of this RandomDigitsFormatEntry.
        :rtype: int
        """
        return self._end_length

    @end_length.setter
    def end_length(self, end_length):
        """
        Sets the end_length of this RandomDigitsFormatEntry.
        The maximum number of digits the generated values should have. It can
        be any integer greater than zero, but it must be greater than or equal
        to the start length.


        :param end_length: The end_length of this RandomDigitsFormatEntry.
        :type: int
        """
        self._end_length = end_length

    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