mirror of https://github.com/pixelfed/pixelfed.git
70 lines
2.0 KiB
PHP
70 lines
2.0 KiB
PHP
|
<?php
|
||
|
|
||
|
namespace App\Http\Requests\Status;
|
||
|
|
||
|
use Illuminate\Foundation\Http\FormRequest;
|
||
|
use App\Media;
|
||
|
use App\Status;
|
||
|
use Closure;
|
||
|
|
||
|
class StoreStatusEditRequest extends FormRequest
|
||
|
{
|
||
|
/**
|
||
|
* Determine if the user is authorized to make this request.
|
||
|
*/
|
||
|
public function authorize(): bool
|
||
|
{
|
||
|
$profile = $this->user()->profile;
|
||
|
if($profile->status != null) {
|
||
|
return false;
|
||
|
}
|
||
|
if($profile->unlisted == true && $profile->cw == true) {
|
||
|
return false;
|
||
|
}
|
||
|
$types = [
|
||
|
"photo",
|
||
|
"photo:album",
|
||
|
"photo:video:album",
|
||
|
"reply",
|
||
|
"text",
|
||
|
"video",
|
||
|
"video:album"
|
||
|
];
|
||
|
$scopes = ['public', 'unlisted', 'private'];
|
||
|
$status = Status::whereNull('reblog_of_id')->whereIn('type', $types)->whereIn('scope', $scopes)->find($this->route('id'));
|
||
|
return $status && $this->user()->profile_id === $status->profile_id;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Get the validation rules that apply to the request.
|
||
|
*
|
||
|
* @return array<string, \Illuminate\Contracts\Validation\ValidationRule|array|string>
|
||
|
*/
|
||
|
public function rules(): array
|
||
|
{
|
||
|
return [
|
||
|
'status' => 'sometimes|max:'.config('pixelfed.max_caption_length', 500),
|
||
|
'spoiler_text' => 'nullable|string|max:140',
|
||
|
'sensitive' => 'sometimes|boolean',
|
||
|
'media_ids' => [
|
||
|
'nullable',
|
||
|
'required_without:status',
|
||
|
'array',
|
||
|
'max:' . config('pixelfed.max_album_length'),
|
||
|
function (string $attribute, mixed $value, Closure $fail) {
|
||
|
Media::whereProfileId($this->user()->profile_id)
|
||
|
->where(function($query) {
|
||
|
return $query->whereNull('status_id')
|
||
|
->orWhere('status_id', '=', $this->route('id'));
|
||
|
})
|
||
|
->findOrFail($value);
|
||
|
},
|
||
|
],
|
||
|
'location' => 'sometimes|nullable',
|
||
|
'location.id' => 'sometimes|integer|min:1|max:128769',
|
||
|
'location.country' => 'required_with:location.id',
|
||
|
'location.name' => 'required_with:location.id',
|
||
|
];
|
||
|
}
|
||
|
}
|