refactor: reuse snmp oid editor in security form

This commit is contained in:
zxr
2026-07-05 23:04:21 +08:00
parent 58365870ef
commit 3f4d50b395

View File

@@ -157,13 +157,11 @@
</a-form-item>
</a-col>
</a-row>
<a-form-item field="snmp_oids" label="SNMP OID配置(JSON数组)">
<a-textarea
v-model="formData.snmp_oids"
:rows="3"
placeholder='可留空使用默认模板,或填写如 [{"oid":"1.3.6.1.2.1.1.3.0","metric_name":"sys_uptime","metric_unit":"timeticks"}]'
/>
</a-form-item>
<SnmpOidEditor
ref="snmpOidEditorRef"
v-model="formData.snmp_oids"
:reset-key="snmpOidEditorResetKey"
/>
</template>
<a-row :gutter="20">
@@ -214,6 +212,7 @@ import type { FormInstance } from '@arco-design/web-vue'
import { createSecurityService, updateSecurityService, SECURITY_TYPE_OPTIONS, type SecurityServiceFormData } from '@/api/ops/security'
import { fetchPolicyOptions, type PolicyOptionItem } from '@/api/ops/alertPolicy'
import { fetchServerList, type ServerItem } from '@/api/ops/server'
import SnmpOidEditor from '../../components/SnmpOidEditor.vue'
interface Props {
visible: boolean
@@ -227,6 +226,8 @@ const props = withDefaults(defineProps<Props>(), {
const emit = defineEmits(['update:visible', 'success'])
const formRef = ref<FormInstance>()
const snmpOidEditorRef = ref<InstanceType<typeof SnmpOidEditor>>()
const snmpOidEditorResetKey = ref(0)
const confirmLoading = ref(false)
const policyOptions = ref<PolicyOptionItem[]>([])
const serverOptions = ref<ServerItem[]>([])
@@ -336,6 +337,7 @@ watch(
extra: props.record.extra || '',
policy_ids: props.record.policy_ids || [],
})
snmpOidEditorResetKey.value += 1
} else {
Object.assign(formData, {
service_identity: '',
@@ -368,6 +370,7 @@ watch(
extra: '',
policy_ids: [],
})
snmpOidEditorResetKey.value += 1
}
}
}
@@ -402,13 +405,8 @@ const handleOk = async () => {
Message.warning('SNMP v2c 模式下请填写 community')
return
}
if (formData.snmp_oids?.trim()) {
try {
JSON.parse(formData.snmp_oids)
} catch {
Message.warning('SNMP OID配置必须是合法 JSON')
return
}
if (!snmpOidEditorRef.value?.validate()) {
return
}
}