* Author: Tony Baldwin <https://free-haven.org/u/tony>
*/
+use Friendica\App;
use Friendica\Content\Text\BBCode;
-use Friendica\Core\Addon;
+use Friendica\Core\Hook;
use Friendica\Core\L10n;
+use Friendica\Core\Logger;
use Friendica\Core\PConfig;
-use Friendica\Database\dba;
+use Friendica\Database\DBA;
use Friendica\Util\Network;
-function libertree_install() {
- Addon::registerHook('post_local', 'addon/libertree/libertree.php', 'libertree_post_local');
- Addon::registerHook('notifier_normal', 'addon/libertree/libertree.php', 'libertree_send');
- Addon::registerHook('jot_networks', 'addon/libertree/libertree.php', 'libertree_jot_nets');
- Addon::registerHook('connector_settings', 'addon/libertree/libertree.php', 'libertree_settings');
- Addon::registerHook('connector_settings_post', 'addon/libertree/libertree.php', 'libertree_settings_post');
-
-}
-function libertree_uninstall() {
- Addon::unregisterHook('post_local', 'addon/libertree/libertree.php', 'libertree_post_local');
- Addon::unregisterHook('notifier_normal', 'addon/libertree/libertree.php', 'libertree_send');
- Addon::unregisterHook('jot_networks', 'addon/libertree/libertree.php', 'libertree_jot_nets');
- Addon::unregisterHook('connector_settings', 'addon/libertree/libertree.php', 'libertree_settings');
- Addon::unregisterHook('connector_settings_post', 'addon/libertree/libertree.php', 'libertree_settings_post');
+function libertree_install()
+{
+ Hook::register('hook_fork', 'addon/libertree/libertree.php', 'libertree_hook_fork');
+ Hook::register('post_local', 'addon/libertree/libertree.php', 'libertree_post_local');
+ Hook::register('notifier_normal', 'addon/libertree/libertree.php', 'libertree_send');
+ Hook::register('jot_networks', 'addon/libertree/libertree.php', 'libertree_jot_nets');
+ Hook::register('connector_settings', 'addon/libertree/libertree.php', 'libertree_settings');
+ Hook::register('connector_settings_post', 'addon/libertree/libertree.php', 'libertree_settings_post');
}
+function libertree_uninstall()
+{
+ Hook::unregister('hook_fork', 'addon/libertree/libertree.php', 'libertree_hook_fork');
+ Hook::unregister('post_local', 'addon/libertree/libertree.php', 'libertree_post_local');
+ Hook::unregister('notifier_normal', 'addon/libertree/libertree.php', 'libertree_send');
+ Hook::unregister('jot_networks', 'addon/libertree/libertree.php', 'libertree_jot_nets');
+ Hook::unregister('connector_settings', 'addon/libertree/libertree.php', 'libertree_settings');
+ Hook::unregister('connector_settings_post', 'addon/libertree/libertree.php', 'libertree_settings_post');
+}
-function libertree_jot_nets(&$a,&$b) {
- if(! local_user())
+function libertree_jot_nets(App &$a, array &$jotnets_fields)
+{
+ if(! local_user()) {
return;
-
- $ltree_post = PConfig::get(local_user(),'libertree','post');
- if(intval($ltree_post) == 1) {
- $ltree_defpost = PConfig::get(local_user(),'libertree','post_by_default');
- $selected = ((intval($ltree_defpost) == 1) ? ' checked="checked" ' : '');
- $b .= '<div class="profile-jot-net"><input type="checkbox" name="libertree_enable"' . $selected . ' value="1" /> '
- . L10n::t('Post to libertree') . '</div>';
}
+
+ if (PConfig::get(local_user(), 'libertree', 'post')) {
+ $jotnets_fields[] = [
+ 'type' => 'checkbox',
+ 'field' => [
+ 'libertree_enable',
+ L10n::t('Post to libertree'),
+ PConfig::get(local_user(), 'libertree', 'post_by_default')
+ ]
+ ];
+ }
}
/* Add our stylesheet to the page so we can make our settings look nice */
- $a->page['htmlhead'] .= '<link rel="stylesheet" type="text/css" href="' . $a->get_baseurl() . '/addon/libertree/libertree.css' . '" media="all" />' . "\r\n";
+ $a->page['htmlhead'] .= '<link rel="stylesheet" type="text/css" href="' . $a->getBaseURL() . '/addon/libertree/libertree.css' . '" media="all" />' . "\r\n";
/* Get the current state of our config variables */
function libertree_settings_post(&$a,&$b) {
- if(x($_POST,'libertree-submit')) {
+ if(!empty($_POST['libertree-submit'])) {
PConfig::set(local_user(),'libertree','post',intval($_POST['libertree']));
PConfig::set(local_user(),'libertree','post_by_default',intval($_POST['libertree_bydefault']));
}
+function libertree_hook_fork(App &$a, array &$b)
+{
+ if ($b['name'] != 'notifier_normal') {
+ return;
+ }
+
+ $post = $b['data'];
+
+ if ($post['deleted'] || $post['private'] || ($post['created'] !== $post['edited']) ||
+ !strstr($post['postopts'], 'libertree') || ($post['parent'] != $post['id'])) {
+ $b['execute'] = false;
+ return;
+ }
+}
+
function libertree_post_local(&$a,&$b) {
// This can probably be changed to allow editing by pointing to a different API endpoint
$ltree_post = intval(PConfig::get(local_user(),'libertree','post'));
- $ltree_enable = (($ltree_post && x($_REQUEST,'libertree_enable')) ? intval($_REQUEST['libertree_enable']) : 0);
+ $ltree_enable = (($ltree_post && !empty($_REQUEST['libertree_enable'])) ? intval($_REQUEST['libertree_enable']) : 0);
if ($b['api_source'] && intval(PConfig::get(local_user(),'libertree','post_by_default'))) {
$ltree_enable = 1;
function libertree_send(&$a,&$b) {
- logger('libertree_send: invoked');
+ Logger::log('libertree_send: invoked');
if ($b['deleted'] || $b['private'] || ($b['created'] !== $b['edited'])) {
return;
// Dont't post if the post doesn't belong to us.
// This is a check for forum postings
- $self = dba::selectFirst('contact', ['id'], ['uid' => $b['uid'], 'self' => true]);
+ $self = DBA::selectFirst('contact', ['id'], ['uid' => $b['uid'], 'self' => true]);
if ($b['contact-id'] != $self['id']) {
return;
}
$ltree_api_token = PConfig::get($b['uid'],'libertree','libertree_api_token');
$ltree_url = PConfig::get($b['uid'],'libertree','libertree_url');
$ltree_blog = "$ltree_url/api/v1/posts/create/?token=$ltree_api_token";
- $ltree_source = $a->get_hostname();
+ $ltree_source = $a->getHostName();
if ($b['app'] != "")
$ltree_source .= " (".$b['app'].")";
// 'token' => $ltree_api_token
];
- $result = Network::post($ltree_blog, $params);
- logger('libertree: ' . $result);
+ $result = Network::post($ltree_blog, $params)->getBody();
+ Logger::log('libertree: ' . $result);
}
}