function handle($args) { parent::handle($args); if (!common_logged_in()) { $this->clientError(_('Not logged in.')); return; } $user = common_current_user(); if ($_SERVER['REQUEST_METHOD'] != 'POST') { common_redirect(common_local_url('subscriptions', array('nickname' => $user->nickname))); return; } # CSRF protection $token = $this->trimmed('token'); if (!$token || $token != common_session_token()) { $this->clientError(_('There was a problem with your session token. Try again, please.')); return; } $other_id = $this->arg('subscribeto'); $other = User::staticGet('id', $other_id); if (!$other) { $this->clientError(_('Not a local user.')); return; } $result = subs_subscribe_to($user, $other); if ($result != true) { $this->clientError($result); return; } if ($this->boolean('ajax')) { $this->startHTML('text/xml;charset=utf-8'); $this->elementStart('head'); $this->element('title', null, _('Subscribed')); $this->elementEnd('head'); $this->elementStart('body'); $unsubscribe = new UnsubscribeForm($this, $other->getProfile()); $unsubscribe->show(); $this->elementEnd('body'); $this->elementEnd('html'); } else { common_redirect(common_local_url('subscriptions', array('nickname' => $user->nickname))); } }
function showProfile() { $this->elementStart('div', 'entity_profile vcard author'); $this->element('h2', null, _('User profile')); $avatar = $this->profile->getAvatar(AVATAR_PROFILE_SIZE); $this->elementStart('dl', 'entity_depiction'); $this->element('dt', null, _('Photo')); $this->elementStart('dd'); $this->element('img', array('src' => $avatar ? $avatar->displayUrl() : Avatar::defaultImage(AVATAR_PROFILE_SIZE), 'class' => 'photo avatar', 'width' => AVATAR_PROFILE_SIZE, 'height' => AVATAR_PROFILE_SIZE, 'alt' => $this->profile->nickname)); $this->elementEnd('dd'); $user = User::staticGet('id', $this->profile->id); $cur = common_current_user(); if ($cur && $cur->id == $user->id) { $this->elementStart('dd'); $this->element('a', array('href' => common_local_url('avatarsettings')), _('Edit Avatar')); $this->elementEnd('dd'); } $this->elementEnd('dl'); $this->elementStart('dl', 'entity_nickname'); $this->element('dt', null, _('Nickname')); $this->elementStart('dd'); $hasFN = $this->profile->fullname ? 'nickname url uid' : 'fn nickname url uid'; $this->element('a', array('href' => $this->profile->profileurl, 'rel' => 'me', 'class' => $hasFN), $this->profile->nickname); $this->elementEnd('dd'); $this->elementEnd('dl'); if ($this->profile->fullname) { $this->elementStart('dl', 'entity_fn'); $this->element('dt', null, _('Full name')); $this->elementStart('dd'); $this->element('span', 'fn', $this->profile->fullname); $this->elementEnd('dd'); $this->elementEnd('dl'); } if ($this->profile->location) { $this->elementStart('dl', 'entity_location'); $this->element('dt', null, _('Location')); $this->element('dd', 'label', $this->profile->location); $this->elementEnd('dl'); } if ($this->profile->homepage) { $this->elementStart('dl', 'entity_url'); $this->element('dt', null, _('URL')); $this->elementStart('dd'); $this->element('a', array('href' => $this->profile->homepage, 'rel' => 'me', 'class' => 'url'), $this->profile->homepage); $this->elementEnd('dd'); $this->elementEnd('dl'); } if ($this->profile->bio) { $this->elementStart('dl', 'entity_note'); $this->element('dt', null, _('Note')); $this->element('dd', 'note', $this->profile->bio); $this->elementEnd('dl'); } $tags = Profile_tag::getTags($this->profile->id, $this->profile->id); if (count($tags) > 0) { $this->elementStart('dl', 'entity_tags'); $this->element('dt', null, _('Tags')); $this->elementStart('dd'); $this->elementStart('ul', 'tags xoxo'); foreach ($tags as $tag) { $this->elementStart('li'); // Avoid space by using raw output. $pt = '<span class="mark_hash">#</span><a rel="tag" href="' . common_local_url('peopletag', array('tag' => $tag)) . '">' . $tag . '</a>'; $this->raw($pt); $this->elementEnd('li'); } $this->elementEnd('ul'); $this->elementEnd('dd'); $this->elementEnd('dl'); } $this->elementEnd('div'); $this->elementStart('div', 'entity_actions'); $this->element('h2', null, _('User actions')); $this->elementStart('ul'); $cur = common_current_user(); if ($cur && $cur->id == $this->profile->id) { $this->elementStart('li', 'entity_edit'); $this->element('a', array('href' => common_local_url('profilesettings'), 'title' => _('Edit profile settings')), _('Edit')); $this->elementEnd('li'); } if ($cur) { if ($cur->id != $this->profile->id) { $this->elementStart('li', 'entity_subscribe'); if ($cur->isSubscribed($this->profile)) { $usf = new UnsubscribeForm($this, $this->profile); $usf->show(); } else { $sf = new SubscribeForm($this, $this->profile); $sf->show(); } $this->elementEnd('li'); } } else { $this->elementStart('li', 'entity_subscribe'); $this->showRemoteSubscribeLink(); $this->elementEnd('li'); } if ($cur && $cur->id != $user->id && $cur->mutuallySubscribed($user)) { $this->elementStart('li', 'entity_send-a-message'); $this->element('a', array('href' => common_local_url('newmessage', array('to' => $user->id)), 'title' => _('Send a direct message to this user')), _('Message')); $this->elementEnd('li'); if ($user->email && $user->emailnotifynudge) { $this->elementStart('li', 'entity_nudge'); $nf = new NudgeForm($this, $user); $nf->show(); $this->elementEnd('li'); } } if ($cur && $cur->id != $this->profile->id) { $blocked = $cur->hasBlocked($this->profile); $this->elementStart('li', 'entity_block'); if ($blocked) { $ubf = new UnblockForm($this, $this->profile); $ubf->show(); } else { $bf = new BlockForm($this, $this->profile); $bf->show(); } $this->elementEnd('li'); } $this->elementEnd('ul'); $this->elementEnd('div'); }
/** * Handle request * * Does the subscription and returns results. * * @param Array $args unused. * * @return void */ function handle($args) { // Throws exception on error Subscription::start($this->user->getProfile(), $this->other); if ($this->boolean('ajax')) { $this->startHTML('text/xml;charset=utf-8'); $this->elementStart('head'); $this->element('title', null, _('Subscribed')); $this->elementEnd('head'); $this->elementStart('body'); $unsubscribe = new UnsubscribeForm($this, $this->other); $unsubscribe->show(); $this->elementEnd('body'); $this->elementEnd('html'); } else { $url = common_local_url('subscriptions', array('nickname' => $this->user->nickname)); common_redirect($url, 303); } }
function showSubscribeButton() { // Is this a logged-in user, looking at someone else's // profile? $user = common_current_user(); if (!empty($user) && $this->profile->id != $user->id) { $this->out->elementStart('li', 'entity_subscribe'); if ($user->isSubscribed($this->profile)) { $usf = new UnsubscribeForm($this->out, $this->profile); $usf->show(); } else { if (Event::handle('StartShowProfileListSubscribeButton', array($this))) { $sf = new SubscribeForm($this->out, $this->profile); $sf->show(); Event::handle('EndShowProfileListSubscribeButton', array($this)); } } $this->out->elementEnd('li'); } }
function showEntityActions() { if ($this->profile->hasRole(Profile_role::DELETED)) { $this->out->elementStart('div', 'entity_actions'); $this->out->element('h2', null, _('User actions')); $this->out->elementStart('ul'); $this->out->elementStart('p', array('class' => 'profile_deleted')); $this->out->text(_('User deletion in progress...')); $this->out->elementEnd('p'); $this->out->elementEnd('ul'); $this->out->elementEnd('div'); return; } if (Event::handle('StartProfilePageActionsSection', array(&$this->out, $this->profile))) { $cur = common_current_user(); $this->out->elementStart('div', 'entity_actions'); $this->out->element('h2', null, _('User actions')); $this->out->elementStart('ul'); if (Event::handle('StartProfilePageActionsElements', array(&$this->out, $this->profile))) { if (empty($cur)) { // not logged in if (Event::handle('StartProfileRemoteSubscribe', array(&$this->out, $this->profile))) { $this->out->elementStart('li', 'entity_subscribe'); $this->showRemoteSubscribeLink(); $this->out->elementEnd('li'); Event::handle('EndProfileRemoteSubscribe', array(&$this->out, $this->profile)); } } else { if ($cur->id == $this->profile->id) { // your own page $this->out->elementStart('li', 'entity_edit'); $this->out->element('a', array('href' => common_local_url('profilesettings'), 'title' => _('Edit profile settings')), _('Edit')); $this->out->elementEnd('li'); } else { // someone else's page // subscribe/unsubscribe button $this->out->elementStart('li', 'entity_subscribe'); if ($cur->isSubscribed($this->profile)) { $usf = new UnsubscribeForm($this->out, $this->profile); $usf->show(); } else { $sf = new SubscribeForm($this->out, $this->profile); $sf->show(); } $this->out->elementEnd('li'); if ($cur->mutuallySubscribed($this->user)) { // message $this->out->elementStart('li', 'entity_send-a-message'); $this->out->element('a', array('href' => common_local_url('newmessage', array('to' => $this->user->id)), 'title' => _('Send a direct message to this user')), _('Message')); $this->out->elementEnd('li'); // nudge if ($this->user->email && $this->user->emailnotifynudge) { $this->out->elementStart('li', 'entity_nudge'); $nf = new NudgeForm($this->out, $this->user); $nf->show(); $this->out->elementEnd('li'); } } // return-to args, so we don't have to keep re-writing them list($action, $r2args) = $this->out->returnToArgs(); // push the action into the list $r2args['action'] = $action; // block/unblock $blocked = $cur->hasBlocked($this->profile); $this->out->elementStart('li', 'entity_block'); if ($blocked) { $ubf = new UnblockForm($this->out, $this->profile, $r2args); $ubf->show(); } else { $bf = new BlockForm($this->out, $this->profile, $r2args); $bf->show(); } $this->out->elementEnd('li'); if ($cur->hasRight(Right::SANDBOXUSER) || $cur->hasRight(Right::SILENCEUSER) || $cur->hasRight(Right::DELETEUSER)) { $this->out->elementStart('li', 'entity_moderation'); $this->out->element('p', null, _('Moderate')); $this->out->elementStart('ul'); if ($cur->hasRight(Right::SANDBOXUSER)) { $this->out->elementStart('li', 'entity_sandbox'); if ($this->user->isSandboxed()) { $usf = new UnSandboxForm($this->out, $this->profile, $r2args); $usf->show(); } else { $sf = new SandboxForm($this->out, $this->profile, $r2args); $sf->show(); } $this->out->elementEnd('li'); } if ($cur->hasRight(Right::SILENCEUSER)) { $this->out->elementStart('li', 'entity_silence'); if ($this->user->isSilenced()) { $usf = new UnSilenceForm($this->out, $this->profile, $r2args); $usf->show(); } else { $sf = new SilenceForm($this->out, $this->profile, $r2args); $sf->show(); } $this->out->elementEnd('li'); } if ($cur->hasRight(Right::DELETEUSER)) { $this->out->elementStart('li', 'entity_delete'); $df = new DeleteUserForm($this->out, $this->profile, $r2args); $df->show(); $this->out->elementEnd('li'); } $this->out->elementEnd('ul'); $this->out->elementEnd('li'); } if ($cur->hasRight(Right::GRANTROLE)) { $this->out->elementStart('li', 'entity_role'); $this->out->element('p', null, _('User role')); $this->out->elementStart('ul'); $this->roleButton('administrator', _m('role', 'Administrator')); $this->roleButton('moderator', _m('role', 'Moderator')); $this->out->elementEnd('ul'); $this->out->elementEnd('li'); } } } Event::handle('EndProfilePageActionsElements', array(&$this->out, $this->profile)); } $this->out->elementEnd('ul'); $this->out->elementEnd('div'); Event::handle('EndProfilePageActionsSection', array(&$this->out, $this->profile)); } }
function showActions() { if (Event::handle('StartProfilePageActionsSection', array($this->out, $this->profile))) { if ($this->profile->hasRole(Profile_role::DELETED)) { $this->out->elementStart('div', 'entity_actions'); // TRANS: H2 for user actions in a profile. $this->out->element('h2', null, _('User actions')); $this->out->elementStart('ul'); $this->out->elementStart('p', array('class' => 'profile_deleted')); // TRANS: Text shown in user profile of not yet compeltely deleted users. $this->out->text(_('User deletion in progress...')); $this->out->elementEnd('p'); $this->out->elementEnd('ul'); $this->out->elementEnd('div'); return; } $cur = common_current_user(); $this->out->elementStart('div', 'entity_actions'); // TRANS: H2 for entity actions in a profile. $this->out->element('h2', null, _('User actions')); $this->out->elementStart('ul'); if (Event::handle('StartProfilePageActionsElements', array($this->out, $this->profile))) { if (empty($cur)) { // not logged in if (Event::handle('StartProfileRemoteSubscribe', array($this->out, $this->profile))) { Event::handle('EndProfileRemoteSubscribe', array($this->out, $this->profile)); } } else { if ($cur->id == $this->profile->id) { // your own page $this->out->elementStart('li', 'entity_edit'); $this->out->element('a', array('href' => common_local_url('profilesettings'), 'title' => _('Edit profile settings.')), _m('BUTTON', 'Edit')); $this->out->elementEnd('li'); } else { // someone else's page // subscribe/unsubscribe button $this->out->elementStart('li', 'entity_subscribe'); if ($cur->isSubscribed($this->profile)) { $usf = new UnsubscribeForm($this->out, $this->profile); $usf->show(); } else { if ($cur->hasPendingSubscription($this->profile)) { $sf = new CancelSubscriptionForm($this->out, $this->profile); $sf->show(); } else { $sf = new SubscribeForm($this->out, $this->profile); $sf->show(); } } $this->out->elementEnd('li'); if ($this->profile->isLocal() && $cur->mutuallySubscribed($this->profile)) { // nudge if ($this->user->email && $this->user->emailnotifynudge) { $this->out->elementStart('li', 'entity_nudge'); $nf = new NudgeForm($this->out, $this->user); $nf->show(); $this->out->elementEnd('li'); } } // return-to args, so we don't have to keep re-writing them list($action, $r2args) = $this->out->returnToArgs(); // push the action into the list $r2args['action'] = $action; // block/unblock $blocked = $cur->hasBlocked($this->profile); $this->out->elementStart('li', 'entity_block'); if ($blocked) { $ubf = new UnblockForm($this->out, $this->profile, $r2args); $ubf->show(); } else { $bf = new BlockForm($this->out, $this->profile, $r2args); $bf->show(); } $this->out->elementEnd('li'); // Some actions won't be applicable to non-local users. $isLocal = !empty($this->user); if ($cur->hasRight(Right::SANDBOXUSER) || $cur->hasRight(Right::SILENCEUSER) || $cur->hasRight(Right::DELETEUSER)) { $this->out->elementStart('li', 'entity_moderation'); // TRANS: Label text on user profile to select a user role. $this->out->element('p', null, _('Moderate')); $this->out->elementStart('ul'); if ($cur->hasRight(Right::SANDBOXUSER)) { $this->out->elementStart('li', 'entity_sandbox'); if ($this->profile->isSandboxed()) { $usf = new UnSandboxForm($this->out, $this->profile, $r2args); $usf->show(); } else { $sf = new SandboxForm($this->out, $this->profile, $r2args); $sf->show(); } $this->out->elementEnd('li'); } if ($cur->hasRight(Right::SILENCEUSER)) { $this->out->elementStart('li', 'entity_silence'); if ($this->profile->isSilenced()) { $usf = new UnSilenceForm($this->out, $this->profile, $r2args); $usf->show(); } else { $sf = new SilenceForm($this->out, $this->profile, $r2args); $sf->show(); } $this->out->elementEnd('li'); } if ($isLocal && $cur->hasRight(Right::DELETEUSER)) { $this->out->elementStart('li', 'entity_delete'); $df = new DeleteUserForm($this->out, $this->profile, $r2args); $df->show(); $this->out->elementEnd('li'); } $this->out->elementEnd('ul'); $this->out->elementEnd('li'); } if ($isLocal && $cur->hasRight(Right::GRANTROLE)) { $this->out->elementStart('li', 'entity_role'); // TRANS: Label text on user profile to select a user role. $this->out->element('p', null, _('User role')); $this->out->elementStart('ul'); // TRANS: Role that can be set for a user profile. $this->roleButton('administrator', _m('role', 'Administrator')); // TRANS: Role that can be set for a user profile. $this->roleButton('moderator', _m('role', 'Moderator')); $this->out->elementEnd('ul'); $this->out->elementEnd('li'); } } } Event::handle('EndProfilePageActionsElements', array($this->out, $this->profile)); } $this->out->elementEnd('ul'); $this->out->elementEnd('div'); Event::handle('EndProfilePageActionsSection', array($this->out, $this->profile)); } }
function showProfile() { $this->out->elementStart('li', array('class' => 'profile', 'id' => 'profile-' . $this->profile->id)); $user = common_current_user(); $is_own = !is_null($user) && isset($this->owner) && $user->id === $this->owner->id; $this->out->elementStart('div', 'entity_profile vcard'); $avatar = $this->profile->getAvatar(AVATAR_STREAM_SIZE); $this->out->elementStart('a', array('href' => $this->profile->profileurl, 'class' => 'url')); $this->out->element('img', array('src' => $avatar ? $avatar->displayUrl() : Avatar::defaultImage(AVATAR_STREAM_SIZE), 'class' => 'photo avatar', 'width' => AVATAR_STREAM_SIZE, 'height' => AVATAR_STREAM_SIZE, 'alt' => $this->profile->fullname ? $this->profile->fullname : $this->profile->nickname)); $hasFN = $this->profile->fullname !== '' ? 'nickname' : 'fn nickname'; $this->out->elementStart('span', $hasFN); $this->out->raw($this->highlight($this->profile->nickname)); $this->out->elementEnd('span'); $this->out->elementEnd('a'); if (!empty($this->profile->fullname)) { $this->out->elementStart('dl', 'entity_fn'); $this->out->element('dt', null, 'Full name'); $this->out->elementStart('dd'); $this->out->elementStart('span', 'fn'); $this->out->raw($this->highlight($this->profile->fullname)); $this->out->elementEnd('span'); $this->out->elementEnd('dd'); $this->out->elementEnd('dl'); } if (!empty($this->profile->location)) { $this->out->elementStart('dl', 'entity_location'); $this->out->element('dt', null, _('Location')); $this->out->elementStart('dd', 'label'); $this->out->raw($this->highlight($this->profile->location)); $this->out->elementEnd('dd'); $this->out->elementEnd('dl'); } if (!empty($this->profile->homepage)) { $this->out->elementStart('dl', 'entity_url'); $this->out->element('dt', null, _('URL')); $this->out->elementStart('dd'); $this->out->elementStart('a', array('href' => $this->profile->homepage, 'class' => 'url')); $this->out->raw($this->highlight($this->profile->homepage)); $this->out->elementEnd('a'); $this->out->elementEnd('dd'); $this->out->elementEnd('dl'); } if (!empty($this->profile->bio)) { $this->out->elementStart('dl', 'entity_note'); $this->out->element('dt', null, _('Note')); $this->out->elementStart('dd', 'note'); $this->out->raw($this->highlight($this->profile->bio)); $this->out->elementEnd('dd'); $this->out->elementEnd('dl'); } # If we're on a list with an owner (subscriptions or subscribers)... if ($this->owner) { # Get tags $tags = Profile_tag::getTags($this->owner->id, $this->profile->id); $this->out->elementStart('dl', 'entity_tags'); $this->out->elementStart('dt'); if ($is_own) { $this->out->element('a', array('href' => common_local_url('tagother', array('id' => $this->profile->id))), _('Tags')); } else { $this->out->text(_('Tags')); } $this->out->elementEnd('dt'); $this->out->elementStart('dd'); if ($tags) { $this->out->elementStart('ul', 'tags xoxo'); foreach ($tags as $tag) { $this->out->elementStart('li'); $this->out->element('span', 'mark_hash', '#'); $this->out->element('a', array('rel' => 'tag', 'href' => common_local_url($this->action->trimmed('action'), array('nickname' => $this->owner->nickname, 'tag' => $tag))), $tag); $this->out->elementEnd('li'); } $this->out->elementEnd('ul'); } else { $this->out->text(_('(none)')); } $this->out->elementEnd('dd'); $this->out->elementEnd('dl'); } if ($is_own) { $this->showOwnerControls($this->profile); } $this->out->elementEnd('div'); $this->out->elementStart('div', 'entity_actions'); $this->out->elementStart('ul'); // Is this a logged-in user, looking at someone else's // profile? if (!empty($user) && $this->profile->id != $user->id) { $this->out->elementStart('li', 'entity_subscribe'); if ($user->isSubscribed($this->profile)) { $usf = new UnsubscribeForm($this->out, $this->profile); $usf->show(); } else { $sf = new SubscribeForm($this->out, $this->profile); $sf->show(); } $this->out->elementEnd('li'); $this->out->elementStart('li', 'entity_block'); if ($user->id == $this->owner->id) { $this->showBlockForm(); } $this->out->elementEnd('li'); } $this->out->elementEnd('ul'); $this->out->elementEnd('div'); $this->out->elementEnd('li'); }
function showSubscribeButton() { // Is this a logged-in user, looking at someone else's // profile? $user = common_current_user(); if (!empty($user) && $this->profile->id != $user->id) { $this->out->elementStart('li', 'entity_subscribe'); if ($user->isSubscribed($this->profile)) { $usf = new UnsubscribeForm($this->out, $this->profile); $usf->show(); } else { // We can't initiate sub for a remote OMB profile. $remote = Remote_profile::staticGet('id', $this->profile->id); if (empty($remote)) { $sf = new SubscribeForm($this->out, $this->profile); $sf->show(); } } $this->out->elementEnd('li'); } }