mirror of
				https://github.com/v2board/v2board.git
				synced 2025-10-31 09:21:46 +08:00 
			
		
		
		
	feature: shadowsocks and more
This commit is contained in:
		| @@ -24,6 +24,49 @@ class OrderService | ||||
|         $this->order = $order; | ||||
|     } | ||||
|  | ||||
|     public function open() | ||||
|     { | ||||
|         $order = $this->order; | ||||
|         $user = User::find($order->user_id); | ||||
|         $plan = Plan::find($order->plan_id); | ||||
|  | ||||
|         if ($order->refund_amount) { | ||||
|             $user->balance = $user->balance + $order->refund_amount; | ||||
|         } | ||||
|         DB::beginTransaction(); | ||||
|         if ($order->surplus_order_ids) { | ||||
|             try { | ||||
|                 Order::whereIn('id', json_decode($order->surplus_order_ids))->update([ | ||||
|                     'status' => 4 | ||||
|                 ]); | ||||
|             } catch (\Exception $e) { | ||||
|                 DB::rollback(); | ||||
|                 abort(500, '开通失败'); | ||||
|             } | ||||
|         } | ||||
|         switch ((string)$order->cycle) { | ||||
|             case 'onetime_price': | ||||
|                 $this->buyByOneTime($user, $plan); | ||||
|                 break; | ||||
|             case 'reset_price': | ||||
|                 $this->buyByResetTraffic($user); | ||||
|                 break; | ||||
|             default: | ||||
|                 $this->buyByCycle($order, $user, $plan); | ||||
|         } | ||||
|         if (!$user->save()) { | ||||
|             DB::rollBack(); | ||||
|             abort(500, '开通失败'); | ||||
|         } | ||||
|         $order->status = 3; | ||||
|         if (!$order->save()) { | ||||
|             DB::rollBack(); | ||||
|             abort(500, '开通失败'); | ||||
|         } | ||||
|  | ||||
|         DB::commit(); | ||||
|     } | ||||
|  | ||||
|     public function cancel():bool | ||||
|     { | ||||
|         $order = $this->order; | ||||
| @@ -165,4 +208,61 @@ class OrderService | ||||
|         $order->callback_no = $callbackNo; | ||||
|         return $order->save(); | ||||
|     } | ||||
|  | ||||
|  | ||||
|     private function buyByResetTraffic(User $user) | ||||
|     { | ||||
|         $user->u = 0; | ||||
|         $user->d = 0; | ||||
|     } | ||||
|  | ||||
|     private function buyByCycle(Order $order, User $user, Plan $plan) | ||||
|     { | ||||
|         // change plan process | ||||
|         if ((int)$order->type === 3) { | ||||
|             $user->expired_at = time(); | ||||
|         } | ||||
|         $user->transfer_enable = $plan->transfer_enable * 1073741824; | ||||
|  | ||||
|         // 续费重置&类型=续费 | ||||
|         if ((int)config('v2board.renew_reset_traffic_enable', 1) && $order->type === 2) $this->buyByResetTraffic($user); | ||||
|         // 购买前用户过期为NULL(一次性) | ||||
|         if ($user->expired_at === NULL) $this->buyByResetTraffic($user); | ||||
|         // 新购 | ||||
|         if ($order->type === 1) $this->buyByResetTraffic($user); | ||||
|         $user->plan_id = $plan->id; | ||||
|         $user->group_id = $plan->group_id; | ||||
|         $user->expired_at = $this->getTime($order->cycle, $user->expired_at); | ||||
|     } | ||||
|  | ||||
|     private function buyByOneTime(User $user, Plan $plan) | ||||
|     { | ||||
|         $user->transfer_enable = $plan->transfer_enable * 1073741824; | ||||
|         $user->u = 0; | ||||
|         $user->d = 0; | ||||
|         $user->plan_id = $plan->id; | ||||
|         $user->group_id = $plan->group_id; | ||||
|         $user->expired_at = NULL; | ||||
|     } | ||||
|  | ||||
|     private function getTime($str, $timestamp) | ||||
|     { | ||||
|         if ($timestamp < time()) { | ||||
|             $timestamp = time(); | ||||
|         } | ||||
|         switch ($str) { | ||||
|             case 'month_price': | ||||
|                 return strtotime('+1 month', $timestamp); | ||||
|             case 'quarter_price': | ||||
|                 return strtotime('+3 month', $timestamp); | ||||
|             case 'half_year_price': | ||||
|                 return strtotime('+6 month', $timestamp); | ||||
|             case 'year_price': | ||||
|                 return strtotime('+12 month', $timestamp); | ||||
|             case 'two_year_price': | ||||
|                 return strtotime('+24 month', $timestamp); | ||||
|             case 'three_year_price': | ||||
|                 return strtotime('+36 month', $timestamp); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -3,11 +3,13 @@ | ||||
| namespace App\Services; | ||||
|  | ||||
| use App\Models\ServerLog; | ||||
| use App\Models\ServerShadowsocks; | ||||
| use App\Models\User; | ||||
| use App\Models\Server; | ||||
| use App\Models\ServerTrojan; | ||||
| use App\Utils\CacheKey; | ||||
| use App\Utils\Helper; | ||||
| use App\Utils\URLSchemes; | ||||
| use Illuminate\Support\Facades\Cache; | ||||
|  | ||||
| class ServerService | ||||
| @@ -24,9 +26,10 @@ class ServerService | ||||
|         } | ||||
|         $vmesss = $model->get(); | ||||
|         foreach ($vmesss as $k => $v) { | ||||
|             $vmesss[$k]['protocol_type'] = 'vmess'; | ||||
|             $groupId = json_decode($vmesss[$k]['group_id']); | ||||
|             if (in_array($user->group_id, $groupId)) { | ||||
|                 $vmesss[$k]['link'] = Helper::buildVmessLink($vmesss[$k], $user); | ||||
|                 $vmesss[$k]['link'] = URLSchemes::buildVmess($vmesss[$k], $user); | ||||
|                 if ($vmesss[$k]['parent_id']) { | ||||
|                     $vmesss[$k]['last_check_at'] = Cache::get(CacheKey::get('SERVER_V2RAY_LAST_CHECK_AT', $vmesss[$k]['parent_id'])); | ||||
|                 } else { | ||||
| @@ -49,7 +52,9 @@ class ServerService | ||||
|         } | ||||
|         $trojans = $model->get(); | ||||
|         foreach ($trojans as $k => $v) { | ||||
|             $trojans[$k]['protocol_type'] = 'trojan'; | ||||
|             $groupId = json_decode($trojans[$k]['group_id']); | ||||
|             $trojans[$k]['link'] = URLSchemes::buildTrojan($trojans[$k], $user); | ||||
|             if (in_array($user->group_id, $groupId)) { | ||||
|                 if ($trojans[$k]['parent_id']) { | ||||
|                     $trojans[$k]['last_check_at'] = Cache::get(CacheKey::get('SERVER_TROJAN_LAST_CHECK_AT', $trojans[$k]['parent_id'])); | ||||
| @@ -63,9 +68,35 @@ class ServerService | ||||
|         return $trojan; | ||||
|     } | ||||
|  | ||||
|     public function getShadowsocks(User $user, $all = false) | ||||
|     { | ||||
|         $shadowsocks = []; | ||||
|         $model = ServerShadowsocks::orderBy('sort', 'ASC'); | ||||
|         if (!$all) { | ||||
|             $model->where('show', 1); | ||||
|         } | ||||
|         $shadowsockss = $model->get(); | ||||
|         foreach ($shadowsockss as $k => $v) { | ||||
|             $shadowsockss[$k]['protocol_type'] = 'shadowsocks'; | ||||
|             $groupId = json_decode($shadowsockss[$k]['group_id']); | ||||
|             $shadowsockss[$k]['link'] = URLSchemes::buildShadowsocks($shadowsockss[$k], $user); | ||||
|             if (in_array($user->group_id, $groupId)) { | ||||
|                 if ($shadowsockss[$k]['parent_id']) { | ||||
|                     $shadowsockss[$k]['last_check_at'] = Cache::get(CacheKey::get('SERVER_TROJAN_LAST_CHECK_AT', $shadowsockss[$k]['parent_id'])); | ||||
|                 } else { | ||||
|                     $shadowsockss[$k]['last_check_at'] = Cache::get(CacheKey::get('SERVER_TROJAN_LAST_CHECK_AT', $shadowsockss[$k]['id'])); | ||||
|                 } | ||||
|                 array_push($shadowsocks, $shadowsockss[$k]); | ||||
|             } | ||||
|  | ||||
|         } | ||||
|         return $shadowsocks; | ||||
|     } | ||||
|  | ||||
|     public function getAllServers(User $user, $all = false) | ||||
|     { | ||||
|         return [ | ||||
|             'shadowsocks' => $this->getShadowsocks($user, $all), | ||||
|             'vmess' => $this->getVmess($user, $all), | ||||
|             'trojan' => $this->getTrojan($user, $all) | ||||
|         ]; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user