'string', 'email' => 'WPMailSMTP\\Vendor\\SendinBlue\\Client\\Model\\SendReportEmail']; /** * Array of property to format mappings. Used for (de)serialization * * @var string[] */ protected static $swaggerFormats = ['language' => null, 'email' => null]; /** * Array of property to type mappings. Used for (de)serialization * * @return array */ public static function swaggerTypes() { return self::$swaggerTypes; } /** * Array of property to format mappings. Used for (de)serialization * * @return array */ public static function swaggerFormats() { return self::$swaggerFormats; } /** * Array of attributes where the key is the local name, * and the value is the original name * * @var string[] */ protected static $attributeMap = ['language' => 'language', 'email' => 'email']; /** * Array of attributes to setter functions (for deserialization of responses) * * @var string[] */ protected static $setters = ['language' => 'setLanguage', 'email' => 'setEmail']; /** * Array of attributes to getter functions (for serialization of requests) * * @var string[] */ protected static $getters = ['language' => 'getLanguage', 'email' => 'getEmail']; /** * Array of attributes where the key is the local name, * and the value is the original name * * @return array */ public static function attributeMap() { return self::$attributeMap; } /** * Array of attributes to setter functions (for deserialization of responses) * * @return array */ public static function setters() { return self::$setters; } /** * Array of attributes to getter functions (for serialization of requests) * * @return array */ public static function getters() { return self::$getters; } /** * The original name of the model. * * @return string */ public function getModelName() { return self::$swaggerModelName; } const LANGUAGE_FR = 'fr'; const LANGUAGE_ES = 'es'; const LANGUAGE_PT = 'pt'; const LANGUAGE_IT = 'it'; const LANGUAGE_DE = 'de'; const LANGUAGE_EN = 'en'; /** * Gets allowable values of the enum * * @return string[] */ public function getLanguageAllowableValues() { return [self::LANGUAGE_FR, self::LANGUAGE_ES, self::LANGUAGE_PT, self::LANGUAGE_IT, self::LANGUAGE_DE, self::LANGUAGE_EN]; } /** * Associative array for storing property values * * @var mixed[] */ protected $container = []; /** * Constructor * * @param mixed[] $data Associated array of property values * initializing the model */ public function __construct(array $data = null) { $this->container['language'] = isset($data['language']) ? $data['language'] : 'fr'; $this->container['email'] = isset($data['email']) ? $data['email'] : null; } /** * Show all the invalid properties with reasons. * * @return array invalid properties with reasons */ public function listInvalidProperties() { $invalidProperties = []; $allowedValues = $this->getLanguageAllowableValues(); if (!\is_null($this->container['language']) && !\in_array($this->container['language'], $allowedValues, \true)) { $invalidProperties[] = \sprintf("invalid value for 'language', must be one of '%s'", \implode("', '", $allowedValues)); } if ($this->container['email'] === null) { $invalidProperties[] = "'email' can't be null"; } return $invalidProperties; } /** * Validate all the properties in the model * return true if all passed * * @return bool True if all properties are valid */ public function valid() { return \count($this->listInvalidProperties()) === 0; } /** * Gets language * * @return string */ public function getLanguage() { return $this->container['language']; } /** * Sets language * * @param string $language Language of email content for campaign report sending. * * @return $this */ public function setLanguage($language) { $allowedValues = $this->getLanguageAllowableValues(); if (!\is_null($language) && !\in_array($language, $allowedValues, \true)) { throw new \InvalidArgumentException(\sprintf("Invalid value for 'language', must be one of '%s'", \implode("', '", $allowedValues))); } $this->container['language'] = $language; return $this; } /** * Gets email * * @return \SendinBlue\Client\Model\SendReportEmail */ public function getEmail() { return $this->container['email']; } /** * Sets email * * @param \SendinBlue\Client\Model\SendReportEmail $email email * * @return $this */ public function setEmail($email) { $this->container['email'] = $email; return $this; } /** * Returns true if offset exists. False otherwise. * * @param integer $offset Offset * * @return boolean */ #[\ReturnTypeWillChange] public function offsetExists($offset) { return isset($this->container[$offset]); } /** * Gets offset. * * @param integer $offset Offset * * @return mixed */ #[\ReturnTypeWillChange] public function offsetGet($offset) { return isset($this->container[$offset]) ? $this->container[$offset] : null; } /** * Sets value based on offset. * * @param integer $offset Offset * @param mixed $value Value to be set * * @return void */ #[\ReturnTypeWillChange] public function offsetSet($offset, $value) { if (\is_null($offset)) { $this->container[] = $value; } else { $this->container[$offset] = $value; } } /** * Unsets offset. * * @param integer $offset Offset * * @return void */ #[\ReturnTypeWillChange] public function offsetUnset($offset) { unset($this->container[$offset]); } /** * Gets the string presentation of the object * * @return string */ public function __toString() { if (\defined('JSON_PRETTY_PRINT')) { // use JSON pretty print return \json_encode(\WPMailSMTP\Vendor\SendinBlue\Client\ObjectSerializer::sanitizeForSerialization($this), \JSON_PRETTY_PRINT); } return \json_encode(\WPMailSMTP\Vendor\SendinBlue\Client\ObjectSerializer::sanitizeForSerialization($this)); } }