Files
Arch1Panel/apps/nps/0.34.7/web/views/index/hadd.html

329 lines
18 KiB
HTML
Raw Normal View History

2025-07-08 15:11:58 +08:00
<div class="row tile">
<div class="col-md-12 col-md-auto">
<div class="ibox float-e-margins">
<h3 class="ibox-title" langtag="page-hostadd"></h3>
<div class="ibox-content">
<form class="form-horizontal">
<div class="form-group">
<label class="control-label font-bold" langtag="word-clientid"></label>
<div class="col-sm-12">
<select class="form-control" name="client_id" data-live-search="true"></select>
</div>
</div>
<div class="form-group">
<label class="control-label font-bold" langtag="word-remark"></label>
<div class="col-sm-12">
<input class="form-control" type="text" name="remark" placeholder="" langtag="word-remark">
</div>
</div>
<div class="form-group">
<label class="control-label font-bold" langtag="word-host"></label>
<div class="col-sm-12">
<input class="form-control" type="text" name="host" placeholder="" langtag="info-suchashost">
</div>
</div>
<div class="form-group" id="scheme">
<label class="control-label font-bold" langtag="word-scheme"></label>
<div class="col-sm-12">
<select id="scheme_select" class="form-control selectpicker" name="scheme">
<option value="all" langtag="word-all"></option>
<option value="http" langtag="word-http"></option>
<option value="https" langtag="word-https"></option>
</select>
</div>
</div>
{{if eq true .allow_flow_limit}}
<div class="form-group" id="flow_limit">
<label class="control-label font-bold" langtag="word-flowlimit"></label>
<div class="col-sm-12">
<input class="form-control" langtag="info-unrestricted" name="flow_limit" placeholder="" type="text">
<span class="help-block m-b-none" langtag="word-unit"></span>: M
</div>
</div>
{{end}}
{{if eq true .allow_time_limit}}
<div class="form-group" id="time_limit">
<label class="control-label font-bold" langtag="word-timelimit"></label>
<div class="col-sm-12">
<input class="form-control" id="time_limit_input" langtag="info-unrestricted" name="time_limit" placeholder="" type="datetime-local">
<span class="help-block m-b-none" langtag="info-timelimit"></span>
</div>
</div>
{{end}}
<div class="form-group" id="auto_https">
<label class="control-label font-bold" langtag="word-autohttps"></label>
<div class="col-sm-12">
<select class="form-control selectpicker" name="auto_https">
<option langtag="word-no" value="0"></option>
<option langtag="word-yes" value="1"></option>
</select>
</div>
</div>
<div class="form-group" id="auto_cors">
<label class="control-label font-bold" langtag="word-autocors"></label>
<div class="col-sm-12">
<select class="form-control selectpicker" name="auto_cors">
<option langtag="word-no" value="0"></option>
<option langtag="word-yes" value="1"></option>
</select>
</div>
</div>
<div class="form-group" id="compat_mode">
<label class="control-label font-bold" langtag="word-compatmode"></label>
<div class="col-sm-12">
<select class="form-control selectpicker" name="compat_mode">
<option langtag="word-no" value="0"></option>
<option langtag="word-yes" value="1"></option>
</select>
</div>
</div>
<div class="form-group" id="https_just_proxy">
<label class="control-label font-bold" langtag="word-httpsjustproxy"></label>
<div class="col-sm-12">
<select class="form-control selectpicker" id="https_just_proxy_select" name="https_just_proxy">
<option langtag="word-no" value="0"></option>
<option langtag="word-yes" value="1"></option>
</select>
</div>
</div>
<div class="form-group" id="proxy_protocol">
<label class="control-label font-bold" langtag="word-proxyprotocol"></label>
<div class="col-sm-12">
<select class="form-control selectpicker" name="proxy_protocol">
<option langtag="word-disable" value="0"></option>
<option langtag="word-proxyprotocolv1" value="1"></option>
<option langtag="word-proxyprotocolv2" value="2"></option>
</select>
</div>
</div>
<div class="form-group" id="auto_ssl">
<label class="control-label font-bold" langtag="word-autossl"></label>
<div class="col-sm-12">
<select class="form-control selectpicker" name="auto_ssl">
<option langtag="word-no" value="0"></option>
<option langtag="word-yes" value="1"></option>
</select>
</div>
</div>
<div class="form-group" id="cert_file">
<label class="control-label font-bold" langtag="word-httpscert"></label>
<div class="col-sm-12">
<textarea class="form-control" id="pemText" langtag="info-pemtext" name="cert_file" placeholder="" rows="6" type="text"></textarea>
</div>
</div>
<div class="form-group" id="key_file">
<label class="control-label font-bold" langtag="word-httpskey"></label>
<div class="col-sm-12">
<textarea class="form-control" id="pemKey" langtag="info-pemkey" name="key_file" placeholder="" rows="6" type="text"></textarea>
</div>
</div>
<div class="form-group">
<label class="control-label font-bold" langtag="word-urlroute"></label>
<div class="col-sm-12">
<input class="form-control" langtag="info-unrestricted" name="location" placeholder="" type="text">
</div>
</div>
<div class="form-group">
<label class="control-label font-bold" langtag="word-urlrewrite"></label>
<div class="col-sm-12">
<input class="form-control" langtag="info-urlrewrite" name="path_rewrite" placeholder="" type="text">
</div>
</div>
{{if eq true .allow_local_proxy}}
<div class="form-group" id="local_proxy">
<label class="control-label font-bold" langtag="word-proxytolocal"></label>
<div class="col-sm-12">
<select class="form-control selectpicker" name="local_proxy">
<option langtag="word-no" value="0"></option>
<option langtag="word-yes" value="1"></option>
</select>
</div>
</div>
{{end}}
<div class="form-group" id="auth">
<label class="control-label font-bold" langtag="word-auth"></label>
<div class="col-sm-12">
<textarea class="form-control" langtag="info-suchasauth" name="auth" placeholder="" rows="4"></textarea>
<span class="help-block m-b-none" langtag="info-targetauth"></span>
</div>
</div>
<div class="form-group" id="target_is_https">
<label class="control-label font-bold" langtag="word-targetishttps"></label>
<div class="col-sm-12">
<select class="form-control selectpicker" name="target_is_https">
<option value="0">HTTP</option>
<option value="1">HTTPS</option>
</select>
</div>
</div>
<div class="form-group">
<label class="control-label font-bold" langtag="word-target"></label>
<div class="col-sm-12">
<textarea class="form-control" langtag="info-suchasiplist" name="target" placeholder="" rows="4" type="text"></textarea>
<span class="help-block m-b-none" langtag="info-targethost"></span>
</div>
</div>
<div class="form-group" id="header">
<label class="control-label font-bold" langtag="word-requestheader"></label>
<div class="col-sm-12">
<textarea class="form-control" name="header" placeholder="Cache-Control: no-cache" rows="4" type="text"></textarea>
<span class="help-block m-b-none" langtag="info-header"></span>
</div>
</div>
<div class="form-group" id="hostchange">
<label class="control-label font-bold" langtag="word-requesthost"></label>
<div class="col-sm-12">
<input class="form-control" langtag="word-requesthost" name="hostchange" placeholder="" type="text" value="">
</div>
</div>
<div class="hr-line-dashed"></div>
<div class="form-group">
<div class="col-lg-12 col-sm-offset-2">
<button class="btn btn-secondary" onclick="goback()" type="button">
<i class="fa fa-fw fa-lg fa-window-close"></i> <span langtag="word-cancel"></span>
</button>
<button class="btn btn-success" onclick="submitform('add', '{{.web_base_url}}/index/addhost', $('form').serializeArray())" type="button">
<i class="fa fa-fw fa-lg fa-check-circle"></i> <span langtag="word-add"></span>
</button>
</div>
</div>
</form>
</div>
</div>
</div>
</div>
<script>
$(function () {
const pemText = document.getElementById("pemText");
const pemKey = document.getElementById("pemKey");
// 阻止浏览器默认打开文件的行为
document.addEventListener("dragover", function (event) {
event.preventDefault();
});
pemText.addEventListener("drop", function (event) {
event.preventDefault();
const file = event.dataTransfer.files[0];
const reader = new FileReader();
reader.onload = function (e) {
pemText.value = e.target.result;
console.log("Upload pem")
$('#edit_form').data('bootstrapValidator').updateStatus('pemText', 'NOT_VALIDATED');
$('#edit_form').data('bootstrapValidator').validateField('pemText');
}
reader.readAsText(file);
});
pemKey.addEventListener("drop", function (event) {
event.preventDefault();
const file = event.dataTransfer.files[0];
const reader = new FileReader();
reader.onload = function (e) {
pemKey.value = e.target.result;
$('#edit_form').data('bootstrapValidator').updateStatus('pemKey', 'NOT_VALIDATED');
$('#edit_form').data('bootstrapValidator').validateField('pemKey');
}
reader.readAsText(file);
});
$("#scheme_select").on("change", function () {
if ($("#scheme_select").val() == "all" || $("#scheme_select").val() == "https") {
$("#auto_https").css("display", "block")
$("#https_just_proxy").css("display", "block")
if ($("#https_just_proxy_select").val() == "1") {
$("#auto_ssl").css("display", "none")
$("#cert_file").css("display", "none")
$("#key_file").css("display", "none")
} else {
$("#auto_ssl").css("display", "block")
$("#cert_file").css("display", "block")
$("#key_file").css("display", "block")
}
} else {
$("#auto_ssl").css("display", "none")
$("#cert_file").css("display", "none")
$("#key_file").css("display", "none")
$("#https_just_proxy").css("display", "none")
$("#auto_https").css("display", "none")
}
})
$("#https_just_proxy_select").on("change", function () {
if ($("#https_just_proxy_select").val() == "1") {
$("#auto_ssl").css("display", "none")
$("#cert_file").css("display", "none")
$("#key_file").css("display", "none")
} else {
$("#auto_ssl").css("display", "block")
$("#cert_file").css("display", "block")
$("#key_file").css("display", "block")
}
})
});
function getClientList() {
const clientId = "{{.client_id}}"; // 获取 client_id
$("select[name='client_id']").selectpicker({
liveSearch: true,
source: {
data: function (callback, page) {
$.ajax({
method: 'POST',
url: "{{.web_base_url}}/client/list",
dataType: 'json',
data: { order: "asc", offset: 0, limit: 0 },
success: function(response) {
// 转换数据格式(必须包含 `value` 和 `text`
const results = $.map(response.rows, function(item) {
let displayText = item.Remark ? item.Id + ' · ' + item.Remark : item.Id.toString();
return {
value: item.Id, // 选项的 value
text: displayText, // 选项的显示文本
selected: item.Id == clientId // 默认选中
};
});
callback(results); // 返回给 selectpicker
},
error: function() {
callback([]); // 出错时返回空数组
}
});
},
search: function (callback, page, searchTerm) {
let data = { search: searchTerm, order: "asc", offset: 0, limit: 0 };
$.ajax({
method: 'POST',
url: "{{.web_base_url}}/client/list",
data: data,
dataType: 'json',
success: function(response) {
// 转换数据格式(必须包含 `value` 和 `text`
const results = $.map(response.rows, function(item) {
let displayText = item.Remark ? item.Id + ' · ' + item.Remark : item.Id.toString();
return {
value: item.Id, // 选项的 value
text: displayText, // 选项的显示文本
selected: item.Id == clientId // 默认选中
};
});
callback(results); // 返回给 selectpicker
},
error: function() {
callback([]); // 出错时返回空数组
}
});
}
}
});
}
function internationalized(current) {
$.fn.selectpicker.defaults = {
noneSelectedText: languages['content']['bootstrap-select']['noneSelectedText'][current],
noneResultsText: languages['content']['bootstrap-select']['noneResultsText'][current]
};
getClientList();
}
</script>