Merge pull request #1183 from openclassify/vedat

added api
This commit is contained in:
Fatih Alp 2021-10-02 22:57:44 +03:00 committed by GitHub
commit f527a7ee85
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 69 additions and 0 deletions

View File

@ -32,4 +32,5 @@ return [
'sold_status_change' => "Your Ad's Status Has Been Set to Sold!",
'status_change' => "Your Ad's Status Has Been Set to :status!",
'disabled_detailed_options_for_admin_role' => "Detailed product options are disabled.",
'permission_error' => 'You do not have permission for this action',
];

View File

@ -32,4 +32,5 @@ return [
'sold_status_change' => "İlanın Durumu Satıldı Olarak Ayarlanmıştır!",
'status_change' => "İlanın durumu Ayarland :status !",
'disabled_detailed_options_for_admin_role' => "Ayrıntılı ürün seçenekleri devre dışı bırakıldı.",
'permission_error' => 'Bu işlem için yetkiniz bulunmamaktadır',
];

View File

@ -1,11 +1,78 @@
<?php namespace Visiosoft\AdvsModule\Adv;
use Carbon\Carbon;
use Illuminate\Foundation\Bus\DispatchesJobs;
use Illuminate\Support\Facades\Auth;
use Visiosoft\ConnectModule\Command\CheckRequiredParams;
class AdvApiCollection extends AdvRepository
{
use DispatchesJobs;
public function getMyAds()
{
return $this->model->userAdv()
->where('advs_advs.finish_at', '>', date('Y-m-d H:i:s'));
}
public function createNewAd(array $params)
{
return $this->newQuery()->create($params);
}
public function deleteAd(array $params)
{
$this->dispatch(new CheckRequiredParams(['ad_id'], $params));
$ad = $this->checkAd($params['ad_id']);
$this->checkOwner($ad);
return $ad->delete();
}
public function updateAd(array $params)
{
$this->dispatch(new CheckRequiredParams(['ad_id'], $params));
$ad = $this->checkAd($params['ad_id']);
$this->checkOwner($ad);
unset($params['ad_id'],$params['id'], $params['created_at'], $params['updated_at'],
$params['deleted_at'], $params['created_by_id'], $params['updated_by_id']);
$update_params = [
'updated_by_id' => Auth::id(),
'updated_at' => Carbon::now()
];
$ad->update(array_merge($update_params,$params));
return $ad;
}
public function getAds()
{
return $this->currentAds();
}
public function checkAd($id)
{
if (!$ad = $this->newQuery()->find($id)) {
throw new \Exception(trans('visiosoft.module.advs::message.ad_doesnt_exist'), 404);
die;
}
return $ad;
}
public function checkOwner($ad)
{
if ($ad->created_by_id != Auth::id()) {
throw new \Exception(trans('visiosoft.module.advs::message.permission_error'), 403);
die;
}
}
}