Files
UNIT3D-Community-Edition/app/Models/Post.php
HDVinnie 472c820f99 update: UNIT3D linting
- github action updated with new ruleset in pint.json
- codebase linted with new ruleset
- contributors can now run `./vendor/bin/pint`
- action workflow will auto correct any lint issues upon commit/opened pull request
2023-02-02 08:02:34 -05:00

135 lines
3.3 KiB
PHP

<?php
/**
* NOTICE OF LICENSE.
*
* UNIT3D Community Edition is open-sourced software licensed under the GNU Affero General Public License v3.0
* The details is bundled with this project in the file LICENSE.txt.
*
* @project UNIT3D Community Edition
*
* @author HDVinnie <hdinnovations@protonmail.com>
* @license https://www.gnu.org/licenses/agpl-3.0.en.html/ GNU Affero General Public License v3.0
*/
namespace App\Models;
use App\Helpers\Bbcode;
use App\Helpers\Linkify;
use App\Traits\Auditable;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
use voku\helper\AntiXSS;
class Post extends Model
{
use Auditable;
use HasFactory;
/**
* Belongs To A Topic.
*/
public function topic(): \Illuminate\Database\Eloquent\Relations\BelongsTo
{
return $this->belongsTo(Topic::class);
}
/**
* Belongs To A User.
*/
public function user(): \Illuminate\Database\Eloquent\Relations\BelongsTo
{
return $this->belongsTo(User::class)->withDefault([
'username' => 'System',
'id' => '1',
]);
}
/**
* A Post Has Many Likes.
*/
public function likes(): \Illuminate\Database\Eloquent\Relations\HasMany
{
return $this->hasMany(Like::class)->where('like', '=', 1);
}
/**
* A Post Has Many Dislikes.
*/
public function dislikes(): \Illuminate\Database\Eloquent\Relations\HasMany
{
return $this->hasMany(Like::class)->where('dislike', '=', 1);
}
/**
* A Post Has Many Tips.
*/
public function tips(): \Illuminate\Database\Eloquent\Relations\HasMany
{
return $this->hasMany(BonTransactions::class);
}
/**
* Set The Posts Content After Its Been Purified.
*/
public function setContentAttribute(?string $value): void
{
$this->attributes['content'] = htmlspecialchars((new AntiXSS())->xss_clean($value), ENT_NOQUOTES);
}
/**
* Parse Content And Return Valid HTML.
*/
public function getContentHtml(): string
{
$bbcode = new Bbcode();
return (new Linkify())->linky($bbcode->parse(htmlspecialchars_decode($this->content), true));
}
/**
* Post Trimming.t.
*/
public function getBrief(int $length = 100, bool $ellipses = true, bool $stripHtml = false): string
{
$input = $this->content;
//strip tags, if desired
if ($stripHtml) {
$input = strip_tags($input);
}
//no need to trim, already shorter than trim length
if (\strlen((string) $input) <= $length) {
return $input;
}
//find last space within length
$lastSpace = strrpos(substr($input, 0, $length), ' ');
$trimmedText = substr($input, 0, $lastSpace);
//add ellipses (...)
if ($ellipses) {
$trimmedText .= '...';
}
return $trimmedText;
}
/**
* Get A Post From A ID.
*/
public function getPostNumber(): string
{
return $this->topic->postNumberFromId($this->id);
}
/**
* Get A Posts Page Number.
*/
public function getPageNumber(): float
{
$result = ($this->getPostNumber() - 1) / 25 + 1;
return floor($result);
}
}