<?php
/**
* StatusNet - the distributed open-source microblogging tool
- * Copyright (C) 2008-2010, StatusNet, Inc.
+ * Copyright (C) 2008-2011, StatusNet, Inc.
*
* Subscription action.
*
$this->user = common_current_user();
if (empty($this->user)) {
- // TRANS: Client error displayed trying to subscribe when not logged in.
+ // TRANS: Error message displayed when trying to perform an action that requires a logged in user.
$this->clientError(_('Not logged in.'));
return false;
}
return false;
}
- // OMB 0.1 doesn't have a mechanism for local-server-
- // originated subscription.
-
- $omb01 = Remote_profile::staticGet('id', $other_id);
-
- if (!empty($omb01)) {
- // TRANS: Client error displayed trying to subscribe to an OMB 0.1 remote profile.
- $this->clientError(_('You cannot subscribe to an OMB 0.1'.
- ' remote profile with this action.'));
- return false;
- }
-
return true;
}
{
// Throws exception on error
- Subscription::start($this->user->getProfile(),
- $this->other);
+ $sub = Subscription::start($this->user->getProfile(),
+ $this->other);
if ($this->boolean('ajax')) {
$this->startHTML('text/xml;charset=utf-8');
$this->element('title', null, _('Subscribed'));
$this->elementEnd('head');
$this->elementStart('body');
- $unsubscribe = new UnsubscribeForm($this, $this->other);
- $unsubscribe->show();
+ if ($sub instanceof Subscription) {
+ $form = new UnsubscribeForm($this, $this->other);
+ } else {
+ $form = new CancelSubscriptionForm($this, $this->other);
+ }
+ $form->show();
$this->elementEnd('body');
$this->elementEnd('html');
} else {