]> git.mxchange.org Git - friendica-addons.git/blobdiff - tumblr/tumblr.php
Merge pull request #439 from zeroadam/Issue3873
[friendica-addons.git] / tumblr / tumblr.php
old mode 100755 (executable)
new mode 100644 (file)
index 054b53f..0a22d14
 require_once('library/OAuth1.php');
 require_once('addon/tumblr/tumblroauth/tumblroauth.php');
 
+use Friendica\Core\Config;
+use Friendica\Core\PConfig;
+
 function tumblr_install() {
-    register_hook('post_local',           'addon/tumblr/tumblr.php', 'tumblr_post_local');
-    register_hook('notifier_normal',      'addon/tumblr/tumblr.php', 'tumblr_send');
-    register_hook('jot_networks',         'addon/tumblr/tumblr.php', 'tumblr_jot_nets');
-    register_hook('connector_settings',      'addon/tumblr/tumblr.php', 'tumblr_settings');
-    register_hook('connector_settings_post', 'addon/tumblr/tumblr.php', 'tumblr_settings_post');
+       register_hook('post_local',           'addon/tumblr/tumblr.php', 'tumblr_post_local');
+       register_hook('notifier_normal',      'addon/tumblr/tumblr.php', 'tumblr_send');
+       register_hook('jot_networks',         'addon/tumblr/tumblr.php', 'tumblr_jot_nets');
+       register_hook('connector_settings',      'addon/tumblr/tumblr.php', 'tumblr_settings');
+       register_hook('connector_settings_post', 'addon/tumblr/tumblr.php', 'tumblr_settings_post');
 
 }
 function tumblr_uninstall() {
-    unregister_hook('post_local',       'addon/tumblr/tumblr.php', 'tumblr_post_local');
-    unregister_hook('notifier_normal',  'addon/tumblr/tumblr.php', 'tumblr_send');
-    unregister_hook('jot_networks',     'addon/tumblr/tumblr.php', 'tumblr_jot_nets');
-    unregister_hook('connector_settings',      'addon/tumblr/tumblr.php', 'tumblr_settings');
-    unregister_hook('connector_settings_post', 'addon/tumblr/tumblr.php', 'tumblr_settings_post');
+       unregister_hook('post_local',       'addon/tumblr/tumblr.php', 'tumblr_post_local');
+       unregister_hook('notifier_normal',  'addon/tumblr/tumblr.php', 'tumblr_send');
+       unregister_hook('jot_networks',     'addon/tumblr/tumblr.php', 'tumblr_jot_nets');
+       unregister_hook('connector_settings',      'addon/tumblr/tumblr.php', 'tumblr_settings');
+       unregister_hook('connector_settings_post', 'addon/tumblr/tumblr.php', 'tumblr_settings_post');
 }
 
 function tumblr_module() {}
@@ -54,6 +57,25 @@ function tumblr_content(&$a) {
        return $o;
 }
 
