diff options
author | Craig Andrews <candrews@integralblue.com> | 2010-02-22 22:57:16 -0500 |
---|---|---|
committer | Craig Andrews <candrews@integralblue.com> | 2010-02-22 23:09:14 -0500 |
commit | f0d1d07b94fbd2fe0ecd1c2f18d831a177d11c5c (patch) | |
tree | 92695af4999f72917dab39d65cbef7b8f4d8c5f2 /lib/subs.php | |
parent | daccaeb748fff65186fff85e28cda92f268dbc60 (diff) |
Add lose <nickname> command to the command interpreter
Diffstat (limited to 'lib/subs.php')
-rw-r--r-- | lib/subs.php | 45 |
1 files changed, 44 insertions, 1 deletions
diff --git a/lib/subs.php b/lib/subs.php index 1c240c475..e2ce0667e 100644 --- a/lib/subs.php +++ b/lib/subs.php @@ -42,4 +42,47 @@ function subs_unsubscribe_to($user, $other) } catch (Exception $e) { return $e->getMessage(); } -}
\ No newline at end of file +} + +function subs_unsubscribe_from($user, $other){ + $local = User::staticGet("nickname",$other); + if($local){ + return subs_unsubscribe_to($local,$user); + } else { + try { + $remote = Profile::staticGet("nickname",$other); + if(is_string($remote)){ + return $remote; + } + if (Event::handle('StartUnsubscribe', array($remote,$user))) { + + $sub = DB_DataObject::factory('subscription'); + + $sub->subscriber = $remote->id; + $sub->subscribed = $user->id; + + $sub->find(true); + + // note we checked for existence above + + if (!$sub->delete()) + return _('Couldn\'t delete subscription.'); + + $cache = common_memcache(); + + if ($cache) { + $cache->delete(common_cache_key('user:notices_with_friends:' . $remote->id)); + } + + + $user->blowSubscribersCount(); + $remote->blowSubscribersCount(); + + Event::handle('EndUnsubscribe', array($remote, $user)); + } + } catch (Exception $e) { + return $e->getMessage(); + } + } +} + |