mirror of
https://github.com/openvk/openvk
synced 2025-01-05 15:30:49 +03:00
40 lines
1.7 KiB
PHP
40 lines
1.7 KiB
PHP
<?php declare(strict_types=1);
|
|
namespace openvk\VKAPI\Handlers;
|
|
use Chandler\Database\DatabaseConnection;
|
|
use openvk\Web\Models\Repositories\Posts as PostsRepo;
|
|
use openvk\VKAPI\Handlers\Wall;
|
|
|
|
final class Newsfeed extends VKAPIRequestHandler
|
|
{
|
|
function get(string $fields = "", int $start_from = 0, int $offset = 0, int $count = 30, int $extended = 0)
|
|
{
|
|
$this->requireUser();
|
|
|
|
$id = $this->getUser()->getId();
|
|
$subs = DatabaseConnection::i()
|
|
->getContext()
|
|
->table("subscriptions")
|
|
->where("follower", $id);
|
|
$ids = array_map(function($rel) {
|
|
return $rel->target * ($rel->model === "openvk\Web\Models\Entities\User" ? 1 : -1);
|
|
}, iterator_to_array($subs));
|
|
$ids[] = $this->getUser()->getId();
|
|
|
|
$posts = DatabaseConnection::i()
|
|
->getContext()
|
|
->table("posts")
|
|
->select("id")
|
|
->where("wall IN (?)", $ids)
|
|
->where("deleted", 0)
|
|
->where("id < (?)", empty($start_from) ? time()+1 : $start_from)
|
|
->order("created DESC");
|
|
|
|
$rposts = [];
|
|
foreach($posts->page((int) ($offset + 1), $count) as $post)
|
|
$rposts[] = (new PostsRepo)->get($post->id)->getPrettyId();
|
|
|
|
$response = (new Wall)->getById(implode(',', $rposts), $extended, $fields, $this->getUser());
|
|
$response->next_from = end(end($posts->page((int) ($offset + 1), $count))); // ну и костыли пиздец конечно)
|
|
return $response;
|
|
}
|
|
}
|