]> git.mxchange.org Git - quix0rs-gnu-social.git/commitdiff
trac750 configurable sync flags for Facebook app (noticesync, replysync)
authorZach Copley <zach@controlyourself.ca>
Mon, 5 Jan 2009 04:02:12 +0000 (23:02 -0500)
committerZach Copley <zach@controlyourself.ca>
Mon, 5 Jan 2009 04:02:12 +0000 (23:02 -0500)
darcs-hash:20090105040212-7b5ce-37f6195649dc673241e4566a93183b13e428d98f.gz

15 files changed:
_darcs/inventory
_darcs/patches/20090105040212-7b5ce-37f6195649dc673241e4566a93183b13e428d98f.gz [new file with mode: 0644]
_darcs/pristine/actions/facebookhome.php
_darcs/pristine/actions/facebooksettings.php
_darcs/pristine/actions/twittersettings.php
_darcs/pristine/classes/Foreign_link.php
_darcs/pristine/lib/facebookaction.php
_darcs/pristine/scripts/update_facebook.php
_darcs/tentative_pristine
actions/facebookhome.php
actions/facebooksettings.php
actions/twittersettings.php
classes/Foreign_link.php
lib/facebookaction.php
scripts/update_facebook.php

index 8c94c559c81f262736b7c8c647b42490280ea766..909443c81e9e72dca08712529e2938c97f7c48c9 100644 (file)
@@ -114,4 +114,6 @@ Evan Prodromou <evan@prodromou.name>**20081230211957]
 [wrapper element for config.xml
 Evan Prodromou <evan@prodromou.name>**20081230212202] 
 [trac750 Automatically update linked Facebook users' statuses
-Zach Copley <zach@controlyourself.ca>**20090105010407] 
\ No newline at end of file
+Zach Copley <zach@controlyourself.ca>**20090105010407] 
+[trac750 configurable sync flags for Facebook app (noticesync, replysync)
+Zach Copley <zach@controlyourself.ca>**20090105040212] 
\ No newline at end of file
diff --git a/_darcs/patches/20090105040212-7b5ce-37f6195649dc673241e4566a93183b13e428d98f.gz b/_darcs/patches/20090105040212-7b5ce-37f6195649dc673241e4566a93183b13e428d98f.gz
new file mode 100644 (file)
index 0000000..d497340
Binary files /dev/null and b/_darcs/patches/20090105040212-7b5ce-37f6195649dc673241e4566a93183b13e428d98f.gz differ
index a23d1aa07f516a58bebc9efe3bb43dbc81bc9812..069ea5e75ce691c1cae0ed27e0cff41fc9fcba90 100644 (file)
@@ -70,8 +70,7 @@ class FacebookhomeAction extends FacebookAction
                     $flink->foreign_id = $fbuid;
                     $flink->service = 2; # Facebook
                     $flink->created = common_sql_now();
-
-                    # $this->set_flags($flink, $noticesync, $replysync, $friendsync);
+                    $flink->set_flags(true, false, false);
 
                     $flink_id = $flink->insert();
 
index 17812850c05b618d1acafcbc2478a1aa1c3b2510..469bcfc459f19d08204f11f0ce18ff99dae16b76 100644 (file)
@@ -28,30 +28,82 @@ class FacebooksettingsAction extends FacebookAction
     {
         parent::handle($args);
 
-        $this->display();
+        if ($this->arg('save')) {
+            $this->save_settings();
+        } else {
+            $this->show_form();
+        }
     }
 
-    function display()
-    {
+
+    function save_settings() {
+
+        $noticesync = $this->arg('noticesync');
+        $replysync = $this->arg('replysync');
 
         $facebook = get_facebook();
+        $fbuid = $facebook->require_login();
+
+        $flink = Foreign_link::getByForeignID($fbuid, 2); // 2 == Facebook
+
+        $original = clone($flink);
+        $flink->set_flags($noticesync, $replysync, false);
+        $result = $flink->update($original);
+
+        if ($result) {
+            echo '<fb:success message="Sync preferences saved." />';
+        }
+
+        $this->show_form();
+
+    }
+
+    function show_form() {
 
+        $facebook = get_facebook();
         $fbuid = $facebook->require_login();
 
+        $flink = Foreign_link::getByForeignID($fbuid, 2); // 2 == Facebook
+
+        $this->show_header('Settings');
+
         $fbml = '<fb:if-section-not-added section="profile">'
-            .'<h2>Add an Identi.ca box to your profile!</h2>'
+            .'<h2>Add an Identi.ca box to my profile</h2>'
             .'<fb:add-section-button section="profile"/>'
             .'</fb:if-section-not-added>';
 
-
         $fbml .= '<fb:prompt-permission perms="status_update"><h2>Allow Identi.ca to update my Facebook status</h2></fb:prompt-permission>';
 
-        $this->show_header('Settings');
+        $fbml .= '<form method="post" id="facebook_settings">'
+        .'<h2>Sync preferences</h2>'
+        .'<p>';
+
+        if ($flink->noticesync & FOREIGN_NOTICE_SEND) {
+            $fbml .= '<input name="noticesync" type="checkbox" class="checkbox" id="noticesync" checked="checked"/>';
+        } else {
+            $fbml .= '<input name="noticesync" type="checkbox" class="checkbox" id="noticesync">';
+        }
+
+        $fbml .= '<label class="checkbox_label" for="noticesync">Automatically update my Facebook status with my notices.</label>'
+        .'</p>'
+        .'<p>';
+
+        if ($flink->noticesync & FOREIGN_NOTICE_SEND_REPLY) {
+            $fbml .= '<input name="replysync" type="checkbox" class="checkbox" id="replysync" checked="checked"/>';
+        } else {
+            $fbml .= '<input name="replysync" type="checkbox" class="checkbox" id="replysync"/>';
+        }
+
+        $fbml .= '<label class="checkbox_label" for="replysync">Send &quot;@&quot; replies to Facebook.</label>'
+        .'</p>'
+        .'<p>'
+        .'<input type="submit" id="save" name="save" class="submit" value="Save"/>'
+        .'</p>'
+        .'</form>';
 
         echo $fbml;
 
         $this->show_footer();
-
     }
 
 }
