mirror of
https://github.com/ProxyPanel/ProxyPanel.git
synced 2026-04-06 20:50:01 +00:00
751 lines
48 KiB
PHP
751 lines
48 KiB
PHP
@extends('admin.layouts')
|
||
@section('css')
|
||
<link href="/assets/global/vendor/bootstrap-select/bootstrap-select.min.css" rel="stylesheet">
|
||
<link href="/assets/global/vendor/switchery/switchery.min.css" rel="stylesheet">
|
||
<style>
|
||
.hidden {
|
||
display: none
|
||
}
|
||
</style>
|
||
@endsection
|
||
@section('content')
|
||
<div class="page-content container-fluid">
|
||
<div class="panel">
|
||
<div class="panel-heading">
|
||
<h2 class="panel-title">@isset($node)
|
||
编辑节点
|
||
@else
|
||
添加节点
|
||
@endisset</h2>
|
||
</div>
|
||
<div class="alert alert-info" role="alert">
|
||
<button class="close" data-dismiss="alert" aria-label="Close">
|
||
<span aria-hidden="true">×</span>
|
||
<span class="sr-only">{{trans('common.close')}}</span>
|
||
</button>
|
||
<strong>注意:</strong> 添加节点后自动生成的<code>ID</code>,即为该节点部署ShadowsocksR Python版后端时<code>usermysql.json</code>中的<code>node_id</code>的值,同时也是部署V2Ray后端时的<code>nodeId</code>的值;
|
||
</div>
|
||
<div class="panel-body">
|
||
<form class="form-horizontal" onsubmit="return Submit()">
|
||
<div class="row">
|
||
<div class="col-lg-6">
|
||
<div class="example-wrap">
|
||
<h4 class="example-title">基础信息</h4>
|
||
<div class="example">
|
||
<div class="form-group row">
|
||
<label for="is_ddns" class="col-md-3 col-form-label">DDNS</label>
|
||
<div class="col-md-9">
|
||
<input type="checkbox" id="is_ddns" name="is_ddns" data-plugin="switchery" onchange="switchSetting('is_ddns')">
|
||
</div>
|
||
<div class="text-help offset-md-3">
|
||
动态IP节点需要<a href="https://github.com/NewFuture/DDNS" target="_blank">配置DDNS</a>,对此类型节点,节点阻断功能会通过域名进行检测
|
||
</div>
|
||
</div>
|
||
<div class="form-group row">
|
||
<label for="name" class="col-md-3 col-form-label"> 节点名称 </label>
|
||
<input type="text" class="form-control col-md-4" name="name" id="name" required>
|
||
</div>
|
||
<div class="form-group row">
|
||
<label for="server" class="col-md-3 col-form-label"> 域名 </label>
|
||
<input type="text" class="form-control col-md-4" name="server" id="server" placeholder="服务器域名地址,填则优先取域名地址">
|
||
<span class="text-help offset-md-3">系统设置中开启【DDNS模式】,域名将会自动与下方IP内容进行绑定操作!无需再前往域名注册商页面修改IP信息了哟</span>
|
||
</div>
|
||
<div class="form-group row">
|
||
<label for="ip" class="col-md-3 col-form-label"> IPv4地址 </label>
|
||
<input type="text" class="form-control col-md-4" name="ip" id="ip" placeholder="服务器IPv4地址" required>
|
||
<span class="text-help offset-md-3">多IP使用“, ”分割,例:1.1.1.1, 8.8.8.8</span>
|
||
</div>
|
||
<div class="form-group row">
|
||
<label for="ipv6" class="col-md-3 col-form-label"> IPv6地址 </label>
|
||
<input type="text" class="form-control col-md-4" name="ipv6" id="ipv6" placeholder="服务器IPv6地址,填写则用户可见,域名无效">
|
||
<span class="text-help offset-md-3">多IP使用“, ”分割,例:1.1.1.1, 8.8.8.8</span>
|
||
</div>
|
||
<div class="form-group row">
|
||
<label for="push_port" class="col-md-3 col-form-label"> 消息推送端口 </label>
|
||
<input type="number" class="form-control col-md-4" name="push_port" value="1080" id="push_port">
|
||
<span class="text-help offset-md-3">必填且防火墙需放行,否则将导致消息推送异常</span>
|
||
</div>
|
||
<div class="form-group row">
|
||
<label for="traffic_rate" class="col-md-3 col-form-label"> 流量比例 </label>
|
||
<input type="number" class="form-control col-md-4" name="traffic_rate" value="1.0" id="traffic_rate" step="0.01" required>
|
||
<div class="text-help offset-md-3"> 举例:0.1用100M结算10M,5用100M结算500M</div>
|
||
</div>
|
||
<div class="form-group row">
|
||
<label for="level" class="col-md-3 col-form-label">等级</label>
|
||
<select data-plugin="selectpicker" data-style="btn-outline btn-primary" class="col-md-5 form-control show-tick" id="level" name="level">
|
||
@foreach($levels as $level)
|
||
<option value="{{$level->level}}">{{$level->name}}</option>
|
||
@endforeach
|
||
</select>
|
||
<div class="text-help offset-md-3"> 等级:0-无等级,全部可见</div>
|
||
</div>
|
||
<div class="form-group row">
|
||
<label for="ruleGroup" class="col-md-3 col-form-label">审计分组</label>
|
||
<select data-plugin="selectpicker" data-style="btn-outline btn-primary" class="col-md-5 form-control show-tick"
|
||
id="ruleGroup" name="ruleGroup">
|
||
<option value="">不使用</option>
|
||
@foreach($ruleGroups as $ruleGroup)
|
||
<option value="{{$ruleGroup->id}}">{{$ruleGroup->name}}</option>
|
||
@endforeach
|
||
</select>
|
||
</div>
|
||
<div class="form-group row">
|
||
<label for="speed_limit" class="col-md-3 col-form-label">节点限速</label>
|
||
<div class="col-md-4 input-group p-0">
|
||
<input type="number" class="form-control" id="speed_limit" name="speed_limit" value="1000" required>
|
||
<span class="input-group-text">Mbps</span>
|
||
</div>
|
||
</div>
|
||
<div class="form-group row">
|
||
<label for="client_limit" class="col-md-3 col-form-label">设备数限制</label>
|
||
<input type="number" class="form-control col-md-4" id="client_limit" name="client_limit" value="1000" required>
|
||
</div>
|
||
<div class="form-group row">
|
||
<label for="labels" class="col-md-3 col-form-label">标签</label>
|
||
<select data-plugin="selectpicker" data-style="btn-outline btn-primary" class="col-md-5 form-control show-tick" id="labels" name="labels"
|
||
multiple>
|
||
@foreach($labels as $label)
|
||
<option value="{{$label->id}}">{{$label->name}}</option>
|
||
@endforeach
|
||
</select>
|
||
</div>
|
||
<div class="form-group row">
|
||
<label for="country_code" class="col-md-3 col-form-label"> 国家/地区 </label>
|
||
<select data-plugin="selectpicker" data-style="btn-outline btn-primary"
|
||
class="col-md-5 form-control" name="country_code" id="country_code">
|
||
@foreach($countries as $country)
|
||
<option value="{{$country->code}}">{{$country->code}} - {{$country->name}}</option>
|
||
@endforeach
|
||
</select>
|
||
</div>
|
||
<div class="form-group row">
|
||
<label for="description" class="col-md-3 col-form-label"> 描述 </label>
|
||
<input type="text" class="form-control col-md-6" name="description" id="description" placeholder="简单描述">
|
||
</div>
|
||
<div class="form-group row">
|
||
<label for="sort" class="col-md-3 col-form-label">排序</label>
|
||
<input type="text" class="form-control col-md-4" name="sort" id="sort" value="1" required/>
|
||
<div class="text-help offset-md-3"> 排序值越大排越前       </div>
|
||
</div>
|
||
<div class="form-group row">
|
||
<label for="is_udp" class="col-md-3 col-form-label">UDP</label>
|
||
<div class="col-md-9">
|
||
<input type="checkbox" id="is_udp" name="is_udp" data-plugin="switchery">
|
||
</div>
|
||
</div>
|
||
<div class="form-group row">
|
||
<label for="status" class="col-md-3 col-form-label">状态</label>
|
||
<div class="col-md-9">
|
||
<input type="checkbox" id="status" name="status" data-plugin="switchery">
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
<div class="col-lg-6">
|
||
<div class="example-wrap">
|
||
<h4 class="example-title">扩展信息</h4>
|
||
<div class="example">
|
||
<div class="form-group row">
|
||
<label for="is_subscribe" class="col-md-3 col-form-label">订阅</label>
|
||
<div class="col-md-9">
|
||
<input type="checkbox" id="is_subscribe" name="is_subscribe" data-plugin="switchery">
|
||
</div>
|
||
</div>
|
||
<div class="form-group row">
|
||
<label for="detection_type" class="col-md-3 col-form-label">节点阻断检测</label>
|
||
<ul class="col-md-9 list-unstyled list-inline">
|
||
<li class="list-inline-item">
|
||
<div class="radio-custom radio-primary">
|
||
<input type="radio" id="detect_disable" name="detection_type" value="0" checked/>
|
||
<label for="detect_disable">关闭</label>
|
||
</div>
|
||
</li>
|
||
<li class="list-inline-item">
|
||
<div class="radio-custom radio-primary">
|
||
<input type="radio" id="detect_tcp" name="detection_type" value="1"/>
|
||
<label for="detect_tcp">只检测TCP</label>
|
||
</div>
|
||
</li>
|
||
<li class="list-inline-item">
|
||
<div class="radio-custom radio-primary">
|
||
<input type="radio" id="detect_icmp" name="detection_type" value="2"/>
|
||
<label for="detect_icmp">只检测ICMP</label>
|
||
</div>
|
||
</li>
|
||
<li class="list-inline-item">
|
||
<div class="radio-custom radio-primary">
|
||
<input type="radio" id="detect_all" name="detection_type" value="3"/>
|
||
<label for="detect_all">检测全部</label>
|
||
</div>
|
||
</li>
|
||
</ul>
|
||
<div class="text-help offset-md-3"> 每30~60分钟随机进行节点阻断检测</div>
|
||
</div>
|
||
<!-- 中转 设置部分 -->
|
||
<div class="form-group row">
|
||
<label for="relay_node_id" class="col-md-3 col-form-label">中转</label>
|
||
<select data-plugin="selectpicker" data-style="btn-outline btn-primary" class="col-md-5 form-control show-tick"
|
||
id="relay_node_id" name="relay_node_id">
|
||
<option value="">不使用</option>
|
||
@foreach($nodes as $name => $id)
|
||
<option value="{{$id}}">{{$id}} - {{$name}}</option>
|
||
@endforeach
|
||
</select>
|
||
</div>
|
||
<hr/>
|
||
<!-- 代理 设置部分 -->
|
||
<div class="proxy-config">
|
||
<div class="form-group row">
|
||
<label for="type" class="col-md-3 col-form-label">类型</label>
|
||
<ul class="col-md-9 list-unstyled list-inline">
|
||
<li class="list-inline-item">
|
||
<div class="radio-custom radio-primary">
|
||
<input type="radio" id="shadowsocks" name="type" value="0">
|
||
<label for="shadowsocks">Shadowsocks</label>
|
||
</div>
|
||
</li>
|
||
<li class="list-inline-item">
|
||
<div class="radio-custom radio-primary">
|
||
<input type="radio" id="shadowsocksR" name="type" value="1">
|
||
<label for="shadowsocksR">ShadowsocksR</label>
|
||
</div>
|
||
</li>
|
||
<li class="list-inline-item">
|
||
<div class="radio-custom radio-primary">
|
||
<input type="radio" id="v2ray" name="type" value="2">
|
||
<label for="v2ray">V2Ray</label>
|
||
</div>
|
||
</li>
|
||
<li class="list-inline-item">
|
||
<div class="radio-custom radio-primary">
|
||
<input type="radio" id="trojan" name="type" value="3">
|
||
<label for="trojan">Trojan</label>
|
||
</div>
|
||
</li>
|
||
<li class="list-inline-item">
|
||
<div class="radio-custom radio-primary">
|
||
<input type="radio" id="vnet" name="type" value="4">
|
||
<label for="vnet">VNET</label>
|
||
</div>
|
||
</li>
|
||
</ul>
|
||
</div>
|
||
<hr/>
|
||
<!-- SS/SSR 设置部分 -->
|
||
<div class="ss-setting">
|
||
<div class="form-group row">
|
||
<label for="method" class="col-md-3 col-form-label">加密方式</label>
|
||
<select data-plugin="selectpicker" data-style="btn-outline btn-primary" class="col-md-5 form-control" name="method" id="method">
|
||
@foreach (Helpers::methodList() as $method)
|
||
<option value="{{$method->name}}" @if(!isset($node) && $method->is_default) selected @endif>{{$method->name}}</option>
|
||
@endforeach
|
||
</select>
|
||
</div>
|
||
<div class="ssr-setting">
|
||
<div class="form-group row">
|
||
<label for="protocol" class="col-md-3 col-form-label">协议</label>
|
||
<select data-plugin="selectpicker" data-style="btn-outline btn-primary" class="col-md-5 form-control" name="protocol"
|
||
id="protocol">
|
||
@foreach (Helpers::protocolList() as $protocol)
|
||
<option value="{{$protocol->name}}"
|
||
@if(!isset($node) && $protocol->is_default) selected @endif>{{$protocol->name}}</option>
|
||
@endforeach
|
||
</select>
|
||
</div>
|
||
<div class="form-group row">
|
||
<label for="protocol_param" class="col-md-3 col-form-label"> 协议参数 </label>
|
||
<input type="text" class="form-control col-md-4" name="protocol_param" id="protocol_param">
|
||
</div>
|
||
<div class="form-group row">
|
||
<label for="obfs" class="col-md-3 col-form-label">混淆</label>
|
||
<select data-plugin="selectpicker" data-style="btn-outline btn-primary" class="col-md-5 form-control" name="obfs" id="obfs">
|
||
@foreach (Helpers::obfsList() as $obfs)
|
||
<option value="{{$obfs->name}}" @if(!isset($node) && $obfs->is_default) selected @endif>{{$obfs->name}}</option>
|
||
@endforeach
|
||
</select>
|
||
</div>
|
||
<div class="form-group row obfs_param">
|
||
<label for="obfs_param" class="col-md-3 col-form-label"> 混淆参数 </label>
|
||
<textarea class="form-control col-md-8" rows="5" name="obfs_param" id="obfs_param"
|
||
placeholder="混淆不为 [plain] 时可填入参数进行流量伪装; 混淆为 [http_simple] 时,建议端口为 80; 混淆为 [tls] 时,建议端口为 443;"></textarea>
|
||
</div>
|
||
<div class="form-group row">
|
||
<label class="col-md-3 col-form-label">*兼容 SS</label>
|
||
<div class="text-help col-md-9">
|
||
如果兼容请在服务端配置协议和混淆时加上<span class="red-700">_compatible</span>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
<hr/>
|
||
<div class="form-group row">
|
||
<label for="single" class="col-md-3 col-form-label">单端口</label>
|
||
<div class="col-md-9">
|
||
<input type="checkbox" id="single" name="single" data-plugin="switchery" onchange="switchSetting('single')">
|
||
</div>
|
||
<div class="text-help offset-md-3">
|
||
如果启用请配置服务端的<span class="red-700"><a href="javascript:showTnc();">additional_ports</a></span>信息
|
||
</div>
|
||
</div>
|
||
<div class="single-setting">
|
||
<div class="form-group row">
|
||
<label for="single_port" class="col-md-3 col-form-label">[单] 端口</label>
|
||
<input type="number" class="form-control col-md-4" name="port" id="single_port" value="443" hidden/>
|
||
<span class="text-help offset-md-3"> 推荐80或443,服务端需要配置 <br>
|
||
严格模式:用户的端口无法连接,只能通过以下指定的端口进行连接(<a href="javascript:showPortsOnlyConfig();">如何配置</a>)</span>
|
||
</div>
|
||
<div class="form-group row ssr-setting">
|
||
<label for="passwd" class="col-md-3 col-form-label">[单] 密码</label>
|
||
<input type="text" class="form-control col-md-4" name="passwd" id="passwd" placeholder="password">
|
||
</div>
|
||
</div>
|
||
</div>
|
||
<!-- V2ray 设置部分 -->
|
||
<div class="v2ray-setting">
|
||
<div class="form-group row">
|
||
<label for="v2_alter_id" class="col-md-3 col-form-label">额外ID</label>
|
||
<input type="text" class="form-control col-md-4" name="v2_alter_id" value="16" id="v2_alter_id" required/>
|
||
</div>
|
||
<div class="form-group row">
|
||
<label for="v2_port" class="col-md-3 col-form-label">服务端口</label>
|
||
<input type="number" class="form-control col-md-4" name="port" id="v2_port" value="10053" hidden/>
|
||
</div>
|
||
<div class="form-group row">
|
||
<label for="v2_method" class="col-md-3 col-form-label">加密方式</label>
|
||
<select data-plugin="selectpicker" data-style="btn-outline btn-primary" class="col-md-5 form-control" id="v2_method">
|
||
<option value="auto">auto</option>
|
||
<option value="none">none</option>
|
||
<option value="aes-128-gcm">aes-128-gcm</option>
|
||
<option value="chacha20-poly1305">chacha20-poly1305</option>
|
||
</select>
|
||
<div class="text-help offset-md-3"> 使用WebSocket传输协议时不要使用none</div>
|
||
</div>
|
||
<div class="form-group row">
|
||
<label for="v2_net" class="col-md-3 col-form-label">传输方式</label>
|
||
<select data-plugin="selectpicker" data-style="btn-outline btn-primary" class="col-md-5 form-control" id="v2_net">
|
||
<option value="tcp">TCP</option>
|
||
<option value="kcp">mKCP</option>
|
||
<option value="ws">WebSocket</option>
|
||
<option value="http">HTTP/2</option>
|
||
<option value="domainsocket">DomainSocket</option>
|
||
<option value="quic">QUIC</option>
|
||
</select>
|
||
<div class="text-help offset-md-3"> 使用WebSocket传输协议时请启用TLS</div>
|
||
</div>
|
||
<div class="form-group row v2_type">
|
||
<label for="v2_type" class="col-md-3 col-form-label">伪装类型</label>
|
||
<select data-plugin="selectpicker" data-style="btn-outline btn-primary" class="col-md-5 form-control" id="v2_type">
|
||
<option value="none">无伪装</option>
|
||
<option value="http">HTTP数据流</option>
|
||
<optgroup id="type_option" label="">
|
||
<option value="srtp">视频通话数据 (SRTP)</option>
|
||
<option value="utp">BT下载数据 (uTP)</option>
|
||
<option value="wechat-video">微信视频通话</option>
|
||
<option value="dtls">DTLS1.2数据包</option>
|
||
<option value="wireguard">WireGuard数据包</option>
|
||
</optgroup>
|
||
</select>
|
||
</div>
|
||
<div class="form-group row v2_host">
|
||
<label for="v2_host" class="col-md-3 col-form-label">伪装域名</label>
|
||
<div class="col-md-4 pl-0">
|
||
<input type="text" class="form-control" name="v2_other" id="v2_host">
|
||
</div>
|
||
<div class="text-help offset-md-3">
|
||
伪装类型为http时多个伪装域名逗号隔开,使用WebSocket传输协议时只允许单个
|
||
</div>
|
||
</div>
|
||
<div class="form-group row">
|
||
<label for="v2_path" class="col-md-3 col-form-label">路径 | 密钥</label>
|
||
<input type="text" class="form-control col-md-4" name="v2_path" id="v2_path">
|
||
</div>
|
||
<div class="form-group row">
|
||
<label for="v2_sni" class="col-md-3 col-form-label">SNI</label>
|
||
<input type="text" class="form-control col-md-4" name="v2_sni" id="v2_sni">
|
||
</div>
|
||
<div class="form-group row">
|
||
<label for="v2_tls" class="col-md-3 col-form-label">连接TLS</label>
|
||
<div class="col-md-9">
|
||
<input type="checkbox" id="v2_tls" name="v2_tls" data-plugin="switchery" onchange="switchSetting('v2_tls')">
|
||
</div>
|
||
</div>
|
||
<div class="form-group row">
|
||
<label for="tls_provider" class="col-md-3 col-form-label">TLS配置</label>
|
||
<input type="text" class="form-control col-md-9" name="tls_provider" id="tls_provider"/>
|
||
<div class="text-help offset-md-3"> 不同后端配置不同:
|
||
<a href="https://proxypanel.gitbook.io/wiki/webapi/webapi-basic-setting#vnet-v2-ray-hou-duan" target="_blank">VNET-V2Ray</a>、
|
||
<a href="https://proxypanel.gitbook.io/wiki/webapi/webapi-basic-setting#v-2-ray-poseidon-hou-duan"
|
||
target="_blank">V2Ray-Poseidon</a>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
<!-- Trojan 设置部分 -->
|
||
<div class="trojan-setting">
|
||
<div class="form-group row">
|
||
<label for="trojan_port" class="col-md-3 col-form-label">连接端口</label>
|
||
<input type="number" class="form-control col-md-4" name="port" id="trojan_port" value="443" hidden/>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
<div class="relay-config">
|
||
<div class="form-group row">
|
||
<label for="relay_port" class="col-md-3 col-form-label">中转端口</label>
|
||
<input type="number" class="form-control col-md-4" name="port" id="relay_port" value="443" hidden/>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
<div class="col-md-12 form-actions">
|
||
<div class="float-right">
|
||
<a href="{{route('admin.node.index')}}" class="btn btn-danger">返 回</a>
|
||
<button type="submit" class="btn btn-success">提 交</button>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</form>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
@endsection
|
||
@section('javascript')
|
||
<script src="/assets/global/vendor/bootstrap-select/bootstrap-select.min.js"></script>
|
||
<script src="/assets/global/js/Plugin/bootstrap-select.js"></script>
|
||
<script src="/assets/global/vendor/switchery/switchery.min.js"></script>
|
||
<script src="/assets/global/js/Plugin/switchery.js"></script>
|
||
<script>
|
||
const string = "{{strtolower(Str::random())}}";
|
||
$(document).ready(function() {
|
||
$('.relay-config').hide();
|
||
let v2_path = $('#v2_path');
|
||
switchSetting('single');
|
||
switchSetting('is_ddns');
|
||
@isset($node)
|
||
|
||
@if($node->is_ddns)
|
||
$('#is_ddns').click();
|
||
@endif
|
||
$('#name').val('{{$node->name}}');
|
||
$('#server').val('{{$node->server}}');
|
||
$('#ip').val('{{$node->ip}}');
|
||
$('#ipv6').val('{{$node->ipv6}}');
|
||
$('#push_port').val('{{$node->push_port}}');
|
||
$('#traffic_rate').val('{{$node->traffic_rate}}');
|
||
$('#level').selectpicker('val', '{{$node->level}}');
|
||
$('#ruleGroup').selectpicker('val', '{{$node->rule_group_id}}');
|
||
$('#speed_limit').val('{{$node->speed_limit}}');
|
||
$('#client_limit').val('{{$node->client_limit}}');
|
||
$('#labels').selectpicker('val', {{$node->labels->pluck('id')}});
|
||
$('#country_code').selectpicker('val', '{{$node->country_code}}');
|
||
$('#relay_node_id').selectpicker('val', '{{$node->relay_node_id}}');
|
||
$('#description').val('{{$node->description}}');
|
||
$('#sort').val('{{$node->sort}}');
|
||
@if($node->is_udp)
|
||
$('#is_udp').click();
|
||
@endif
|
||
@if($node->status)
|
||
$('#status').click();
|
||
@endif
|
||
@if($node->is_subscribe)
|
||
$('#is_subscribe').click();
|
||
@endif
|
||
$("input[name='detection_type'][value='{{$node->detection_type}}']").click();
|
||
@if(!empty($node->profile['passwd']) && $node->port)
|
||
$('#single').click();
|
||
$('#passwd').val('{{$node->profile['passwd']}}');
|
||
@endif
|
||
$('input[name = port]').val('{{$node->port}}');
|
||
$("input[name='type'][value='{{$node->type}}']").click();
|
||
|
||
@if(isset($node->relay_node_id))
|
||
$('#relay_port').val('{{$node->port}}');
|
||
@else
|
||
@switch($node->type)
|
||
@case(1)
|
||
@case(4)
|
||
$('#protocol').selectpicker('val', '{{$node->profile['protocol'] ?? null}}');
|
||
$('#protocol_param').val('{{$node->profile['protocol_param'] ?? null}}');
|
||
$('#obfs').selectpicker('val', '{{$node->profile['obfs'] ?? null}}');
|
||
$('#obfs_param').val('{{$node->profile['obfs_param'] ?? null}}');
|
||
@case(0)
|
||
$('#method').selectpicker('val', '{{$node->profile['method'] ?? null}}');
|
||
@break
|
||
|
||
@case(2)
|
||
//V2Ray
|
||
$('#v2_alter_id').val('{{$node->profile['v2_alter_id'] ?? null}}');
|
||
$('#v2_method').selectpicker('val', '{{$node->profile['v2_method'] ?? null}}');
|
||
$('#v2_net').selectpicker('val', '{{$node->profile['v2_net'] ?? null}}');
|
||
$('#v2_type').selectpicker('val', '{{$node->profile['v2_type'] ?? null}}');
|
||
$('#v2_host').val('{{$node->profile['v2_host'] ?? null}}');
|
||
$('#v2_port').val('{{$node->port}}');
|
||
$('#v2_sni').val('{{$node->profile['v2_sni'] ?? null}}');
|
||
v2_path.val('{{$node->profile['v2_path'] ?? null}}');
|
||
@if($node->profile['v2_tls'] ?? false)
|
||
$('#v2_tls').click();
|
||
@endif
|
||
$('#tls_provider').val('{!! $node->tls_provider !!}');
|
||
|
||
@break
|
||
@case(3)
|
||
$('#trojan_port').val('{{$node->port}}');
|
||
@break
|
||
@default
|
||
@endswitch
|
||
@endif
|
||
|
||
@else
|
||
$('input[name=\'type\'][value=\'0\']').click();
|
||
$('#status').click();
|
||
$('#is_udp').click();
|
||
$('#is_subscribe').click();
|
||
v2_path.val('/' + string);
|
||
@endisset
|
||
if ($('#obfs').val() === 'plain') {
|
||
$('.obfs_param').hide();
|
||
}
|
||
});
|
||
|
||
// ajax同步提交
|
||
function Submit() {
|
||
$.ajax({
|
||
method: @isset($node) 'PUT' @else 'POST' @endisset,
|
||
url: '{{isset($node)? route('admin.node.update', $node) : route('admin.node.store')}}',
|
||
dataType: 'json',
|
||
data: {
|
||
_token: '{{csrf_token()}}',
|
||
is_ddns: document.getElementById('is_ddns').checked ? 1 : 0,
|
||
name: $('#name').val(),
|
||
server: $('#server').val(),
|
||
ip: $('#ip').val(),
|
||
ipv6: $('#ipv6').val(),
|
||
push_port: $('#push_port').val(),
|
||
traffic_rate: $('#traffic_rate').val(),
|
||
level: $('#level').val(),
|
||
rule_group_id: $('#ruleGroup').val(),
|
||
speed_limit: $('#speed_limit').val(),
|
||
client_limit: $('#client_limit').val(),
|
||
labels: $('#labels').val(),
|
||
country_code: $('#country_code option:selected').val(),
|
||
description: $('#description').val(),
|
||
sort: $('#sort').val(),
|
||
is_udp: document.getElementById('is_udp').checked ? 1 : 0,
|
||
status: document.getElementById('status').checked ? 1 : 0,
|
||
type: $('input[name=\'type\']:checked').val(),
|
||
method: $('#method').val(),
|
||
protocol: $('#protocol').val(),
|
||
protocol_param: $('#protocol_param').val(),
|
||
obfs: $('#obfs').val(),
|
||
obfs_param: $('#obfs_param').val(),
|
||
is_subscribe: document.getElementById('is_subscribe').checked ? 1 : 0,
|
||
detection_type: $('input[name=\'detection_type\']:checked').val(),
|
||
single: document.getElementById('single').checked ? 1 : 0,
|
||
port: $('input[name="port"]:not([hidden])').val(),
|
||
passwd: $('#passwd').val(),
|
||
v2_alter_id: $('#v2_alter_id').val(),
|
||
v2_method: $('#v2_method').val(),
|
||
v2_net: $('#v2_net').val(),
|
||
v2_type: $('#v2_type').val(),
|
||
v2_host: $('#v2_host').val(),
|
||
v2_path: $('#v2_path').val(),
|
||
v2_sni: $('#v2_sni').val(),
|
||
v2_tls: document.getElementById('v2_tls').checked ? 1 : 0,
|
||
tls_provider: $('#tls_provider').val(),
|
||
relay_node_id: $('#relay_node_id option:selected').val(),
|
||
},
|
||
success: function(ret) {
|
||
if (ret.status === 'success') {
|
||
swal.fire({
|
||
title: ret.message,
|
||
icon: 'success',
|
||
timer: 1000,
|
||
showConfirmButton: false,
|
||
}).then(() => window.location.href = '{{route('admin.node.index').(Request::getQueryString()?('?'.Request::getQueryString()):'') }}');
|
||
} else {
|
||
swal.fire({title: '[错误 | Error]', text: ret.message, icon: 'error'});
|
||
}
|
||
},
|
||
error: function(data) {
|
||
let str = '';
|
||
const errors = data.responseJSON;
|
||
if ($.isEmptyObject(errors) === false) {
|
||
$.each(errors.errors, function(index, value) {
|
||
str += '<li>' + value + '</li>';
|
||
});
|
||
swal.fire({title: '提示', html: str, icon: 'error', confirmButtonText: '{{trans('common.confirm')}}'});
|
||
}
|
||
},
|
||
});
|
||
|
||
return false;
|
||
}
|
||
|
||
function switchSetting(id) {
|
||
let check = document.getElementById(id).checked ? 1 : 0;
|
||
switch (id) {
|
||
// 设置单端口多用户
|
||
case 'single':
|
||
if (check) {
|
||
$('.single-setting').show();
|
||
$('#single_port').removeAttr('hidden').attr('required', true);
|
||
} else {
|
||
$('#single_port').removeAttr('required').attr('hidden', true);
|
||
$('#passwd').val('');
|
||
$('.single-setting').hide();
|
||
}
|
||
break;
|
||
// 设置是否使用DDNS
|
||
case 'is_ddns':
|
||
if (check) {
|
||
$('#ip').val('').attr('readonly', true);
|
||
$('#ipv6').val('').attr('readonly', true);
|
||
$('#server').attr('required', true);
|
||
} else {
|
||
$('#ip').removeAttr('readonly');
|
||
$('#ipv6').removeAttr('readonly');
|
||
$('#server').removeAttr('required');
|
||
}
|
||
break;
|
||
default:
|
||
break;
|
||
}
|
||
}
|
||
|
||
// 设置服务类型
|
||
$('input:radio[name=\'type\']').on('change', function() {
|
||
const type = parseInt($(this).val());
|
||
const $ss_setting = $('.ss-setting');
|
||
const $ssr_setting = $('.ssr-setting');
|
||
const $v2ray_setting = $('.v2ray-setting');
|
||
const $trojan_setting = $('.trojan-setting');
|
||
$ssr_setting.hide();
|
||
$ss_setting.hide();
|
||
$v2ray_setting.hide();
|
||
$trojan_setting.hide();
|
||
$('#v2_port').removeAttr('required').attr('hidden', true);
|
||
$('#trojan_port').removeAttr('required');
|
||
switch (type) {
|
||
case 0:
|
||
$ss_setting.show();
|
||
break;
|
||
case 2:
|
||
$v2ray_setting.show();
|
||
$('#v2_port').removeAttr('hidden').attr('required', true);
|
||
$('#v2_net').selectpicker('val', 'tcp');
|
||
break;
|
||
case 3:
|
||
$trojan_setting.show();
|
||
$('#trojan_port').removeAttr('hidden').attr('required', true);
|
||
break;
|
||
case 1:
|
||
case 4:
|
||
$ss_setting.show();
|
||
$ssr_setting.show();
|
||
break;
|
||
default:
|
||
}
|
||
});
|
||
|
||
$('#obfs').on('changed.bs.select', function() {
|
||
const obfs_param = $('.obfs_param');
|
||
if ($('#obfs').val() === 'plain') {
|
||
$('#obfs_param').val('');
|
||
obfs_param.hide();
|
||
} else {
|
||
obfs_param.show();
|
||
}
|
||
});
|
||
|
||
$('#relay_node_id').on('changed.bs.select', function() {
|
||
const relay = $('.relay-config');
|
||
const config = $('.proxy-config');
|
||
if ($('#relay_node_id').val() === '') {
|
||
relay.hide();
|
||
$('#relay_port').removeAttr('required').attr('hidden', true);
|
||
config.show();
|
||
} else {
|
||
relay.show();
|
||
config.hide();
|
||
$('#relay_port').removeAttr('hidden').attr('required', true);
|
||
}
|
||
});
|
||
|
||
// 设置V2Ray详细设置
|
||
$('#v2_net').on('changed.bs.select', function() {
|
||
const type = $('.v2_type');
|
||
const type_option = $('#type_option');
|
||
const host = $('.v2_host');
|
||
const path = $('#v2_path');
|
||
const v2_other = $('[name="v2_other"]');
|
||
type.show();
|
||
host.show();
|
||
v2_other.show();
|
||
path.val('/' + string);
|
||
switch ($(this).val()) {
|
||
case 'kcp':
|
||
type_option.attr('disabled', false);
|
||
break;
|
||
case 'ws':
|
||
type.hide();
|
||
break;
|
||
case 'http':
|
||
type.hide();
|
||
break;
|
||
case 'domainsocket':
|
||
type.hide();
|
||
host.hide();
|
||
break;
|
||
case 'quic':
|
||
type_option.attr('disabled', false);
|
||
path.val(string);
|
||
break;
|
||
case 'tcp':
|
||
default:
|
||
type_option.attr('disabled', true);
|
||
break;
|
||
}
|
||
$('#v2_type').selectpicker('refresh');
|
||
});
|
||
|
||
// 服务条款
|
||
function showTnc() {
|
||
const content =
|
||
'<ol>' +
|
||
'<li>请勿直接复制黏贴以下配置,SSR(R)会报错的</li>' +
|
||
'<li>确保服务器时间为CST</li>' +
|
||
'</ol>' +
|
||
'  "additional_ports" : {<br />' +
|
||
'   "443": {<br />' +
|
||
'    "passwd": "ProxyPanel",<br />' +
|
||
'    "method": "none",<br />' +
|
||
'    "protocol": "auth_chain_a",<br />' +
|
||
'    "protocol_param": "#",<br />' +
|
||
'    "obfs": "plain",<br />' +
|
||
'    "obfs_param": "fe2.update.microsoft.com"<br />' +
|
||
'   }<br />' +
|
||
'  },';
|
||
|
||
swal.fire({
|
||
title: '[节点 user-config.json 配置示例]',
|
||
html: '<div class="p-10 bg-grey-900 text-white font-weight-300 text-left" style="line-height: 22px;">' +
|
||
content + '</div>',
|
||
icon: 'info',
|
||
});
|
||
}
|
||
|
||
// 模式提示
|
||
function showPortsOnlyConfig() {
|
||
const content = '严格模式:"additional_ports_only": "true"'
|
||
+ '<br><br>'
|
||
+ '兼容模式:"additional_ports_only": "false"';
|
||
|
||
swal.fire({
|
||
title: '[节点 user-config.json 配置示例]',
|
||
html: '<div class="p-10 bg-grey-900 text-white font-weight-300 text-left" style="line-height: 22px;">' +
|
||
content + '</div>',
|
||
icon: 'info',
|
||
});
|
||
}
|
||
</script>
|
||
@endsection
|