mirror of
https://github.com/openvk/openvk
synced 2025-01-09 01:09:46 +03:00
VKAPI: Add reposted posts support (???)
This commit is contained in:
parent
25064b6e4f
commit
0c97ca1a4d
1 changed files with 73 additions and 61 deletions
|
@ -23,22 +23,37 @@ final class Wall extends VKAPIRequestHandler
|
||||||
$from_id = get_class($post->getOwner()) == "openvk\Web\Models\Entities\Club" ? $post->getOwner()->getId() * (-1) : $post->getOwner()->getId();
|
$from_id = get_class($post->getOwner()) == "openvk\Web\Models\Entities\Club" ? $post->getOwner()->getId() * (-1) : $post->getOwner()->getId();
|
||||||
|
|
||||||
$attachments = [];
|
$attachments = [];
|
||||||
|
$repost = [];
|
||||||
foreach($post->getChildren() as $attachment) {
|
foreach($post->getChildren() as $attachment) {
|
||||||
if($attachment instanceof \openvk\Web\Models\Entities\Photo) {
|
if($attachment instanceof \openvk\Web\Models\Entities\Photo) {
|
||||||
if($attachment->isDeleted())
|
if($attachment->isDeleted())
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
$attachments[] = [
|
$attachments[] = $this->getApiPhoto($attachment);
|
||||||
"type" => "photo",
|
} else if ($attachment instanceof \openvk\Web\Models\Entities\Post) {
|
||||||
"photo" => [
|
$repostAttachments = [];
|
||||||
"album_id" => $attachment->getAlbum() ? $attachment->getAlbum()->getId() : NULL,
|
|
||||||
"date" => $attachment->getPublicationTime()->timestamp(),
|
foreach($attachment->getChildren() as $repostAttachment) {
|
||||||
|
if($repostAttachment instanceof \openvk\Web\Models\Entities\Photo) {
|
||||||
|
if($attachment->isDeleted())
|
||||||
|
continue;
|
||||||
|
|
||||||
|
$repostAttachments[] = $this->getApiPhoto($repostAttachment);
|
||||||
|
/* Рекурсии, сука! Заказывали? */
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$repost[] = [
|
||||||
"id" => $attachment->getVirtualId(),
|
"id" => $attachment->getVirtualId(),
|
||||||
"owner_id" => $attachment->getOwner()->getId(),
|
"owner_id" => $attachment->getOwner()->getId(),
|
||||||
"sizes" => array_values($attachment->getVkApiSizes()),
|
"from_id" => $attachment->getOwner()->getId(),
|
||||||
"text" => "",
|
"date" => $attachment->getPublicationTime()->timestamp(),
|
||||||
"has_tags" => false
|
"post_type" => "post",
|
||||||
]
|
"text" => $attachment->getText(false),
|
||||||
|
"attachments" => $repostAttachments,
|
||||||
|
"post_source" => [
|
||||||
|
"type" => "vk"
|
||||||
|
],
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -50,6 +65,7 @@ final class Wall extends VKAPIRequestHandler
|
||||||
"date" => $post->getPublicationTime()->timestamp(),
|
"date" => $post->getPublicationTime()->timestamp(),
|
||||||
"post_type" => "post",
|
"post_type" => "post",
|
||||||
"text" => $post->getText(false),
|
"text" => $post->getText(false),
|
||||||
|
"copy_history" => $repost,
|
||||||
"can_edit" => 0, # TODO
|
"can_edit" => 0, # TODO
|
||||||
"can_delete" => $post->canBeDeletedBy($this->getUser()),
|
"can_delete" => $post->canBeDeletedBy($this->getUser()),
|
||||||
"can_pin" => $post->canBePinnedBy($this->getUser()),
|
"can_pin" => $post->canBePinnedBy($this->getUser()),
|
||||||
|
@ -148,56 +164,35 @@ final class Wall extends VKAPIRequestHandler
|
||||||
$post = (new PostsRepo)->getPostById(intval($id[0]), intval($id[1]));
|
$post = (new PostsRepo)->getPostById(intval($id[0]), intval($id[1]));
|
||||||
if($post) {
|
if($post) {
|
||||||
$from_id = get_class($post->getOwner()) == "openvk\Web\Models\Entities\Club" ? $post->getOwner()->getId() * (-1) : $post->getOwner()->getId();
|
$from_id = get_class($post->getOwner()) == "openvk\Web\Models\Entities\Club" ? $post->getOwner()->getId() * (-1) : $post->getOwner()->getId();
|
||||||
$attachments;
|
$attachments = [];
|
||||||
|
$repost = []; // чел высрал семь сигарет 😳 помянем 🕯
|
||||||
foreach($post->getChildren() as $attachment) {
|
foreach($post->getChildren() as $attachment) {
|
||||||
if($attachment instanceof \openvk\Web\Models\Entities\Photo) {
|
if($attachment instanceof \openvk\Web\Models\Entities\Photo) {
|
||||||
$attachments[] = [
|
$attachments[] = $this->getApiPhoto($attachment);
|
||||||
"type" => "photo",
|
} else if ($attachment instanceof \openvk\Web\Models\Entities\Post) {
|
||||||
"photo" => [
|
$repostAttachments = [];
|
||||||
"album_id" => $attachment->getAlbum() ? $attachment->getAlbum()->getId() : NULL,
|
|
||||||
"date" => $attachment->getPublicationTime()->timestamp(),
|
foreach($attachment->getChildren() as $repostAttachment) {
|
||||||
|
if($repostAttachment instanceof \openvk\Web\Models\Entities\Photo) {
|
||||||
|
if($attachment->isDeleted())
|
||||||
|
continue;
|
||||||
|
|
||||||
|
$repostAttachments[] = $this->getApiPhoto($repostAttachment);
|
||||||
|
/* Рекурсии, сука! Заказывали? */
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$repost[] = [
|
||||||
"id" => $attachment->getVirtualId(),
|
"id" => $attachment->getVirtualId(),
|
||||||
"owner_id" => $attachment->getOwner()->getId(),
|
"owner_id" => $attachment->getOwner()->getId(),
|
||||||
"sizes" => array(
|
"from_id" => $attachment->getOwner()->getId(),
|
||||||
[
|
"date" => $attachment->getPublicationTime()->timestamp(),
|
||||||
"height" => 2560,
|
"post_type" => "post",
|
||||||
"url" => $attachment->getURLBySizeId("normal"),
|
"text" => $attachment->getText(false),
|
||||||
"type" => "m",
|
"attachments" => $repostAttachments,
|
||||||
"width" => 2560,
|
"post_source" => [
|
||||||
|
"type" => "vk"
|
||||||
],
|
],
|
||||||
[
|
|
||||||
"height" => 130,
|
|
||||||
"url" => $attachment->getURLBySizeId("tiny"),
|
|
||||||
"type" => "o",
|
|
||||||
"width" => 130,
|
|
||||||
],
|
|
||||||
[
|
|
||||||
"height" => 604,
|
|
||||||
"url" => $attachment->getURLBySizeId("normal"),
|
|
||||||
"type" => "p",
|
|
||||||
"width" => 604,
|
|
||||||
],
|
|
||||||
[
|
|
||||||
"height" => 807,
|
|
||||||
"url" => $attachment->getURLBySizeId("large"),
|
|
||||||
"type" => "q",
|
|
||||||
"width" => 807,
|
|
||||||
],
|
|
||||||
[
|
|
||||||
"height" => 1280,
|
|
||||||
"url" => $attachment->getURLBySizeId("larger"),
|
|
||||||
"type" => "r",
|
|
||||||
"width" => 1280,
|
|
||||||
],
|
|
||||||
[
|
|
||||||
"height" => 75, # Для временного компросима оставляю статическое число. Если каждый раз обращаться к файлу за количеством пикселов, то наступает пuпuська полная с производительностью, так что пока так
|
|
||||||
"url" => $attachment->getURLBySizeId("miniscule"),
|
|
||||||
"type" => "s",
|
|
||||||
"width" => 75,
|
|
||||||
]),
|
|
||||||
"text" => "",
|
|
||||||
"has_tags" => false
|
|
||||||
]
|
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -209,6 +204,7 @@ final class Wall extends VKAPIRequestHandler
|
||||||
"date" => $post->getPublicationTime()->timestamp(),
|
"date" => $post->getPublicationTime()->timestamp(),
|
||||||
"post_type" => "post",
|
"post_type" => "post",
|
||||||
"text" => $post->getText(false),
|
"text" => $post->getText(false),
|
||||||
|
"copy_history" => $repost,
|
||||||
"can_edit" => 0, # TODO
|
"can_edit" => 0, # TODO
|
||||||
"can_delete" => $post->canBeDeletedBy($user),
|
"can_delete" => $post->canBeDeletedBy($user),
|
||||||
"can_pin" => $post->canBePinnedBy($user),
|
"can_pin" => $post->canBePinnedBy($user),
|
||||||
|
@ -238,7 +234,8 @@ final class Wall extends VKAPIRequestHandler
|
||||||
else
|
else
|
||||||
$groups[] = $from_id * -1;
|
$groups[] = $from_id * -1;
|
||||||
|
|
||||||
$attachments = NULL; # free attachments so it will not clone everythingg
|
$attachments = NULL; # free attachments so it will not clone everything
|
||||||
|
$repost = NULL; # same
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -374,7 +371,7 @@ final class Wall extends VKAPIRequestHandler
|
||||||
return (object)["post_id" => $post->getVirtualId()];
|
return (object)["post_id" => $post->getVirtualId()];
|
||||||
}
|
}
|
||||||
|
|
||||||
function repost(string $object, string $message) {
|
function repost(string $object, string $message = "") {
|
||||||
$this->requireUser();
|
$this->requireUser();
|
||||||
|
|
||||||
$postArray;
|
$postArray;
|
||||||
|
@ -401,4 +398,19 @@ final class Wall extends VKAPIRequestHandler
|
||||||
"likes_count" => $post->getLikesCount()
|
"likes_count" => $post->getLikesCount()
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private function getApiPhoto($attachment) {
|
||||||
|
return [
|
||||||
|
"type" => "photo",
|
||||||
|
"photo" => [
|
||||||
|
"album_id" => $attachment->getAlbum() ? $attachment->getAlbum()->getId() : NULL,
|
||||||
|
"date" => $attachment->getPublicationTime()->timestamp(),
|
||||||
|
"id" => $attachment->getVirtualId(),
|
||||||
|
"owner_id" => $attachment->getOwner()->getId(),
|
||||||
|
"sizes" => array_values($attachment->getVkApiSizes()),
|
||||||
|
"text" => "",
|
||||||
|
"has_tags" => false
|
||||||
|
]
|
||||||
|
];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue