Files
lotteryLaravel/app/Models/AdminSite.php
kang a10135d6ee feat: 增强玩家管理功能,集成接入站点权限控制
在多个玩家相关控制器中引入 AdminSiteScope,确保管理员在执行操作前具备相应的接入站点权限。更新 Player 相关请求以支持 site_code 参数,增强权限验证逻辑,确保系统安全性与灵活性。同时,新增 AdminUser 模型方法以获取可访问的站点 ID 列表,优化权限管理。
2026-05-27 13:36:23 +08:00

74 lines
1.7 KiB
PHP

<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Model;
/**
* 后台站点 / 主站接入配置({@see $table admin_sites})。
*
* `code` 对外即 JWT 与钱包回调中的 `site_code`,创建后不可修改。
*/
final class AdminSite extends Model
{
protected $table = 'admin_sites';
protected $fillable = [
'code',
'name',
'currency_code',
'status',
'is_default',
'extra_json',
'wallet_api_url',
'wallet_debit_path',
'wallet_credit_path',
'wallet_balance_path',
'wallet_api_key_encrypted',
'sso_jwt_secret_encrypted',
'wallet_timeout_seconds',
'iframe_allowed_origins',
'lottery_h5_base_url',
'notes',
];
protected function casts(): array
{
return [
'status' => 'integer',
'is_default' => 'boolean',
'extra_json' => 'array',
'iframe_allowed_origins' => 'array',
'wallet_timeout_seconds' => 'integer',
];
}
public function isEnabled(): bool
{
return (int) $this->status === 1;
}
public function decryptedSsoJwtSecret(): ?string
{
return $this->decryptSecret($this->sso_jwt_secret_encrypted);
}
public function decryptedWalletApiKey(): ?string
{
return $this->decryptSecret($this->wallet_api_key_encrypted);
}
private function decryptSecret(?string $encrypted): ?string
{
if (! is_string($encrypted) || $encrypted === '') {
return null;
}
try {
return decrypt($encrypted);
} catch (\Throwable) {
return null;
}
}
}