westdc-zf1/application/admin/controllers/UserController.php

1243 lines
30 KiB
PHP
Executable File
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<?php
use Helpers\View as view;
use Helpers\PDO;
class Admin_UserController extends Zend_Controller_Action
{
function preDispatch()
{
$this->db=Zend_Registry::get('db');
$this->view->config = Zend_Registry::get('config');
$this->messenger=$this->_helper->getHelper('FlashMessenger');
$this->view->messages = $this->messenger->getMessages();
$this->view->theme = new Theme();
$this->_helper->layout->setLayout('administry');
}
function postDispatch()
{
$this->view->messages = $this->messenger->getMessages();
}
function indexAction()
{
$sql="select count(id) as total from users";
$uq=$this->db->query($sql);
$row=$uq->fetch();
$sqlt="select count(id) as total from users where usertype='administrator'";
$uqt=$this->db->query($sqlt);
$adminrow=$uqt->fetch();
$this->view->su=$row;
$this->view->suadmin=$adminrow;
}//indexAction
function listAction()
{
$select=$this->db->select();
$select->from('users')
->where('usertype = ?', 'member')
->order('users.id desc');
$paginator = Zend_Paginator::factory($select);
$paginator->setCurrentPageNumber($this->_getParam('page'));
$paginator->setItemCountPerPage(30);
$paginator->setView($this->view);
Zend_View_Helper_PaginationControl::setDefaultViewPartial('pagination.phtml');
$this->view->paginator=$paginator;
}//listAction
function searchAction()
{
$search = $this->_getParam('search');
$realname = $this->view->realname = $this->_getParam('realname');
$unit = $this->view->unit = $this->_getParam('unit');
$project = $this->view->project = $this->_getParam('project');
$select=$this->db->select();
if(!empty($search) && ( !empty($realname) || !empty($unit) || !empty($project) ))
{
$this->messenger->addMessage('搜索结果');
$select->from('users');
if(!empty($realname))
{
$select->where('realname like ? ', '%'.$realname.'%');
$select->orWhere('username like ? ', '%'.$realname.'%');
}
if(!empty($unit))
$select->where('unit like ? ', '%'.$unit.'%');
if(!empty($project))
$select->where('project like ? ', '%'.$project.'%');
$select->order('users.id desc');
$paginator = Zend_Paginator::factory($select);
$paginator->setCurrentPageNumber($this->_getParam('page'));
$paginator->setItemCountPerPage(30);
$paginator->setView($this->view);
Zend_View_Helper_PaginationControl::setDefaultViewPartial('pagination_param.phtml');
$this->view->paginator=$paginator;
$this->_helper->viewRenderer('list');
}
else {
$this->_redirect("/admin/user/list");
}
}//searchAction
function deleteAction()
{
$delete=(int)$this->_getParam('id');
$deletename = $this->_getParam('uname');
if (isset($delete))
{
$sql="delete from users where id=?";
try {
$this->db->query($sql,array($delete));
$this->messenger->addMessage('您已经成功的删除了用户:'.$deletename);
} catch (Exception $e) {
$this->messenger->addMessage($e->getMessage());
}
$this->_redirect("/admin/user/list");
}
}
function adminlistAction()
{
$select=$this->db->select();
$select->from('users')
->where('usertype = ?', 'administrator')
->order('users.id desc');
$paginator = Zend_Paginator::factory($select);
$paginator->setCurrentPageNumber($this->_getParam('page'));
$paginator->setItemCountPerPage(30);
$paginator->setView($this->view);
Zend_View_Helper_PaginationControl::setDefaultViewPartial('pagination.phtml');
$this->view->paginator=$paginator;
$ac = $this->_getParam('ac');
if($ac == 'sync')
{
$sql = "SELECT id FROM users WHERE usertype='administrator'";
$rs = $this->db->query($sql);
$ids = $rs->fetchAll();
$data = array();
foreach($ids as $v)
{
$data[] = $v['id'];
}
unset($ids);
$ids = join(",",$data);
$gn_sql = "update users set profile='Administrator' where id in ($ids)";
$gn_db = new PDO(array(
'host'=> $this->view->config->geonetwork->params->host,
'port' => 5432,
'user' => $this->view->config->geonetwork->params->username,
'pwd' => $this->view->config->geonetwork->params->password ,
'db' => $this->view->config->geonetwork->params->dbname
));
$gn_db->exec("update users set profile='Editor' where id>1 and profile='Administrator'");
$gn_db->exec($gn_sql);
view::Post($this,"同步成功!",-1);
}
}
function showAction()
{
$id=(int)$this->_getParam('id');
if (isset($id))
{
try {
$user = new \Users\Users;
$this->view->infos=$user->getUser($id);
$this->view->usertypes = $user->getUserType();
} catch (Exception $e) {
$this->messenger->addMessage($e->getMessage());
}
}
else
{
$this->_redirect("/admin/user/list");
}
}//showAction()
function upAction()
{
$id=(int)$this->_getParam('id');
if (isset($id))
{
try {
$sql="select u.*,m.id as mid from users u left join mdexperts m on m.id=u.id where u.id='$id'";
$result = $this->db->query($sql);
$ex = $result->fetch();
if(empty($ex['mid'])){
$submit=$this->_getParam('submit');
$speciality = $this->_getParam('speciality');
if($submit)
{
$sql="insert into mdexperts (id,speciality) values ('$id','$speciality')";
if($this->db->exec($sql)>0)
{
$this->messenger->addMessage('已经成功将用户提升为评审专家');
$this->_redirect("/admin/user/list");
}
}
else
{
$this->view->infos = $ex;
}
}else
{
$this->messenger->addMessage("该用户已经是评审专家");
$this->_redirect("/admin/user/list");
}
} catch (Exception $e) {
$this->messenger->addMessage($e->getMessage());
$this->_redirect("/admin/user/list");
}
}
else
{
$this->_redirect("/admin/user/list");
}
}//upAction() 把用户提升为评审专家
function editAction()
{
$id=(int)$this->_getParam('id');
$usertype=$this->_getParam('usertype');
$newpwd=$this->_getParam('newpwd');
$cfnewpwd=$this->_getParam('cfnewpwd');
$sql="";
$updates=array();
if (isset($id))
{
if(!empty($newpwd)&&!empty($cfnewpwd))
{
if($newpwd==$cfnewpwd)
{
$password=md5($newpwd);
$updates[]="password='$password'";
}
else
{
$this->messenger->addMessage('两次密码不相同');
$this->_redirect("/admin/user/show/id/$id");
}
}
if(isset($usertype))
{
$updates[]="usertype='$usertype'";
}
$update=join(',',$updates);
$sql="update users set $update where id='$id'";
try {
$this->db->query($sql);
$this->messenger->addMessage('编辑成功!');
} catch (Exception $e) {
$this->messenger->addMessage($e->getMessage());
}
$this->_redirect("/admin/user/show/id/$id");
}
else {
$this->_redirect("/admin/user/list");
}
}
function fetchpwdAction()
{
$id=(int)$this->_getParam('id');
$email=$this->_getParam('email');
if (!empty($email))
{
try {
$sql="select * from users where email=?";
$uq=$this->db->query($sql,$email);
if ($urow=$uq->fetch())
{
//email the url to user
$username=$urow['username'];
$sql="update users set activation=? where email=?";
$uid=uniqid();
$this->db->query($sql,array($uid,$email));
$mail=new WestdcMailer($this->view->config->smtp);
$body="尊敬的西部数据中心用户:
有人提出了针对此用户名的密码重置请求。
用户名:";
$body.=$username;
$body.="
若想重置您的密码请打开下面的链接,否则请忽略此邮件,一切如常。
";
$body.="http://westdc.westgis.ac.cn/account/fetchpwd/".$username."/".$uid;
$mail->setBodyText($body);
$mail->setFrom($this->view->config->service->email,'西部数据中心服务组');
$mail->addTo($email);
$mail->setSubject('密码已重置');
$mail->send();
$this->messenger->addMessage('密码重置成功!');
}
} catch (Exception $e) {
$this->messenger->addMessage($e->getMessage().$email);
}
$this->_redirect("/admin/user/show/id/$id");
}
else {
$this->_redirect("/admin/user/list");
}
} //overview
/*
* groupAction() 用户组管理
*
*/
function groupAction(){
$ac = $this->_getParam('ac');
$groupsTable = "groups";
$userGroupTable = "usergroup";
$nameField = $paramName = "name";
include_once("Users.php");
$u = new Users($this->db);
if(empty($ac) || $ac == "index")
{
$select=$this->db->select();
$select->from($groupsTable)
->order('groups.id desc');
$paginator = Zend_Paginator::factory($select);
$paginator->setCurrentPageNumber($this->_getParam('page'));
$paginator->setItemCountPerPage(30);
$paginator->setView($this->view);
Zend_View_Helper_PaginationControl::setDefaultViewPartial('pagination.phtml');
$this->view->paginator=$paginator;
}//首页
if($ac == "add")
{
$this->_helper->layout->disableLayout();
$this->_helper->viewRenderer->setNoRender();
$data[$nameField] = $this->_getParam($paramName);
if(empty($data[$nameField]))
{
$this->jsonexit(array("error"=>'请输入组名'));
return true;
}
if($this->db->insert($groupsTable,$data))
{
$this->jsonexit(array("status"=>1));
return true;
}else{
$this->jsonexit(array("error"=>"出现错误,请重试"));
return true;
}
return true;
}//增加用户组
if($ac == "edit")
{
$this->_helper->layout->disableLayout();
$this->_helper->viewRenderer->setNoRender();
$id = $this->_getParam('id');
$data[$nameField] = $this->_getParam($paramName);
if(empty($id))
{
$this->jsonexit(array("error"=>'参数错误'));
return true;
}
if(empty($data[$nameField]))
{
$this->jsonexit(array("error"=>'请输入组名'));
return true;
}
if($this->db->update($groupsTable,$data,"id=$id"))
{
$this->jsonexit(array("status"=>1,"name"=>$data[$nameField]));
return true;
}else{
$this->jsonexit(array("error"=>"出现错误,请重试"));
return true;
}
return true;
}//编辑
if($ac == "del")
{
$this->_helper->layout->disableLayout();
$this->_helper->viewRenderer->setNoRender();
$id = $this->_getParam('id');
if(empty($id))
{
$this->jsonexit(array("error"=>'参数错误'));
return true;
}
if($this->db->delete($groupsTable,"id=$id"))
{
$this->jsonexit(array("status"=>1));
return true;
}else{
$this->jsonexit(array("error"=>"出现错误,请重试"));
return true;
}
return true;
}//删除
if($ac == "show")
{
$this->_helper->viewRenderer('group-users');
$gid = (int)$this->_getParam('id');
if(empty($gid))
{
echo "参数错误!";
return true;
}
$this->view->groupid = $gid;
$sql = "SELECT ug.uid,ug.gid,u.id,u.username,u.realname,u.email FROM $userGroupTable ug
LEFT JOIN users u ON ug.uid=u.id
WHERE ug.gid=$gid
ORDER BY ug.ts_created DESC";
$sth = $this->db->query($sql);
$rows = $sth->fetchAll();
$paginator = Zend_Paginator::factory($rows);
$paginator->setCurrentPageNumber($this->_getParam('page'));
$paginator->setItemCountPerPage(20);
$paginator->setView($this->view);
Zend_View_Helper_PaginationControl::setDefaultViewPartial('pagination_param.phtml');
$this->view->paginator=$paginator;
}//查看用户
if($ac == "adduser")
{
$this->_helper->layout->disableLayout();
$this->_helper->viewRenderer->setNoRender();
$data['uid'] = $this->_getParam('uid');
$data['gid'] = $this->_getParam('gid');
if(empty($data['uid']) || empty($data['gid']))
{
$this->jsonexit(array("error"=>'参数错误'));
return true;
}
$sql = "SELECT * FROM users WHERE id={$data['uid']}";
$sth = $this->db->query($sql);
$rows = $sth->fetchAll();
if(count($rows)<1)
{
$this->jsonexit(array("error"=>'用户不存在'));
return true;
}
$sql = "SELECT * FROM $userGroupTable WHERE uid={$data['uid']} AND gid='{$data['gid']}'";
$sth = $this->db->query($sql);
$rows = $sth->fetchAll();
if(count($rows)>0)
{
$this->jsonexit(array("error"=>'该用户已经存在于要加入的组'));
return true;
}
if($this->db->insert($userGroupTable,$data))
{
$this->jsonexit(array("status"=>1));
return true;
}else{
$this->jsonexit(array("error"=>"出现错误,请重试"));
return true;
}
return true;
}//往组中添加用户
if($ac == "deluser")
{
$this->_helper->layout->disableLayout();
$this->_helper->viewRenderer->setNoRender();
$uid = $this->_getParam('uid');
$gid = $this->_getParam('gid');
if(empty($uid) || empty($gid))
{
$this->jsonexit(array("error"=>'参数错误'));
return true;
}
if($this->db->delete($userGroupTable,"uid=$uid AND gid=$gid"))
{
$this->jsonexit(array("status"=>1));
return true;
}else{
$this->jsonexit(array("error"=>"出现错误,请重试"));
return true;
}
return true;
}//从组中删除用户
}// groupAction()
//管理用户权限
public function userauthAction()
{
$this->_helper->viewRenderer('auth-user');
include_once("Users.php");
$User = new Users($this->db);
$uid = $this->_getParam('uid');
if(!empty($uid))
{
$this->view->uid = $uid;
}
$ac = $this->_getParam('ac');
if(empty($ac) || $ac == "index")
{
if(empty($uid))
{
$this->view->error = "参数错误";
return true;
}
$paginator = Zend_Paginator::factory($User->UAuthFetch($uid));
$paginator->setCurrentPageNumber($this->_getParam('page'));
$paginator->setItemCountPerPage(20);
$paginator->setView($this->view);
Zend_View_Helper_PaginationControl::setDefaultViewPartial('pagination_param.phtml');
$this->view->paginator=$paginator;
}//index
if($ac == "add")
{
$this->_helper->viewRenderer('auth-user-add');
$this->view->ac = "add";
if(empty($uid))
{
$this->view->msg = "参数错误";
return true;
}
$submit = $this->_getParam('submit');
if(!empty($submit))
{
$module = $this->_getParam('name_module');
$controller = $this->_getParam('name_controller');
$action = $this->_getParam('name_action');
$special = $this->_getparam('name_special');
$allow = $this->_getParam('allow');
if(empty($module) && empty($controller) && empty($action) && empty($special))
{
$this->view->error = "参数错误";
return true;
}
$options = array(
'module'=>$module,
'controller'=>$controller,
'action'=>$action,
'special'=>$special
);
if($User->UAuthAdd($uid,$options,$allow))
{
$this->view->msg = "添加成功!";
$this->view->jump_url = "/admin/user/userauth?uid=".$uid;
}else{
$this->view->msg = "添加失败,请重试";
}
}
}//add
if($ac == "del")
{
$this->_helper->layout->disableLayout();
$this->_helper->viewRenderer->setNoRender();
$id = $this->_getParam('id');
if(empty($id))
{
$data = array("error"=>'参数错误');
$this->jsonexit($data);
return true;
}
if($User->UAuthDel($id))
{
$this->jsonexit(array('deleted'=>$id));
return true;
}else{
$this->jsonexit(array('error'=>'移除失败,请重试'));
return true;
}
}//del
if($ac == "clearall")
{
if(empty($uid))
{
$this->view->error = "参数错误";
return true;
}
if($User->UAuthDel(-1,$uid))
{
$this->view->msg = "清除成功!";
$this->view->jump_url = "/admin/user/userauth?uid=".$uid;
return true;
}else{
$this->view->msg = "清除失败,请重试";
$this->view->jump_url = "/admin/user/userauth?uid=".$uid;
return true;
}
}//clearall
if($ac == "clone")
{
if(empty($uid))
{
$this->view->msg = "参数错误";
return true;
}
$this->_helper->viewRenderer('auth-user-clone');
$this->view->ac = "clone";
$submit = $this->_getParam('submit');
if(!empty($submit))
{
$target = $this->_getParam('target');
if(empty($target))
{
$this->view->error = "请输入将此用户权限要克隆到的用户ID";
return true;
}
if($User->AuthClone($uid,$target)>0)
{
$this->view->msg = "克隆成功";
return true;
}else{
$this->view->error = "克隆失败请查证Email的正确性";
return true;
}
}
}//clone
}//userauthAction()
//组权限
public function groupauthAction(){
$this->_helper->viewRenderer('auth-group');
include_once("Users.php");
$User = new Users($this->db);
$gid = $this->_getParam('gid');
if(!empty($gid))
{
$this->view->gid = $gid;
}
$ac = $this->_getParam('ac');
if(empty($ac) || $ac == "index")
{
if(empty($gid))
{
$this->view->error = "参数错误";
return true;
}
$paginator = Zend_Paginator::factory($User->GAuthFetch($gid));
$paginator->setCurrentPageNumber($this->_getParam('page'));
$paginator->setItemCountPerPage(20);
$paginator->setView($this->view);
Zend_View_Helper_PaginationControl::setDefaultViewPartial('pagination_param.phtml');
$this->view->paginator=$paginator;
}//index
if($ac == "add")
{
$this->_helper->viewRenderer('auth-group-add');
$this->view->ac = "add";
if(empty($gid))
{
$this->view->msg = "参数错误";
return true;
}
$submit = $this->_getParam('submit');
if(!empty($submit))
{
$module = $this->_getParam('name_module');
$controller = $this->_getParam('name_controller');
$action = $this->_getParam('name_action');
$special = $this->_getparam('name_special');
$allow = $this->_getParam('allow');
if(empty($module) && empty($controller) && empty($action) && empty($special))
{
$this->view->error = "参数错误";
return true;
}
$options = array(
'module'=>$module,
'controller'=>$controller,
'action'=>$action,
'special'=>$special
);
if($User->GAuthAdd($gid,$options,$allow))
{
$this->view->msg = "添加成功!";
$this->view->jump_url = "/admin/user/groupauth?gid=".$gid;
}else{
$this->view->msg = "添加失败,请重试";
}
}
}//add
if($ac == "del")
{
$this->_helper->layout->disableLayout();
$this->_helper->viewRenderer->setNoRender();
$id = $this->_getParam('id');
if(empty($id))
{
$data = array("error"=>'参数错误');
$this->jsonexit($data);
return true;
}
if($User->GAuthDel($id))
{
$this->jsonexit(array('deleted'=>$id));
return true;
}else{
$this->jsonexit(array('error'=>'移除失败,请重试'));
return true;
}
}//del
if($ac == "clearall")
{
if(empty($gid))
{
$this->view->error = "参数错误";
return true;
}
if($User->GAuthDel(-1,$gid))
{
$this->view->msg = "清除成功!";
$this->view->jump_url = "/admin/user/userauth?gid=".$gid;
return true;
}else{
$this->view->msg = "清除失败,请重试";
$this->view->jump_url = "/admin/user/userauth?gid=".$gid;
return true;
}
}//clearall
}
/*
*
* 给时间长没有登录的用户发送邀请邮件
*
*/
public function sendmailAction(){
$ac = $this->_getParam('ac');
if(empty($ac) || $ac=='index')
{
$time = date("Y-m-d H:i:s",time()-3*365*24*3600);
$sql = "SELECT * FROM users
WHERE ts_last_login<'$time'
ORDER BY ts_last_login DESC";
$sth = $this->db->query($sql);
$rows = $sth->fetchAll();
$paginator = Zend_Paginator::factory($rows);
$paginator->setCurrentPageNumber($this->_getParam('page'));
$paginator->setItemCountPerPage(20);
$paginator->setView($this->view);
Zend_View_Helper_PaginationControl::setDefaultViewPartial('pagination_param.phtml');
$this->view->paginator=$paginator;
$this->view->count_users = count($rows);
return true;
}
if($ac == "send")
{
$this->_helper->viewRenderer('sendmail-send');
//当前进行到的数量
$now = $this->_getParam('now');
//需要将起始的时间传递过来防止sql中出现多余的用户
$time = $this->_getParam('time');
if(empty($time))
{
$time = date("Y-m-d H:i:s",time()-3*365*24*3600);
}
$this->view->gotime = $time;
//当前处理的页数
$page = $this->_getParam('page');
if(empty($page))
{
$page = 0;
}
$step = 20;
$sql = "SELECT count(id) as c FROM users
WHERE ts_last_login<'$time'";
$sth = $this->db->query($sql);
$row = $sth->fetch();
$total = $row['c'];
if(empty($now))
{
$now = 0;
}
//此次读取的起点
$start = $now + $step;
if($start>$total)
{
$this->view->stop = "YES";
$msg = array(
"title"=>"为长时间未登录用户发送邀请",
"body"=>"".time()." 时间给最后登陆时间在". $time ."之前的用户发送了邀请访问邮件。 "
);
include_once("message.php");
message::post($this->db,0,-1,$msg['title'],$msg['body']);
return true;
}
$sql = "SELECT * FROM users
WHERE ts_last_login<'$time'
ORDER BY ts_last_login DESC
LIMIT $step
OFFSET $start";
$sth = $this->db->query($sql);
$rows = $sth->fetchAll();
$result = array();
foreach($rows as $k=>$v)
{
include_once("EmailText.php");
$mail=new WestdcMailer($this->view->config->smtp);
$mail->setFrom($this->view->config->service->email,'西部数据中心服务组');
$mailtp=new EmailText($this->db,"user-invite",array(
'user' => $v['username'],
'uid' => $v['id'],
'realname'=> $v['realname'],
'lastlogin'=> date("Y-m-d",strtotime($v['ts_last_login'])),
));
$mail->setBodyText($mailtp->getBody());
$mail->setSubject($mailtp->getSubject());
@$mail->addTo($v['email']);
$result[$v['id']] = array(
'username'=>$v['username'],
'email'=>$v['email'],
'lastlogin'=>date("Y-m-d",strtotime($v['ts_last_login']))
);
//@$mail->send();
}
$this->view->result = $result;
$this->view->now = $start;
$this->view->total = $total;
$percent = round( ( $start / $total ) * 100 ,1);
$this->view->percent = $percent;
$page ++;
$this->view->page = $page;
return true;
}
//黑河用户邮件
if($ac == "heihe")
{
$this->_helper->viewRenderer('sendmail-heihe');
$sql = "SELECT * FROM heiheuser ORDER BY id DESC";
$sth = $this->db->query($sql);
$rows = $sth->fetchAll();
$paginator = Zend_Paginator::factory($rows);
$paginator->setCurrentPageNumber($this->_getParam('page'));
$paginator->setItemCountPerPage(20);
$paginator->setView($this->view);
Zend_View_Helper_PaginationControl::setDefaultViewPartial('pagination_param.phtml');
$this->view->paginator=$paginator;
$this->view->count_users = count($rows);
return true;
}
//黑河邮件发送
if($ac == "heihemail")
{
$this->_helper->viewRenderer('sendmail-heihe-send');
//当前进行到的数量
$now = $this->_getParam('now');
//当前处理的页数
$page = $this->_getParam('page');
if(empty($page))
{
$page = 0;
}
$step = 20;
$sql = "SELECT count(id) as c FROM heiheuser";
$sth = $this->db->query($sql);
$row = $sth->fetch();
$total = $row['c'];
if(empty($now))
{
$now = 0;
}
//此次读取的起点
$start = $now + $step;
if($start>$total)
{
$this->view->stop = "YES";
$msg = array(
"title"=>"为数字黑河用户发送了邮件通知",
"body"=>"".time()." 时间给数字黑河用户发送了邮件通知 "
);
include_once("message.php");
message::post($this->db,0,-1,$msg['title'],$msg['body']);
return true;
}
$sql = "SELECT * FROM heiheuser
ORDER BY id DESC
LIMIT $step
OFFSET $start";
$sth = $this->db->query($sql);
$rows = $sth->fetchAll();
$result = array();
foreach($rows as $k=>$v)
{
include_once("EmailText.php");
$mail=new WestdcMailer($this->view->config->smtp);
$mail->setFrom($this->view->config->service->email,'西部数据中心服务组');
$mailtp=new EmailText($this->db,"user-heihe-invite",array(
'user' => $v['username'],
'uid' => $v['id'],
'lastlogin'=> date("Y-m-d",strtotime($v['lastlogin'])),
));
$mail->setBodyText($mailtp->getBody());
$mail->setSubject($mailtp->getSubject());
@$mail->addTo($v['email']);
$result[$v['id']] = array(
'username'=>$v['username'],
'email'=>$v['email'],
'lastlogin'=>date("Y-m-d",strtotime($v['lastlogin']))
);
//@$mail->send();
}
$this->view->result = $result;
$this->view->now = $start;
$this->view->total = $total;
$percent = round( ( $start / $total ) * 100 ,1);
$this->view->percent = $percent;
$page ++;
$this->view->page = $page;
$this->view->url = "/admin/user/sendmail/ac/heihemail?now=".$start."&page=".$page;
return true;
}
//节日祝贺邮件
if($ac == "holiday")
{
$this->_helper->viewRenderer('sendmail-holiday');
$sql = "SELECT count(id) as c FROM users";
$sth = $this->db->query($sql);
$row = $sth->fetch();
$this->view->count_users = $row['c'];
$sql = "SELECT * FROM emailtext WHERE \"template\"='user-holiday-email'";
$sth = $this->db->query($sql);
$row = $sth->fetch();
$this->view->mailtemp = $row;
return true;
}
//节日祝贺邮件
if($ac == "holidaymail")
{
$this->_helper->layout->disableLayout();
$this->_helper->viewRenderer->setNoRender();
$title = $this->_getParam('title');
$body = $this->_getParam('content');
if(empty($title) || empty($body))
{
$this->jsonexit(array("error"=>"请填写邮件标题和内容"));
return true;
}
//当前进行到的数量
$now = $this->_getParam('now');
//当前处理的页数
$page = $this->_getParam('page');
if(empty($page))
{
$page = 0;
}
$step = 20;
$sql = "SELECT count(id) as c FROM users";
$sth = $this->db->query($sql);
$row = $sth->fetch();
$total = $row['c'];
if(empty($now))
{
$now = 0;
}
//此次读取的起点
$start = $now + $step;
if($start>$total)
{
$stop = "YES";
$msg = array(
"title"=>"为用户发送了节日祝贺邮件",
"body"=>"".time()." 为用户发送了节日祝贺邮件 "
);
include_once("message.php");
message::post($this->db,0,-1,$msg['title'],$msg['body']);
}
$sql = "SELECT * FROM users
ORDER BY id DESC
LIMIT $step
OFFSET $start";
$sth = $this->db->query($sql);
$rows = $sth->fetchAll();
$result = array();
$sended = 0;
foreach($rows as $k=>$v)
{
$replace_data = array(
'username' => $v['username'],
'uid' => $v['id'],
'lastlogin'=> date("Y-m-d",strtotime($v['ts_last_login'])),
);
$patterns = array();
$replacements = array();
foreach($replace_data as $k=>$v)
{
$patterns[]='/{'.$k.'}/i';
$replacements[]=$v;
}
ksort($patterns);
ksort($replacements);
$send_body = preg_replace($patterns, $replacements, $body);
$send_subject = preg_replace($patterns, $replacements, $title);
/*
$mail=new WestdcMailer($this->view->config->smtp);
$mail->setFrom($this->view->config->service->email,'西部数据中心服务组');
$mail->setBodyText($send_body);
$mail->setSubject($send_subject);
@$mail->addTo($v['email']);
if(@$mail->send())
{
$sended ++;
$status = "成功";
}else{
$status = "失败";
}
*/
$sended ++;
/*
调试时前台循环输出result
$result[$v['id']] = array(
'username'=>$v['username'],
'email'=>$v['email'],
'send_body'=>$send_body,
'send_subject'=>$send_subject
);
*/
}
$percent = round( ( $start / $total ) * 100 ,1);
if($percent > 100)
{
$percent = 100;
}
$page ++;
$data = array(
'now'=>$start,
'total'=>$total,
'percent'=>$percent,
'page'=>$page,
'sended'=>$sended,
'url'=> "/admin/user/sendmail/ac/holidaymail?now=".$start."&page=".$page."&title=".$title."&body=".urlencode($body),
'content'=>$body,
'title'=>$title,
'status'=>1,
'result'=>$result //用于调试
);
if(!empty($stop))
{
$data['stop'] = $stop;
$data['status'] = 0;
}
$this->jsonexit($data);
return true;
}
}//sendemailAction()
public function jsonexit($data){
$this->getResponse()->setHeader('Content-Type', 'application/json')->appendBody(json_encode($data,JSON_NUMERIC_CHECK));
return true;
}
}