X-Git-Url: https://reisub.nsupdate.info/git/?a=blobdiff_plain;f=testdrive%2Ftestdrive.php;h=6daf136e19fd09a08970772b613a64b96da833e8;hb=d836593a3b54a30f961fc17c4e48c622f1e0b8e7;hp=b7c021a102c775393cd63cd1b82a775a6f2c4668;hpb=0f6f6bd0f149fcf39dfe742fc841030dba7b7084;p=friendica-addons.git%2F.git diff --git a/testdrive/testdrive.php b/testdrive/testdrive.php index b7c021a1..6daf136e 100644 --- a/testdrive/testdrive.php +++ b/testdrive/testdrive.php @@ -1,44 +1,64 @@ */ - - +use Friendica\App; +use Friendica\Core\Addon; +use Friendica\Core\Config; +use Friendica\Core\L10n; +use Friendica\Database\DBA; +use Friendica\Model\User; +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'); + Addon::registerHook('load_config', 'addon/testdrive/testdrive.php', 'testdrive_load_config'); + Addon::registerHook('register_account', 'addon/testdrive/testdrive.php', 'testdrive_register_account'); + Addon::registerHook('cron', 'addon/testdrive/testdrive.php', 'testdrive_cron'); + Addon::registerHook('enotify','addon/testdrive/testdrive.php', 'testdrive_enotify'); + Addon::registerHook('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'); + Addon::unregisterHook('load_config', 'addon/testdrive/testdrive.php', 'testdrive_load_config'); + Addon::unregisterHook('register_account', 'addon/testdrive/testdrive.php', 'testdrive_register_account'); + Addon::unregisterHook('cron', 'addon/testdrive/testdrive.php', 'testdrive_cron'); + Addon::unregisterHook('enotify','addon/testdrive/testdrive.php', 'testdrive_enotify'); + Addon::unregisterHook('globaldir_update','addon/testdrive/testdrive.php', 'testdrive_globaldir_update'); + +} + +function testdrive_load_config(App $a) +{ + $a->loadConfigFile(__DIR__ . '/config/testdrive.config.php'); +} +function testdrive_globaldir_update($a,&$b) { + $b['url'] = ''; } function testdrive_register_account($a,$b) { $uid = $b; - $days = get_config('testdrive','expiredays'); + $days = Config::get('testdrive','expiredays'); if(! $days) return; - $r = q("UPDATE user set account_expires_on = '%s' where uid = %d limit 1", - dbesc(datetime_convert('UTC','UTC','now +' . $days . ' days')), + $r = q("UPDATE user set account_expires_on = '%s' where uid = %d", + DBA::escape(DateTimeFormat::convert('now +' . $days . ' days')), intval($uid) ); }; - + function testdrive_cron($a,$b) { require_once('include/enotify.php'); @@ -48,42 +68,40 @@ function testdrive_cron($a,$b) { if(count($r)) { foreach($r as $rr) { - notification(array( + notification([ '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' => L10n::t('Administrator'), + 'source_link' => $a->getBaseURL(), + 'source_photo' => $a->getBaseURL() . '/images/person-80.jpg', + ]); - q("update user set expire_notification_sent = '%s' where uid = %d limit 1", - dbesc(datetime_convert()), + q("update user set expire_notification_sent = '%s' where uid = %d", + DBA::escape(DateTimeFormat::utcNow()), intval($rr['uid']) ); - + } } $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 http://dir.friendica.com/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]"); + if (!empty($b['params']) && $b['params']['type'] == NOTIFY_SYSTEM + && !empty($b['params']['system_type']) && $b['params']['system_type'] === 'testdrive_expire') { + $b['itemlink'] = $a->getBaseURL(); + $b['epreamble'] = $b['preamble'] = L10n::t('Your account on %s will expire in a few days.', Config::get('system', 'sitename')); + $b['subject'] = L10n::t('Your Friendica test account is about to expire.'); + $b['body'] = 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=".Config::get('system', 'url')."]".Config::get('config', 'sitename')."[/url]", get_server()); } }