setTitleId($titleId) ->setFirstname($firstname) ->setLastname($lastname) ->setEmail($email) ->setPassword($plainPassword) ->setReseller($reseller) ->setSponsor($sponsor) ->setDiscount($discount) ; if(!is_null($lang)) { $this->setLang($lang); } $con = Propel::getWriteConnection(CustomerTableMap::DATABASE_NAME); $con->beginTransaction(); try { if ($this->isNew()) { $address = new Address(); $address ->setTitleId($titleId) ->setFirstname($firstname) ->setLastname($lastname) ->setAddress1($address1) ->setAddress2($address2) ->setAddress3($address3) ->setPhone($phone) ->setCellphone($cellphone) ->setZipcode($zipcode) ->setCountryId($countryId) ->setIsDefault(1) ; $this->addAddress($address); } else { $address = $this->getDefaultAddress(); $address ->setTitleId($titleId) ->setFirstname($firstname) ->setLastname($lastname) ->setAddress1($address1) ->setAddress2($address2) ->setAddress3($address3) ->setPhone($phone) ->setCellphone($cellphone) ->setZipcode($zipcode) ->setCountryId($countryId) ->save($con) ; } $this->save($con); $con->commit(); } catch(Exception $e) { $con->rollback(); throw $e; } } protected function generateRef() { return uniqid(substr($this->getLastname(), 0, (strlen($this->getLastname()) >= 3) ? 3 : strlen($this->getLastname())), true); } /** * @return Address */ public function getDefaultAddress() { return AddressQuery::create() ->filterByCustomer($this) ->filterByIsDefault(1) ->findOne(); } /** * create hash for plain password and set it in Customer object * * @param string $password plain password before hashing * @throws Exception\InvalidArgumentException * @return $this|Customer */ public function setPassword($password) { if ($this->isNew() && ($password === null || trim($password) == "")) { throw new InvalidArgumentException("customer password is mandatory on creation"); } if($password !== null && trim($password) != "") { $this->setAlgo("PASSWORD_BCRYPT"); return parent::setPassword(password_hash($password, PASSWORD_BCRYPT)); } return $this; } public function setEmail($email, $force = false) { $email = trim($email); if ($this->isNew() && ($email === null || $email == "")) { throw new InvalidArgumentException("customer email is mandatory on creation"); } if (!$this->isNew() && $force === false) { return $this; } return parent::setEmail($email); } /** * {@inheritDoc} */ public function getUsername() { return $this->getEmail(); } /** * {@inheritDoc} */ public function checkPassword($password) { return password_verify($password, $this->password); } /** * {@inheritDoc} */ public function eraseCredentials() { $this->setPassword(null); } /** * {@inheritDoc} */ public function getRoles() { return array(new Role('CUSTOMER')); } /** * {@inheritDoc} */ public function preInsert(ConnectionInterface $con = null) { $this->setRef($this->generateRef()); $this->dispatchEvent(TheliaEvents::BEFORE_CREATECUSTOMER, new CustomerEvent($this)); return true; } /** * {@inheritDoc} */ public function postInsert(ConnectionInterface $con = null) { $this->dispatchEvent(TheliaEvents::AFTER_CREATECUSTOMER, new CustomerEvent($this)); } /** * {@inheritDoc} */ public function preUpdate(ConnectionInterface $con = null) { $this->dispatchEvent(TheliaEvents::BEFORE_CHANGECUSTOMER, new CustomerEvent($this)); return true; } /** * {@inheritDoc} */ public function postUpdate(ConnectionInterface $con = null) { $this->dispatchEvent(TheliaEvents::AFTER_CHANGECUSTOMER, new CustomerEvent($this)); } /** * {@inheritDoc} */ public function preDelete(ConnectionInterface $con = null) { $this->dispatchEvent(TheliaEvents::BEFORE_DELETECONFIG, new CustomerEvent($this)); return true; } /** * {@inheritDoc} */ public function postDelete(ConnectionInterface $con = null) { $this->dispatchEvent(TheliaEvents::AFTER_DELETECONFIG, new CustomerEvent($this)); } }