index 26dede0ac2cff7889f301d1f33c6b3a9c9d300e0..d664273397b5d3e33be608aea971513fcc1ad8db 100644 (file)
@@ -251,7 +251,7 @@ class TwittersettingsAction extends SettingsAction
         $flink->credentials = $password;
         $flink->created = common_sql_now();
 
-        $this->set_flags($flink, $noticesync, $replysync, $friendsync);
+        $flink->set_flags($noticesync, $replysync, $friendsync);
 
         $flink_id = $flink->insert();
 
@@ -323,7 +323,7 @@ class TwittersettingsAction extends SettingsAction
         $screen_name = $fuser->nickname;
 
         $original = clone($flink);
-        $this->set_flags($flink, $noticesync, $replysync, $friendsync);
+        $flink->set_flags($noticesync, $replysync, $friendsync);
         $result = $flink->update($original);
 
         if ($result === false) {
@@ -363,27 +363,5 @@ class TwittersettingsAction extends SettingsAction
         return false;
     }
 
-    function set_flags(&$flink, $noticesync, $replysync, $friendsync)
-    {
-        if ($noticesync) {
-            $flink->noticesync |= FOREIGN_NOTICE_SEND;
-        } else {
-            $flink->noticesync &= ~FOREIGN_NOTICE_SEND;
-        }
-
-        if ($replysync) {
-            $flink->noticesync |= FOREIGN_NOTICE_SEND_REPLY;
-        } else {
-            $flink->noticesync &= ~FOREIGN_NOTICE_SEND_REPLY;
-        }
-
-        if ($friendsync) {
-            $flink->friendsync |= FOREIGN_FRIEND_RECV;
-        } else {
-            $flink->friendsync &= ~FOREIGN_FRIEND_RECV;
-        }
-
-        $flink->profilesync = 0;
-    }
 
 }
\ No newline at end of file
index c89124d19c59ce84839e09a3ea6f1b2d0b724030..afc0e2180455644130c757e351303f23c6538e5e 100644 (file)
@@ -57,6 +57,29 @@ class Foreign_link extends Memcached_DataObject
         return null;
     }
 
+    function set_flags($noticesync, $replysync, $friendsync)
+    {
+        if ($noticesync) {
+            $this->noticesync |= FOREIGN_NOTICE_SEND;
+        } else {
+            $this->noticesync &= ~FOREIGN_NOTICE_SEND;
+        }
+
+        if ($replysync) {
+            $this->noticesync |= FOREIGN_NOTICE_SEND_REPLY;
+        } else {
+            $this->noticesync &= ~FOREIGN_NOTICE_SEND_REPLY;
+        }
+
+        if ($friendsync) {
+            $this->friendsync |= FOREIGN_FRIEND_RECV;
+        } else {
+            $this->friendsync &= ~FOREIGN_FRIEND_RECV;
+        }
+
+        $this->profilesync = 0;
+    }
+
     # Convenience methods
     function getForeignUser()
     {
index ee9f783c400c746a18b627b73698bf5d4359ace3..7fa097587d8f45035f5f97d93c1f4f9fafe62409 100644 (file)
@@ -37,47 +37,48 @@ class FacebookAction extends Action
 
         # Need to include inline CSS for styling the Profile box
 
-        $style = '<style>
-        #notices {
-        clear: both;
-        margin: 0 auto;
-        padding: 0;
-        list-style-type: none;
-        width: 600px;
-        border-top: 1px solid #dec5b5;
-        }
-        #notices a:hover {
-        text-decoration: underline;
-        }
-        .notice_single {
-        clear: both;
-        display: block;
-        margin: 0;
-        padding: 5px 5px 5px 0;
-        min-height: 48px;
-        font-family: Georgia, "Times New Roman", Times, serif;
-        font-size: 13px;
-        line-height: 16px;
-        border-bottom: 1px solid #dec5b5;
-        background-color:#FCFFF5;
-        opacity:1;
-        }
-        .notice_single:hover {
-        background-color: #f7ebcc;
-        }
-        .notice_single p {
-        display: inline;
-        margin: 0;
-        padding: 0;
-        }
-        </style>';
-
-        $html = $this->render_notice($notice);
-
-        $fbml = "<fb:wide>$content $html</fb:wide>";
-        $fbml .= "<fb:narrow>$content $html</fb:narrow>";
-
-        $fbml_main = "<fb:narrow>$content $html</fb:narrow>";
+         $style = '<style>
+         #notices {
+         clear: both;
+         margin: 0 auto;
+         padding: 0;
+         list-style-type: none;
+         width: 600px;
+         border-top: 1px solid #dec5b5;
+         }
+         #notices a:hover {
+         text-decoration: underline;
+         }
+         .notice_single {
+         clear: both;
+         display: block;
+         margin: 0;
+         padding: 5px 5px 5px 0;
+         min-height: 48px;
+         font-family: Georgia, "Times New Roman", Times, serif;
+         font-size: 13px;
+         line-height: 16px;
+         border-bottom: 1px solid #dec5b5;
+         background-color:#FCFFF5;
+         opacity:1;
+         }
+         .notice_single:hover {
+         background-color: #f7ebcc;
+         }
+         .notice_single p {
+         display: inline;
+         margin: 0;
+         padding: 0;
+         }
+         </style>';
+
+        $html = Facebookaction::Aender_notice($notice);
+
+        $fbml = "<fb:wide>$style $html</fb:wide>";
+        $fbml .= "<fb:narrow>$style $html</fb:narrow>";
+
+        $fbml_main = "<fb:narrow>$style $html</fb:narrow>";
 
         $facebook->api_client->profile_setFBML(null, $fbuid, $fbml, null, null, $fbml_main);
     }
