i18n/src/messenger/webim/operator/resetpwd.php

69 lines
1.9 KiB
PHP
Raw Normal View History

<?php
/*
2013-03-07 01:22:53 +04:00
* Copyright 2005-2013 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
require_once('../libs/common.php');
require_once('../libs/operator.php');
require_once('../libs/settings.php');
$errors = array();
$page = array('version' => $version, 'showform' => true);
2011-02-26 17:06:19 +03:00
$opId = verifyparam("id", "/^\d{1,9}$/");
$token = verifyparam("token", "/^[\dabcdef]+$/");
$operator = operator_by_id($opId);
2011-02-26 17:06:19 +03:00
if (!$operator) {
$errors[] = "No such operator";
$page['showform'] = false;
2011-02-26 17:06:19 +03:00
} else if ($token != $operator['vcrestoretoken']) {
$errors[] = "Wrong token";
$page['showform'] = false;
}
if (count($errors) == 0 && isset($_POST['password'])) {
$password = getparam('password');
$passwordConfirm = getparam('passwordConfirm');
2011-02-26 17:06:19 +03:00
if (!$password)
$errors[] = no_field("form.field.password");
2011-02-26 17:06:19 +03:00
if ($password != $passwordConfirm)
$errors[] = getlocal("my_settings.error.password_match");
2011-02-26 17:06:19 +03:00
if (count($errors) == 0) {
$page['isdone'] = true;
$link = connect();
2011-02-26 17:06:19 +03:00
$query = "update ${mysqlprefix}chatoperator set vcpassword = '" . md5($password) . "', vcrestoretoken = '' where operatorid = " . $opId;
perform_query($query, $link);
close_connection($link);
2011-02-26 17:06:19 +03:00
$page['loginname'] = $operator['vclogin'];
start_html_output();
require('../view/resetpwd.php');
exit;
2011-02-26 17:06:19 +03:00
}
}
$page['id'] = $opId;
$page['token'] = $token;
$page['isdone'] = false;
start_html_output();
require('../view/resetpwd.php');
?>