mirror of
https://github.com/pixelfed/pixelfed.git
synced 2025-01-11 06:30:46 +00:00
commit
8513b6d1e5
6 changed files with 559 additions and 454 deletions
|
@ -4,6 +4,7 @@
|
||||||
### Added
|
### Added
|
||||||
- WebP Support ([069a0e4a](https://github.com/pixelfed/pixelfed/commit/069a0e4a))
|
- WebP Support ([069a0e4a](https://github.com/pixelfed/pixelfed/commit/069a0e4a))
|
||||||
- Auto Following support for admins ([68aa2540](https://github.com/pixelfed/pixelfed/commit/68aa2540))
|
- Auto Following support for admins ([68aa2540](https://github.com/pixelfed/pixelfed/commit/68aa2540))
|
||||||
|
- Mark as spammer mod tool, unlists and applies content warning to existing and future post ([6d956a86](https://github.com/pixelfed/pixelfed/commit/6d956a86))
|
||||||
|
|
||||||
### Updated
|
### Updated
|
||||||
- Updated PrettyNumber, fix deprecated warning. ([20ec870b](https://github.com/pixelfed/pixelfed/commit/20ec870b))
|
- Updated PrettyNumber, fix deprecated warning. ([20ec870b](https://github.com/pixelfed/pixelfed/commit/20ec870b))
|
||||||
|
|
|
@ -28,6 +28,7 @@ use App\Transformer\Api\{
|
||||||
};
|
};
|
||||||
use App\Util\Media\Filter;
|
use App\Util\Media\Filter;
|
||||||
use App\Jobs\StatusPipeline\NewStatusPipeline;
|
use App\Jobs\StatusPipeline\NewStatusPipeline;
|
||||||
|
use App\Jobs\ModPipeline\HandleSpammerPipeline;
|
||||||
use League\Fractal\Serializer\ArraySerializer;
|
use League\Fractal\Serializer\ArraySerializer;
|
||||||
use League\Fractal\Pagination\IlluminatePaginatorAdapter;
|
use League\Fractal\Pagination\IlluminatePaginatorAdapter;
|
||||||
use Illuminate\Validation\Rule;
|
use Illuminate\Validation\Rule;
|
||||||
|
@ -175,8 +176,8 @@ class InternalApiController extends Controller
|
||||||
Rule::in([
|
Rule::in([
|
||||||
'addcw',
|
'addcw',
|
||||||
'remcw',
|
'remcw',
|
||||||
'unlist'
|
'unlist',
|
||||||
|
'spammer'
|
||||||
])
|
])
|
||||||
],
|
],
|
||||||
'item_id' => 'required|integer|min:1',
|
'item_id' => 'required|integer|min:1',
|
||||||
|
@ -311,6 +312,23 @@ class InternalApiController extends Controller
|
||||||
$u->save();
|
$u->save();
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case 'spammer':
|
||||||
|
$status = Status::findOrFail($item_id);
|
||||||
|
HandleSpammerPipeline::dispatch($status->profile);
|
||||||
|
ModLogService::boot()
|
||||||
|
->user(Auth::user())
|
||||||
|
->objectUid($status->profile->user_id)
|
||||||
|
->objectId($status->id)
|
||||||
|
->objectType('App\User::class')
|
||||||
|
->action('admin.status.moderate')
|
||||||
|
->metadata([
|
||||||
|
'action' => 'spammer',
|
||||||
|
'message' => 'Success!'
|
||||||
|
])
|
||||||
|
->accessLevel('admin')
|
||||||
|
->save();
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
Cache::forget('_api:statuses:recent_9:' . $status->profile_id);
|
Cache::forget('_api:statuses:recent_9:' . $status->profile_id);
|
||||||
|
|
52
app/Jobs/ModPipeline/HandleSpammerPipeline.php
Normal file
52
app/Jobs/ModPipeline/HandleSpammerPipeline.php
Normal file
|
@ -0,0 +1,52 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Jobs\ModPipeline;
|
||||||
|
|
||||||
|
use Cache;
|
||||||
|
use App\Profile;
|
||||||
|
use App\Status;
|
||||||
|
use Illuminate\Bus\Queueable;
|
||||||
|
use Illuminate\Contracts\Queue\ShouldQueue;
|
||||||
|
use Illuminate\Foundation\Bus\Dispatchable;
|
||||||
|
use Illuminate\Queue\InteractsWithQueue;
|
||||||
|
use Illuminate\Queue\SerializesModels;
|
||||||
|
use App\Services\StatusService;
|
||||||
|
|
||||||
|
class HandleSpammerPipeline implements ShouldQueue
|
||||||
|
{
|
||||||
|
use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
|
||||||
|
|
||||||
|
protected $profile;
|
||||||
|
|
||||||
|
public $deleteWhenMissingModels = true;
|
||||||
|
|
||||||
|
public function __construct(Profile $profile)
|
||||||
|
{
|
||||||
|
$this->profile = $profile;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function handle()
|
||||||
|
{
|
||||||
|
$profile = $this->profile;
|
||||||
|
|
||||||
|
$profile->unlisted = true;
|
||||||
|
$profile->cw = true;
|
||||||
|
$profile->no_autolink = true;
|
||||||
|
$profile->save();
|
||||||
|
|
||||||
|
Status::whereProfileId($profile->id)
|
||||||
|
->chunk(50, function($statuses) {
|
||||||
|
foreach($statuses as $status) {
|
||||||
|
$status->is_nsfw = true;
|
||||||
|
$status->scope = $status->scope === 'public' ? 'unlisted' : $status->scope;
|
||||||
|
$status->visibility = $status->scope;
|
||||||
|
$status->save();
|
||||||
|
StatusService::del($status->id);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
Cache::forget('_api:statuses:recent_9:'.$profile->id);
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
}
|
BIN
public/js/timeline.js
vendored
BIN
public/js/timeline.js
vendored
Binary file not shown.
Binary file not shown.
|
@ -37,6 +37,10 @@
|
||||||
<div class="list-group-item rounded cursor-pointer" @click="moderatePost(status, 'unlist')">Unlist from Timelines</div>
|
<div class="list-group-item rounded cursor-pointer" @click="moderatePost(status, 'unlist')">Unlist from Timelines</div>
|
||||||
<div v-if="status.sensitive" class="list-group-item rounded cursor-pointer" @click="moderatePost(status, 'remcw')">Remove Content Warning</div>
|
<div v-if="status.sensitive" class="list-group-item rounded cursor-pointer" @click="moderatePost(status, 'remcw')">Remove Content Warning</div>
|
||||||
<div v-else class="list-group-item rounded cursor-pointer" @click="moderatePost(status, 'addcw')">Add Content Warning</div>
|
<div v-else class="list-group-item rounded cursor-pointer" @click="moderatePost(status, 'addcw')">Add Content Warning</div>
|
||||||
|
<div class="list-group-item rounded cursor-pointer" @click="moderatePost(status, 'spammer')">
|
||||||
|
Mark as Spammer<br />
|
||||||
|
<span class="small">Unlist + CW existing and future posts</span>
|
||||||
|
</div>
|
||||||
<!-- <div class="list-group-item rounded cursor-pointer" @click="ctxModOtherMenuShow()">Other</div> -->
|
<!-- <div class="list-group-item rounded cursor-pointer" @click="ctxModOtherMenuShow()">Other</div> -->
|
||||||
<div class="list-group-item rounded cursor-pointer text-lighter" @click="ctxModMenuClose()">Cancel</div>
|
<div class="list-group-item rounded cursor-pointer text-lighter" @click="ctxModMenuClose()">Cancel</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -465,6 +469,7 @@
|
||||||
|
|
||||||
moderatePost(status, action, $event) {
|
moderatePost(status, action, $event) {
|
||||||
let username = status.account.username;
|
let username = status.account.username;
|
||||||
|
let pid = status.id;
|
||||||
let msg = '';
|
let msg = '';
|
||||||
let self = this;
|
let self = this;
|
||||||
switch(action) {
|
switch(action) {
|
||||||
|
@ -559,6 +564,35 @@
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case 'spammer':
|
||||||
|
msg = 'Are you sure you want to mark this user as a spammer? All existing and future posts will be unlisted on timelines and a content warning will be applied.';
|
||||||
|
swal({
|
||||||
|
title: 'Confirm',
|
||||||
|
text: msg,
|
||||||
|
icon: 'warning',
|
||||||
|
buttons: true,
|
||||||
|
dangerMode: true
|
||||||
|
}).then(res => {
|
||||||
|
if(res) {
|
||||||
|
axios.post('/api/v2/moderator/action', {
|
||||||
|
action: action,
|
||||||
|
item_id: status.id,
|
||||||
|
item_type: 'status'
|
||||||
|
}).then(res => {
|
||||||
|
swal('Success', 'Successfully marked account as spammer', 'success');
|
||||||
|
self.ctxModMenuClose();
|
||||||
|
}).catch(err => {
|
||||||
|
self.ctxModMenuClose();
|
||||||
|
swal(
|
||||||
|
'Error',
|
||||||
|
'Something went wrong, please try again later.',
|
||||||
|
'error'
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue