| 
									
										
										
										
											2008-06-20 01:15:36 -04:00
										 |  |  | <?php | 
					
						
							| 
									
										
										
										
											2020-06-29 01:41:46 +03:00
										 |  |  | // This file is part of GNU social - https://www.gnu.org/software/social
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // GNU social is free software: you can redistribute it and/or modify
 | 
					
						
							|  |  |  | // it under the terms of the GNU Affero General Public License as published by
 | 
					
						
							|  |  |  | // the Free Software Foundation, either version 3 of the License, or
 | 
					
						
							|  |  |  | // (at your option) any later version.
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // GNU social is distributed in the hope that it will be useful,
 | 
					
						
							|  |  |  | // but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
					
						
							|  |  |  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | 
					
						
							|  |  |  | // GNU Affero General Public License for more details.
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // You should have received a copy of the GNU Affero General Public License
 | 
					
						
							|  |  |  | // along with GNU social.  If not, see <http://www.gnu.org/licenses/>.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-20 01:15:36 -04:00
										 |  |  | /** | 
					
						
							| 
									
										
										
										
											2008-06-22 11:50:28 -04:00
										 |  |  |  * Table Definition for confirm_address | 
					
						
							| 
									
										
										
										
											2008-06-20 01:15:36 -04:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-29 01:41:46 +03:00
										 |  |  | defined('GNUSOCIAL') || die(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-03 15:52:36 +01:00
										 |  |  | class Confirm_address extends Managed_DataObject | 
					
						
							| 
									
										
										
										
											2008-06-20 01:15:36 -04:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2008-06-22 11:50:28 -04:00
										 |  |  |     public $__table = 'confirm_address';                 // table name
 | 
					
						
							| 
									
										
										
										
											2008-06-20 01:15:36 -04:00
										 |  |  |     public $code;                            // varchar(32)  primary_key not_null
 | 
					
						
							| 
									
										
										
										
											2020-07-06 20:01:16 +03:00
										 |  |  |     public $user_id;                         // int()
 | 
					
						
							| 
									
										
										
										
											2015-02-12 18:18:55 +01:00
										 |  |  |     public $address;                         // varchar(191)   not_null   not 255 because utf8mb4 takes more space
 | 
					
						
							|  |  |  |     public $address_extra;                   // varchar(191)   not_null   not 255 because utf8mb4 takes more space
 | 
					
						
							| 
									
										
										
										
											2008-06-22 12:16:07 -04:00
										 |  |  |     public $address_type;                    // varchar(8)   not_null
 | 
					
						
							| 
									
										
										
										
											2019-06-03 15:52:36 +01:00
										 |  |  |     public $claimed;                         // datetime()
 | 
					
						
							|  |  |  |     public $sent;                            // datetime()
 | 
					
						
							| 
									
										
										
										
											2020-06-29 01:41:46 +03:00
										 |  |  |     public $modified;                        // timestamp()  not_null default_CURRENT_TIMESTAMP
 | 
					
						
							| 
									
										
										
										
											2008-06-20 01:15:36 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-22 17:52:02 -04:00
										 |  |  |     public static function schemaDef() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return array( | 
					
						
							|  |  |  |             'fields' => array( | 
					
						
							|  |  |  |                 'code' => array('type' => 'varchar', 'length' => 32, 'not null' => true, 'description' => 'good random code'), | 
					
						
							| 
									
										
										
										
											2020-07-06 20:01:16 +03:00
										 |  |  |                 'user_id' => array('type' => 'int', 'description' => 'user who requested confirmation'), | 
					
						
							| 
									
										
										
										
											2015-02-12 18:18:55 +01:00
										 |  |  |                 'address' => array('type' => 'varchar', 'length' => 191, 'not null' => true, 'description' => 'address (email, xmpp, SMS, etc.)'), | 
					
						
							| 
									
										
										
										
											2015-12-27 15:01:28 +01:00
										 |  |  |                 'address_extra' => array('type' => 'varchar', 'length' => 191, 'description' => 'carrier ID, for SMS'), | 
					
						
							| 
									
										
										
										
											2011-08-22 17:52:02 -04:00
										 |  |  |                 'address_type' => array('type' => 'varchar', 'length' => 8, 'not null' => true, 'description' => 'address type ("email", "xmpp", "sms")'), | 
					
						
							|  |  |  |                 'claimed' => array('type' => 'datetime', 'description' => 'date this was claimed for queueing'), | 
					
						
							|  |  |  |                 'sent' => array('type' => 'datetime', 'description' => 'date this was sent for queueing'), | 
					
						
							| 
									
										
										
										
											2020-06-29 01:41:46 +03:00
										 |  |  |                 'modified' => array('type' => 'timestamp', 'not null' => true, 'description' => 'date this record was modified'), | 
					
						
							| 
									
										
										
										
											2011-08-22 17:52:02 -04:00
										 |  |  |             ), | 
					
						
							|  |  |  |             'primary key' => array('code'), | 
					
						
							|  |  |  |             'foreign keys' => array( | 
					
						
							|  |  |  |                 'confirm_address_user_id_fkey' => array('user', array('user_id' => 'id')), | 
					
						
							|  |  |  |             ), | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-29 01:41:46 +03:00
										 |  |  |     public static function getByAddress($address, $addressType) | 
					
						
							| 
									
										
										
										
											2011-04-17 17:46:32 -04:00
										 |  |  |     { | 
					
						
							|  |  |  |         $ca = new Confirm_address(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $ca->address      = $address; | 
					
						
							|  |  |  |         $ca->address_type = $addressType; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-06 17:27:40 +01:00
										 |  |  |         if (!$ca->find(true)) { | 
					
						
							|  |  |  |             throw new NoResultException($ca); | 
					
						
							| 
									
										
										
										
											2011-04-17 17:46:32 -04:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-06 17:27:40 +01:00
										 |  |  |         return $ca; | 
					
						
							| 
									
										
										
										
											2011-04-17 17:46:32 -04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-29 01:41:46 +03:00
										 |  |  |     public static function saveNew($user, $address, $addressType, $extra = null) | 
					
						
							| 
									
										
										
										
											2011-04-17 17:46:32 -04:00
										 |  |  |     { | 
					
						
							|  |  |  |         $ca = new Confirm_address(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (!empty($user)) { | 
					
						
							|  |  |  |             $ca->user_id = $user->id; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $ca->address       = $address; | 
					
						
							|  |  |  |         $ca->address_type  = $addressType; | 
					
						
							|  |  |  |         $ca->address_extra = $extra; | 
					
						
							|  |  |  |         $ca->code          = common_confirmation_code(64); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $ca->insert(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $ca; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-03-02 15:31:48 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-06 17:27:40 +01:00
										 |  |  |     public function getAddress() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->address; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function getAddressType() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->address_type; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function getCode() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->code; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function getProfile() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return Profile::getByID($this->user_id); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function getUrl() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return common_local_url('confirmaddress', array('code' => $this->code)); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Supply arguments in $args. Currently known args: | 
					
						
							|  |  |  |      *  headers     Array with headers (only used for email) | 
					
						
							|  |  |  |      *  nickname    How we great the user (defaults to nickname, but can be any string) | 
					
						
							|  |  |  |      *  sitename    Name we sign the email with (defaults to sitename, but can be any string) | 
					
						
							|  |  |  |      *  url         The confirmation address URL. | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2020-06-29 01:41:46 +03:00
										 |  |  |     public function sendConfirmation(array $args = []) | 
					
						
							| 
									
										
										
										
											2016-03-06 17:27:40 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |         common_debug('Sending confirmation URL for user '._ve($this->user_id).' using '._ve($this->address_type)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $defaults = [ | 
					
						
							| 
									
										
										
										
											2020-06-29 01:41:46 +03:00
										 |  |  |             'headers'  => [], | 
					
						
							|  |  |  |             'nickname' => $this->getProfile()->getNickname(), | 
					
						
							|  |  |  |             'sitename' => common_config('site', 'name'), | 
					
						
							|  |  |  |             'url'      => $this->getUrl(), | 
					
						
							|  |  |  |         ]; | 
					
						
							| 
									
										
										
										
											2016-03-06 17:27:40 +01:00
										 |  |  |         foreach (array_keys($defaults) as $key) { | 
					
						
							|  |  |  |             if (!isset($args[$key])) { | 
					
						
							|  |  |  |                 $args[$key] = $defaults[$key]; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         switch ($this->getAddressType()) { | 
					
						
							|  |  |  |         case 'email': | 
					
						
							|  |  |  |             $this->sendEmailConfirmation($args); | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |         default: | 
					
						
							|  |  |  |             throw ServerException('Unable to handle confirm_address address type: '._ve($this->address_type)); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-29 01:41:46 +03:00
										 |  |  |     public function sendEmailConfirmation(array $args = []) | 
					
						
							| 
									
										
										
										
											2016-03-06 17:27:40 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |         // TRANS: Subject for address confirmation email.
 | 
					
						
							|  |  |  |         $subject = _('Email address confirmation'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // TRANS: Body for address confirmation email.
 | 
					
						
							|  |  |  |         // TRANS: %1$s is the addressed user's nickname, %2$s is the StatusNet sitename,
 | 
					
						
							|  |  |  |         // TRANS: %3$s is the URL to confirm at.
 | 
					
						
							| 
									
										
										
										
											2020-06-29 01:41:46 +03:00
										 |  |  |         $body = sprintf( | 
					
						
							|  |  |  |             _("Hey, %1\$s.\n\n" . | 
					
						
							|  |  |  |               "Someone just entered this email address on %2\$s.\n\n" . | 
					
						
							|  |  |  |               "If it was you, and you want to confirm your entry, ". | 
					
						
							|  |  |  |               "use the URL below:\n\n\t%3\$s\n\n" . | 
					
						
							|  |  |  |               "If not, just ignore this message.\n\n". | 
					
						
							|  |  |  |               "Thanks for your time, \n%2\$s\n"), | 
					
						
							|  |  |  |             $args['nickname'], | 
					
						
							|  |  |  |             $args['sitename'], | 
					
						
							|  |  |  |             $args['url'] | 
					
						
							|  |  |  |         ); | 
					
						
							| 
									
										
										
										
											2016-03-06 17:27:40 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-23 13:36:02 +01:00
										 |  |  |         require_once INSTALLDIR . '/lib/util/mail.php'; | 
					
						
							| 
									
										
										
										
											2016-03-06 17:27:40 +01:00
										 |  |  |         return mail_to_user($this->getProfile()->getUser(), $subject, $body, $args['headers'], $this->getAddress()); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-29 01:41:46 +03:00
										 |  |  |     public function delete($useWhere = false) | 
					
						
							| 
									
										
										
										
											2016-03-02 15:31:48 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |         $result = parent::delete($useWhere); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if ($result === false) { | 
					
						
							|  |  |  |             common_log_db_error($confirm, 'DELETE', __FILE__); | 
					
						
							|  |  |  |             // TRANS: Server error displayed when an address confirmation code deletion from the
 | 
					
						
							|  |  |  |             // TRANS: database fails in the contact address confirmation action.
 | 
					
						
							|  |  |  |             throw new ServerException(_('Could not delete address confirmation.')); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return $result; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2008-06-20 01:15:36 -04:00
										 |  |  | } |