X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=testdrive%2Ftestdrive.php;h=7c3af59e0253e21c5442d605dc5895669db64823;hb=e53818d9f109f42865343dcca9b7c4e54305bfb8;hp=9bbeb1d854b11cda874d6aa1277c026105d05338;hpb=6d6e73096afb22e95678c651e055337f1bf5405d;p=friendica-addons.git diff --git a/testdrive/testdrive.php b/testdrive/testdrive.php index 9bbeb1d8..7c3af59e 100644 --- a/testdrive/testdrive.php +++ b/testdrive/testdrive.php @@ -1,32 +1,34 @@ */ - - +use Friendica\App; +use Friendica\Core\Hook; +use Friendica\Core\Search; +use Friendica\Database\DBA; +use Friendica\DI; +use Friendica\Model\Notification; +use Friendica\Model\User; +use Friendica\Util\ConfigFileLoader; +use Friendica\Util\DateTimeFormat; function testdrive_install() { - register_hook('register_account', 'addon/testdrive/testdrive.php', 'testdrive_register_account'); - register_hook('cron', 'addon/testdrive/testdrive.php', 'testdrive_cron'); - register_hook('enotify','addon/testdrive/testdrive.php', 'testdrive_enotify'); - register_hook('globaldir_update','addon/testdrive/testdrive.php', 'testdrive_globaldir_update'); + Hook::register('load_config', 'addon/testdrive/testdrive.php', 'testdrive_load_config'); + Hook::register('register_account', 'addon/testdrive/testdrive.php', 'testdrive_register_account'); + Hook::register('cron', 'addon/testdrive/testdrive.php', 'testdrive_cron'); + Hook::register('enotify','addon/testdrive/testdrive.php', 'testdrive_enotify'); + Hook::register('globaldir_update','addon/testdrive/testdrive.php', 'testdrive_globaldir_update'); } - -function testdrive_uninstall() { - - unregister_hook('register_account', 'addon/testdrive/testdrive.php', 'testdrive_register_account'); - unregister_hook('cron', 'addon/testdrive/testdrive.php', 'testdrive_cron'); - unregister_hook('enotify','addon/testdrive/testdrive.php', 'testdrive_enotify'); - unregister_hook('globaldir_update','addon/testdrive/testdrive.php', 'testdrive_globaldir_update'); - +function testdrive_load_config(App $a, ConfigFileLoader $loader) +{ + $a->getConfigCache()->load($loader->loadAddonConfig('testdrive')); } function testdrive_globaldir_update($a,&$b) { @@ -37,12 +39,12 @@ function testdrive_register_account($a,$b) { $uid = $b; - $days = get_config('testdrive','expiredays'); + $days = DI::config()->get('testdrive','expiredays'); if(! $days) return; $r = q("UPDATE user set account_expires_on = '%s' where uid = %d", - dbesc(datetime_convert('UTC','UTC','now +' . $days . ' days')), + DBA::escape(DateTimeFormat::convert('now +' . $days . ' days')), intval($uid) ); @@ -50,27 +52,22 @@ function testdrive_register_account($a,$b) { function testdrive_cron($a,$b) { - require_once('include/enotify.php'); - $r = q("select * from user where account_expires_on < UTC_TIMESTAMP() + INTERVAL 5 DAY and expire_notification_sent = '0000-00-00 00:00:00' "); if(count($r)) { foreach($r as $rr) { - notification(array( + notification([ + 'type' => Notification\Type::SYSTEM, 'uid' => $rr['uid'], - 'type' => NOTIFY_SYSTEM, 'system_type' => 'testdrive_expire', - 'language' => $rr['language'], - 'to_name' => $rr['username'], - 'to_email' => $rr['email'], - 'source_name' => t('Administrator'), - 'source_link' => $a->get_baseurl(), - 'source_photo' => $a->get_baseurl() . '/images/person-80.jpg', - )); + 'source_name' => DI::l10n()->t('Administrator'), + 'source_link' => DI::baseUrl()->get(), + 'source_photo' => DI::baseUrl()->get() . '/images/person-80.jpg', + ]); q("update user set expire_notification_sent = '%s' where uid = %d", - dbesc(datetime_convert()), + DBA::escape(DateTimeFormat::utcNow()), intval($rr['uid']) ); @@ -79,20 +76,18 @@ function testdrive_cron($a,$b) { $r = q("select * from user where account_expired = 1 and account_expires_on < UTC_TIMESTAMP() - INTERVAL 5 DAY "); if(count($r)) { - require_once('include/Contact.php'); - foreach($r as $rr) - user_remove($rr['uid']); - + foreach($r as $rr) { + User::remove($rr['uid']); + } } - } function testdrive_enotify(&$a, &$b) { - if (x($b, 'params') && $b['params']['type'] == NOTIFY_SYSTEM - && x($b['params'], 'system_type') && $b['params']['system_type'] === 'testdrive_expire') { - $b['itemlink'] = $a->get_baseurl(); - $b['epreamble'] = $b['preamble'] = sprintf( t('Your account on %s will expire in a few days.'), get_config('system','sitename')); - $b['subject'] = t('Your Friendica test account is about to expire.'); - $b['body'] = sprintf( t("Hi %1\$s,\n\nYour test account on %2\$s will expire in less than five days. We hope you enjoyed this test drive and use this opportunity to find a permanent Friendica website for your integrated social communications. A list of public sites is available at %s/siteinfo - and for more information on setting up your own Friendica server please see the Friendica project website at http://friendica.com."), $b['params']['to_name'], "[url=".$app->config["system"]["url"]."]".$app->config["sitename"]."[/url]", get_server()); + if (!empty($b['params']) && $b['params']['type'] == Notification\Type::SYSTEM + && !empty($b['params']['system_type']) && $b['params']['system_type'] === 'testdrive_expire') { + $b['itemlink'] = DI::baseUrl()->get(); + $b['epreamble'] = $b['preamble'] = DI::l10n()->t('Your account on %s will expire in a few days.', DI::config()->get('system', 'sitename')); + $b['subject'] = DI::l10n()->t('Your Friendica test account is about to expire.'); + $b['body'] = DI::l10n()->t("Hi %1\$s,\n\nYour test account on %2\$s will expire in less than five days. We hope you enjoyed this test drive and use this opportunity to find a permanent Friendica website for your integrated social communications. A list of public sites is available at %s/siteinfo - and for more information on setting up your own Friendica server please see the Friendica project website at https://friendi.ca.", $b['params']['to_name'], "[url=".DI::config()->get('system', 'url')."]".DI::config()->get('config', 'sitename')."[/url]", Search::getGlobalDirectory()); } }