2022-09-14 14:19:28 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Models;
|
|
|
|
|
2022-10-07 05:15:08 +00:00
|
|
|
use App\Exceptions\ChargeException;
|
2022-10-03 03:10:58 +00:00
|
|
|
use Illuminate\Support\Facades\Log;
|
2022-10-07 05:15:08 +00:00
|
|
|
use Illuminate\Support\Facades\Cache;
|
|
|
|
use Jenssegers\Mongodb\Eloquent\Model;
|
|
|
|
use Illuminate\Contracts\Cache\LockTimeoutException;
|
2022-09-14 14:19:28 +00:00
|
|
|
|
|
|
|
class Transaction extends Model
|
|
|
|
{
|
|
|
|
// $t = (new App\Models\Transaction)->create(['name' => 1])
|
|
|
|
|
|
|
|
protected $connection = 'mongodb';
|
|
|
|
protected $collection = 'transactions';
|
|
|
|
|
2022-09-15 04:13:37 +00:00
|
|
|
// 停用 updated_at
|
|
|
|
const UPDATED_AT = null;
|
|
|
|
|
2022-09-14 14:19:28 +00:00
|
|
|
protected $dates = [
|
|
|
|
'created_at',
|
|
|
|
'updated_at',
|
2022-09-15 04:13:37 +00:00
|
|
|
'paid_at',
|
2022-09-14 14:19:28 +00:00
|
|
|
];
|
|
|
|
|
|
|
|
protected $fillable = [
|
2022-09-15 04:13:37 +00:00
|
|
|
// 交易类型
|
|
|
|
'type',
|
|
|
|
|
|
|
|
// 交易渠道
|
|
|
|
'payment',
|
|
|
|
|
|
|
|
// 描述
|
|
|
|
'description',
|
|
|
|
|
|
|
|
// 入账
|
|
|
|
'income',
|
|
|
|
|
|
|
|
// 入账 Drops
|
|
|
|
'income_drops',
|
|
|
|
|
|
|
|
// 出账
|
|
|
|
'outcome',
|
|
|
|
// 出账 Drops
|
|
|
|
'outcome_drops',
|
|
|
|
|
|
|
|
// 可用余额
|
|
|
|
'balance',
|
|
|
|
|
|
|
|
// 可用 Drops
|
|
|
|
'drops',
|
|
|
|
|
|
|
|
// 赠送金额
|
|
|
|
'gift',
|
|
|
|
|
|
|
|
// 赠送 Drops
|
|
|
|
'gift_drops',
|
|
|
|
|
|
|
|
'user_id',
|
2022-09-15 05:38:50 +00:00
|
|
|
'host_id',
|
|
|
|
'module_id',
|
2022-09-14 14:19:28 +00:00
|
|
|
];
|
2022-09-15 04:13:37 +00:00
|
|
|
|
|
|
|
|
|
|
|
// scope this user
|
|
|
|
public function scopeThisUser($query)
|
|
|
|
{
|
|
|
|
return $query->where('user_id', auth()->id());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function getDrops($user_id = null)
|
|
|
|
{
|
|
|
|
//
|
|
|
|
if (!$user_id) {
|
|
|
|
$user_id = auth()->id();
|
|
|
|
}
|
|
|
|
|
|
|
|
$cache_key = 'user_drops_' . $user_id;
|
|
|
|
|
2022-10-03 05:05:39 +00:00
|
|
|
$drops = Cache::get($cache_key, [
|
|
|
|
'drops' => 0,
|
|
|
|
]);
|
2022-09-15 04:13:37 +00:00
|
|
|
|
2022-10-03 05:05:39 +00:00
|
|
|
return $drops['drops'];
|
2022-09-15 04:13:37 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function increaseCurrentUserDrops($amount = 0)
|
|
|
|
{
|
|
|
|
return $this->increaseDrops(auth()->id(), $amount);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function increaseDrops($user_id, $amount = 0)
|
|
|
|
{
|
|
|
|
$cache_key = 'user_drops_' . $user_id;
|
|
|
|
|
2022-10-03 05:05:39 +00:00
|
|
|
$current_drops = Cache::get($cache_key, [
|
|
|
|
'drops' => 0,
|
|
|
|
]);
|
2022-09-15 04:13:37 +00:00
|
|
|
|
2022-10-03 05:05:39 +00:00
|
|
|
$current_drops['drops'] += $amount;
|
2022-09-15 04:13:37 +00:00
|
|
|
|
2022-10-03 05:05:39 +00:00
|
|
|
Cache::forever($cache_key, $current_drops);
|
2022-09-15 04:13:37 +00:00
|
|
|
|
2022-10-03 05:05:39 +00:00
|
|
|
return $current_drops['drops'];
|
2022-09-15 04:13:37 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2022-09-15 05:38:50 +00:00
|
|
|
public function reduceDrops($user_id, $host_id, $module_id, $auto = 1, $amount = 0)
|
2022-09-15 04:13:37 +00:00
|
|
|
{
|
2022-09-15 05:38:50 +00:00
|
|
|
|
2022-09-15 04:13:37 +00:00
|
|
|
$cache_key = 'user_drops_' . $user_id;
|
|
|
|
|
2022-10-03 05:05:39 +00:00
|
|
|
$current_drops = Cache::get($cache_key, [
|
|
|
|
'drops' => 0,
|
|
|
|
]);
|
|
|
|
|
|
|
|
$current_drops['drops'] = $current_drops['drops'] - $amount;
|
|
|
|
|
|
|
|
$current_drops['drops'] = round($current_drops['drops'], 5);
|
2022-09-15 04:13:37 +00:00
|
|
|
|
2022-10-03 05:05:39 +00:00
|
|
|
Cache::forever($cache_key, $current_drops);
|
2022-09-15 04:13:37 +00:00
|
|
|
|
2022-09-15 05:38:50 +00:00
|
|
|
if ($auto) {
|
|
|
|
$description = '平台按时间自动扣费。';
|
|
|
|
} else {
|
|
|
|
$description = '集成模块发起的扣费。';
|
|
|
|
}
|
2022-09-15 04:13:37 +00:00
|
|
|
|
2022-10-03 05:05:39 +00:00
|
|
|
$this->addPayoutDrops($user_id, $amount, $description, $host_id, $module_id);
|
2022-09-15 04:13:37 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2022-09-15 05:38:50 +00:00
|
|
|
public function addPayoutDrops($user_id, $amount, $description, $host_id, $module_id)
|
2022-09-15 04:13:37 +00:00
|
|
|
{
|
|
|
|
$data = [
|
|
|
|
'type' => 'payout',
|
|
|
|
'payment' => 'drops',
|
|
|
|
'description' => $description,
|
|
|
|
'income' => 0,
|
|
|
|
'income_drops' => 0,
|
|
|
|
'outcome' => 0,
|
|
|
|
'outcome_drops' => $amount,
|
2022-09-15 05:38:50 +00:00
|
|
|
'host_id' => $host_id,
|
|
|
|
'module_id' => $module_id,
|
2022-09-15 04:13:37 +00:00
|
|
|
];
|
|
|
|
|
2022-10-03 02:38:25 +00:00
|
|
|
|
2022-10-03 04:07:17 +00:00
|
|
|
// $amount = (double) $amount;
|
|
|
|
|
|
|
|
// Log::debug($amount);
|
|
|
|
|
|
|
|
// $month = now()->month;
|
|
|
|
|
|
|
|
// Cache::increment('user_' . $user_id . '_month_' . $month . '_drops', $amount);
|
2022-10-03 02:38:25 +00:00
|
|
|
|
2022-09-15 04:13:37 +00:00
|
|
|
return $this->addLog($user_id, $data);
|
|
|
|
}
|
|
|
|
|
2022-09-15 05:38:50 +00:00
|
|
|
|
2022-09-15 04:13:37 +00:00
|
|
|
public function addIncomeDrops($user_id, $amount, $description)
|
|
|
|
{
|
|
|
|
$data = [
|
|
|
|
'type' => 'income',
|
|
|
|
'payment' => 'balance',
|
|
|
|
'description' => $description,
|
|
|
|
'income' => 0,
|
|
|
|
'income_drops' => $amount,
|
|
|
|
'outcome' => 0,
|
|
|
|
'outcome_drops' => 0,
|
|
|
|
];
|
|
|
|
|
|
|
|
return $this->addLog($user_id, $data);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function addIncomeBalance($user_id, $payment, $amount, $description)
|
|
|
|
{
|
|
|
|
$data = [
|
|
|
|
'type' => 'income',
|
|
|
|
'payment' => $payment,
|
|
|
|
'description' => $description,
|
|
|
|
'income' => $amount,
|
|
|
|
'income_drops' => 0,
|
|
|
|
'outcome' => 0,
|
|
|
|
'outcome_drops' => 0,
|
|
|
|
];
|
|
|
|
|
|
|
|
return $this->addLog($user_id, $data);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function addPayoutBalance($user_id, $amount, $description)
|
|
|
|
{
|
|
|
|
$data = [
|
|
|
|
'type' => 'payout',
|
|
|
|
'payment' => 'balance',
|
|
|
|
'description' => $description,
|
|
|
|
'income' => 0,
|
|
|
|
'income_drops' => 0,
|
|
|
|
'outcome' => $amount,
|
2022-09-15 05:38:50 +00:00
|
|
|
'outcome_drops' => 0
|
2022-09-15 04:13:37 +00:00
|
|
|
];
|
|
|
|
|
|
|
|
return $this->addLog($user_id, $data);
|
|
|
|
}
|
|
|
|
|
2022-10-07 05:15:08 +00:00
|
|
|
|
|
|
|
|
2022-10-02 13:26:59 +00:00
|
|
|
public function reduceAmount($user_id, $amount = 0, $description = '扣除费用请求。')
|
|
|
|
{
|
|
|
|
|
2022-10-07 05:15:08 +00:00
|
|
|
$lock = Cache::lock("user_balance_lock_" . $user_id, 10);
|
|
|
|
try {
|
|
|
|
|
|
|
|
$lock->block(5);
|
|
|
|
|
|
|
|
$user = User::findOrFail($user_id);
|
2022-10-02 13:26:59 +00:00
|
|
|
|
2022-10-07 05:15:08 +00:00
|
|
|
$user->balance -= $amount;
|
2022-10-02 13:26:59 +00:00
|
|
|
$user->save();
|
2022-10-07 05:15:08 +00:00
|
|
|
|
|
|
|
$this->addPayoutBalance($user_id, $amount, $description);
|
|
|
|
|
|
|
|
return $user->balance;
|
|
|
|
} finally {
|
|
|
|
optional($lock)->release();
|
2022-10-02 13:26:59 +00:00
|
|
|
}
|
|
|
|
|
2022-10-07 05:15:08 +00:00
|
|
|
return false;
|
|
|
|
}
|
2022-10-02 13:26:59 +00:00
|
|
|
|
2022-10-07 05:15:08 +00:00
|
|
|
public function addAmount($user_id, $payment = 'console', $amount = 0, $description = null)
|
|
|
|
{
|
|
|
|
$lock = Cache::lock("user_balance_lock_" . $user_id, 10);
|
|
|
|
try {
|
|
|
|
|
|
|
|
$lock->block(5);
|
|
|
|
|
|
|
|
$user = User::findOrFail($user_id);
|
|
|
|
|
|
|
|
$left_balance = $user->balance + $amount;
|
|
|
|
|
|
|
|
$user->increment('balance', $amount);
|
|
|
|
|
|
|
|
if (!$description) {
|
|
|
|
$description = '充值金额。';
|
|
|
|
} else {
|
|
|
|
$description = '充值 ' . $amount . ' 元';
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->addIncomeBalance($user_id, $payment, $amount, $description);
|
|
|
|
|
|
|
|
return $left_balance;
|
|
|
|
} catch (LockTimeoutException $e) {
|
|
|
|
Log::error($e);
|
|
|
|
throw new ChargeException('充值失败,请稍后再试。');
|
|
|
|
} finally {
|
|
|
|
optional($lock)->release();
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
2022-10-02 13:26:59 +00:00
|
|
|
}
|
|
|
|
|
2022-09-15 04:13:37 +00:00
|
|
|
|
|
|
|
private function addLog($user_id, $data)
|
|
|
|
{
|
|
|
|
$user = User::find($user_id);
|
|
|
|
|
|
|
|
$current = [
|
|
|
|
'balance' => $user->balance,
|
|
|
|
'drops' => $this->getDrops($user_id),
|
2022-10-02 13:26:59 +00:00
|
|
|
'user_id' => intval($user_id),
|
2022-09-15 04:13:37 +00:00
|
|
|
];
|
|
|
|
|
|
|
|
// merge
|
|
|
|
$data = array_merge($data, $current);
|
|
|
|
|
|
|
|
// add expired at
|
|
|
|
$data['expired_at'] = now()->addSeconds(7);
|
|
|
|
|
|
|
|
|
|
|
|
return $this->create($data);
|
|
|
|
}
|
2022-09-14 14:19:28 +00:00
|
|
|
}
|