source: tags/release-1_7_0RC1/password.php @ 27569

Last change on this file since 27569 was 1809, checked in by rub, 17 years ago

When not template are selected for mail, PWG uses default template..

Sent multi-part message in MIME format. (With only one part for the moment).

Improvement pwg_mail function.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 6.3 KB
Line 
1<?php
2// +-----------------------------------------------------------------------+
3// | PhpWebGallery - a PHP based picture gallery                           |
4// | Copyright (C) 2002-2003 Pierrick LE GALL - pierrick@phpwebgallery.net |
5// | Copyright (C) 2003-2006 PhpWebGallery Team - http://phpwebgallery.net |
6// +-----------------------------------------------------------------------+
7// | branch        : BSF (Best So Far)
8// | file          : $RCSfile$
9// | last update   : $Date: 2007-02-12 23:21:23 +0000 (Mon, 12 Feb 2007) $
10// | last modifier : $Author: rub $
11// | revision      : $Revision: 1809 $
12// +-----------------------------------------------------------------------+
13// | This program is free software; you can redistribute it and/or modify  |
14// | it under the terms of the GNU General Public License as published by  |
15// | the Free Software Foundation                                          |
16// |                                                                       |
17// | This program is distributed in the hope that it will be useful, but   |
18// | WITHOUT ANY WARRANTY; without even the implied warranty of            |
19// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU      |
20// | General Public License for more details.                              |
21// |                                                                       |
22// | You should have received a copy of the GNU General Public License     |
23// | along with this program; if not, write to the Free Software           |
24// | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, |
25// | USA.                                                                  |
26// +-----------------------------------------------------------------------+
27
28// +-----------------------------------------------------------------------+
29// |                           initialization                              |
30// +-----------------------------------------------------------------------+
31
32define('PHPWG_ROOT_PATH','./');
33include_once( PHPWG_ROOT_PATH.'include/common.inc.php' );
34include_once(PHPWG_ROOT_PATH.'include/functions_mail.inc.php');
35
36// +-----------------------------------------------------------------------+
37// |                          send a new password                          |
38// +-----------------------------------------------------------------------+
39
40$page['errors'] = array();
41$page['infos'] = array();
42
43if (isset($_POST['submit']))
44{
45  $mailto =
46    '<a href="mailto:'.get_webmaster_mail_address().'">'
47    .l10n('Contact webmaster')
48    .'</a>'
49    ;
50
51  if (isset($_POST['no_mail_address']) and $_POST['no_mail_address'] == 1)
52  {
53    array_push($page['infos'], l10n('Email address is missing'));
54    array_push($page['infos'], $mailto);
55  }
56  else if (isset($_POST['mail_address']) and !empty($_POST['mail_address']))
57  {
58    $mail_address = mysql_escape_string($_POST['mail_address']);
59   
60    $query = '
61SELECT '.$conf['user_fields']['id'].' AS id
62     , '.$conf['user_fields']['username'].' AS username
63     , '.$conf['user_fields']['email'].' AS email
64FROM '.USERS_TABLE.' as u
65  INNER JOIN '.USER_INFOS_TABLE.' AS ui
66      ON u.'.$conf['user_fields']['id'].' = ui.user_id
67WHERE '
68  .$conf['user_fields']['email'].' = \''.$mail_address.'\' AND
69  ui.status not in (\'guest\', \'generic\', \'webmaster\')
70;';
71    $result = pwg_query($query);
72
73    if (mysql_num_rows($result) > 0)
74    {
75      $error_on_mail = false;
76      $datas = array();
77     
78      while ($row = mysql_fetch_array($result))
79      {
80        $new_password = generate_key(6);
81
82        $infos =
83          l10n('Username').': '.$row['username']
84          ."\n".l10n('Password').': '.$new_password
85          ;
86
87        if (pwg_mail($row['email'],
88              array('subject' => l10n('password updated'), 'content' => $infos)))
89        {
90          $data =
91            array(
92              $conf['user_fields']['id']
93              => $row['id'],
94             
95              $conf['user_fields']['password']
96              => $conf['pass_convert']($new_password)
97              );
98
99          array_push($datas, $data);
100        }
101        else
102        {
103          $error_on_mail = true;
104        }
105      }
106     
107      if ($error_on_mail)
108      {
109        array_push($page['errors'], l10n('Error sending email'));
110        array_push($page['errors'], $mailto);
111      }
112      else
113      {
114        include_once(PHPWG_ROOT_PATH.'admin/include/functions.php');
115        mass_updates(
116          USERS_TABLE,
117          array(
118            'primary' => array($conf['user_fields']['id']),
119            'update' => array($conf['user_fields']['password'])
120          ),
121          $datas
122          );
123
124        array_push($page['infos'], l10n('New password sent by email'));
125      }
126    }
127    else
128    {
129      array_push($page['errors'], l10n('No user matches this email address'));
130      array_push($page['errors'], $mailto);
131    }
132  }
133}
134
135// +-----------------------------------------------------------------------+
136// |                        template initialization                        |
137// +-----------------------------------------------------------------------+
138
139$title = l10n('Forgot your password?');
140$page['body_id'] = 'thePasswordPage';
141include(PHPWG_ROOT_PATH.'include/page_header.php');
142$template->set_filenames(array('password'=>'password.tpl'));
143
144$template->assign_vars(
145  array(
146    'U_HOME' => make_index_url(),
147    )
148  );
149
150// +-----------------------------------------------------------------------+
151// |                        infos & errors display                         |
152// +-----------------------------------------------------------------------+
153
154if (count($page['errors']) != 0)
155{
156  $template->assign_block_vars('errors', array());
157 
158  foreach ($page['errors'] as $error)
159  {
160    $template->assign_block_vars(
161      'errors.error',
162      array(
163        'ERROR' => $error
164        )
165      );
166  }
167}
168
169if (count($page['infos']) != 0)
170{
171  $template->assign_block_vars('infos', array());
172 
173  foreach ($page['infos'] as $info)
174  {
175    $template->assign_block_vars(
176      'infos.info',
177      array(
178        'INFO' => $info
179        )
180      );
181  }
182}
183
184// +-----------------------------------------------------------------------+
185// |                           html code display                           |
186// +-----------------------------------------------------------------------+
187
188$template->parse('password');
189include(PHPWG_ROOT_PATH.'include/page_tail.php');
190
191?>
Note: See TracBrowser for help on using the repository browser.