PageRenderTime 44ms CodeModel.GetById 10ms RepoModel.GetById 0ms app.codeStats 0ms

/plugins/com_acymailing_starter_2.0.0_2011-07-06/front/views/archive/view.html.php

https://gitlab.com/endomorphosis/OLAAaction
PHP | 244 lines | 239 code | 1 blank | 4 comment | 45 complexity | 4ee119fff6bf4e38647afdcf83ddb0fd MD5 | raw file
  1. <?php
  2. /**
  3. * @copyright Copyright (C) 2009-2011 ACYBA SARL - All rights reserved.
  4. * @license http://www.gnu.org/licenses/gpl-3.0.html GNU/GPL
  5. */
  6. defined('_JEXEC') or die('Restricted access');
  7. ?>
  8. <?php
  9. class archiveViewArchive extends JView
  10. {
  11. function display($tpl = null)
  12. {
  13. $function = $this->getLayout();
  14. if(method_exists($this,$function)) $this->$function();
  15. parent::display($tpl);
  16. }
  17. function forward(){
  18. return $this->view();
  19. }
  20. function listing(){
  21. global $Itemid;
  22. $app =& JFactory::getApplication();
  23. $my =& JFactory::getUser();
  24. $pathway =& $app->getPathway();
  25. $values = null;
  26. $menus = &JSite::getMenu();
  27. $menu = $menus->getActive();
  28. $config = acymailing_config();
  29. if(empty($menu) AND !empty($Itemid)){
  30. $menus->setActive($Itemid);
  31. $menu = $menus->getItem($Itemid);
  32. }
  33. $myItem = empty($Itemid) ? '' : '&Itemid='.$Itemid;
  34. $this->assignRef('item',$myItem);
  35. if (is_object( $menu )) {
  36. jimport('joomla.html.parameter');
  37. $menuparams = new JParameter( $menu->params );
  38. }
  39. $pageInfo = null;
  40. $paramBase = ACYMAILING_COMPONENT.'.'.$this->getName();
  41. $pageInfo->filter->order->value = $app->getUserStateFromRequest( $paramBase.".filter_order", 'filter_order', 'a.senddate','cmd' );
  42. $pageInfo->filter->order->dir = $app->getUserStateFromRequest( $paramBase.".filter_order_Dir", 'filter_order_Dir', 'desc', 'word' );
  43. $pageInfo->search = $app->getUserStateFromRequest( $paramBase.".search", 'search', '', 'string' );
  44. $pageInfo->search = JString::strtolower( $pageInfo->search );
  45. $pageInfo->limit->value = $app->getUserStateFromRequest( $paramBase.'.list_limit', 'limit', $app->getCfg('list_limit'), 'int' );
  46. $pageInfo->limit->start = JRequest::getInt('limitstart',0);
  47. $listClass = acymailing_get('class.list');
  48. $listid = acymailing_getCID('listid');
  49. if(empty($listid) AND !empty($menuparams)){
  50. $listid = $menuparams->get('listid');
  51. }
  52. if(empty($listid)){
  53. return JError::raiseError( 404, 'Mailing List not found' );
  54. }
  55. $oneList = $listClass->get($listid);
  56. if(empty($oneList->listid)){
  57. return JError::raiseError( 404, 'Mailing List not found : '.$listid );
  58. }
  59. $access = null;
  60. $access->frontEndManament = false;
  61. $access->frontEndAccess = true;
  62. if(!$access->frontEndManament AND (!$oneList->published OR !$oneList->visible OR !$access->frontEndAccess)){
  63. if(empty($my->id)){
  64. $uri = JFactory::getURI();
  65. $url = 'index.php?option=com_user&view=login';
  66. $url .= '&return='.base64_encode($uri->toString());
  67. $app->redirect($url, JText::_('ACY_NOTALLOWED') );
  68. return false;
  69. }else{
  70. $app->enqueueMessage(JText::_('ACY_NOTALLOWED'),'error');
  71. $app->redirect(acymailing_completeLink('lists',false,true));
  72. return false;
  73. }
  74. }
  75. if($config->get('open_popup')) JHTML::_('behavior.modal','a.modal');
  76. if(!empty($menuparams)){
  77. $values->suffix = $menuparams->get('pageclass_sfx','');
  78. $values->page_title = $menuparams->get('page_title');
  79. $values->show_page_title = $menuparams->get('show_page_title',1);
  80. }else{
  81. $values->suffix = '';
  82. $values->show_page_title = 1;
  83. }
  84. $values->show_description = $config->get('show_description',1);
  85. $values->show_headings = $config->get('show_headings',1);
  86. $values->show_senddate = $config->get('show_senddate',1);
  87. $values->filter = $config->get('show_filter',1);
  88. if(empty($values->page_title)) $values->page_title = $oneList->name;
  89. if(empty($menuparams)){
  90. $pathway->addItem(JText::_('MAILING_LISTS'),acymailing_completeLink('lists'));
  91. $pathway->addItem($values->page_title);
  92. }else{
  93. $pathway->addItem($values->page_title);
  94. }
  95. $document =& JFactory::getDocument();
  96. $document->setTitle( $values->page_title );
  97. $link = '&format=feed&limitstart=';
  98. if($config->get('acyrss_format') == 'rss' || $config->get('acyrss_format') == 'both'){
  99. $attribs = array('type' => 'application/rss+xml', 'title' => 'RSS 2.0');
  100. $document->addHeadLink(JRoute::_($link.'&type=rss'), 'alternate', 'rel', $attribs);
  101. }
  102. if($config->get('acyrss_format') == 'atom' || $config->get('acyrss_format') == 'both'){
  103. $attribs = array('type' => 'application/atom+xml', 'title' => 'Atom 1.0');
  104. $document->addHeadLink(JRoute::_($link.'&type=atom'), 'alternate', 'rel', $attribs);
  105. }
  106. $db =& JFactory::getDBO();
  107. $searchMap = array('a.mailid','a.subject','a.alias');
  108. $filters = array();
  109. if(!empty($pageInfo->search)){
  110. $searchVal = '\'%'.$db->getEscaped($pageInfo->search,true).'%\'';
  111. $filters[] = implode(" LIKE $searchVal OR ",$searchMap)." LIKE $searchVal";
  112. }
  113. $filters[] = 'a.type = \'news\'';
  114. if(!$access->frontEndManament){
  115. $filters[] = 'a.published = 1';
  116. $filters[] = 'a.visible = 1';
  117. }
  118. $filters[] = 'c.listid = '.$oneList->listid;
  119. $selection = array_merge($searchMap,array('a.senddate','a.visible','a.published','a.fromname','a.fromemail','a.replyname','a.replyemail','a.userid'));
  120. $query = 'SELECT '.implode(',',$selection);
  121. $query .= ' FROM '.acymailing_table('listmail').' as c';
  122. $query .= ' LEFT JOIN '.acymailing_table('mail').' as a on a.mailid = c.mailid ';
  123. $query .= ' WHERE ('.implode(') AND (',$filters).')';
  124. $query .= ' ORDER BY '.acymailing_secureField($pageInfo->filter->order->value).' '.acymailing_secureField($pageInfo->filter->order->dir).', c.mailid DESC';
  125. $db->setQuery($query,$pageInfo->limit->start,$pageInfo->limit->value);
  126. $rows = $db->loadObjectList();
  127. $pageInfo->elements->page = count($rows);
  128. if(!empty($pageInfo->search)){
  129. $rows = acymailing_search($pageInfo->search,$rows);
  130. }
  131. if($pageInfo->limit->value > $pageInfo->elements->page){
  132. $pageInfo->elements->total = $pageInfo->limit->start + $pageInfo->elements->page;
  133. }else{
  134. $queryCount = 'SELECT COUNT(c.mailid) FROM '.acymailing_table('listmail').' as c';
  135. $queryCount .= ' LEFT JOIN '.acymailing_table('mail').' as a on a.mailid = c.mailid ';
  136. $queryCount .= ' WHERE ('.implode(') AND (',$filters).')';
  137. $db->setQuery($queryCount);
  138. $pageInfo->elements->total = $db->loadResult();
  139. }
  140. jimport('joomla.html.pagination');
  141. $pagination = new JPagination( $pageInfo->elements->total, $pageInfo->limit->start, $pageInfo->limit->value );
  142. $js = 'function tableOrdering( order, dir, task ){
  143. var form = document.adminForm;
  144. form.filter_order.value = order;
  145. form.filter_order_Dir.value = dir;
  146. document.adminForm.submit( task );
  147. }';
  148. $doc =& JFactory::getDocument();
  149. $doc->addScriptDeclaration( $js);
  150. $this->assignRef('access',$access);
  151. $this->assignRef('rows',$rows);
  152. $this->assignRef('values',$values);
  153. $this->assignRef('list',$oneList);
  154. $this->assignRef('pagination',$pagination);
  155. $this->assignRef('pageInfo',$pageInfo);
  156. $this->assignRef('config',$config);
  157. $this->assignRef('my',$my);
  158. }
  159. function view(){
  160. $app =& JFactory::getApplication();
  161. $pathway =& $app->getPathway();
  162. $my = JFactory::getUser();
  163. $frontEndManagement = false;
  164. $listid = acymailing_getCID('listid');
  165. if(!empty($listid)){
  166. $listClass = acymailing_get('class.list');
  167. $oneList = $listClass->get($listid);
  168. if(!empty($oneList->visible) AND $oneList->published){
  169. $pathway->addItem($oneList->name,acymailing_completeLink('archive&listid='.$oneList->listid.':'.$oneList->alias));
  170. }
  171. if(!empty($oneList->listid) AND acymailing_level(3)){
  172. if(!empty($my->id) AND (int)$my->id == (int)$oneList->userid){
  173. $frontEndManagement = true;
  174. }
  175. if(!empty($my->id)){
  176. if($oneList->access_manage == 'all' OR acymailing_isAllowed($oneList->access_manage)){
  177. $frontEndManagement = true;
  178. }
  179. }
  180. }
  181. }
  182. $mailid = JRequest::getString('mailid','nomailid');
  183. if(empty($mailid)) return JError::raiseError( 404, 'You can not preview a Newsletter-template, please create a Newsletter from your template');
  184. if($mailid == 'nomailid'){
  185. $db=&JFactory::getDBO();
  186. $query = 'SELECT m.`mailid` FROM `#__acymailing_list` as l LEFT JOIN `#__acymailing_listmail` as lm ON l.listid=lm.listid LEFT JOIN `#__acymailing_mail` as m on lm.mailid = m.mailid';
  187. $query .= ' WHERE l.`visible` = 1 AND l.`published` = 1 AND m.`visible`= 1 AND m.`published` = 1';
  188. if(!empty($listid)) $query .= ' AND l.`listid` = '.(int) $listid;
  189. $query .= ' ORDER BY m.`mailid` DESC LIMIT 1';
  190. $db->setQuery($query);
  191. $mailid = $db->loadResult();
  192. }
  193. $mailid = intval($mailid);
  194. if(empty($mailid)) return JError::raiseError( 404, 'Newsletter not found');
  195. $access_sub = true;
  196. $mailClass = acymailing_get('helper.mailer');
  197. $oneMail = $mailClass->load($mailid);
  198. if(empty($oneMail->mailid)){
  199. return JError::raiseError( 404, 'Newsletter not found : '.$mailid );
  200. }
  201. if(!$frontEndManagement AND (!$access_sub OR !$oneMail->published OR !$oneMail->visible)){
  202. $key = JRequest::getString('key');
  203. if(empty($key) OR $key !== $oneMail->key){
  204. $reason = (!$oneMail->published) ? 'Newsletter not published' : (!$oneMail->visible ? 'Newsletter not visible' : (!$access_sub ? 'Access not allowed' : ''));
  205. $app->enqueueMessage('You can not have access to this e-mail : '.$reason,'error');
  206. $app->redirect(acymailing_completeLink('lists',false,true));
  207. return false;
  208. }
  209. }
  210. $subkeys = JRequest::getString('subid',JRequest::getString('sub'));
  211. if(!empty($subkeys)){
  212. $db =& JFactory::getDBO();
  213. $subid = intval(substr($subkeys,0,strpos($subkeys,'-')));
  214. $subkey = substr($subkeys,strpos($subkeys,'-')+1);
  215. $db->setQuery('SELECT * FROM '.acymailing_table('subscriber').' WHERE `subid` = '.$db->Quote($subid).' AND `key` = '.$db->Quote($subkey).' LIMIT 1');
  216. $receiver = $db->loadObject();
  217. }
  218. if(empty($receiver) AND !empty($my->email)){
  219. $userClass = acymailing_get('class.subscriber');
  220. $receiver = $userClass->get($my->email);
  221. }
  222. if(empty($receiver)){
  223. $receiver = null;
  224. $receiver->name = JText::_('VISITOR');
  225. }
  226. $oneMail->sendHTML = true;
  227. $mailClass->dispatcher->trigger('acymailing_replaceusertagspreview',array(&$oneMail,&$receiver));
  228. $pathway->addItem($oneMail->subject);
  229. $document =& JFactory::getDocument();
  230. $document->setTitle( $oneMail->subject );
  231. if (!empty($oneMail->metadesc)) {
  232. $document->setDescription( $oneMail->metadesc );
  233. }
  234. if (!empty($oneMail->metakey)) {
  235. $document->setMetadata('keywords', $oneMail->metakey);
  236. }
  237. $this->assignRef('mail',$oneMail);
  238. $this->assignRef('frontEndManagement',$frontEndManagement);
  239. $this->assignRef('list',$oneList);
  240. $this->assignRef('config',acymailing_config());
  241. $this->assignRef('my',$my);
  242. }
  243. }