X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=mod%2Fvideos.php;h=e025269693d3fe9cad036c52843963b217638533;hb=25f0f0c4396ece49634be517b92d638ef9c73505;hp=1ba566eeaab78d4fbb6158c1a0a7667bc1adf25a;hpb=122ad0af14f046c2462a03fe33967dc41abfc8b5;p=friendica.git diff --git a/mod/videos.php b/mod/videos.php index 1ba566eeaa..e025269693 100644 --- a/mod/videos.php +++ b/mod/videos.php @@ -1,6 +1,6 @@ argc > 1) { - $nick = $a->argv[1]; - $user = q("SELECT * FROM `user` WHERE `nickname` = '%s' AND `blocked` = 0 LIMIT 1", - DBA::escape($nick) - ); - - if (!DBA::isResult($user)) { - return; + if (DI::args()->getArgc() > 1) { + $owner = User::getOwnerDataByNick(DI::args()->getArgv()[1]); + if (empty($owner)) { + throw new HTTPException\NotFoundException(DI::l10n()->t('User not found.')); } - $a->data['user'] = $user[0]; - $a->profile_uid = $user[0]['uid']; - - $profile = Profile::getByNickname($nick, $a->profile_uid); - - $account_type = Contact::getAccountType($profile); - - $tpl = Renderer::getMarkupTemplate('widget/vcard.tpl'); - - $vcard_widget = Renderer::replaceMacros($tpl, [ - '$name' => $profile['name'], - '$photo' => $profile['photo'], - '$addr' => $profile['addr'] ?? '', - '$account_type' => $account_type, - '$about' => BBCode::convert($profile['about']), - ]); - // If not there, create 'aside' empty if (!isset(DI::page()['aside'])) { DI::page()['aside'] = ''; } - DI::page()['aside'] .= $vcard_widget; + DI::page()['aside'] .= Widget\VCard::getHTML($owner); $tpl = Renderer::getMarkupTemplate("videos_head.tpl"); DI::page()['htmlhead'] .= Renderer::replaceMacros($tpl); @@ -86,13 +64,16 @@ function videos_init(App $a) function videos_post(App $a) { - $owner_uid = $a->data['user']['uid']; + $user = User::getByNickname(DI::args()->getArgv()[1]); + if (!DBA::isResult($user)) { + throw new HTTPException\NotFoundException(DI::l10n()->t('User not found.')); + } - if (local_user() != $owner_uid) { - DI::baseUrl()->redirect('videos/' . $a->data['user']['nickname']); + if (local_user() != $user['uid']) { + DI::baseUrl()->redirect('videos/' . $user['nickname']); } - if (($a->argc == 2) && !empty($_POST['delete']) && !empty($_POST['id'])) { + if ((DI::args()->getArgc() == 2) && !empty($_POST['delete']) && !empty($_POST['id'])) { $video_id = $_POST['id']; if (Attach::exists(['id' => $video_id, 'uid' => local_user()])) { @@ -106,11 +87,11 @@ function videos_post(App $a) ], local_user()); } - DI::baseUrl()->redirect('videos/' . $a->data['user']['nickname']); + DI::baseUrl()->redirect('videos/' . $user['nickname']); return; // NOTREACHED } - DI::baseUrl()->redirect('videos/' . $a->data['user']['nickname']); + DI::baseUrl()->redirect('videos/' . $user['nickname']); } function videos_content(App $a) @@ -124,13 +105,17 @@ function videos_content(App $a) // videos/name/video/xxxxx // videos/name/video/xxxxx/edit + $user = User::getByNickname(DI::args()->getArgv()[1]); + if (!DBA::isResult($user)) { + throw new HTTPException\NotFoundException(DI::l10n()->t('User not found.')); + } if (DI::config()->get('system', 'block_public') && !Session::isAuthenticated()) { notice(DI::l10n()->t('Public access denied.')); return; } - if (empty($a->data['user'])) { + if (empty($user)) { notice(DI::l10n()->t('No videos selected') . EOL ); return; } @@ -142,9 +127,9 @@ function videos_content(App $a) // // Parse arguments // - if ($a->argc > 3) { - $datatype = $a->argv[2]; - } elseif(($a->argc > 2) && ($a->argv[2] === 'upload')) { + if (DI::args()->getArgc() > 3) { + $datatype = DI::args()->getArgv()[2]; + } elseif((DI::args()->getArgc() > 2) && (DI::args()->getArgv()[2] === 'upload')) { $datatype = 'upload'; } else { $datatype = 'summary'; @@ -155,41 +140,38 @@ function videos_content(App $a) // $can_post = false; $visitor = 0; - $contact = null; $remote_contact = false; $contact_id = 0; - $owner_uid = $a->data['user']['uid']; - - $community_page = (($a->data['user']['page-flags'] == User::PAGE_FLAGS_COMMUNITY) ? true : false); + $community_page = (($user['page-flags'] == User::PAGE_FLAGS_COMMUNITY) ? true : false); - if ((local_user()) && (local_user() == $owner_uid)) { + if ((local_user()) && (local_user() == $user['uid'])) { $can_post = true; - } elseif ($community_page && !empty(Session::getRemoteContactID($owner_uid))) { - $contact_id = Session::getRemoteContactID($owner_uid); + } elseif ($community_page && !empty(Session::getRemoteContactID($user['uid']))) { + $contact_id = Session::getRemoteContactID($user['uid']); $can_post = true; $remote_contact = true; $visitor = $contact_id; } // perhaps they're visiting - but not a community page, so they wouldn't have write access - if (!empty(Session::getRemoteContactID($owner_uid)) && !$visitor) { - $contact_id = Session::getRemoteContactID($owner_uid); + if (!empty(Session::getRemoteContactID($user['uid'])) && !$visitor) { + $contact_id = Session::getRemoteContactID($user['uid']); $remote_contact = true; } - if ($a->data['user']['hidewall'] && (local_user() != $owner_uid) && !$remote_contact) { + if ($user['hidewall'] && (local_user() != $user['uid']) && !$remote_contact) { notice(DI::l10n()->t('Access to this item is restricted.')); return; } - $sql_extra = Security::getPermissionsSQLByUserId($owner_uid); + $sql_extra = Security::getPermissionsSQLByUserId($user['uid']); $o = ""; // tabs - $_is_owner = (local_user() && (local_user() == $owner_uid)); - $o .= BaseProfile::getTabsHTML($a, 'videos', $_is_owner, $a->data['user']['nickname']); + $_is_owner = (local_user() && (local_user() == $user['uid'])); + $o .= BaseProfile::getTabsHTML($a, 'videos', $_is_owner, $user); // // dispatch request @@ -219,7 +201,7 @@ function videos_content(App $a) $total = 0; $r = q("SELECT hash FROM `attach` WHERE `uid` = %d AND filetype LIKE '%%video%%' $sql_extra GROUP BY hash", - intval($a->data['user']['uid']) + intval($user['uid']) ); if (DBA::isResult($r)) { $total = count($r); @@ -232,7 +214,7 @@ function videos_content(App $a) FROM `attach` WHERE `uid` = %d AND filetype LIKE '%%video%%' $sql_extra GROUP BY hash ORDER BY `created` DESC LIMIT %d , %d", - intval($a->data['user']['uid']), + intval($user['uid']), $pager->getStart(), $pager->getItemsPerPage() ); @@ -248,13 +230,13 @@ function videos_content(App $a) $videos[] = [ 'id' => $rr['id'], - 'link' => DI::baseUrl() . '/videos/' . $a->data['user']['nickname'] . '/video/' . $rr['hash'], + 'link' => DI::baseUrl() . '/videos/' . $user['nickname'] . '/video/' . $rr['hash'], 'title' => DI::l10n()->t('View Video'), 'src' => DI::baseUrl() . '/attach/' . $rr['id'] . '?attachment=0', 'alt' => $alt_e, 'mime' => $rr['filetype'], 'album' => [ - 'link' => DI::baseUrl() . '/videos/' . $a->data['user']['nickname'] . '/album/' . bin2hex($rr['album']), + 'link' => DI::baseUrl() . '/videos/' . $user['nickname'] . '/album/' . bin2hex($rr['album']), 'name' => $name_e, 'alt' => DI::l10n()->t('View Album'), ], @@ -266,9 +248,9 @@ function videos_content(App $a) $o .= Renderer::replaceMacros($tpl, [ '$title' => DI::l10n()->t('Recent Videos'), '$can_post' => $can_post, - '$upload' => [DI::l10n()->t('Upload New Videos'), DI::baseUrl() . '/videos/' . $a->data['user']['nickname'] . '/upload'], + '$upload' => [DI::l10n()->t('Upload New Videos'), DI::baseUrl() . '/videos/' . $user['nickname'] . '/upload'], '$videos' => $videos, - '$delete_url' => (($can_post) ? DI::baseUrl() . '/videos/' . $a->data['user']['nickname'] : false) + '$delete_url' => (($can_post) ? DI::baseUrl() . '/videos/' . $user['nickname'] : false) ]); $o .= $pager->renderFull($total);