index d2440b163ce1a62c3524447b8a5955fd6918c5cb..02e47cefea514a16369f0100944de4f2d879d7fb 100644 (file)
@@ -52,9 +52,16 @@ while($notice->fetch()) {
 
     $flink = Foreign_link::getByUserID($notice->profile_id, 2);
     $fbuid = $flink->foreign_id;
+    $content = $notice->content;
 
-    update_status($fbuid, $notice);
+    if (($flink->noticesync & FOREIGN_NOTICE_SEND) == FOREIGN_NOTICE_SEND) {
 
+        // If it's not a reply, or if the user WANTS to send replies...
+        if (!preg_match('/@[a-zA-Z0-9_]{1,15}\b/u', $content) ||
+            (($flink->noticesync & FOREIGN_NOTICE_SEND_REPLY) == FOREIGN_NOTICE_SEND_REPLY)) {
+                update_status($fbuid, $content);
+            }
+    }
 }
 
 update_last_updated($current_time);
@@ -63,18 +70,14 @@ exit(0);
 
 
 
-function update_status($fbuid, $notice) {
+function update_status($fbuid, $content) {
     global $facebook;
 
     try {
-
-        $result = $facebook->api_client->users_setStatus($notice->content, $fbuid, false, true);
-
+        $result = $facebook->api_client->users_setStatus($content, $fbuid, false, true);
     } catch(FacebookRestClientException $e){
-
        print_r($e);
     }
-
 }
 
 function get_last_updated(){
index 15afe3e0994caa38384093a7a0f1fda7ad5b217c..a69792432d6945b38ee2f5379a942c74d8eaeb28 100644 (file)
-hunk ./actions/facebookhome.php 39
--        $facebook = $this->get_facebook();
-+        $facebook = get_facebook();
-hunk ./actions/facebookinvite.php 37
--        $facebook = $this->get_facebook();
-+        $facebook = get_facebook();
-hunk ./actions/facebooksettings.php 37
--        $facebook = $this->get_facebook();
-+        $facebook = get_facebook();
-hunk ./actions/facebooksettings.php 47
-+        $fbml .= '<fb:prompt-permission perms="status_update"><h2>Allow Identi.ca to update my Facebook status</h2></fb:prompt-permission>';
-+
-hunk ./classes/Foreign_link.php 7
--class Foreign_link extends Memcached_DataObject 
-+class Foreign_link extends Memcached_DataObject
-hunk ./classes/Foreign_link.php 16
--    public $credentials;                     // varchar(255)  
-+    public $credentials;                     // varchar(255)
-hunk ./classes/Foreign_link.php 32
--    static function getByUserID($user_id, $service) {
-+    static function getByUserID($user_id, $service)
-+    {
-hunk ./classes/Foreign_link.php 43
--        return null;        
-+        return null;
-hunk ./classes/Foreign_link.php 45
--    
--    static function getByForeignID($foreign_id, $service) {
-+
-+    static function getByForeignID($foreign_id, $service)
-+    {
-hunk ./classes/Foreign_link.php 57
--        return null;        
-+        return null;
-hunk ./classes/Foreign_link.php 59
--        
-+
-hunk ./classes/Foreign_link.php 62
--    {        
-+    {
-hunk ./classes/Foreign_link.php 66
--        
-+
-hunk ./classes/Foreign_link.php 68
--        
-+
-hunk ./classes/Foreign_link.php 72
--        
--        return null;        
-+
-+        return null;
-hunk ./classes/Foreign_link.php 75
--    
-+
-hunk ./classes/Foreign_link.php 80
--        
-+
-hunk ./lib/facebookaction.php 22
--require_once(INSTALLDIR.'/extlib/facebook/facebook.php');
-+require_once(INSTALLDIR.'/lib/facebookutil.php');
-+
-hunk ./lib/facebookaction.php 32
+hunk ./actions/facebookhome.php 73
 -
--    function get_facebook()
+-                    # $this->set_flags($flink, $noticesync, $replysync, $friendsync);
++                    $flink->set_flags(true, false, false);
+hunk ./actions/facebooksettings.php 31
+-        $this->display();
++        if ($this->arg('save')) {
++            $this->save_settings();
++        } else {
++            $this->show_form();
++        }
+hunk ./actions/facebooksettings.php 38
+-    function display()
 -    {
--        $apikey = common_config('facebook', 'apikey');
--        $secret = common_config('facebook', 'secret');
--        return new Facebook($apikey, $secret);
--    }
-addfile ./lib/facebookutil.php
-hunk ./lib/facebookutil.php 1
-+<?php
-+/*
-+ * Laconica - a distributed open-source microblogging tool
-+ * Copyright (C) 2008, Controlez-Vous, Inc.
-+ *
-+ * This program is free software: you can redistribute it and/or modify
-+ * it under the terms of the GNU Affero General Public License as published by
-+ * the Free Software Foundation, either version 3 of the License, or
-+ * (at your option) any later version.
-+ *
-+ * This program is distributed in the hope that it will be useful,
-+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
-+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-+ * GNU Affero General Public License for more details.
-+ *
-+ * You should have received a copy of the GNU Affero General Public License
-+ * along with this program.  If not, see <http://www.gnu.org/licenses/>.
-+ */
-+
-+require_once(INSTALLDIR.'/extlib/facebook/facebook.php');
-+
-+// Gets all the notices from users with a Facebook link since a given ID
-+function get_facebook_notices($since)
-+{
-+    $qry = 'SELECT notice.* ' .
-+        'FROM notice ' .
-+        'JOIN foreign_link ' .
-+        'WHERE notice.profile_id = foreign_link.user_id ' .
-+        'AND foreign_link.service = 2';
-+
-+    // XXX: What should the limit be?
-+    return Notice::getStreamDirect($qry, 0, 100, 0, 0, null, $since);
-+}
-+
-+function get_facebook()
-+{
-+    $apikey = common_config('facebook', 'apikey');
-+    $secret = common_config('facebook', 'secret');
-+    return new Facebook($apikey, $secret);
-+}
-addfile ./scripts/update_facebook.php
-hunk ./scripts/update_facebook.php 1
-+#!/usr/bin/env php
-+<?php
-+/*
-+ * Laconica - a distributed open-source microblogging tool
-+ * Copyright (C) 2008, Controlez-Vous, Inc.
-+ *
-+ * This program is free software: you can redistribute it and/or modify
-+ * it under the terms of the GNU Affero General Public License as published by
-+ * the Free Software Foundation, either version 3 of the License, or
-+ * (at your option) any later version.
-+ *
-+ * This program is distributed in the hope that it will be useful,
-+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
-+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.     See the
-+ * GNU Affero General Public License for more details.
-+ *
-+ * You should have received a copy of the GNU Affero General Public License
-+ * along with this program.     If not, see <http://www.gnu.org/licenses/>.
-+ */
-+
-+# Abort if called from a web server
-+if (isset($_SERVER) && array_key_exists('REQUEST_METHOD', $_SERVER)) {
-+    print "This script must be run from the command line\n";
-+    exit();
-+}
-+
-+define('INSTALLDIR', realpath(dirname(__FILE__) . '/..'));
-+define('LACONICA', true);
-+
-+require_once(INSTALLDIR . '/lib/common.php');
-+require_once(INSTALLDIR . '/lib/facebookutil.php');
-+
-+// For storing the last run date-time
-+$last_updated_file = "/home/zach/laconica/scripts/facebook_last_updated";
-+
-+// Lock file name
-+$tmp_file = "/tmp/update_facebook.lock";
-+
-+// Make sure only one copy of the script is running at a time
-+if (!($tmp_file = @fopen($tmp_file, "w")))
-+{
-+      die("Can't open lock file. Script already running?");
-+}
-+
-+$facebook = get_facebook();
-+
-+$current_time = time();
-+
-+$notice = get_facebook_notices(get_last_updated());
-+
-+while($notice->fetch()) {
-+
-+    $flink = Foreign_link::getByUserID($notice->profile_id, 2);
-+    $fbuid = $flink->foreign_id;
-+
-+    update_status($fbuid, $notice);
-+
-+}
-+
-+update_last_updated($current_time);
-+
-+exit(0);
-+
-+
-+
-+function update_status($fbuid, $notice) {
-+    global $facebook;
-+
-+    try {
 +
-+        $result = $facebook->api_client->users_setStatus($notice->content, $fbuid, false, true);
++    function save_settings() {
 +
-+    } catch(FacebookRestClientException $e){
++        $noticesync = $this->arg('noticesync');
++        $replysync = $this->arg('replysync');
+hunk ./actions/facebooksettings.php 45
++        $fbuid = $facebook->require_login();
 +
-+      print_r($e);
-+    }
++        $flink = Foreign_link::getByForeignID($fbuid, 2); // 2 == Facebook
++
++        $original = clone($flink);
++        $flink->set_flags($noticesync, $replysync, false);
++        $result = $flink->update($original);
 +
-+}
++        if ($result) {
++            echo '<fb:success message="Sync preferences saved." />';
++        }
+hunk ./actions/facebooksettings.php 57
++        $this->show_form();
 +
-+function get_last_updated(){
-+      global $last_updated_file, $current_time;
++    }
 +
-+      $file = fopen($last_updated_file, 'r');
++    function show_form() {
 +
-+      if ($file) {
-+          $last = fgets($file);
-+      } else {
-+          print "Unable to read $last_updated_file. Using current time.\n";
-+          return $current_time;
-+      }
++        $facebook = get_facebook();
+hunk ./actions/facebooksettings.php 66
++        $flink = Foreign_link::getByForeignID($fbuid, 2); // 2 == Facebook
 +
-+      fclose($file);
++        $this->show_header('Settings');
 +
-+      return $last;
-+}
+hunk ./actions/facebooksettings.php 71
+-            .'<h2>Add an Identi.ca box to your profile!</h2>'
++            .'<h2>Add an Identi.ca box to my profile</h2>'
+hunk ./actions/facebooksettings.php 75
+-
+hunk ./actions/facebooksettings.php 77
+-        $this->show_header('Settings');
++        $fbml .= '<form method="post" id="facebook_settings">'
++        .'<h2>Sync preferences</h2>'
++        .'<p>';
++
++        if ($flink->noticesync & FOREIGN_NOTICE_SEND) {
++            $fbml .= '<input name="noticesync" type="checkbox" class="checkbox" id="noticesync" checked="checked"/>';
++        } else {
++            $fbml .= '<input name="noticesync" type="checkbox" class="checkbox" id="noticesync">';
++        }
++
++        $fbml .= '<label class="checkbox_label" for="noticesync">Automatically update my Facebook status with my notices.</label>'
++        .'</p>'
++        .'<p>';
++
++        if ($flink->noticesync & FOREIGN_NOTICE_SEND_REPLY) {
++            $fbml .= '<input name="replysync" type="checkbox" class="checkbox" id="replysync" checked="checked"/>';
++        } else {
++            $fbml .= '<input name="replysync" type="checkbox" class="checkbox" id="replysync"/>';
++        }
++
++        $fbml .= '<label class="checkbox_label" for="replysync">Send &quot;@&quot; replies to Facebook.</label>'
++        .'</p>'
++        .'<p>'
++        .'<input type="submit" id="save" name="save" class="submit" value="Save"/>'
++        .'</p>'
++        .'</form>';
+hunk ./actions/facebooksettings.php 107
+-
+hunk ./actions/twittersettings.php 254
+-        $this->set_flags($flink, $noticesync, $replysync, $friendsync);
++        $flink->set_flags($noticesync, $replysync, $friendsync);
+hunk ./actions/twittersettings.php 326
+-        $this->set_flags($flink, $noticesync, $replysync, $friendsync);
++        $flink->set_flags($noticesync, $replysync, $friendsync);
+hunk ./actions/twittersettings.php 366
+-    function set_flags(&$flink, $noticesync, $replysync, $friendsync)
+-    {
+-        if ($noticesync) {
+-            $flink->noticesync |= FOREIGN_NOTICE_SEND;
+-        } else {
+-            $flink->noticesync &= ~FOREIGN_NOTICE_SEND;
+-        }
+-
+-        if ($replysync) {
+-            $flink->noticesync |= FOREIGN_NOTICE_SEND_REPLY;
+-        } else {
+-            $flink->noticesync &= ~FOREIGN_NOTICE_SEND_REPLY;
+-        }
+-
+-        if ($friendsync) {
+-            $flink->friendsync |= FOREIGN_FRIEND_RECV;
+-        } else {
+-            $flink->friendsync &= ~FOREIGN_FRIEND_RECV;
+-        }
+-
+-        $flink->profilesync = 0;
+-    }
+hunk ./classes/Foreign_link.php 59
 +
-+function update_last_updated($time){
-+      global $last_updated_file;
-+      $file = fopen($last_updated_file, 'w') or die("Can't open $last_updated_file for writing!");
-+      fwrite($file, $time);
-+      fclose($file);
-+}
++    function set_flags($noticesync, $replysync, $friendsync)
++    {
++        if ($noticesync) {
++            $this->noticesync |= FOREIGN_NOTICE_SEND;
++        } else {
++            $this->noticesync &= ~FOREIGN_NOTICE_SEND;
++        }
++
++        if ($replysync) {
++            $this->noticesync |= FOREIGN_NOTICE_SEND_REPLY;
++        } else {
++            $this->noticesync &= ~FOREIGN_NOTICE_SEND_REPLY;
++        }
++
++        if ($friendsync) {
++            $this->friendsync |= FOREIGN_FRIEND_RECV;
++        } else {
++            $this->friendsync &= ~FOREIGN_FRIEND_RECV;
++        }
++
++        $this->profilesync = 0;
++    }
+hunk ./lib/facebookaction.php 40
+-        $style = '<style>
+-        #notices {
+-        clear: both;
+-        margin: 0 auto;
+-        padding: 0;
+-        list-style-type: none;
+-        width: 600px;
+-        border-top: 1px solid #dec5b5;
+-        }
+-        #notices a:hover {
+-        text-decoration: underline;
+-        }
+-        .notice_single {
+-        clear: both;
+-        display: block;
+-        margin: 0;
+-        padding: 5px 5px 5px 0;
+-        min-height: 48px;
+-        font-family: Georgia, "Times New Roman", Times, serif;
+-        font-size: 13px;
+-        line-height: 16px;
+-        border-bottom: 1px solid #dec5b5;
+-        background-color:#FCFFF5;
+-        opacity:1;
+-        }
+-        .notice_single:hover {
+-        background-color: #f7ebcc;
+-        }
+-        .notice_single p {
+-        display: inline;
+-        margin: 0;
+-        padding: 0;
+-        }
+-        </style>';
++         $style = '<style>
++         #notices {
++         clear: both;
++         margin: 0 auto;
++         padding: 0;
++         list-style-type: none;
++         width: 600px;
++         border-top: 1px solid #dec5b5;
++         }
++         #notices a:hover {
++         text-decoration: underline;
++         }
++         .notice_single {
++         clear: both;
++         display: block;
++         margin: 0;
++         padding: 5px 5px 5px 0;
++         min-height: 48px;
++         font-family: Georgia, "Times New Roman", Times, serif;
++         font-size: 13px;
++         line-height: 16px;
++         border-bottom: 1px solid #dec5b5;
++         background-color:#FCFFF5;
++         opacity:1;
++         }
++         .notice_single:hover {
++         background-color: #f7ebcc;
++         }
++         .notice_single p {
++         display: inline;
++         margin: 0;
++         padding: 0;
++         }
++         </style>';
+hunk ./lib/facebookaction.php 75
+-        $html = $this->render_notice($notice);
++        $html = Facebookaction::Aender_notice($notice);
+hunk ./lib/facebookaction.php 77
+-        $fbml = "<fb:wide>$content $html</fb:wide>";
+-        $fbml .= "<fb:narrow>$content $html</fb:narrow>";
++ 
++        $fbml = "<fb:wide>$style $html</fb:wide>";
++        $fbml .= "<fb:narrow>$style $html</fb:narrow>";
+hunk ./lib/facebookaction.php 81
+-        $fbml_main = "<fb:narrow>$content $html</fb:narrow>";
++        $fbml_main = "<fb:narrow>$style $html</fb:narrow>";
+hunk ./scripts/update_facebook.php 55
++    $content = $notice->content;
+hunk ./scripts/update_facebook.php 57
+-    update_status($fbuid, $notice);
++    if (($flink->noticesync & FOREIGN_NOTICE_SEND) == FOREIGN_NOTICE_SEND) {
+hunk ./scripts/update_facebook.php 59
++        // If it's not a reply, or if the user WANTS to send replies...
++        if (!preg_match('/@[a-zA-Z0-9_]{1,15}\b/u', $content) ||
++            (($flink->noticesync & FOREIGN_NOTICE_SEND_REPLY) == FOREIGN_NOTICE_SEND_REPLY)) {
++                update_status($fbuid, $content);
++            }
++    }
+hunk ./scripts/update_facebook.php 73
+-function update_status($fbuid, $notice) {
++function update_status($fbuid, $content) {
+hunk ./scripts/update_facebook.php 77
+-
+-        $result = $facebook->api_client->users_setStatus($notice->content, $fbuid, false, true);
+-
++        $result = $facebook->api_client->users_setStatus($content, $fbuid, false, true);
+hunk ./scripts/update_facebook.php 79
+-
+hunk ./scripts/update_facebook.php 81
+-
index a23d1aa07f516a58bebc9efe3bb43dbc81bc9812..069ea5e75ce691c1cae0ed27e0cff41fc9fcba90 100644 (file)
@@ -70,8 +70,7 @@ class FacebookhomeAction extends FacebookAction
                     $flink->foreign_id = $fbuid;
                     $flink->service = 2; # Facebook
                     $flink->created = common_sql_now();
-
-                    # $this->set_flags($flink, $noticesync, $replysync, $friendsync);
+                    $flink->set_flags(true, false, false);
 
                     $flink_id = $flink->insert();
 
index 17812850c05b618d1acafcbc2478a1aa1c3b2510..469bcfc459f19d08204f11f0ce18ff99dae16b76 100644 (file)
@@ -28,30 +28,82 @@ class FacebooksettingsAction extends FacebookAction
     {
         parent::handle($args);
 
-        $this->display();
+        if ($this->arg('save')) {
+            $this->save_settings();
+        } else {
+            $this->show_form();
+        }
     }
 
-    function display()
-    {
+
+    function save_settings() {
+
+        $noticesync = $this->arg('noticesync');
+        $replysync = $this->arg('replysync');
 
         $facebook = get_facebook();
+        $fbuid = $facebook->require_login();
+
+        $flink = Foreign_link::getByForeignID($fbuid, 2); // 2 == Facebook
+
+        $original = clone($flink);
+        $flink->set_flags($noticesync, $replysync, false);
+        $result = $flink->update($original);
+
+        if ($result) {
+            echo '<fb:success message="Sync preferences saved." />';
+        }
+
+        $this->show_form();
+
+    }
+
+    function show_form() {
 
+        $facebook = get_facebook();
         $fbuid = $facebook->require_login();
 
+        $flink = Foreign_link::getByForeignID($fbuid, 2); // 2 == Facebook
+
+        $this->show_header('Settings');
+
         $fbml = '<fb:if-section-not-added section="profile">'
-            .'<h2>Add an Identi.ca box to your profile!</h2>'
+            .'<h2>Add an Identi.ca box to my profile</h2>'
             .'<fb:add-section-button section="profile"/>'
             .'</fb:if-section-not-added>';
 
-
         $fbml .= '<fb:prompt-permission perms="status_update"><h2>Allow Identi.ca to update my Facebook status</h2></fb:prompt-permission>';
 
-        $this->show_header('Settings');
+        $fbml .= '<form method="post" id="facebook_settings">'
+        .'<h2>Sync preferences</h2>'
+        .'<p>';
+
+        if ($flink->noticesync & FOREIGN_NOTICE_SEND) {
+            $fbml .= '<input name="noticesync" type="checkbox" class="checkbox" id="noticesync" checked="checked"/>';
+        } else {
+            $fbml .= '<input name="noticesync" type="checkbox" class="checkbox" id="noticesync">';
+        }
+
+        $fbml .= '<label class="checkbox_label" for="noticesync">Automatically update my Facebook status with my notices.</label>'
+        .'</p>'
+        .'<p>';
+
+        if ($flink->noticesync & FOREIGN_NOTICE_SEND_REPLY) {
+            $fbml .= '<input name="replysync" type="checkbox" class="checkbox" id="replysync" checked="checked"/>';
+        } else {
+            $fbml .= '<input name="replysync" type="checkbox" class="checkbox" id="replysync"/>';
+        }
+
+        $fbml .= '<label class="checkbox_label" for="replysync">Send &quot;@&quot; replies to Facebook.</label>'
+        .'</p>'
+        .'<p>'
+        .'<input type="submit" id="save" name="save" class="submit" value="Save"/>'
+        .'</p>'
+        .'</form>';
 
         echo $fbml;
 
         $this->show_footer();
-
     }
 
 }
index 26dede0ac2cff7889f301d1f33c6b3a9c9d300e0..d664273397b5d3e33be608aea971513fcc1ad8db 100644 (file)
@@ -251,7 +251,7 @@ class TwittersettingsAction extends SettingsAction
         $flink->credentials = $password;
         $flink->created = common_sql_now();
 
-        $this->set_flags($flink, $noticesync, $replysync, $friendsync);
+        $flink->set_flags($noticesync, $replysync, $friendsync);
 
         $flink_id = $flink->insert();
 
@@ -323,7 +323,7 @@ class TwittersettingsAction extends SettingsAction
         $screen_name = $fuser->nickname;
 
         $original = clone($flink);
-        $this->set_flags($flink, $noticesync, $replysync, $friendsync);
+        $flink->set_flags($noticesync, $replysync, $friendsync);
         $result = $flink->update($original);
 
         if ($result === false) {
@@ -363,27 +363,5 @@ class TwittersettingsAction extends SettingsAction
         return false;
     }
 
-    function set_flags(&$flink, $noticesync, $replysync, $friendsync)
-    {
-        if ($noticesync) {
-            $flink->noticesync |= FOREIGN_NOTICE_SEND;
-        } else {
-            $flink->noticesync &= ~FOREIGN_NOTICE_SEND;
-        }
-
-        if ($replysync) {
-            $flink->noticesync |= FOREIGN_NOTICE_SEND_REPLY;
-        } else {
-            $flink->noticesync &= ~FOREIGN_NOTICE_SEND_REPLY;
-        }
-
-        if ($friendsync) {
-            $flink->friendsync |= FOREIGN_FRIEND_RECV;
-        } else {
-            $flink->friendsync &= ~FOREIGN_FRIEND_RECV;
-        }
-
-        $flink->profilesync = 0;
-    }
 
 }
\ No newline at end of file
index c89124d19c59ce84839e09a3ea6f1b2d0b724030..afc0e2180455644130c757e351303f23c6538e5e 100644 (file)
@@ -57,6 +57,29 @@ class Foreign_link extends Memcached_DataObject
         return null;
     }
 
+    function set_flags($noticesync, $replysync, $friendsync)
+    {
+        if ($noticesync) {
+            $this->noticesync |= FOREIGN_NOTICE_SEND;
+        } else {
+            $this->noticesync &= ~FOREIGN_NOTICE_SEND;
+        }
+
+        if ($replysync) {
+            $this->noticesync |= FOREIGN_NOTICE_SEND_REPLY;
+        } else {
+            $this->noticesync &= ~FOREIGN_NOTICE_SEND_REPLY;
+        }
+
+        if ($friendsync) {
+            $this->friendsync |= FOREIGN_FRIEND_RECV;
+        } else {
+            $this->friendsync &= ~FOREIGN_FRIEND_RECV;
+        }
+
+        $this->profilesync = 0;
+    }
+
     # Convenience methods
     function getForeignUser()
     {
index ee9f783c400c746a18b627b73698bf5d4359ace3..7fa097587d8f45035f5f97d93c1f4f9fafe62409 100644 (file)
@@ -37,47 +37,48 @@ class FacebookAction extends Action
 
         # Need to include inline CSS for styling the Profile box
 
-        $style = '<style>
-        #notices {
-        clear: both;
-        margin: 0 auto;
-        padding: 0;
-        list-style-type: none;
-        width: 600px;
-        border-top: 1px solid #dec5b5;
-        }
-        #notices a:hover {
-        text-decoration: underline;
-        }
-        .notice_single {
-        clear: both;
-        display: block;
-        margin: 0;
-        padding: 5px 5px 5px 0;
-        min-height: 48px;
-        font-family: Georgia, "Times New Roman", Times, serif;
-        font-size: 13px;
-        line-height: 16px;
-        border-bottom: 1px solid #dec5b5;
-        background-color:#FCFFF5;
-        opacity:1;
-        }
-        .notice_single:hover {
-        background-color: #f7ebcc;
-        }
-        .notice_single p {
-        display: inline;
-        margin: 0;
-        padding: 0;
-        }
-        </style>';
-
-        $html = $this->render_notice($notice);
-
-        $fbml = "<fb:wide>$content $html</fb:wide>";
-        $fbml .= "<fb:narrow>$content $html</fb:narrow>";
-
-        $fbml_main = "<fb:narrow>$content $html</fb:narrow>";
+         $style = '<style>
+         #notices {
+         clear: both;
+         margin: 0 auto;
+         padding: 0;
+         list-style-type: none;
+         width: 600px;
+         border-top: 1px solid #dec5b5;
+         }
+         #notices a:hover {
+         text-decoration: underline;
+         }
+         .notice_single {
+         clear: both;
+         display: block;
+         margin: 0;
+         padding: 5px 5px 5px 0;
+         min-height: 48px;
+         font-family: Georgia, "Times New Roman", Times, serif;
+         font-size: 13px;
+         line-height: 16px;
+         border-bottom: 1px solid #dec5b5;
+         background-color:#FCFFF5;
+         opacity:1;
+         }
+         .notice_single:hover {
+         background-color: #f7ebcc;
+         }
+         .notice_single p {
+         display: inline;
+         margin: 0;
+         padding: 0;
+         }
+         </style>';
+
+        $html = Facebookaction::Aender_notice($notice);
+
+        $fbml = "<fb:wide>$style $html</fb:wide>";
+        $fbml .= "<fb:narrow>$style $html</fb:narrow>";
+
+        $fbml_main = "<fb:narrow>$style $html</fb:narrow>";
 
         $facebook->api_client->profile_setFBML(null, $fbuid, $fbml, null, null, $fbml_main);
     }
index d2440b163ce1a62c3524447b8a5955fd6918c5cb..02e47cefea514a16369f0100944de4f2d879d7fb 100755 (executable)
@@ -52,9 +52,16 @@ while($notice->fetch()) {
 
     $flink = Foreign_link::getByUserID($notice->profile_id, 2);
     $fbuid = $flink->foreign_id;
+    $content = $notice->content;
 
-    update_status($fbuid, $notice);
+    if (($flink->noticesync & FOREIGN_NOTICE_SEND) == FOREIGN_NOTICE_SEND) {
 
+        // If it's not a reply, or if the user WANTS to send replies...
+        if (!preg_match('/@[a-zA-Z0-9_]{1,15}\b/u', $content) ||
+            (($flink->noticesync & FOREIGN_NOTICE_SEND_REPLY) == FOREIGN_NOTICE_SEND_REPLY)) {
+                update_status($fbuid, $content);
+            }
+    }
 }
 
 update_last_updated($current_time);
@@ -63,18 +70,14 @@ exit(0);
 
 
 
-function update_status($fbuid, $notice) {
+function update_status($fbuid, $content) {
     global $facebook;
 
     try {
-
-        $result = $facebook->api_client->users_setStatus($notice->content, $fbuid, false, true);
-
+        $result = $facebook->api_client->users_setStatus($content, $fbuid, false, true);
     } catch(FacebookRestClientException $e){
-
        print_r($e);
     }
-
 }
 
 function get_last_updated(){