]> git.mxchange.org Git - friendica-addons.git/blobdiff - notifyall/notifyall.php
Merge pull request #1203 from annando/deprecated
[friendica-addons.git] / notifyall / notifyall.php
index 3f2cdc890ab0fa6f565a587996f026d7c9d934ea..8eff509313db966ae641d79e1906df5c11114c93 100644 (file)
@@ -1,5 +1,4 @@
 <?php
-
 /**
  *
  * Name: Notifyall
@@ -9,99 +8,73 @@
  * Author: Rabuzarus <https://friendica.kommune4.de/profile/rabuzarus> (Port to Friendica)
  */
 
-require_once('include/Emailer.php');
-
-function notifyall_install() {
-       logger("installed notifyall");
-}
-
-function notifyall_uninstall() {
-       logger("removed notifyall");
-}
+use Friendica\Addon\notifyall\NotifyAllEmail;
+use Friendica\App;
+use Friendica\Database\DBA;
+use Friendica\Core\Logger;
+use Friendica\Core\Renderer;
+use Friendica\DI;
 
 function notifyall_module() {}
 
-function notifyall_plugin_admin(&$a, &$o) {
-
-       $o = '<div></div>&nbsp;&nbsp;&nbsp;&nbsp;<a href="' . z_root() . '/notifyall">' . t('Send email to all members') . '</a></br/>';
-
+function notifyall_addon_admin(App $a, &$o)
+{
+       $o = '<div></div>&nbsp;&nbsp;&nbsp;&nbsp;<a href="' . DI::baseUrl()->get() . '/notifyall">' . DI::l10n()->t('Send email to all members') . '</a></br/>';
 }
 
 
-function notifyall_post(&$a) {
-       if(! is_site_admin())
+function notifyall_post(App $a)
+{
+       if (!$a->isSiteAdmin()) {
                return;
+       }
 
        $text = trim($_REQUEST['text']);
-       if(! $text)
-               return;
-
-       $sitename = $a->config['sitename'];
 
-       if (!x($a->config['admin_name']))
-               $sender_name = sprintf(t('%s Administrator'), $sitename);
-       else
-               $sender_name = sprintf(t('%1$s, %2$s Administrator'), $a->config['admin_name'], $sitename);
-       
-       if (! x($a->config['sender_email']))
-               $sender_email = 'noreply@' . $a->get_hostname();
-       else
-               $sender_email = $a->config['sender_email'];
-
-       $subject = $_REQUEST['subject'];
-
-
-       $textversion = strip_tags(html_entity_decode(bbcode(stripslashes(str_replace(array("\\r", "\\n"),array( "", "\n"), $text))),ENT_QUOTES,'UTF-8'));
+       if(! $text) {
+               return;
+       }
 
-       $htmlversion = bbcode(stripslashes(str_replace(array("\\r","\\n"), array("","<br />\n"),$text)));
-       
        // if this is a test, send it only to the admin(s)
        // admin_email might be a comma separated list, but we need "a@b','c@d','e@f
-       if ( intval($_REQUEST['test'])) {
-               $email = $a->config['admin_email'];
-               $email = "'" . str_replace(array(" ",","), array("","','"), $email) . "'";
+       if (intval($_REQUEST['test'])) {
+               $email = DI::config()->get('config', 'admin_email');
+               $email = "'" . str_replace([" ",","], ["","','"], $email) . "'";
        }
        $sql_extra = ((intval($_REQUEST['test'])) ? sprintf(" AND `email` in ( %s )", $email) : '');
 
-       $recips = q("SELECT DISTINCT `email` FROM `user` WHERE `verified` AND NOT `account_removed` AND NOT `account_expired` $sql_extra");
+       $recipients = DBA::p("SELECT DISTINCT `email` FROM `user` WHERE `verified` AND NOT `account_removed` AND NOT `account_expired` $sql_extra");
 
-       if(! $recips) {
-               notice( t('No recipients found.') . EOL);
+       if (! $recipients) {
+               notice(DI::l10n()->t('No recipients found.') . EOL);
                return;
        }
 
-       foreach($recips as $recip) {
+       $notifyEmail = new NotifyAllEmail(DI::l10n(), DI::config(), DI::baseUrl(), $text);
 
-
-               Emailer::send(array(
-                       'fromName'             => $sender_name,
-                       'fromEmail'            => $sender_email,
-                       'replyTo'              => $sender_email,
-                       'toEmail'              => $recip['email'],
-                       'messageSubject'       => $subject,
-                       'htmlVersion'          => $htmlversion,
-                       'textVersion'          => $textversion
-               ));
+       foreach ($recipients as $recipient) {
+               DI::emailer()->send($notifyEmail->withRecipient($recipient['email']));
        }
 
-       notice( t('Emails sent'));
-       goaway('admin');
+       info(DI::l10n()->t('Emails sent'));
+       DI::baseUrl()->redirect('admin');
 }
 
-function notifyall_content(&$a) {
-       if(! is_site_admin())
-               return;
+function notifyall_content(&$a)
+{
+       if (!$a->isSiteAdmin()) {
+               return '';
+       }
 
-       $title = t('Send email to all members of this Friendica instance.');
+       $title = DI::l10n()->t('Send email to all members of this Friendica instance.');
 
-       $o = replace_macros(get_markup_template('notifyall_form.tpl','addon/notifyall/'),array(
+       $o = Renderer::replaceMacros(Renderer::getMarkupTemplate('notifyall_form.tpl', 'addon/notifyall/'), [
                '$title' => $title,
-               '$text' => htmlspecialchars($_REQUEST['text']),
-               '$subject' => array('subject',t('Message subject'),$_REQUEST['subject'],''),
-               '$test' => array('test',t('Test mode (only send to administrator)'), 0,''),
-               '$submit' => t('Submit')
-       ));
+               '$text' => htmlspecialchars($_REQUEST['text'] ?? ''),
+               '$subject' => ['subject', DI::l10n()->t('Message subject'), $_REQUEST['subject'] ?? '',''],
+               '$test' => ['test',DI::l10n()->t('Test mode (only send to administrator)'), 0,''],
+               '$submit' => DI::l10n()->t('Submit')
+       ]);
 
        return $o;
-
 }