фикс ошибок: пустая строка qos.class.filters.proto в запросе, не применяющиеся настройки сети, нет шага у "ACM*" и "*ослабление"

This commit is contained in:
Vladislav Ostapov 2024-11-15 09:50:43 +03:00
parent 200dfef698
commit cc354b73e3
2 changed files with 20 additions and 15 deletions

View File

@ -425,21 +425,21 @@ public:
}
void setNetworkSettings(TerminalNetworkSettings& s, bool readback = true) {
const auto [mAddr, mMask] = splitIpAndMask(s.managementIp);
const auto [dAddr, dMask] = splitIpAndMask(s.dataIp);
const auto mang = splitIpAndMask(s.managementIp);
std::pair<std::string, std::string> data;
bool isL2;
if (s.mode == "l2") { isL2 = true; }
else if (s.mode == "l3") { isL2 = false; }
else if (s.mode == "l3") { isL2 = false; data = splitIpAndMask(s.dataIp); }
else { throw std::runtime_error("invalid mode"); }
std::lock_guard lock(this->cpApiMutex);
CP_SetDmaDebug(sid, "begin_save_config", "");
CP_SetNetwork(sid, "mode", isL2 ? "tap" : "tun");
CP_SetNetwork(sid, "addr", mAddr.c_str());
CP_SetNetwork(sid, "mask", mMask.c_str());
CP_SetNetwork(sid, "addr", mang.first.c_str());
CP_SetNetwork(sid, "mask", mang.second.c_str());
CP_SetNetwork(sid, "gateway", s.managementGateway.c_str());
if (!isL2) {
CP_SetNetwork(sid, "data_addr", dAddr.c_str());
CP_SetNetwork(sid, "data_addr", data.first.c_str());
// TODO маска не устанавливается, потому что в API этого нет
}
// TODO MTU не устанавливается, потому что в API этого нет
@ -447,6 +447,7 @@ public:
if (readback) {
std::string tmp;
s.reset();
s.managementIp.clear();
CP_GetNetwork(sid, "addr", &s.managementIp);
CP_GetNetwork(sid, "mask", &tmp);
s.managementIp += "/";

View File

@ -185,7 +185,7 @@
</label>
<label>
<span>Ослабление, дБ</span>
<input v-model="param.tx.attenuation" type="number"/>
<input v-model="param.tx.attenuation" type="number" step="0.01"/>
</label>
</div>
@ -270,7 +270,7 @@
</label>
<label v-show="param.dvbs2.mode === 'acm'">
<span>Запас ОСШ</span>
<input v-model="param.dvbs2.snrReserve" type="number">
<input v-model="param.dvbs2.snrReserve" type="number" step="0.01">
</label>
<h3>Авто-регулировка мощности</h3>
@ -283,15 +283,15 @@
</label>
<label>
<span>Максимальное ослабление</span>
<input v-model="param.acm.maxAttenuation" type="number"/>
<input v-model="param.acm.maxAttenuation" type="number" step="0.01"/>
</label>
<label>
<span>Минимальное ослабление</span>
<input v-model="param.acm.minAttenuation" type="number"/>
<input v-model="param.acm.minAttenuation" type="number" step="0.01"/>
</label>
<label>
<span>Требуемое ОСШ</span>
<input v-model="param.acm.requiredSnr" type="number"/>
<input v-model="param.acm.requiredSnr" type="number" step="0.01"/>
</label>
</div>
<div class="settings-set-container">
@ -349,15 +349,15 @@
<h3 v-show="param.cinc.mode === 'positional'">Настройки позиционирования</h3>
<label v-show="param.cinc.mode === 'positional'">
<span>Широта станции</span>
<input v-model="param.cinc.position.station.latitude" type="number" step="0.0001"/>
<input v-model="param.cinc.position.station.latitude" type="number" step="0.000001"/>
</label>
<label v-show="param.cinc.mode === 'positional'">
<span>Долгота станции</span>
<input v-model="param.cinc.position.station.longitude" type="number" step="0.0001"/>
<input v-model="param.cinc.position.station.longitude" type="number" step="0.000001"/>
</label>
<label v-show="param.cinc.mode === 'positional'">
<span>Подспутниковая точка</span>
<input v-model="param.cinc.position.satelliteLongitude" type="number" step="0.0001"/>
<input v-model="param.cinc.position.satelliteLongitude" type="number" step="0.000001"/>
</label>
<h3 v-show="param.cinc.mode === 'delay'">Задержка до спутника</h3>
@ -1173,7 +1173,7 @@
for (const fi in qc.filters) {
let filter = {}
if (qc['filters'][fi].vlan !== "") { filter['vlan'] = qc['filters'][fi].vlan }
if (qc['filters'][fi].proto !== "") {
if (qc['filters'][fi].proto.length > 0) {
let tmp = "";
for (let pid = 0; pid < qc['filters'][fi].proto.length; pid++) {
if (pid !== 0) { tmp += ',' }
@ -1192,6 +1192,10 @@
res.filters.push(filter)
}
if (res.filters.length === 0) {
// автоматическое выключение класса, если правил нет
res.disabled = true
}
return res
}