cop-web/src/views/task/graph/software/components/RabbitMq.vue

235 lines
8.1 KiB
Vue
Raw Normal View History

2024-03-14 03:36:22 +00:00
<template>
<basic-form :model="itemData" ref="form" :disabled="isPreview">
<el-row>
2024-11-12 06:32:03 +00:00
<el-alert v-if="itemData.cluster_install" class="m-b-sm" type="warning" :closable="false" title="注:支持集群(三节点)安装"></el-alert>
2024-03-14 03:36:22 +00:00
<el-col :span="12">
<basic-form-item label="部署方式:">
<el-radio-group v-model="itemData.cluster_install" :disabled="isTaskInstance">
<el-radio :label="false" :disabled="isPreview">单点</el-radio>
<el-radio :label="true" :disabled="isPreview">集群</el-radio>
</el-radio-group>
</basic-form-item>
</el-col>
<el-col :span="12">
<basic-form-item label="软件版本:" prop="version" validate="required">
<el-select v-model="itemData.version" placeholder="版本">
2024-11-12 06:32:03 +00:00
<el-option v-for="(row, index) in versionData" :key="index" :label="row.name" :value="row.value"> </el-option>
2024-03-14 03:36:22 +00:00
</el-select>
</basic-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="24" class="line"></el-col>
<el-col :span="24" class="title">
创建用户
<el-button v-if="!isPreview" class="m-l" type="primary" size="mini" @click="addUser(itemData.rabbitmq_users)"></el-button>
</el-col>
</el-row>
<div v-for="(item, index) in itemData.rabbitmq_users" :key="index" class="search-container">
<el-button type="text" v-if="!isPreview" class="del_operate" @click="removeItem(itemData.rabbitmq_users, index, 'required')">
<i class="el-icon-delete" />
</el-button>
<el-row>
<el-col :span="12">
2024-11-12 06:32:03 +00:00
<basic-form-item label="用户:" :prop="'rabbitmq_users.' + index + '.user'" validate="required">
2024-03-14 03:36:22 +00:00
<el-input v-model="item.user"></el-input>
</basic-form-item>
</el-col>
<el-col :span="12">
2024-11-12 06:32:03 +00:00
<basic-form-item label="密码:" :prop="'rabbitmq_users.' + index + '.password'" validate="required" required-message="">
<el-input type="password" v-model="item.password" show-password></el-input>
2024-03-14 03:36:22 +00:00
</basic-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<basic-form-item label="标签:" prop="tags">
<el-input v-model="item.tags" auto-complete="off" :disabled="isPreview"></el-input>
</basic-form-item>
</el-col>
<el-col :span="12">
<basic-form-item label="配置权限:" prop="configure_priv">
<el-input v-model="item.configure_priv" auto-complete="off" :disabled="isPreview"></el-input>
</basic-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<basic-form-item label="读权限:" prop="read_priv">
<el-input v-model="item.read_priv" auto-complete="off" :disabled="isPreview"></el-input>
</basic-form-item>
</el-col>
<el-col :span="12">
<basic-form-item label="写权限:" prop="write_priv">
<el-input v-model="item.write_priv" auto-complete="off" :disabled="isPreview"></el-input>
</basic-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<basic-form-item label="vhost" prop="vhost">
<el-input v-model="item.vhost"></el-input>
</basic-form-item>
</el-col>
</el-row>
</div>
<el-row>
<el-col :span="24" class="line"></el-col>
<el-col :span="24" class="title">
配置虚拟机
<el-button v-if="!isPreview" class="m-l" type="primary" size="mini" @click="addVhosts(itemData.rabbitmq_vhosts)"></el-button>
</el-col>
</el-row>
<div v-for="(item, index) in itemData.rabbitmq_vhosts" :key="'v' + index" class="search-container">
<el-button type="text" v-if="!isPreview" class="del_operate" @click="removeItem(itemData.rabbitmq_vhosts, index)">
<i class="el-icon-delete" />
</el-button>
<el-row :gutter="20">
<el-col :span="12">
2024-11-12 06:32:03 +00:00
<basic-form-item label="名称:" :prop="'rabbitmq_vhosts.' + index + '.name'" validate="required">
2024-03-14 03:36:22 +00:00
<el-input v-model="item.name"></el-input>
</basic-form-item>
</el-col>
<el-col :span="12">
<basic-form-item label="节点:" prop="node">
<el-input v-model="item.node"></el-input>
</basic-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
<basic-form-item label="跟踪:">
<el-select class="search-item" v-model="item.tracing" :disabled="isPreview">
2024-11-12 06:32:03 +00:00
<el-option v-for="item in yesData" :key="item.value" :label="item.name" :value="item.value"> </el-option>
2024-03-14 03:36:22 +00:00
</el-select>
</basic-form-item>
</el-col>
</el-row>
</div>
<el-row>
<el-col :span="24" class="line"></el-col>
<el-col :span="24" class="title">
插件安装
<el-button v-if="!isPreview" class="m-l" type="primary" size="mini" @click="addItem(itemData.rabbitmq_plugins)"></el-button>
</el-col>
</el-row>
<div v-for="(item, index) in itemData.rabbitmq_plugins" :key="'p' + index" class="search-container">
<el-button v-if="!isPreview" type="text" class="del_operate" @click="removeItem(itemData.rabbitmq_plugins, index)">
<i class="el-icon-delete" />
</el-button>
<el-row>
<el-col :span="12">
2024-11-12 06:32:03 +00:00
<basic-form-item label="名称:" :prop="'rabbitmq_plugins.' + index + '.name'" validate="required">
2024-03-14 03:36:22 +00:00
<el-input v-model="item.name"></el-input>
</basic-form-item>
</el-col>
<el-col :span="12">
<basic-form-item label="URL地址">
<el-input v-model="item.url"></el-input>
</basic-form-item>
</el-col>
</el-row>
</div>
</basic-form>
</template>
<script>
import { cloneDeep } from 'lodash-es'
2024-11-12 06:32:03 +00:00
import node from '../../mixins/index'
import show from '../../mixins/show'
import software from '../mixins/itemOperate'
2024-03-14 03:36:22 +00:00
import { handleArrAttribute } from '../tools.js'
import { getDictChildren } from 'services/system/dictionary'
2024-11-12 06:32:03 +00:00
import { encrypt, decrypt } from 'utils/crypto'
const yesData = [
{ name: '否', value: false },
{ name: '是', value: true }
]
2024-03-14 03:36:22 +00:00
export default {
mixins: [node, show, software],
props: {
itemData: {
type: Object,
default: function () {
return {
cluster_install: false,
2024-11-12 06:32:03 +00:00
rabbitmq_users: [
{
user: '',
password: '',
tags: '',
configure_priv: '.*',
read_priv: '.*',
write_priv: '.*',
vhost: '/'
}
]
2024-03-14 03:36:22 +00:00
}
}
}
},
2024-11-12 06:32:03 +00:00
data() {
2024-03-14 03:36:22 +00:00
return {
yesData,
versionData: []
}
},
2024-11-12 06:32:03 +00:00
created() {
2024-03-14 03:36:22 +00:00
this.getVersion()
2024-11-12 06:32:03 +00:00
handleArrAttribute(['rabbitmq_vhosts', 'rabbitmq_users', 'rabbitmq_plugins'], this)
2024-03-14 03:36:22 +00:00
this.handleCrypto(this.itemData, decrypt)
},
methods: {
// 加密解密处理
handleCrypto(itemData, fun = encrypt) {
2024-11-12 06:32:03 +00:00
const { rabbitmq_users } = itemData
rabbitmq_users.forEach((item) => {
2024-03-14 03:36:22 +00:00
if (item.password) {
item.password = fun(item.password)
}
})
},
2024-11-12 06:32:03 +00:00
getVersion() {
getDictChildren({ value: 'RABBITMQ-VERSION' }).then((data) => {
2024-03-14 03:36:22 +00:00
if (data.success) {
this.versionData = data.data
}
})
},
// 新增虚拟机配置
2024-11-12 06:32:03 +00:00
addVhosts(data) {
2024-03-14 03:36:22 +00:00
data.push({
name: '',
node: 'rabbit',
tracing: false
})
},
// 新增用户
2024-11-12 06:32:03 +00:00
addUser(data) {
2024-03-14 03:36:22 +00:00
data.push({
user: '',
password: '',
tags: '',
configure_priv: '.*',
read_priv: '.*',
write_priv: '.*',
vhost: '/'
})
},
2024-11-12 06:32:03 +00:00
getPostData() {
let data = false
this.$refs.form.validate((valid) => {
2024-03-14 03:36:22 +00:00
if (valid) {
2024-11-12 06:32:03 +00:00
const itemData = cloneDeep(this.itemData)
2024-03-14 03:36:22 +00:00
this.handleCrypto(itemData, encrypt)
data = itemData
}
2024-11-12 06:32:03 +00:00
})
return data
2024-03-14 03:36:22 +00:00
}
}
}
</script>
<style scoped lang="scss">
2024-11-12 06:32:03 +00:00
@import 'index.scss';
2024-03-14 03:36:22 +00:00
</style>