mirror of
https://github.com/openvk/openvk
synced 2024-12-23 09:01:15 +03:00
Add post size limits
This commit is contained in:
parent
524d531c4f
commit
fdb8b35609
4 changed files with 39 additions and 23 deletions
|
@ -86,6 +86,8 @@ class Post extends Postable
|
||||||
{
|
{
|
||||||
if(ctype_space($content))
|
if(ctype_space($content))
|
||||||
throw new \LengthException("Content length must be at least 1 character (not counting whitespaces).");
|
throw new \LengthException("Content length must be at least 1 character (not counting whitespaces).");
|
||||||
|
else if(iconv_strlen($content) > OPENVK_ROOT_CONF["openvk"]["preferences"]["wall"]["postSizes"]["maxSize"])
|
||||||
|
throw new \LengthException("Content is too large.");
|
||||||
|
|
||||||
$this->stateChanges("content", $content);
|
$this->stateChanges("content", $content);
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,6 +5,9 @@ trait TRichText
|
||||||
{
|
{
|
||||||
private function formatEmojis(string $text): string
|
private function formatEmojis(string $text): string
|
||||||
{
|
{
|
||||||
|
if(iconv_strlen($this->getRecord()->content) > OPENVK_ROOT_CONF["openvk"]["preferences"]["wall"]["postSizes"]["emojiProcessingLimit"])
|
||||||
|
return $text;
|
||||||
|
|
||||||
$emojis = \Emoji\detect_emoji($text);
|
$emojis = \Emoji\detect_emoji($text);
|
||||||
$replaced = []; # OVK-113
|
$replaced = []; # OVK-113
|
||||||
foreach($emojis as $emoji) {
|
foreach($emojis as $emoji) {
|
||||||
|
@ -32,7 +35,9 @@ trait TRichText
|
||||||
function getText(bool $html = true): string
|
function getText(bool $html = true): string
|
||||||
{
|
{
|
||||||
$text = htmlentities($this->getRecord()->content, ENT_DISALLOWED | ENT_XHTML);
|
$text = htmlentities($this->getRecord()->content, ENT_DISALLOWED | ENT_XHTML);
|
||||||
|
$proc = iconv_strlen($this->getRecord()->content) <= OPENVK_ROOT_CONF["openvk"]["preferences"]["wall"]["postSizes"]["processingLimit"];
|
||||||
if($html) {
|
if($html) {
|
||||||
|
if($proc) {
|
||||||
$rel = $this->isAd() ? "sponsored" : "ugc";
|
$rel = $this->isAd() ? "sponsored" : "ugc";
|
||||||
$text = preg_replace(
|
$text = preg_replace(
|
||||||
"%((https?|ftp):\/\/(\S*?\.\S*?))([\s)\[\]{},;\"\':<]|\.\s|$)%",
|
"%((https?|ftp):\/\/(\S*?\.\S*?))([\s)\[\]{},;\"\':<]|\.\s|$)%",
|
||||||
|
@ -44,6 +49,8 @@ trait TRichText
|
||||||
$text = preg_replace("%\[(id|club)([0-9]++)\|([\p{L} 0-9@]+)\]%Xu", "<a href='/$1$2'>$3</a>", $text);
|
$text = preg_replace("%\[(id|club)([0-9]++)\|([\p{L} 0-9@]+)\]%Xu", "<a href='/$1$2'>$3</a>", $text);
|
||||||
$text = preg_replace("%(#([\p{L}_-]++[0-9]*[\p{L}_-]*))%Xu", "<a href='/feed/hashtag/$2'>$1</a>", $text);
|
$text = preg_replace("%(#([\p{L}_-]++[0-9]*[\p{L}_-]*))%Xu", "<a href='/feed/hashtag/$2'>$1</a>", $text);
|
||||||
$text = $this->formatEmojis($text);
|
$text = $this->formatEmojis($text);
|
||||||
|
}
|
||||||
|
|
||||||
$text = $this->removeZalgo($text);
|
$text = $this->removeZalgo($text);
|
||||||
$text = nl2br($text);
|
$text = nl2br($text);
|
||||||
}
|
}
|
||||||
|
|
|
@ -163,10 +163,12 @@ final class WallPresenter extends OpenVKPresenter
|
||||||
else
|
else
|
||||||
$canPost = false;
|
$canPost = false;
|
||||||
|
|
||||||
|
|
||||||
if(!$canPost)
|
if(!$canPost)
|
||||||
$this->flashFail("err", "Ошибка доступа", "Вам нельзя писать на эту стену.");
|
$this->flashFail("err", "Ошибка доступа", "Вам нельзя писать на эту стену.");
|
||||||
|
|
||||||
|
if(iconv_strlen($this->postParam("text") ?? "") > 280)
|
||||||
|
$this->flashFail("err", "Не удалось опубликовать пост", "Пост слишком большой.");
|
||||||
|
|
||||||
$flags = 0;
|
$flags = 0;
|
||||||
if($this->postParam("as_group") === "on")
|
if($this->postParam("as_group") === "on")
|
||||||
$flags |= 0b10000000;
|
$flags |= 0b10000000;
|
||||||
|
@ -189,7 +191,7 @@ final class WallPresenter extends OpenVKPresenter
|
||||||
(new Albums)->getUserWallAlbum($wallOwner)->addPhoto($photo);
|
(new Albums)->getUserWallAlbum($wallOwner)->addPhoto($photo);
|
||||||
}
|
}
|
||||||
} catch(ISE $ex) {
|
} catch(ISE $ex) {
|
||||||
$this->flashFail("err", "Не удалось опубликовать пост", "Файл повреждён.");
|
$this->flashFail("err", "Не удалось опубликовать пост", "Файл изображения повреждён, слишком велик или одна сторона изображения в разы больше другой.");
|
||||||
}
|
}
|
||||||
|
|
||||||
$post = new Post;
|
$post = new Post;
|
||||||
|
@ -210,10 +212,10 @@ final class WallPresenter extends OpenVKPresenter
|
||||||
$post->setFlags($flags);
|
$post->setFlags($flags);
|
||||||
$post->save();
|
$post->save();
|
||||||
} catch(\LogicException $ex) {
|
} catch(\LogicException $ex) {
|
||||||
$this->flashFail("err", "Не удалось опубликовать пост", "Нельзя опубликовать пустой пост.");
|
$this->flashFail("err", "Не удалось опубликовать пост", "Пост пустой или слишком большой.");
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
$this->flashFail("err", "Не удалось опубликовать пост", "Нельзя опубликовать пустой пост.");
|
$this->flashFail("err", "Не удалось опубликовать пост", "Пост пустой или слишком большой.");
|
||||||
}
|
}
|
||||||
|
|
||||||
if($wall > 0 && $wall !== $this->user->identity->getId())
|
if($wall > 0 && $wall !== $this->user->identity->getId())
|
||||||
|
|
|
@ -22,6 +22,11 @@ openvk:
|
||||||
adminAccount: 1 # Change this ok
|
adminAccount: 1 # Change this ok
|
||||||
messages:
|
messages:
|
||||||
strict: false
|
strict: false
|
||||||
|
wall:
|
||||||
|
postSizes:
|
||||||
|
maxSize: 60000
|
||||||
|
processingLimit: 3000
|
||||||
|
emojiProcessingLimit: 1000
|
||||||
menu:
|
menu:
|
||||||
links:
|
links:
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue