12 changed files with 931 additions and 5 deletions
@ -0,0 +1,63 @@ |
|||||
|
import request from '@/utils/request'; |
||||
|
import { AxiosPromise } from 'axios'; |
||||
|
import { PlatformConfigurationVO, PlatformConfigurationForm, PlatformConfigurationQuery } from '@/api/im/platformConfiguration/types'; |
||||
|
|
||||
|
/** |
||||
|
* 查询平台管理配置列表 |
||||
|
* @param query |
||||
|
* @returns {*} |
||||
|
*/ |
||||
|
|
||||
|
export const listPlatformConfiguration = (query?: PlatformConfigurationQuery): AxiosPromise<PlatformConfigurationVO[]> => { |
||||
|
return request({ |
||||
|
url: '/im/platformConfiguration/list', |
||||
|
method: 'get', |
||||
|
params: query |
||||
|
}); |
||||
|
}; |
||||
|
|
||||
|
/** |
||||
|
* 查询平台管理配置详细 |
||||
|
* @param id |
||||
|
*/ |
||||
|
export const getPlatformConfiguration = (id: string | number): AxiosPromise<PlatformConfigurationVO> => { |
||||
|
return request({ |
||||
|
url: '/im/platformConfiguration/' + id, |
||||
|
method: 'get' |
||||
|
}); |
||||
|
}; |
||||
|
|
||||
|
/** |
||||
|
* 新增平台管理配置 |
||||
|
* @param data |
||||
|
*/ |
||||
|
export const addPlatformConfiguration = (data: PlatformConfigurationForm) => { |
||||
|
return request({ |
||||
|
url: '/im/platformConfiguration', |
||||
|
method: 'post', |
||||
|
data: data |
||||
|
}); |
||||
|
}; |
||||
|
|
||||
|
/** |
||||
|
* 修改平台管理配置 |
||||
|
* @param data |
||||
|
*/ |
||||
|
export const updatePlatformConfiguration = (data: PlatformConfigurationForm) => { |
||||
|
return request({ |
||||
|
url: '/im/platformConfiguration', |
||||
|
method: 'put', |
||||
|
data: data |
||||
|
}); |
||||
|
}; |
||||
|
|
||||
|
/** |
||||
|
* 删除平台管理配置 |
||||
|
* @param id |
||||
|
*/ |
||||
|
export const delPlatformConfiguration = (id: string | number | Array<string | number>) => { |
||||
|
return request({ |
||||
|
url: '/im/platformConfiguration/' + id, |
||||
|
method: 'delete' |
||||
|
}); |
||||
|
}; |
||||
@ -0,0 +1,61 @@ |
|||||
|
export interface PlatformConfigurationVO { |
||||
|
/** |
||||
|
* 主键ID |
||||
|
*/ |
||||
|
id: string | number; |
||||
|
|
||||
|
/** |
||||
|
* 唯一token |
||||
|
*/ |
||||
|
uniqueToken: string; |
||||
|
|
||||
|
/** |
||||
|
* 域名名称 |
||||
|
*/ |
||||
|
domainName: string; |
||||
|
|
||||
|
/** |
||||
|
* 备注 |
||||
|
*/ |
||||
|
remark: string; |
||||
|
|
||||
|
/** |
||||
|
* 创建时间 |
||||
|
*/ |
||||
|
createdTime: string; |
||||
|
|
||||
|
} |
||||
|
|
||||
|
export interface PlatformConfigurationForm extends BaseEntity { |
||||
|
/** |
||||
|
* 主键ID |
||||
|
*/ |
||||
|
id?: string | number; |
||||
|
|
||||
|
/** |
||||
|
* 域名名称 |
||||
|
*/ |
||||
|
domainName?: string; |
||||
|
|
||||
|
/** |
||||
|
* 备注 |
||||
|
*/ |
||||
|
remark?: string; |
||||
|
|
||||
|
} |
||||
|
|
||||
|
export interface PlatformConfigurationQuery extends PageQuery { |
||||
|
|
||||
|
/** |
||||
|
* 域名名称 |
||||
|
*/ |
||||
|
domainName?: string; |
||||
|
|
||||
|
/** |
||||
|
* 日期范围参数 |
||||
|
*/ |
||||
|
params?: any; |
||||
|
} |
||||
|
|
||||
|
|
||||
|
|
||||
@ -0,0 +1,237 @@ |
|||||
|
<template> |
||||
|
<div class="p-2"> |
||||
|
<transition :enter-active-class="proxy?.animate.searchAnimate.enter" :leave-active-class="proxy?.animate.searchAnimate.leave"> |
||||
|
<div v-show="showSearch" class="mb-[10px]"> |
||||
|
<el-card shadow="hover"> |
||||
|
<el-form ref="queryFormRef" :model="queryParams" :inline="true"> |
||||
|
<el-form-item label="域名名称" prop="domainName"> |
||||
|
<el-input v-model="queryParams.domainName" placeholder="请输入域名名称" clearable @keyup.enter="handleQuery" /> |
||||
|
</el-form-item> |
||||
|
<el-form-item> |
||||
|
<el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button> |
||||
|
<el-button icon="Refresh" @click="resetQuery">重置</el-button> |
||||
|
</el-form-item> |
||||
|
</el-form> |
||||
|
</el-card> |
||||
|
</div> |
||||
|
</transition> |
||||
|
|
||||
|
<el-card shadow="never"> |
||||
|
<template #header> |
||||
|
<el-row :gutter="10" class="mb8"> |
||||
|
<el-col :span="1.5"> |
||||
|
<el-button v-hasPermi="['im:platformConfiguration:add']" type="primary" plain icon="Plus" @click="handleAdd">新增</el-button> |
||||
|
</el-col> |
||||
|
<el-col :span="1.5"> |
||||
|
<el-button v-hasPermi="['im:platformConfiguration:edit']" type="success" plain icon="Edit" :disabled="single" @click="handleUpdate()" |
||||
|
>修改</el-button |
||||
|
> |
||||
|
</el-col> |
||||
|
<el-col :span="1.5"> |
||||
|
<el-button v-hasPermi="['im:platformConfiguration:remove']" type="danger" plain icon="Delete" :disabled="multiple" @click="handleDelete()" |
||||
|
>删除</el-button |
||||
|
> |
||||
|
</el-col> |
||||
|
<right-toolbar v-model:showSearch="showSearch" @query-table="getList"></right-toolbar> |
||||
|
</el-row> |
||||
|
</template> |
||||
|
|
||||
|
<el-table v-loading="loading" :data="platformConfigurationList" @selection-change="handleSelectionChange"> |
||||
|
<el-table-column type="selection" width="55" align="center" /> |
||||
|
<!-- <el-table-column label="主键ID" align="center" prop="id" v-if="true" /> --> |
||||
|
<!-- <el-table-column label="唯一token" align="center" prop="uniqueToken" /> --> |
||||
|
<el-table-column label="域名名称" align="center" prop="domainName" /> |
||||
|
<el-table-column label="备注" align="center" prop="remark" /> |
||||
|
<el-table-column label="创建时间" align="center" prop="createdTime" width="180"> |
||||
|
<template #default="scope"> |
||||
|
<span>{{ parseTime(scope.row.createdTime, '{y}-{m}-{d}') }}</span> |
||||
|
</template> |
||||
|
</el-table-column> |
||||
|
<el-table-column label="操作" align="center" class-name="small-padding fixed-width"> |
||||
|
<template #default="scope"> |
||||
|
<el-tooltip content="修改" placement="top"> |
||||
|
<el-button v-hasPermi="['im:platformConfiguration:edit']" link type="primary" icon="Edit" @click="handleUpdate(scope.row)"></el-button> |
||||
|
</el-tooltip> |
||||
|
<el-tooltip content="删除" placement="top"> |
||||
|
<el-button |
||||
|
v-hasPermi="['im:platformConfiguration:remove']" |
||||
|
link |
||||
|
type="primary" |
||||
|
icon="Delete" |
||||
|
@click="handleDelete(scope.row)" |
||||
|
></el-button> |
||||
|
</el-tooltip> |
||||
|
</template> |
||||
|
</el-table-column> |
||||
|
</el-table> |
||||
|
|
||||
|
<pagination v-show="total > 0" v-model:page="queryParams.pageNum" v-model:limit="queryParams.pageSize" :total="total" @pagination="getList" /> |
||||
|
</el-card> |
||||
|
<!-- 添加或修改平台管理配置对话框 --> |
||||
|
<el-dialog v-model="dialog.visible" :title="dialog.title" width="500px" append-to-body> |
||||
|
<el-form ref="platformConfigurationFormRef" :model="form" :rules="rules" label-width="80px"> |
||||
|
<el-form-item label="域名名称" prop="domainName"> |
||||
|
<el-input v-model="form.domainName" placeholder="请输入域名名称" /> |
||||
|
</el-form-item> |
||||
|
<el-form-item label="备注" prop="remark"> |
||||
|
<el-input v-model="form.remark" placeholder="请输入备注" /> |
||||
|
</el-form-item> |
||||
|
</el-form> |
||||
|
<template #footer> |
||||
|
<div class="dialog-footer"> |
||||
|
<el-button :loading="buttonLoading" type="primary" @click="submitForm">确 定</el-button> |
||||
|
<el-button @click="cancel">取 消</el-button> |
||||
|
</div> |
||||
|
</template> |
||||
|
</el-dialog> |
||||
|
</div> |
||||
|
</template> |
||||
|
|
||||
|
<script setup name="PlatformConfiguration" lang="ts"> |
||||
|
import { |
||||
|
listPlatformConfiguration, |
||||
|
getPlatformConfiguration, |
||||
|
delPlatformConfiguration, |
||||
|
addPlatformConfiguration, |
||||
|
updatePlatformConfiguration |
||||
|
} from '@/api/im/platformConfiguration'; |
||||
|
import { PlatformConfigurationVO, PlatformConfigurationQuery, PlatformConfigurationForm } from '@/api/im/platformConfiguration/types'; |
||||
|
|
||||
|
const { proxy } = getCurrentInstance() as ComponentInternalInstance; |
||||
|
|
||||
|
const platformConfigurationList = ref<PlatformConfigurationVO[]>([]); |
||||
|
const buttonLoading = ref(false); |
||||
|
const loading = ref(true); |
||||
|
const showSearch = ref(true); |
||||
|
const ids = ref<Array<string | number>>([]); |
||||
|
const single = ref(true); |
||||
|
const multiple = ref(true); |
||||
|
const total = ref(0); |
||||
|
|
||||
|
const queryFormRef = ref<ElFormInstance>(); |
||||
|
const platformConfigurationFormRef = ref<ElFormInstance>(); |
||||
|
|
||||
|
const dialog = reactive<DialogOption>({ |
||||
|
visible: false, |
||||
|
title: '' |
||||
|
}); |
||||
|
|
||||
|
const initFormData: PlatformConfigurationForm = { |
||||
|
id: undefined, |
||||
|
domainName: undefined, |
||||
|
remark: undefined |
||||
|
}; |
||||
|
const data = reactive<PageData<PlatformConfigurationForm, PlatformConfigurationQuery>>({ |
||||
|
form: { ...initFormData }, |
||||
|
queryParams: { |
||||
|
pageNum: 1, |
||||
|
pageSize: 10, |
||||
|
domainName: undefined, |
||||
|
params: {} |
||||
|
}, |
||||
|
rules: { |
||||
|
id: [{ required: true, message: '主键ID不能为空', trigger: 'blur' }], |
||||
|
domainName: [{ required: true, message: '域名名称不能为空', trigger: 'blur' }] |
||||
|
} |
||||
|
}); |
||||
|
|
||||
|
const { queryParams, form, rules } = toRefs(data); |
||||
|
|
||||
|
/** 查询平台管理配置列表 */ |
||||
|
const getList = async () => { |
||||
|
loading.value = true; |
||||
|
const res = await listPlatformConfiguration(queryParams.value); |
||||
|
platformConfigurationList.value = res.rows; |
||||
|
total.value = res.total; |
||||
|
loading.value = false; |
||||
|
}; |
||||
|
|
||||
|
/** 取消按钮 */ |
||||
|
const cancel = () => { |
||||
|
reset(); |
||||
|
dialog.visible = false; |
||||
|
}; |
||||
|
|
||||
|
/** 表单重置 */ |
||||
|
const reset = () => { |
||||
|
form.value = { ...initFormData }; |
||||
|
platformConfigurationFormRef.value?.resetFields(); |
||||
|
}; |
||||
|
|
||||
|
/** 搜索按钮操作 */ |
||||
|
const handleQuery = () => { |
||||
|
queryParams.value.pageNum = 1; |
||||
|
getList(); |
||||
|
}; |
||||
|
|
||||
|
/** 重置按钮操作 */ |
||||
|
const resetQuery = () => { |
||||
|
queryFormRef.value?.resetFields(); |
||||
|
handleQuery(); |
||||
|
}; |
||||
|
|
||||
|
/** 多选框选中数据 */ |
||||
|
const handleSelectionChange = (selection: PlatformConfigurationVO[]) => { |
||||
|
ids.value = selection.map((item) => item.id); |
||||
|
single.value = selection.length != 1; |
||||
|
multiple.value = !selection.length; |
||||
|
}; |
||||
|
|
||||
|
/** 新增按钮操作 */ |
||||
|
const handleAdd = () => { |
||||
|
reset(); |
||||
|
dialog.visible = true; |
||||
|
dialog.title = '添加平台管理配置'; |
||||
|
}; |
||||
|
|
||||
|
/** 修改按钮操作 */ |
||||
|
const handleUpdate = async (row?: PlatformConfigurationVO) => { |
||||
|
reset(); |
||||
|
const _id = row?.id || ids.value[0]; |
||||
|
const res = await getPlatformConfiguration(_id); |
||||
|
Object.assign(form.value, res.data); |
||||
|
dialog.visible = true; |
||||
|
dialog.title = '修改平台管理配置'; |
||||
|
}; |
||||
|
|
||||
|
/** 提交按钮 */ |
||||
|
const submitForm = () => { |
||||
|
platformConfigurationFormRef.value?.validate(async (valid: boolean) => { |
||||
|
if (valid) { |
||||
|
buttonLoading.value = true; |
||||
|
if (form.value.id) { |
||||
|
await updatePlatformConfiguration(form.value).finally(() => (buttonLoading.value = false)); |
||||
|
} else { |
||||
|
await addPlatformConfiguration(form.value).finally(() => (buttonLoading.value = false)); |
||||
|
} |
||||
|
proxy?.$modal.msgSuccess('操作成功'); |
||||
|
dialog.visible = false; |
||||
|
await getList(); |
||||
|
} |
||||
|
}); |
||||
|
}; |
||||
|
|
||||
|
/** 删除按钮操作 */ |
||||
|
const handleDelete = async (row?: PlatformConfigurationVO) => { |
||||
|
const _ids = row?.id || ids.value; |
||||
|
await proxy?.$modal.confirm('是否确认删除平台管理配置编号为"' + _ids + '"的数据项?').finally(() => (loading.value = false)); |
||||
|
await delPlatformConfiguration(_ids); |
||||
|
proxy?.$modal.msgSuccess('删除成功'); |
||||
|
await getList(); |
||||
|
}; |
||||
|
|
||||
|
/** 导出按钮操作 */ |
||||
|
const handleExport = () => { |
||||
|
proxy?.download( |
||||
|
'im/platformConfiguration/export', |
||||
|
{ |
||||
|
...queryParams.value |
||||
|
}, |
||||
|
`platformConfiguration_${new Date().getTime()}.xlsx` |
||||
|
); |
||||
|
}; |
||||
|
|
||||
|
onMounted(() => { |
||||
|
getList(); |
||||
|
}); |
||||
|
</script> |
||||
@ -0,0 +1,105 @@ |
|||||
|
package org.dromara.im.controller; |
||||
|
|
||||
|
import java.util.List; |
||||
|
|
||||
|
import lombok.RequiredArgsConstructor; |
||||
|
import jakarta.servlet.http.HttpServletResponse; |
||||
|
import jakarta.validation.constraints.*; |
||||
|
import cn.dev33.satoken.annotation.SaCheckPermission; |
||||
|
import org.springframework.web.bind.annotation.*; |
||||
|
import org.springframework.validation.annotation.Validated; |
||||
|
import org.dromara.common.idempotent.annotation.RepeatSubmit; |
||||
|
import org.dromara.common.log.annotation.Log; |
||||
|
import org.dromara.common.web.core.BaseController; |
||||
|
import org.dromara.common.mybatis.core.page.PageQuery; |
||||
|
import org.dromara.common.core.domain.R; |
||||
|
import org.dromara.common.core.validate.AddGroup; |
||||
|
import org.dromara.common.core.validate.EditGroup; |
||||
|
import org.dromara.common.log.enums.BusinessType; |
||||
|
import org.dromara.common.excel.utils.ExcelUtil; |
||||
|
import org.dromara.im.domain.vo.ImPlatformConfigurationVo; |
||||
|
import org.dromara.im.domain.bo.ImPlatformConfigurationBo; |
||||
|
import org.dromara.im.service.IImPlatformConfigurationService; |
||||
|
import org.dromara.common.mybatis.core.page.TableDataInfo; |
||||
|
|
||||
|
/** |
||||
|
* 平台管理配置 |
||||
|
* |
||||
|
* @author Blue |
||||
|
* @date 2026-04-20 |
||||
|
*/ |
||||
|
@Validated |
||||
|
@RequiredArgsConstructor |
||||
|
@RestController |
||||
|
@RequestMapping("/im/platformConfiguration") |
||||
|
public class ImPlatformConfigurationController extends BaseController { |
||||
|
|
||||
|
private final IImPlatformConfigurationService imPlatformConfigurationService; |
||||
|
|
||||
|
/** |
||||
|
* 查询平台管理配置列表 |
||||
|
*/ |
||||
|
@SaCheckPermission("im:platformConfiguration:list") |
||||
|
@GetMapping("/list") |
||||
|
public TableDataInfo<ImPlatformConfigurationVo> list(ImPlatformConfigurationBo bo, PageQuery pageQuery) { |
||||
|
return imPlatformConfigurationService.queryPageList(bo, pageQuery); |
||||
|
} |
||||
|
|
||||
|
/** |
||||
|
* 导出平台管理配置列表 |
||||
|
*/ |
||||
|
@SaCheckPermission("im:platformConfiguration:export") |
||||
|
@Log(title = "平台管理配置", businessType = BusinessType.EXPORT) |
||||
|
//@PostMapping("/export")
|
||||
|
public void export(ImPlatformConfigurationBo bo, HttpServletResponse response) { |
||||
|
List<ImPlatformConfigurationVo> list = imPlatformConfigurationService.queryList(bo); |
||||
|
ExcelUtil.exportExcel(list, "平台管理配置", ImPlatformConfigurationVo.class, response); |
||||
|
} |
||||
|
|
||||
|
/** |
||||
|
* 获取平台管理配置详细信息 |
||||
|
* |
||||
|
* @param id 主键 |
||||
|
*/ |
||||
|
@SaCheckPermission("im:platformConfiguration:query") |
||||
|
@GetMapping("/{id}") |
||||
|
public R<ImPlatformConfigurationVo> getInfo(@NotNull(message = "主键不能为空") |
||||
|
@PathVariable Long id) { |
||||
|
return R.ok(imPlatformConfigurationService.queryById(id)); |
||||
|
} |
||||
|
|
||||
|
/** |
||||
|
* 新增平台管理配置 |
||||
|
*/ |
||||
|
@SaCheckPermission("im:platformConfiguration:add") |
||||
|
@Log(title = "平台管理配置", businessType = BusinessType.INSERT) |
||||
|
@RepeatSubmit() |
||||
|
@PostMapping() |
||||
|
public R<Void> add(@Validated(AddGroup.class) @RequestBody ImPlatformConfigurationBo bo) { |
||||
|
return toAjax(imPlatformConfigurationService.insertByBo(bo)); |
||||
|
} |
||||
|
|
||||
|
/** |
||||
|
* 修改平台管理配置 |
||||
|
*/ |
||||
|
@SaCheckPermission("im:platformConfiguration:edit") |
||||
|
@Log(title = "平台管理配置", businessType = BusinessType.UPDATE) |
||||
|
@RepeatSubmit() |
||||
|
@PutMapping() |
||||
|
public R<Void> edit(@Validated(EditGroup.class) @RequestBody ImPlatformConfigurationBo bo) { |
||||
|
return toAjax(imPlatformConfigurationService.updateByBo(bo)); |
||||
|
} |
||||
|
|
||||
|
/** |
||||
|
* 删除平台管理配置 |
||||
|
* |
||||
|
* @param ids 主键串 |
||||
|
*/ |
||||
|
@SaCheckPermission("im:platformConfiguration:remove") |
||||
|
@Log(title = "平台管理配置", businessType = BusinessType.DELETE) |
||||
|
@DeleteMapping("/{ids}") |
||||
|
public R<Void> remove(@NotEmpty(message = "主键不能为空") |
||||
|
@PathVariable Long[] ids) { |
||||
|
return toAjax(imPlatformConfigurationService.deleteWithValidByIds(List.of(ids), true)); |
||||
|
} |
||||
|
} |
||||
@ -0,0 +1,64 @@ |
|||||
|
package org.dromara.im.domain; |
||||
|
|
||||
|
import com.fhs.core.trans.vo.TransPojo; |
||||
|
import org.dromara.common.mybatis.core.domain.BaseEntity; |
||||
|
import com.baomidou.mybatisplus.annotation.*; |
||||
|
import lombok.Data; |
||||
|
import lombok.EqualsAndHashCode; |
||||
|
import java.util.Date; |
||||
|
import com.fasterxml.jackson.annotation.JsonFormat; |
||||
|
|
||||
|
import java.io.Serial; |
||||
|
|
||||
|
/** |
||||
|
* 平台管理配置对象 im_platform_configuration |
||||
|
* |
||||
|
* @author Blue |
||||
|
* @date 2026-04-20 |
||||
|
*/ |
||||
|
@Data |
||||
|
@TableName("im_platform_configuration") |
||||
|
public class ImPlatformConfiguration implements TransPojo { |
||||
|
/** |
||||
|
* 主键ID |
||||
|
*/ |
||||
|
@TableId(value = "id") |
||||
|
private Long id; |
||||
|
|
||||
|
/** |
||||
|
* 唯一token |
||||
|
*/ |
||||
|
private String uniqueToken; |
||||
|
|
||||
|
/** |
||||
|
* 域名名称 |
||||
|
*/ |
||||
|
private String domainName; |
||||
|
|
||||
|
/** |
||||
|
* 备注 |
||||
|
*/ |
||||
|
private String remark; |
||||
|
|
||||
|
/** |
||||
|
* 创建时间 |
||||
|
*/ |
||||
|
private Date createdTime; |
||||
|
|
||||
|
/** |
||||
|
* 更新时间 |
||||
|
*/ |
||||
|
private Date updatedTime; |
||||
|
|
||||
|
/** |
||||
|
* 创建者ID |
||||
|
*/ |
||||
|
private Long creatorId; |
||||
|
|
||||
|
/** |
||||
|
* 更新者ID |
||||
|
*/ |
||||
|
private Long updaterId; |
||||
|
|
||||
|
|
||||
|
} |
||||
@ -0,0 +1,43 @@ |
|||||
|
package org.dromara.im.domain.bo; |
||||
|
|
||||
|
import org.dromara.im.domain.ImPlatformConfiguration; |
||||
|
import org.dromara.common.mybatis.core.domain.BaseEntity; |
||||
|
import org.dromara.common.core.validate.AddGroup; |
||||
|
import org.dromara.common.core.validate.EditGroup; |
||||
|
import io.github.linpeilie.annotations.AutoMapper; |
||||
|
import lombok.Data; |
||||
|
import lombok.EqualsAndHashCode; |
||||
|
import jakarta.validation.constraints.*; |
||||
|
import java.util.Date; |
||||
|
import com.fasterxml.jackson.annotation.JsonFormat; |
||||
|
|
||||
|
/** |
||||
|
* 平台管理配置业务对象 im_platform_configuration |
||||
|
* |
||||
|
* @author Blue |
||||
|
* @date 2026-04-20 |
||||
|
*/ |
||||
|
@Data |
||||
|
@EqualsAndHashCode(callSuper = true) |
||||
|
@AutoMapper(target = ImPlatformConfiguration.class, reverseConvertGenerate = false) |
||||
|
public class ImPlatformConfigurationBo extends BaseEntity { |
||||
|
|
||||
|
/** |
||||
|
* 主键ID |
||||
|
*/ |
||||
|
@NotNull(message = "主键ID不能为空", groups = { EditGroup.class }) |
||||
|
private Long id; |
||||
|
|
||||
|
/** |
||||
|
* 域名名称 |
||||
|
*/ |
||||
|
@NotBlank(message = "域名名称不能为空", groups = { AddGroup.class, EditGroup.class }) |
||||
|
private String domainName; |
||||
|
|
||||
|
/** |
||||
|
* 备注 |
||||
|
*/ |
||||
|
private String remark; |
||||
|
|
||||
|
|
||||
|
} |
||||
@ -0,0 +1,64 @@ |
|||||
|
package org.dromara.im.domain.vo; |
||||
|
|
||||
|
import java.util.Date; |
||||
|
import com.fasterxml.jackson.annotation.JsonFormat; |
||||
|
import org.dromara.im.domain.ImPlatformConfiguration; |
||||
|
import com.alibaba.excel.annotation.ExcelIgnoreUnannotated; |
||||
|
import com.alibaba.excel.annotation.ExcelProperty; |
||||
|
import org.dromara.common.excel.annotation.ExcelDictFormat; |
||||
|
import org.dromara.common.excel.convert.ExcelDictConvert; |
||||
|
import io.github.linpeilie.annotations.AutoMapper; |
||||
|
import lombok.Data; |
||||
|
|
||||
|
import java.io.Serial; |
||||
|
import java.io.Serializable; |
||||
|
import java.util.Date; |
||||
|
|
||||
|
|
||||
|
|
||||
|
/** |
||||
|
* 平台管理配置视图对象 im_platform_configuration |
||||
|
* |
||||
|
* @author Blue |
||||
|
* @date 2026-04-20 |
||||
|
*/ |
||||
|
@Data |
||||
|
@ExcelIgnoreUnannotated |
||||
|
@AutoMapper(target = ImPlatformConfiguration.class) |
||||
|
public class ImPlatformConfigurationVo implements Serializable { |
||||
|
|
||||
|
@Serial |
||||
|
private static final long serialVersionUID = 1L; |
||||
|
|
||||
|
/** |
||||
|
* 主键ID |
||||
|
*/ |
||||
|
@ExcelProperty(value = "主键ID") |
||||
|
private Long id; |
||||
|
|
||||
|
/** |
||||
|
* 唯一token |
||||
|
*/ |
||||
|
@ExcelProperty(value = "唯一token") |
||||
|
private String uniqueToken; |
||||
|
|
||||
|
/** |
||||
|
* 域名名称 |
||||
|
*/ |
||||
|
@ExcelProperty(value = "域名名称") |
||||
|
private String domainName; |
||||
|
|
||||
|
/** |
||||
|
* 备注 |
||||
|
*/ |
||||
|
@ExcelProperty(value = "备注") |
||||
|
private String remark; |
||||
|
|
||||
|
/** |
||||
|
* 创建时间 |
||||
|
*/ |
||||
|
@ExcelProperty(value = "创建时间") |
||||
|
private Date createdTime; |
||||
|
|
||||
|
|
||||
|
} |
||||
@ -0,0 +1,15 @@ |
|||||
|
package org.dromara.im.mapper; |
||||
|
|
||||
|
import org.dromara.im.domain.ImPlatformConfiguration; |
||||
|
import org.dromara.im.domain.vo.ImPlatformConfigurationVo; |
||||
|
import org.dromara.common.mybatis.core.mapper.BaseMapperPlus; |
||||
|
|
||||
|
/** |
||||
|
* 平台管理配置Mapper接口 |
||||
|
* |
||||
|
* @author Blue |
||||
|
* @date 2026-04-20 |
||||
|
*/ |
||||
|
public interface ImPlatformConfigurationMapper extends BaseMapperPlus<ImPlatformConfiguration, ImPlatformConfigurationVo> { |
||||
|
|
||||
|
} |
||||
@ -0,0 +1,68 @@ |
|||||
|
package org.dromara.im.service; |
||||
|
|
||||
|
import org.dromara.im.domain.vo.ImPlatformConfigurationVo; |
||||
|
import org.dromara.im.domain.bo.ImPlatformConfigurationBo; |
||||
|
import org.dromara.common.mybatis.core.page.TableDataInfo; |
||||
|
import org.dromara.common.mybatis.core.page.PageQuery; |
||||
|
|
||||
|
import java.util.Collection; |
||||
|
import java.util.List; |
||||
|
|
||||
|
/** |
||||
|
* 平台管理配置Service接口 |
||||
|
* |
||||
|
* @author Blue |
||||
|
* @date 2026-04-20 |
||||
|
*/ |
||||
|
public interface IImPlatformConfigurationService { |
||||
|
|
||||
|
/** |
||||
|
* 查询平台管理配置 |
||||
|
* |
||||
|
* @param id 主键 |
||||
|
* @return 平台管理配置 |
||||
|
*/ |
||||
|
ImPlatformConfigurationVo queryById(Long id); |
||||
|
|
||||
|
/** |
||||
|
* 分页查询平台管理配置列表 |
||||
|
* |
||||
|
* @param bo 查询条件 |
||||
|
* @param pageQuery 分页参数 |
||||
|
* @return 平台管理配置分页列表 |
||||
|
*/ |
||||
|
TableDataInfo<ImPlatformConfigurationVo> queryPageList(ImPlatformConfigurationBo bo, PageQuery pageQuery); |
||||
|
|
||||
|
/** |
||||
|
* 查询符合条件的平台管理配置列表 |
||||
|
* |
||||
|
* @param bo 查询条件 |
||||
|
* @return 平台管理配置列表 |
||||
|
*/ |
||||
|
List<ImPlatformConfigurationVo> queryList(ImPlatformConfigurationBo bo); |
||||
|
|
||||
|
/** |
||||
|
* 新增平台管理配置 |
||||
|
* |
||||
|
* @param bo 平台管理配置 |
||||
|
* @return 是否新增成功 |
||||
|
*/ |
||||
|
Boolean insertByBo(ImPlatformConfigurationBo bo); |
||||
|
|
||||
|
/** |
||||
|
* 修改平台管理配置 |
||||
|
* |
||||
|
* @param bo 平台管理配置 |
||||
|
* @return 是否修改成功 |
||||
|
*/ |
||||
|
Boolean updateByBo(ImPlatformConfigurationBo bo); |
||||
|
|
||||
|
/** |
||||
|
* 校验并批量删除平台管理配置信息 |
||||
|
* |
||||
|
* @param ids 待删除的主键集合 |
||||
|
* @param isValid 是否进行有效性校验 |
||||
|
* @return 是否删除成功 |
||||
|
*/ |
||||
|
Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid); |
||||
|
} |
||||
@ -0,0 +1,199 @@ |
|||||
|
package org.dromara.im.service.impl; |
||||
|
|
||||
|
import cn.hutool.core.date.DateUtil; |
||||
|
import com.baomidou.dynamic.datasource.annotation.DS; |
||||
|
import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; |
||||
|
import org.dromara.common.core.utils.MapstructUtils; |
||||
|
import org.dromara.common.core.utils.StringUtils; |
||||
|
import org.dromara.common.mybatis.core.page.TableDataInfo; |
||||
|
import org.dromara.common.mybatis.core.page.PageQuery; |
||||
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page; |
||||
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; |
||||
|
import com.baomidou.mybatisplus.core.toolkit.Wrappers; |
||||
|
import lombok.RequiredArgsConstructor; |
||||
|
import org.dromara.common.satoken.utils.LoginHelper; |
||||
|
import org.dromara.im.constant.ImConstant; |
||||
|
import org.dromara.im.domain.ImPlatformConfiguration; |
||||
|
import org.dromara.im.service.IImAgentService; |
||||
|
import org.dromara.im.util.LambdaQueryWrapperHelper; |
||||
|
import org.springframework.stereotype.Service; |
||||
|
import org.dromara.im.domain.bo.ImPlatformConfigurationBo; |
||||
|
import org.dromara.im.domain.vo.ImPlatformConfigurationVo; |
||||
|
import org.dromara.im.domain.ImPlatformConfiguration; |
||||
|
import org.dromara.im.mapper.ImPlatformConfigurationMapper; |
||||
|
import org.dromara.im.service.IImPlatformConfigurationService; |
||||
|
|
||||
|
import java.util.List; |
||||
|
import java.util.Map; |
||||
|
import java.util.Collection; |
||||
|
|
||||
|
/** |
||||
|
* 平台管理配置Service业务层处理 |
||||
|
* |
||||
|
* @author Blue |
||||
|
* @date 2026-04-20 |
||||
|
*/ |
||||
|
@RequiredArgsConstructor |
||||
|
@Service |
||||
|
@DS(ImConstant.DS_IM_PLATFORM) |
||||
|
public class ImPlatformConfigurationServiceImpl implements IImPlatformConfigurationService { |
||||
|
|
||||
|
private final ImPlatformConfigurationMapper baseMapper; |
||||
|
|
||||
|
private final IImAgentService imAgentService; |
||||
|
|
||||
|
|
||||
|
/** |
||||
|
* 查询平台管理配置 |
||||
|
* |
||||
|
* @param id 主键 |
||||
|
* @return 平台管理配置 |
||||
|
*/ |
||||
|
@Override |
||||
|
public ImPlatformConfigurationVo queryById(Long id){ |
||||
|
|
||||
|
LambdaQueryWrapper<ImPlatformConfiguration> lqw = Wrappers.lambdaQuery(); |
||||
|
lqw.eq(ImPlatformConfiguration::getId, id); |
||||
|
|
||||
|
if(!LoginHelper.isSuperAdmin()) { |
||||
|
LambdaQueryWrapperHelper.appendToken(lqw, ImPlatformConfiguration::getUniqueToken); |
||||
|
} |
||||
|
|
||||
|
return baseMapper.selectVoOne(lqw); |
||||
|
} |
||||
|
|
||||
|
/** |
||||
|
* 分页查询平台管理配置列表 |
||||
|
* |
||||
|
* @param bo 查询条件 |
||||
|
* @param pageQuery 分页参数 |
||||
|
* @return 平台管理配置分页列表 |
||||
|
*/ |
||||
|
@Override |
||||
|
public TableDataInfo<ImPlatformConfigurationVo> queryPageList(ImPlatformConfigurationBo bo, PageQuery pageQuery) { |
||||
|
LambdaQueryWrapper<ImPlatformConfiguration> lqw = buildQueryWrapper(bo); |
||||
|
Page<ImPlatformConfigurationVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw); |
||||
|
return TableDataInfo.build(result); |
||||
|
} |
||||
|
|
||||
|
/** |
||||
|
* 查询符合条件的平台管理配置列表 |
||||
|
* |
||||
|
* @param bo 查询条件 |
||||
|
* @return 平台管理配置列表 |
||||
|
*/ |
||||
|
@Override |
||||
|
public List<ImPlatformConfigurationVo> queryList(ImPlatformConfigurationBo bo) { |
||||
|
LambdaQueryWrapper<ImPlatformConfiguration> lqw = buildQueryWrapper(bo); |
||||
|
return baseMapper.selectVoList(lqw); |
||||
|
} |
||||
|
|
||||
|
private LambdaQueryWrapper<ImPlatformConfiguration> buildQueryWrapper(ImPlatformConfigurationBo bo) { |
||||
|
Map<String, Object> params = bo.getParams(); |
||||
|
LambdaQueryWrapper<ImPlatformConfiguration> lqw = Wrappers.lambdaQuery(); |
||||
|
lqw.like(StringUtils.isNotBlank(bo.getDomainName()), ImPlatformConfiguration::getDomainName, bo.getDomainName()); |
||||
|
|
||||
|
if(!LoginHelper.isSuperAdmin()) { |
||||
|
LambdaQueryWrapperHelper.appendToken(lqw, ImPlatformConfiguration::getUniqueToken); |
||||
|
} |
||||
|
|
||||
|
return lqw; |
||||
|
} |
||||
|
|
||||
|
/** |
||||
|
* 新增平台管理配置 |
||||
|
* |
||||
|
* @param bo 平台管理配置 |
||||
|
* @return 是否新增成功 |
||||
|
*/ |
||||
|
@Override |
||||
|
public Boolean insertByBo(ImPlatformConfigurationBo bo) { |
||||
|
ImPlatformConfiguration add = MapstructUtils.convert(bo, ImPlatformConfiguration.class); |
||||
|
|
||||
|
if (add == null) { |
||||
|
return false; |
||||
|
} |
||||
|
|
||||
|
add.setCreatorId(LoginHelper.getUserId()); |
||||
|
add.setCreatedTime(DateUtil.date()); |
||||
|
add.setUpdaterId(LoginHelper.getUserId()); |
||||
|
add.setUpdatedTime(DateUtil.date()); |
||||
|
|
||||
|
// 如果不是超级管理员,则设置 uniqueToken
|
||||
|
if(!LoginHelper.isSuperAdmin()) { |
||||
|
add.setUniqueToken(imAgentService.getTokenByUserId()); |
||||
|
} |
||||
|
|
||||
|
|
||||
|
validEntityBeforeSave(add); |
||||
|
boolean flag = baseMapper.insert(add) > 0; |
||||
|
if (flag) { |
||||
|
bo.setId(add.getId()); |
||||
|
} |
||||
|
return flag; |
||||
|
} |
||||
|
|
||||
|
/** |
||||
|
* 修改平台管理配置 |
||||
|
* |
||||
|
* @param bo 平台管理配置 |
||||
|
* @return 是否修改成功 |
||||
|
*/ |
||||
|
@Override |
||||
|
public Boolean updateByBo(ImPlatformConfigurationBo bo) { |
||||
|
ImPlatformConfiguration update = MapstructUtils.convert(bo, ImPlatformConfiguration.class); |
||||
|
if (update == null) { |
||||
|
return false; |
||||
|
} |
||||
|
validEntityBeforeSave(update); |
||||
|
LambdaUpdateWrapper<ImPlatformConfiguration> updateWrapper = new LambdaUpdateWrapper<>(); |
||||
|
updateWrapper.eq(ImPlatformConfiguration::getId, update.getId()); |
||||
|
|
||||
|
if(!LoginHelper.isSuperAdmin()) { |
||||
|
// 使用当前用户的 token 而不是从 bo 中获取,防止篡改
|
||||
|
updateWrapper.eq(ImPlatformConfiguration::getUniqueToken, imAgentService.getTokenByUserId()); |
||||
|
} |
||||
|
|
||||
|
updateWrapper.set(ImPlatformConfiguration::getDomainName, update.getDomainName()); |
||||
|
updateWrapper.set(ImPlatformConfiguration::getRemark, update.getRemark()); |
||||
|
|
||||
|
updateWrapper.set(ImPlatformConfiguration::getUpdaterId, LoginHelper.getUserId()); |
||||
|
updateWrapper.set(ImPlatformConfiguration::getUpdatedTime, DateUtil.date()); |
||||
|
|
||||
|
return baseMapper.update(null, updateWrapper) > 0; |
||||
|
|
||||
|
} |
||||
|
|
||||
|
/** |
||||
|
* 保存前的数据校验 |
||||
|
*/ |
||||
|
private void validEntityBeforeSave(ImPlatformConfiguration entity){ |
||||
|
//TODO 做一些数据校验,如唯一约束
|
||||
|
} |
||||
|
|
||||
|
/** |
||||
|
* 校验并批量删除平台管理配置信息 |
||||
|
* |
||||
|
* @param ids 待删除的主键集合 |
||||
|
* @param isValid 是否进行有效性校验 |
||||
|
* @return 是否删除成功 |
||||
|
*/ |
||||
|
@Override |
||||
|
public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) { |
||||
|
if(isValid){ |
||||
|
if (ids == null || ids.isEmpty()) { |
||||
|
return false; |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
LambdaUpdateWrapper<ImPlatformConfiguration> updateWrapper = new LambdaUpdateWrapper<>(); |
||||
|
updateWrapper.in(ImPlatformConfiguration::getId, ids); |
||||
|
|
||||
|
if(!LoginHelper.isSuperAdmin()) { |
||||
|
// 添加 uniqueToken 条件,确保只能删除当前用户的记录
|
||||
|
updateWrapper.eq(ImPlatformConfiguration::getUniqueToken, imAgentService.getTokenByUserId()); |
||||
|
} |
||||
|
|
||||
|
return baseMapper.delete(updateWrapper) > 0; |
||||
|
} |
||||
|
} |
||||
@ -0,0 +1,7 @@ |
|||||
|
<?xml version="1.0" encoding="UTF-8" ?> |
||||
|
<!DOCTYPE mapper |
||||
|
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" |
||||
|
"http://mybatis.org/dtd/mybatis-3-mapper.dtd"> |
||||
|
<mapper namespace="org.dromara.im.mapper.ImPlatformConfigurationMapper"> |
||||
|
|
||||
|
</mapper> |
||||
Loading…
Reference in new issue