JFIFxxC      C  " }!1AQa"q2#BR$3br %&'()*456789:CDEFGHIJSTUVWXYZcdefghijstuvwxyz w!1AQaq"2B #3Rbr */ class Address implements ModelInterface, ArrayAccess, \JsonSerializable { public const DISCRIMINATOR = null; /** * The original name of the model. * * @var string */ protected static $openAPIModelName = 'Address'; /** * Array of property to type mappings. Used for (de)serialization * * @var string[] */ protected static $openAPITypes = [ 'id' => 'string', 'category' => 'string', 'country' => 'string', 'province_state' => 'string', 'city' => 'string', 'postal_code' => 'string', 'street_line1' => 'string', 'street_line2' => 'string', 'status' => '\Xendit\Customer\AddressStatus', 'is_primary' => 'bool', 'meta' => 'object', 'created' => '\DateTime', 'updated' => '\DateTime' ]; /** * Array of property to format mappings. Used for (de)serialization * * @var string[] * @phpstan-var array * @psalm-var array */ protected static $openAPIFormats = [ 'id' => 'uuid', 'category' => null, 'country' => null, 'province_state' => null, 'city' => null, 'postal_code' => null, 'street_line1' => null, 'street_line2' => null, 'status' => null, 'is_primary' => null, 'meta' => null, 'created' => 'date-time', 'updated' => 'date-time' ]; /** * Array of nullable properties. Used for (de)serialization * * @var boolean[] */ protected static array $openAPINullables = [ 'id' => false, 'category' => true, 'country' => false, 'province_state' => true, 'city' => true, 'postal_code' => true, 'street_line1' => true, 'street_line2' => true, 'status' => true, 'is_primary' => true, 'meta' => true, 'created' => false, 'updated' => false ]; /** * If a nullable field gets set to null, insert it here * * @var boolean[] */ protected array $openAPINullablesSetToNull = []; /** * Array of property to type mappings. Used for (de)serialization * * @return array */ public static function openAPITypes() { return self::$openAPITypes; } /** * Array of property to format mappings. Used for (de)serialization * * @return array */ public static function openAPIFormats() { return self::$openAPIFormats; } /** * Array of nullable properties * * @return array */ protected static function openAPINullables(): array { return self::$openAPINullables; } /** * Array of nullable field names deliberately set to null * * @return boolean[] */ private function getOpenAPINullablesSetToNull(): array { return $this->openAPINullablesSetToNull; } /** * Setter - Array of nullable field names deliberately set to null * * @param boolean[] $openAPINullablesSetToNull */ private function setOpenAPINullablesSetToNull(array $openAPINullablesSetToNull): void { $this->openAPINullablesSetToNull = $openAPINullablesSetToNull; } /** * Checks if a property is nullable * * @param string $property * @return bool */ public static function isNullable(string $property): bool { return self::openAPINullables()[$property] ?? false; } /** * Checks if a nullable property is set to null. * * @param string $property * @return bool */ public function isNullableSetToNull(string $property): bool { return in_array($property, $this->getOpenAPINullablesSetToNull(), true); } /** * Array of attributes where the key is the local name, * and the value is the original name * * @var string[] */ protected static $attributeMap = [ 'id' => 'id', 'category' => 'category', 'country' => 'country', 'province_state' => 'province_state', 'city' => 'city', 'postal_code' => 'postal_code', 'street_line1' => 'street_line1', 'street_line2' => 'street_line2', 'status' => 'status', 'is_primary' => 'is_primary', 'meta' => 'meta', 'created' => 'created', 'updated' => 'updated' ]; /** * Array of attributes to setter functions (for deserialization of responses) * * @var string[] */ protected static $setters = [ 'id' => 'setId', 'category' => 'setCategory', 'country' => 'setCountry', 'province_state' => 'setProvinceState', 'city' => 'setCity', 'postal_code' => 'setPostalCode', 'street_line1' => 'setStreetLine1', 'street_line2' => 'setStreetLine2', 'status' => 'setStatus', 'is_primary' => 'setIsPrimary', 'meta' => 'setMeta', 'created' => 'setCreated', 'updated' => 'setUpdated' ]; /** * Array of attributes to getter functions (for serialization of requests) * * @var string[] */ protected static $getters = [ 'id' => 'getId', 'category' => 'getCategory', 'country' => 'getCountry', 'province_state' => 'getProvinceState', 'city' => 'getCity', 'postal_code' => 'getPostalCode', 'street_line1' => 'getStreetLine1', 'street_line2' => 'getStreetLine2', 'status' => 'getStatus', 'is_primary' => 'getIsPrimary', 'meta' => 'getMeta', 'created' => 'getCreated', 'updated' => 'getUpdated' ]; /** * 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::$openAPIModelName; } /** * 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->setIfExists('id', $data ?? [], null); $this->setIfExists('category', $data ?? [], null); $this->setIfExists('country', $data ?? [], null); $this->setIfExists('province_state', $data ?? [], null); $this->setIfExists('city', $data ?? [], null); $this->setIfExists('postal_code', $data ?? [], null); $this->setIfExists('street_line1', $data ?? [], null); $this->setIfExists('street_line2', $data ?? [], null); $this->setIfExists('status', $data ?? [], null); $this->setIfExists('is_primary', $data ?? [], null); $this->setIfExists('meta', $data ?? [], null); $this->setIfExists('created', $data ?? [], null); $this->setIfExists('updated', $data ?? [], null); } /** * Sets $this->container[$variableName] to the given data or to the given default Value; if $variableName * is nullable and its value is set to null in the $fields array, then mark it as "set to null" in the * $this->openAPINullablesSetToNull array * * @param string $variableName * @param array $fields * @param mixed $defaultValue */ private function setIfExists(string $variableName, array $fields, $defaultValue): void { if (self::isNullable($variableName) && array_key_exists($variableName, $fields) && is_null($fields[$variableName])) { $this->openAPINullablesSetToNull[] = $variableName; } $this->container[$variableName] = $fields[$variableName] ?? $defaultValue; } /** * Show all the invalid properties with reasons. * * @return array invalid properties with reasons */ public function listInvalidProperties() { $invalidProperties = []; if ($this->container['category'] === null) { $invalidProperties[] = "'category' can't be null"; } if ((mb_strlen($this->container['category']) > 255)) { $invalidProperties[] = "invalid value for 'category', the character length must be smaller than or equal to 255."; } if ($this->container['country'] === null) { $invalidProperties[] = "'country' can't be null"; } if ($this->container['province_state'] === null) { $invalidProperties[] = "'province_state' can't be null"; } if ($this->container['city'] === null) { $invalidProperties[] = "'city' can't be null"; } if ($this->container['postal_code'] === null) { $invalidProperties[] = "'postal_code' can't be null"; } if ($this->container['street_line1'] === null) { $invalidProperties[] = "'street_line1' can't be null"; } if ($this->container['street_line2'] === null) { $invalidProperties[] = "'street_line2' can't be null"; } if ($this->container['is_primary'] === null) { $invalidProperties[] = "'is_primary' 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 id * * @return string|null */ public function getId() { return $this->container['id']; } /** * Sets id * * @param string|null $id id * * @return self */ public function setId($id) { if (is_null($id)) { throw new \InvalidArgumentException('non-nullable id cannot be null'); } $this->container['id'] = $id; return $this; } /** * Gets category * * @return string */ public function getCategory() { return $this->container['category']; } /** * Sets category * * @param string $category category * * @return self */ public function setCategory($category) { if (is_null($category)) { array_push($this->openAPINullablesSetToNull, 'category'); } else { $nullablesSetToNull = $this->getOpenAPINullablesSetToNull(); $index = array_search('category', $nullablesSetToNull); if ($index !== FALSE) { unset($nullablesSetToNull[$index]); $this->setOpenAPINullablesSetToNull($nullablesSetToNull); } } if (!is_null($category) && (mb_strlen($category) > 255)) { throw new \InvalidArgumentException('invalid length for $category when calling Address., must be smaller than or equal to 255.'); } $this->container['category'] = $category; return $this; } /** * Gets country * * @return string */ public function getCountry() { return $this->container['country']; } /** * Sets country * * @param string $country country * * @return self */ public function setCountry($country) { if (is_null($country)) { throw new \InvalidArgumentException('non-nullable country cannot be null'); } $this->container['country'] = $country; return $this; } /** * Gets province_state * * @return string */ public function getProvinceState() { return $this->container['province_state']; } /** * Sets province_state * * @param string $province_state province_state * * @return self */ public function setProvinceState($province_state) { if (is_null($province_state)) { array_push($this->openAPINullablesSetToNull, 'province_state'); } else { $nullablesSetToNull = $this->getOpenAPINullablesSetToNull(); $index = array_search('province_state', $nullablesSetToNull); if ($index !== FALSE) { unset($nullablesSetToNull[$index]); $this->setOpenAPINullablesSetToNull($nullablesSetToNull); } } $this->container['province_state'] = $province_state; return $this; } /** * Gets city * * @return string */ public function getCity() { return $this->container['city']; } /** * Sets city * * @param string $city city * * @return self */ public function setCity($city) { if (is_null($city)) { array_push($this->openAPINullablesSetToNull, 'city'); } else { $nullablesSetToNull = $this->getOpenAPINullablesSetToNull(); $index = array_search('city', $nullablesSetToNull); if ($index !== FALSE) { unset($nullablesSetToNull[$index]); $this->setOpenAPINullablesSetToNull($nullablesSetToNull); } } $this->container['city'] = $city; return $this; } /** * Gets postal_code * * @return string */ public function getPostalCode() { return $this->container['postal_code']; } /** * Sets postal_code * * @param string $postal_code postal_code * * @return self */ public function setPostalCode($postal_code) { if (is_null($postal_code)) { array_push($this->openAPINullablesSetToNull, 'postal_code'); } else { $nullablesSetToNull = $this->getOpenAPINullablesSetToNull(); $index = array_search('postal_code', $nullablesSetToNull); if ($index !== FALSE) { unset($nullablesSetToNull[$index]); $this->setOpenAPINullablesSetToNull($nullablesSetToNull); } } $this->container['postal_code'] = $postal_code; return $this; } /** * Gets street_line1 * * @return string */ public function getStreetLine1() { return $this->container['street_line1']; } /** * Sets street_line1 * * @param string $street_line1 street_line1 * * @return self */ public function setStreetLine1($street_line1) { if (is_null($street_line1)) { array_push($this->openAPINullablesSetToNull, 'street_line1'); } else { $nullablesSetToNull = $this->getOpenAPINullablesSetToNull(); $index = array_search('street_line1', $nullablesSetToNull); if ($index !== FALSE) { unset($nullablesSetToNull[$index]); $this->setOpenAPINullablesSetToNull($nullablesSetToNull); } } $this->container['street_line1'] = $street_line1; return $this; } /** * Gets street_line2 * * @return string */ public function getStreetLine2() { return $this->container['street_line2']; } /** * Sets street_line2 * * @param string $street_line2 street_line2 * * @return self */ public function setStreetLine2($street_line2) { if (is_null($street_line2)) { array_push($this->openAPINullablesSetToNull, 'street_line2'); } else { $nullablesSetToNull = $this->getOpenAPINullablesSetToNull(); $index = array_search('street_line2', $nullablesSetToNull); if ($index !== FALSE) { unset($nullablesSetToNull[$index]); $this->setOpenAPINullablesSetToNull($nullablesSetToNull); } } $this->container['street_line2'] = $street_line2; return $this; } /** * Gets status * * @return \Customer\AddressStatus|null */ public function getStatus() { return $this->container['status']; } /** * Sets status * * @param \Customer\AddressStatus|null $status status * * @return self */ public function setStatus($status) { if (is_null($status)) { array_push($this->openAPINullablesSetToNull, 'status'); } else { $nullablesSetToNull = $this->getOpenAPINullablesSetToNull(); $index = array_search('status', $nullablesSetToNull); if ($index !== FALSE) { unset($nullablesSetToNull[$index]); $this->setOpenAPINullablesSetToNull($nullablesSetToNull); } } $this->container['status'] = $status; return $this; } /** * Gets is_primary * * @return bool */ public function getIsPrimary() { return $this->container['is_primary']; } /** * Sets is_primary * * @param bool $is_primary is_primary * * @return self */ public function setIsPrimary($is_primary) { if (is_null($is_primary)) { array_push($this->openAPINullablesSetToNull, 'is_primary'); } else { $nullablesSetToNull = $this->getOpenAPINullablesSetToNull(); $index = array_search('is_primary', $nullablesSetToNull); if ($index !== FALSE) { unset($nullablesSetToNull[$index]); $this->setOpenAPINullablesSetToNull($nullablesSetToNull); } } $this->container['is_primary'] = $is_primary; return $this; } /** * Gets meta * * @return object|null */ public function getMeta() { return $this->container['meta']; } /** * Sets meta * * @param object|null $meta meta * * @return self */ public function setMeta($meta) { if (is_null($meta)) { array_push($this->openAPINullablesSetToNull, 'meta'); } else { $nullablesSetToNull = $this->getOpenAPINullablesSetToNull(); $index = array_search('meta', $nullablesSetToNull); if ($index !== FALSE) { unset($nullablesSetToNull[$index]); $this->setOpenAPINullablesSetToNull($nullablesSetToNull); } } $this->container['meta'] = $meta; return $this; } /** * Gets created * * @return \DateTime|null */ public function getCreated() { return $this->container['created']; } /** * Sets created * * @param \DateTime|null $created created * * @return self */ public function setCreated($created) { if (is_null($created)) { throw new \InvalidArgumentException('non-nullable created cannot be null'); } $this->container['created'] = $created; return $this; } /** * Gets updated * * @return \DateTime|null */ public function getUpdated() { return $this->container['updated']; } /** * Sets updated * * @param \DateTime|null $updated updated * * @return self */ public function setUpdated($updated) { if (is_null($updated)) { throw new \InvalidArgumentException('non-nullable updated cannot be null'); } $this->container['updated'] = $updated; return $this; } /** * Returns true if offset exists. False otherwise. * * @param integer $offset Offset * * @return boolean */ public function offsetExists($offset): bool { return isset($this->container[$offset]); } /** * Gets offset. * * @param integer $offset Offset * * @return mixed|null */ #[\ReturnTypeWillChange] public function offsetGet($offset) { return $this->container[$offset] ?? null; } /** * Sets value based on offset. * * @param int|null $offset Offset * @param mixed $value Value to be set * * @return void */ public function offsetSet($offset, $value): void { if (is_null($offset)) { $this->container[] = $value; } else { $this->container[$offset] = $value; } } /** * Unsets offset. * * @param integer $offset Offset * * @return void */ public function offsetUnset($offset): void { unset($this->container[$offset]); } /** * Serializes the object to a value that can be serialized natively by json_encode(). * @link https://www.php.net/manual/en/jsonserializable.jsonserialize.php * * @return mixed Returns data which can be serialized by json_encode(), which is a value * of any type other than a resource. */ #[\ReturnTypeWillChange] public function jsonSerialize() { return ObjectSerializer::sanitizeForSerialization($this); } /** * Gets the string presentation of the object * * @return string */ public function __toString() { return json_encode( ObjectSerializer::sanitizeForSerialization($this), JSON_PRETTY_PRINT ); } /** * Gets a header-safe presentation of the object * * @return string */ public function toHeaderValue() { return json_encode(ObjectSerializer::sanitizeForSerialization($this)); } }