+function tumblr_plugin_admin(&$a, &$o){
+        $t = get_markup_template( "admin.tpl", "addon/tumblr/" );
+
+        $o = replace_macros($t, array(
+                '$submit' => t('Save Settings'),
+                                                                // name, label, value, help, [extra values]
+                '$consumer_key' => array('consumer_key', t('Consumer Key'),  Config::get('tumblr', 'consumer_key' ), ''),
+                '$consumer_secret' => array('consumer_secret', t('Consumer Secret'),  Config::get('tumblr', 'consumer_secret' ), ''),
+        ));
+}
+
+function tumblr_plugin_admin_post(&$a){
+        $consumer_key     =       ((x($_POST,'consumer_key'))              ? notags(trim($_POST['consumer_key']))   : '');
+        $consumer_secret =       ((x($_POST,'consumer_secret'))   ? notags(trim($_POST['consumer_secret'])): '');
+        Config::set('tumblr','consumer_key',$consumer_key);
+        Config::set('tumblr','consumer_secret',$consumer_secret);
+        info( t('Settings updated.'). EOL );
+}
+
 function tumblr_connect($a) {
        // Start a session.  This is necessary to hold on to  a few keys the callback script will also need
        session_start();
@@ -62,8 +84,8 @@ function tumblr_connect($a) {
        //require_once('addon/tumblr/tumblroauth/tumblroauth.php');
 
        // Define the needed keys
-       $consumer_key = get_config('tumblr','consumer_key');
-       $consumer_secret = get_config('tumblr','consumer_secret');
+       $consumer_key = Config::get('tumblr','consumer_key');
+       $consumer_secret = Config::get('tumblr','consumer_secret');
 
        // The callback URL is the script that gets called after the user authenticates with tumblr
        // In this example, it would be the included callback.php
@@ -85,22 +107,22 @@ function tumblr_connect($a) {
 
        // Check the HTTP Code.  It should be a 200 (OK), if it's anything else then something didn't work.
        switch ($tum_oauth->http_code) {
-         case 200:
-           // Ask Tumblr to give us a special address to their login page
-           $url = $tum_oauth->getAuthorizeURL($token);
-
-               // Redirect the user to the login URL given to us by Tumblr
-           header('Location: ' . $url);
-
-               // That's it for our side.  The user is sent to a Tumblr Login page and
-               // asked to authroize our app.  After that, Tumblr sends the user back to
-               // our Callback URL (callback.php) along with some information we need to get
-               // an access token.
-
-           break;
-       default:
-           // Give an error message
-           $o = 'Could not connect to Tumblr. Refresh the page or try again later.';
+               case 200:
+                       // Ask Tumblr to give us a special address to their login page
+                       $url = $tum_oauth->getAuthorizeURL($token);
+
+                       // Redirect the user to the login URL given to us by Tumblr
+                       header('Location: ' . $url);
+
+                       // That's it for our side.  The user is sent to a Tumblr Login page and
+                       // asked to authroize our app.  After that, Tumblr sends the user back to
+                       // our Callback URL (callback.php) along with some information we need to get
+                       // an access token.
+
+                       break;
+               default:
+                       // Give an error message
+                       $o = 'Could not connect to Tumblr. Refresh the page or try again later.';
        }
        return($o);
 }
@@ -112,8 +134,8 @@ function tumblr_callback($a) {
        //require_once('addon/tumblr/tumblroauth/tumblroauth.php');
 
        // Define the needed keys
-       $consumer_key = get_config('tumblr','consumer_key');
-       $consumer_secret = get_config('tumblr','consumer_secret');
+       $consumer_key = Config::get('tumblr','consumer_key');
+       $consumer_secret = Config::get('tumblr','consumer_secret');
 
        // Once the user approves your app at Tumblr, they are sent back to this script.
        // This script is passed two parameters in the URL, oauth_token (our Request Token)
@@ -124,7 +146,7 @@ function tumblr_callback($a) {
        // It'll need our Consumer Key and Secret as well as our Request Token and Secret
        $tum_oauth = new TumblrOAuth($consumer_key, $consumer_secret, $_SESSION['request_token'], $_SESSION['request_token_secret']);
 
-       // Ok, let's get an Access Token. We'll need to pass along our oauth_verifier which was given to us in the URL. 
+       // Ok, let's get an Access Token. We'll need to pass along our oauth_verifier which was given to us in the URL.
        $access_token = $tum_oauth->getAccessToken($_REQUEST['oauth_verifier']);
 
        // We're done with the Request Token and Secret so let's remove those.
@@ -133,14 +155,14 @@ function tumblr_callback($a) {
 
        // Make sure nothing went wrong.
        if (200 == $tum_oauth->http_code) {
-         // good to go
+               // good to go
        } else {
-         return('Unable to authenticate');
+               return('Unable to authenticate');
        }
 
        // What's next?  Now that we have an Access Token and Secret, we can make an API call.
-       set_pconfig(local_user(), "tumblr", "oauth_token", $access_token['oauth_token']);
-       set_pconfig(local_user(), "tumblr", "oauth_token_secret", $access_token['oauth_token_secret']);
+       PConfig::set(local_user(), "tumblr", "oauth_token", $access_token['oauth_token']);
+       PConfig::set(local_user(), "tumblr", "oauth_token_secret", $access_token['oauth_token_secret']);
 
        $o = t("You are now authenticated to tumblr.");
        $o .= '<br /><a href="'.$a->get_baseurl().'/settings/connectors">'.t("return to the connector page").'</a>';
@@ -148,96 +170,96 @@ function tumblr_callback($a) {
 }
 
 function tumblr_jot_nets(&$a,&$b) {
-    if(! local_user())
-        return;
-
-    $tmbl_post = get_pconfig(local_user(),'tumblr','post');
-    if(intval($tmbl_post) == 1) {
-        $tmbl_defpost = get_pconfig(local_user(),'tumblr','post_by_default');
-        $selected = ((intval($tmbl_defpost) == 1) ? ' checked="checked" ' : '');
-        $b .= '<div class="profile-jot-net"><input type="checkbox" name="tumblr_enable"' . $selected . ' value="1" /> '
-            . t('Post to Tumblr') . '</div>';
-    }
+       if(! local_user())
+               return;
+
+       $tmbl_post = PConfig::get(local_user(),'tumblr','post');
+       if(intval($tmbl_post) == 1) {
+               $tmbl_defpost = PConfig::get(local_user(),'tumblr','post_by_default');
+               $selected = ((intval($tmbl_defpost) == 1) ? ' checked="checked" ' : '');
+               $b .= '<div class="profile-jot-net"><input type="checkbox" name="tumblr_enable"' . $selected . ' value="1" /> '
+                       . t('Post to Tumblr') . '</div>';
+       }
 }
 
 
 function tumblr_settings(&$a,&$s) {
 
-    if(! local_user())
-        return;
+       if(! local_user())
+               return;
 
-    /* Add our stylesheet to the page so we can make our settings look nice */
+       /* 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/tumblr/tumblr.css' . '" media="all" />' . "\r\n";
+       $a->page['htmlhead'] .= '<link rel="stylesheet"  type="text/css" href="' . $a->get_baseurl() . '/addon/tumblr/tumblr.css' . '" media="all" />' . "\r\n";
 
-    /* Get the current state of our config variables */
+       /* Get the current state of our config variables */
 
-    $enabled = get_pconfig(local_user(),'tumblr','post');
-    $checked = (($enabled) ? ' checked="checked" ' : '');
-    $css = (($enabled) ? '' : '-disabled');
+       $enabled = PConfig::get(local_user(),'tumblr','post');
+       $checked = (($enabled) ? ' checked="checked" ' : '');
+       $css = (($enabled) ? '' : '-disabled');
 
-    $def_enabled = get_pconfig(local_user(),'tumblr','post_by_default');
+       $def_enabled = PConfig::get(local_user(),'tumblr','post_by_default');
 
-    $def_checked = (($def_enabled) ? ' checked="checked" ' : '');
+       $def_checked = (($def_enabled) ? ' checked="checked" ' : '');
 
-    /* Add some HTML to the existing form */
+       /* Add some HTML to the existing form */
 
-    $s .= '<span id="settings_tumblr_inflated" class="settings-block fakelink" style="display: block;" onclick="openClose(\'settings_tumblr_expanded\'); openClose(\'settings_tumblr_inflated\');">';
-    $s .= '<img class="connector'.$css.'" src="images/tumblr.png" /><h3 class="connector">'. t('Tumblr Export').'</h3>';
-    $s .= '</span>';
-    $s .= '<div id="settings_tumblr_expanded" class="settings-block" style="display: none;">';
-    $s .= '<span class="fakelink" onclick="openClose(\'settings_tumblr_expanded\'); openClose(\'settings_tumblr_inflated\');">';
-    $s .= '<img class="connector'.$css.'" src="images/tumblr.png" /><h3 class="connector">'. t('Tumblr Export').'</h3>';
-    $s .= '</span>';
+       $s .= '<span id="settings_tumblr_inflated" class="settings-block fakelink" style="display: block;" onclick="openClose(\'settings_tumblr_expanded\'); openClose(\'settings_tumblr_inflated\');">';
+       $s .= '<img class="connector'.$css.'" src="images/tumblr.png" /><h3 class="connector">'. t('Tumblr Export').'</h3>';
+       $s .= '</span>';
+       $s .= '<div id="settings_tumblr_expanded" class="settings-block" style="display: none;">';
+       $s .= '<span class="fakelink" onclick="openClose(\'settings_tumblr_expanded\'); openClose(\'settings_tumblr_inflated\');">';
+       $s .= '<img class="connector'.$css.'" src="images/tumblr.png" /><h3 class="connector">'. t('Tumblr Export').'</h3>';
+       $s .= '</span>';
 
-    $s .= '<div id="tumblr-username-wrapper">';
-    $s .= '<a href="'.$a->get_baseurl().'/tumblr/connect">'.t("(Re-)Authenticate your tumblr page").'</a>';
-    $s .= '</div><div class="clear"></div>';
+       $s .= '<div id="tumblr-username-wrapper">';
+       $s .= '<a href="'.$a->get_baseurl().'/tumblr/connect">'.t("(Re-)Authenticate your tumblr page").'</a>';
+       $s .= '</div><div class="clear"></div>';
 
-    $s .= '<div id="tumblr-enable-wrapper">';
-    $s .= '<label id="tumblr-enable-label" for="tumblr-checkbox">' . t('Enable Tumblr Post Plugin') . '</label>';
-    $s .= '<input id="tumblr-checkbox" type="checkbox" name="tumblr" value="1" ' . $checked . '/>';
-    $s .= '</div><div class="clear"></div>';
+       $s .= '<div id="tumblr-enable-wrapper">';
+       $s .= '<label id="tumblr-enable-label" for="tumblr-checkbox">' . t('Enable Tumblr Post Plugin') . '</label>';
+       $s .= '<input id="tumblr-checkbox" type="checkbox" name="tumblr" value="1" ' . $checked . '/>';
+       $s .= '</div><div class="clear"></div>';
 
-    $s .= '<div id="tumblr-bydefault-wrapper">';
-    $s .= '<label id="tumblr-bydefault-label" for="tumblr-bydefault">' . t('Post to Tumblr by default') . '</label>';
-    $s .= '<input id="tumblr-bydefault" type="checkbox" name="tumblr_bydefault" value="1" ' . $def_checked . '/>';
-    $s .= '</div><div class="clear"></div>';
+       $s .= '<div id="tumblr-bydefault-wrapper">';
+       $s .= '<label id="tumblr-bydefault-label" for="tumblr-bydefault">' . t('Post to Tumblr by default') . '</label>';
+       $s .= '<input id="tumblr-bydefault" type="checkbox" name="tumblr_bydefault" value="1" ' . $def_checked . '/>';
+       $s .= '</div><div class="clear"></div>';
 
-    $oauth_token = get_pconfig(local_user(), "tumblr", "oauth_token");
-    $oauth_token_secret = get_pconfig(local_user(), "tumblr", "oauth_token_secret");
+       $oauth_token = PConfig::get(local_user(), "tumblr", "oauth_token");
+       $oauth_token_secret = PConfig::get(local_user(), "tumblr", "oauth_token_secret");
 
-    $s .= '<div id="tumblr-page-wrapper">';
-    if (($oauth_token != "") and ($oauth_token_secret != "")) {
+       $s .= '<div id="tumblr-page-wrapper">';
+       if (($oauth_token != "") && ($oauth_token_secret != "")) {
 
-       $page = get_pconfig(local_user(),'tumblr','page');
-       $consumer_key = get_config('tumblr','consumer_key');
-       $consumer_secret = get_config('tumblr','consumer_secret');
+               $page = PConfig::get(local_user(),'tumblr','page');
+               $consumer_key = Config::get('tumblr','consumer_key');
+               $consumer_secret = Config::get('tumblr','consumer_secret');
 
-       $tum_oauth = new TumblrOAuth($consumer_key, $consumer_secret, $oauth_token, $oauth_token_secret);
+               $tum_oauth = new TumblrOAuth($consumer_key, $consumer_secret, $oauth_token, $oauth_token_secret);
 
-       $userinfo = $tum_oauth->get('user/info');
+               $userinfo = $tum_oauth->get('user/info');
 
-       $blogs = array();
+               $blogs = array();
 
-       $s .= '<label id="tumblr-page-label" for="tumblr-page">' . t('Post to page:') . '</label>';
-       $s .= '<select name="tumblr_page" id="tumblr-page">';
-       foreach($userinfo->response->user->blogs as $blog) {
-               $blogurl = substr(str_replace(array("http://", "https://"), array("", ""), $blog->url), 0, -1);
-               if ($page == $blogurl)
-                       $s .= "<option value='".$blogurl."' selected>".$blogurl."</option>";
-               else
-                       $s .= "<option value='".$blogurl."'>".$blogurl."</option>";
-       }
+               $s .= '<label id="tumblr-page-label" for="tumblr-page">' . t('Post to page:') . '</label>';
+               $s .= '<select name="tumblr_page" id="tumblr-page">';
+               foreach($userinfo->response->user->blogs as $blog) {
+                       $blogurl = substr(str_replace(array("http://", "https://"), array("", ""), $blog->url), 0, -1);
+                       if ($page == $blogurl)
+                               $s .= "<option value='".$blogurl."' selected>".$blogurl."</option>";
+                       else
+                               $s .= "<option value='".$blogurl."'>".$blogurl."</option>";
+               }
 
-       $s .= "</select>";
-    } else
-       $s .= t("You are not authenticated to tumblr");
-    $s .= '</div><div class="clear"></div>';
+               $s .= "</select>";
+       } else
+               $s .= t("You are not authenticated to tumblr");
+       $s .= '</div><div class="clear"></div>';
 
-    /* provide a submit button */
+       /* provide a submit button */
 
-    $s .= '<div class="settings-submit-wrapper" ><input type="submit" id="tumblr-submit" name="tumblr-submit" class="settings-submit" value="' . t('Save Settings') . '" /></div></div>';
+       $s .= '<div class="settings-submit-wrapper" ><input type="submit" id="tumblr-submit" name="tumblr-submit" class="settings-submit" value="' . t('Save Settings') . '" /></div></div>';
 
 }
 
@@ -246,40 +268,47 @@ function tumblr_settings_post(&$a,&$b) {
 
        if(x($_POST,'tumblr-submit')) {
 
-               set_pconfig(local_user(),'tumblr','post',intval($_POST['tumblr']));
-               set_pconfig(local_user(),'tumblr','page',$_POST['tumblr_page']);
-               set_pconfig(local_user(),'tumblr','post_by_default',intval($_POST['tumblr_bydefault']));
+               PConfig::set(local_user(),'tumblr','post',intval($_POST['tumblr']));
+               PConfig::set(local_user(),'tumblr','page',$_POST['tumblr_page']);
+               PConfig::set(local_user(),'tumblr','post_by_default',intval($_POST['tumblr_bydefault']));
 
        }
 
 }
 
-function tumblr_post_local(&$a,&$b) {
+function tumblr_post_local(&$a, &$b) {
 
        // This can probably be changed to allow editing by pointing to a different API endpoint
 
-       if($b['edit'])
+       if ($b['edit']) {
                return;
+       }
 
-       if((! local_user()) || (local_user() != $b['uid']))
+       if (!local_user() || (local_user() != $b['uid'])) {
                return;
+       }
 
-       if($b['private'] || $b['parent'])
+       if ($b['private'] || $b['parent']) {
                return;
+       }
 
-    $tmbl_post   = intval(get_pconfig(local_user(),'tumblr','post'));
+       $tmbl_post   = intval(PConfig::get(local_user(),'tumblr','post'));
 
        $tmbl_enable = (($tmbl_post && x($_REQUEST,'tumblr_enable')) ? intval($_REQUEST['tumblr_enable']) : 0);
 
-       if($_REQUEST['api_source'] && intval(get_pconfig(local_user(),'tumblr','post_by_default')))
+       if ($b['api_source'] && intval(PConfig::get(local_user(),'tumblr','post_by_default'))) {
                $tmbl_enable = 1;
+       }
+
+       if (!$tmbl_enable) {
+               return;
+       }
 
-    if(! $tmbl_enable)
-       return;
+       if (strlen($b['postopts'])) {
+               $b['postopts'] .= ',';
+       }
 
-    if(strlen($b['postopts']))
-       $b['postopts'] .= ',';
-     $b['postopts'] .= 'tumblr';
+       $b['postopts'] .= 'tumblr';
 }
 
 
@@ -287,18 +316,18 @@ function tumblr_post_local(&$a,&$b) {
 
 function tumblr_send(&$a,&$b) {
 
-    if($b['deleted'] || $b['private'] || ($b['created'] !== $b['edited']))
-        return;
+       if($b['deleted'] || $b['private'] || ($b['created'] !== $b['edited']))
+               return;
 
-    if(! strstr($b['postopts'],'tumblr'))
-        return;
+       if(! strstr($b['postopts'],'tumblr'))
+               return;
 
-    if($b['parent'] != $b['id'])
-        return;
+       if($b['parent'] != $b['id'])
+               return;
 
-       $oauth_token = get_pconfig($b['uid'], "tumblr", "oauth_token");
-       $oauth_token_secret = get_pconfig($b['uid'], "tumblr", "oauth_token_secret");
-       $page = get_pconfig($b['uid'], "tumblr", "page");
+       $oauth_token = PConfig::get($b['uid'], "tumblr", "oauth_token");
+       $oauth_token_secret = PConfig::get($b['uid'], "tumblr", "oauth_token_secret");
+       $page = PConfig::get($b['uid'], "tumblr", "page");
        $tmbl_blog = 'blog/'.$page.'/post';
 
        if($oauth_token && $oauth_token_secret && $tmbl_blog) {
@@ -331,7 +360,7 @@ function tumblr_send(&$a,&$b) {
                if (!isset($siteinfo["type"]))
                        $siteinfo["type"] = "";
 
-               if (($title == "") AND isset($siteinfo["title"]))
+               if (($title == "") && isset($siteinfo["title"]))
                        $title = $siteinfo["title"];
 
                if (isset($siteinfo["text"]))
@@ -372,15 +401,15 @@ function tumblr_send(&$a,&$b) {
                                break;
                }
 
-               if (isset($params['caption']) AND (trim($title) != ""))
+               if (isset($params['caption']) && (trim($title) != ""))
                        $params['caption'] = '<h1>'.$title."</h1>".
                                                "<p>".$params['caption']."</p>";
 
                if (trim($params['caption']) == "")
                        $params['caption'] = bbcode("[quote]".$siteinfo["description"]."[/quote]", false, false, 4);
 
-               $consumer_key = get_config('tumblr','consumer_key');
-               $consumer_secret = get_config('tumblr','consumer_secret');
+               $consumer_key = Config::get('tumblr','consumer_key');
+               $consumer_secret = Config::get('tumblr','consumer_secret');
 
                $tum_oauth = new TumblrOAuth($consumer_key, $consumer_secret, $oauth_token, $oauth_token_secret);