feat(系统设置): 组织日志接口&认证配置测试接口&表单密码框禁止自动填充
This commit is contained in:
parent
3c38b27c1a
commit
6f996e991b
|
@ -13,6 +13,8 @@ import {
|
||||||
UpdateAuthStatusUrl,
|
UpdateAuthStatusUrl,
|
||||||
AddAuthUrl,
|
AddAuthUrl,
|
||||||
DeleteAuthUrl,
|
DeleteAuthUrl,
|
||||||
|
TestLdapConnectUrl,
|
||||||
|
TestLdapLoginUrl,
|
||||||
} from '@/api/requrls/setting/config';
|
} from '@/api/requrls/setting/config';
|
||||||
|
|
||||||
import type { CommonList, TableQueryParams } from '@/models/common';
|
import type { CommonList, TableQueryParams } from '@/models/common';
|
||||||
|
@ -26,6 +28,8 @@ import type {
|
||||||
AuthItem,
|
AuthItem,
|
||||||
AuthParams,
|
AuthParams,
|
||||||
UpdateAuthStatusParams,
|
UpdateAuthStatusParams,
|
||||||
|
LDAPConfig,
|
||||||
|
LDAPConnectConfig,
|
||||||
} from '@/models/setting/config';
|
} from '@/models/setting/config';
|
||||||
|
|
||||||
// 测试邮箱连接
|
// 测试邮箱连接
|
||||||
|
@ -92,3 +96,13 @@ export function updateAuthStatus(data: UpdateAuthStatusParams) {
|
||||||
export function deleteAuth(id: string) {
|
export function deleteAuth(id: string) {
|
||||||
return MSR.get({ url: DeleteAuthUrl, params: id });
|
return MSR.get({ url: DeleteAuthUrl, params: id });
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 测试ldap连接
|
||||||
|
export function testLdapConnect(data: LDAPConnectConfig) {
|
||||||
|
return MSR.post({ url: TestLdapConnectUrl, data });
|
||||||
|
}
|
||||||
|
|
||||||
|
// 测试ldap登录
|
||||||
|
export function testLdapLogin(data: LDAPConfig) {
|
||||||
|
return MSR.post({ url: TestLdapLoginUrl, data });
|
||||||
|
}
|
||||||
|
|
|
@ -1,20 +1,42 @@
|
||||||
import MSR from '@/api/http/index';
|
import MSR from '@/api/http/index';
|
||||||
import { GetLogListUrl, GetLogOptionsUrl, GetLogUserUrl } from '@/api/requrls/setting/log';
|
import {
|
||||||
|
GetSystemLogListUrl,
|
||||||
|
GetSystemLogOptionsUrl,
|
||||||
|
GetSystemLogUserUrl,
|
||||||
|
GetOrgLogListUrl,
|
||||||
|
GetOrgLogOptionsUrl,
|
||||||
|
GetOrgLogUserUrl,
|
||||||
|
} from '@/api/requrls/setting/log';
|
||||||
|
|
||||||
import type { CommonList } from '@/models/common';
|
import type { CommonList } from '@/models/common';
|
||||||
import type { LogOptions, LogItem, UserItem } from '@/models/setting/log';
|
import type { LogOptions, LogItem, UserItem } from '@/models/setting/log';
|
||||||
|
|
||||||
// 获取日志列表
|
// 获取系统日志列表
|
||||||
export function getLogList(data: any) {
|
export function getSystemLogList(data: any) {
|
||||||
return MSR.post<CommonList<LogItem>>({ url: GetLogListUrl, data });
|
return MSR.post<CommonList<LogItem>>({ url: GetSystemLogListUrl, data });
|
||||||
}
|
}
|
||||||
|
|
||||||
// 获取日志操作范围选项
|
// 获取系统日志-操作范围选项
|
||||||
export function getLogOptions() {
|
export function getSystemLogOptions() {
|
||||||
return MSR.get<LogOptions>({ url: GetLogOptionsUrl });
|
return MSR.get<LogOptions>({ url: GetSystemLogOptionsUrl });
|
||||||
}
|
}
|
||||||
|
|
||||||
// 获取日志操作用户列表
|
// 获取系统日志-操作用户列表
|
||||||
export function getLogUsers() {
|
export function getSystemLogUsers() {
|
||||||
return MSR.get<UserItem[]>({ url: GetLogUserUrl });
|
return MSR.get<UserItem[]>({ url: GetSystemLogUserUrl });
|
||||||
|
}
|
||||||
|
|
||||||
|
// 获取组织日志列表
|
||||||
|
export function getOrgLogList(data: any) {
|
||||||
|
return MSR.post<CommonList<LogItem>>({ url: GetOrgLogListUrl, data });
|
||||||
|
}
|
||||||
|
|
||||||
|
// 获取组织日志-操作范围选项
|
||||||
|
export function getOrgLogOptions(id: string) {
|
||||||
|
return MSR.get<LogOptions>({ url: GetOrgLogOptionsUrl, params: id });
|
||||||
|
}
|
||||||
|
|
||||||
|
// 获取组织日志-操作用户列表
|
||||||
|
export function getOrgLogUsers(id: string) {
|
||||||
|
return MSR.get<UserItem[]>({ url: GetOrgLogUserUrl, params: id });
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,10 +0,0 @@
|
||||||
import MSR from '@/api/http/index';
|
|
||||||
import { OrganizationListItem } from '@/models/setting/orgnization';
|
|
||||||
import { GetAllOrgUrl } from '@/api/requrls/setting/orgnization';
|
|
||||||
|
|
||||||
// 获取全部组织列表
|
|
||||||
export function getAllOrgList() {
|
|
||||||
return MSR.post<OrganizationListItem[]>({ url: GetAllOrgUrl });
|
|
||||||
}
|
|
||||||
|
|
||||||
export function other() {}
|
|
|
@ -24,6 +24,11 @@ export const AddAuthUrl = '/system/authsource/add';
|
||||||
export const GetAuthDetailUrl = '/system/authsource/get';
|
export const GetAuthDetailUrl = '/system/authsource/get';
|
||||||
// 删除认证源
|
// 删除认证源
|
||||||
export const DeleteAuthUrl = '/system/authsource/delete';
|
export const DeleteAuthUrl = '/system/authsource/delete';
|
||||||
|
// 测试ldap连接
|
||||||
|
export const TestLdapConnectUrl = '/system/authsource/ldap/test-connect';
|
||||||
|
// 测试ldap登录
|
||||||
|
export const TestLdapLoginUrl = '/system/authsource/ldap/test-login';
|
||||||
|
|
||||||
// 获取系统主页左上角图片
|
// 获取系统主页左上角图片
|
||||||
export const GetTitleImgUrl = `${import.meta.env.VITE_API_BASE_URL}/base-display/get/logo-platform`;
|
export const GetTitleImgUrl = `${import.meta.env.VITE_API_BASE_URL}/base-display/get/logo-platform`;
|
||||||
// 获取登录 logo
|
// 获取登录 logo
|
||||||
|
|
|
@ -1,3 +1,9 @@
|
||||||
export const GetLogListUrl = '/operation/log/list';
|
// 系统级别日志
|
||||||
export const GetLogOptionsUrl = '/operation/log/get/options'; // 获取组织/项目级联下拉框选项
|
export const GetSystemLogListUrl = '/operation/log/list';
|
||||||
export const GetLogUserUrl = '/operation/log/user/list'; // 搜索操作用户
|
export const GetSystemLogOptionsUrl = '/operation/log/get/options'; // 获取组织/项目级联下拉框选项
|
||||||
|
export const GetSystemLogUserUrl = '/operation/log/user/list'; // 搜索操作用户
|
||||||
|
|
||||||
|
// 组织级别日志
|
||||||
|
export const GetOrgLogListUrl = '/organization/log/list';
|
||||||
|
export const GetOrgLogOptionsUrl = '/organization/log/get/options'; // 获取组织/项目级联下拉框选项
|
||||||
|
export const GetOrgLogUserUrl = '/organization/log/user/list'; // 搜索操作用户
|
||||||
|
|
|
@ -1,2 +0,0 @@
|
||||||
export const GetAllOrgUrl = '/system/organization/option/all';
|
|
||||||
export const Other = '';
|
|
|
@ -33,6 +33,7 @@ export default function usePathMap() {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 根据路由的 key 进行路由跳转,自动携带配置的 routeQuery 和 传入的routeQuery
|
* 根据路由的 key 进行路由跳转,自动携带配置的 routeQuery 和 传入的routeQuery
|
||||||
|
* TODO: 权限校验待补充
|
||||||
* @param key
|
* @param key
|
||||||
*/
|
*/
|
||||||
const jumpRouteByMapKey = (key: typeof RouteEnum, routeQuery?: Record<string, any>) => {
|
const jumpRouteByMapKey = (key: typeof RouteEnum, routeQuery?: Record<string, any>) => {
|
||||||
|
|
|
@ -130,3 +130,17 @@ export interface UpdateAuthStatusParams {
|
||||||
id: string;
|
id: string;
|
||||||
enable: boolean;
|
enable: boolean;
|
||||||
}
|
}
|
||||||
|
// ldap 连接配置
|
||||||
|
export interface LDAPConnectConfig {
|
||||||
|
ldapUrl: string;
|
||||||
|
ldapDn: string;
|
||||||
|
ldapPassword: string;
|
||||||
|
}
|
||||||
|
// ldap登录配置
|
||||||
|
export interface LDAPConfig extends LDAPConnectConfig {
|
||||||
|
username: string;
|
||||||
|
password: string;
|
||||||
|
ldapUserFilter: string;
|
||||||
|
ldapUserOu: string;
|
||||||
|
ldapUserMapping: string;
|
||||||
|
}
|
||||||
|
|
|
@ -61,10 +61,7 @@ const useUserStore = defineStore('user', {
|
||||||
const res = await userLogin(loginForm);
|
const res = await userLogin(loginForm);
|
||||||
setToken(res.sessionId, res.csrfToken);
|
setToken(res.sessionId, res.csrfToken);
|
||||||
const appStore = useAppStore();
|
const appStore = useAppStore();
|
||||||
if (appStore.currentOrgId === '') {
|
appStore.setCurrentOrgId(res.lastOrganizationId || '');
|
||||||
// 第一次进系统才设置组织 ID,后续已经持久化存储了
|
|
||||||
appStore.setCurrentOrgId(res.lastOrganizationId || '');
|
|
||||||
}
|
|
||||||
this.setInfo(res);
|
this.setInfo(res);
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
clearToken();
|
clearToken();
|
||||||
|
|
|
@ -15,6 +15,7 @@
|
||||||
v-model="form.password"
|
v-model="form.password"
|
||||||
:placeholder="t('invite.passwordPlaceholder')"
|
:placeholder="t('invite.passwordPlaceholder')"
|
||||||
allow-clear
|
allow-clear
|
||||||
|
autocomplete="new-password"
|
||||||
@input="validatePsw"
|
@input="validatePsw"
|
||||||
@clear="validatePsw(form.password)"
|
@clear="validatePsw(form.password)"
|
||||||
/>
|
/>
|
||||||
|
@ -39,7 +40,12 @@
|
||||||
</a-popover>
|
</a-popover>
|
||||||
</a-form-item>
|
</a-form-item>
|
||||||
<a-form-item field="repassword" class="hidden-item">
|
<a-form-item field="repassword" class="hidden-item">
|
||||||
<a-input-password v-model="form.repassword" :placeholder="t('invite.repasswordPlaceholder')" allow-clear />
|
<a-input-password
|
||||||
|
v-model="form.repassword"
|
||||||
|
:placeholder="t('invite.repasswordPlaceholder')"
|
||||||
|
autocomplete="new-password"
|
||||||
|
allow-clear
|
||||||
|
/>
|
||||||
</a-form-item>
|
</a-form-item>
|
||||||
<a-button type="primary" html-type="submit">{{ t('invite.confirm') }}</a-button>
|
<a-button type="primary" html-type="submit">{{ t('invite.confirm') }}</a-button>
|
||||||
</a-form>
|
</a-form>
|
||||||
|
|
|
@ -402,7 +402,6 @@
|
||||||
v-model:model-value="activeAuthForm.configuration.dn"
|
v-model:model-value="activeAuthForm.configuration.dn"
|
||||||
:max-length="250"
|
:max-length="250"
|
||||||
:placeholder="t('system.config.auth.DNPlaceholder')"
|
:placeholder="t('system.config.auth.DNPlaceholder')"
|
||||||
:input-attrs="{ autocomplete: 'off' }"
|
|
||||||
allow-clear
|
allow-clear
|
||||||
></a-input>
|
></a-input>
|
||||||
</a-form-item>
|
</a-form-item>
|
||||||
|
@ -417,9 +416,9 @@
|
||||||
v-model:model-value="activeAuthForm.configuration.password"
|
v-model:model-value="activeAuthForm.configuration.password"
|
||||||
:max-length="250"
|
:max-length="250"
|
||||||
:placeholder="t('system.config.auth.LDAPPasswordPlaceholder')"
|
:placeholder="t('system.config.auth.LDAPPasswordPlaceholder')"
|
||||||
:input-attrs="{ autocomplete: 'off' }"
|
|
||||||
allow-clear
|
allow-clear
|
||||||
></a-input-password>
|
autocomplete="new-password"
|
||||||
|
/>
|
||||||
</a-form-item>
|
</a-form-item>
|
||||||
<a-form-item
|
<a-form-item
|
||||||
:label="t('system.config.auth.OU')"
|
:label="t('system.config.auth.OU')"
|
||||||
|
@ -467,14 +466,59 @@
|
||||||
<MsFormItemSub :text="t('system.config.auth.LDAPPropertyMapTip')" :show-fill-icon="false" />
|
<MsFormItemSub :text="t('system.config.auth.LDAPPropertyMapTip')" :show-fill-icon="false" />
|
||||||
</a-form-item>
|
</a-form-item>
|
||||||
<div>
|
<div>
|
||||||
<a-button type="outline" class="mr-[16px]" @click="testLink">
|
<a-button type="outline" class="mr-[16px]" :loading="LDAPTestLoading" @click="testLink">
|
||||||
{{ t('system.config.auth.testLink') }}
|
{{ t('system.config.auth.testLink') }}
|
||||||
</a-button>
|
</a-button>
|
||||||
<a-button type="outline" @click="testLogin">{{ t('system.config.auth.testLogin') }}</a-button>
|
<a-button type="outline" :loading="LDAPTestLoading" @click="beforeTestLogin">{{
|
||||||
|
t('system.config.auth.testLogin')
|
||||||
|
}}</a-button>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
</a-form>
|
</a-form>
|
||||||
</MsDrawer>
|
</MsDrawer>
|
||||||
|
<a-modal
|
||||||
|
v-model:visible="testLoginModalVisible"
|
||||||
|
:title="t('system.config.auth.testLogin')"
|
||||||
|
title-align="start"
|
||||||
|
class="ms-modal-form ms-modal-medium"
|
||||||
|
:mask-closable="false"
|
||||||
|
@close="handleTestLoginModalClose"
|
||||||
|
>
|
||||||
|
<a-form ref="LDAPFormRef" class="rounded-[4px]" :model="LDAPForm" layout="vertical">
|
||||||
|
<a-form-item
|
||||||
|
field="username"
|
||||||
|
:label="t('system.config.auth.testLoginName')"
|
||||||
|
:rules="[{ required: true, message: t('system.config.auth.testLoginNameNotNull') }]"
|
||||||
|
asterisk-position="end"
|
||||||
|
>
|
||||||
|
<a-input
|
||||||
|
v-model:model-value="LDAPForm.username"
|
||||||
|
:placeholder="t('system.config.auth.testLoginNamePlaceholder')"
|
||||||
|
:max-length="250"
|
||||||
|
></a-input>
|
||||||
|
</a-form-item>
|
||||||
|
<a-form-item
|
||||||
|
field="password"
|
||||||
|
:label="t('system.config.auth.testLoginPassword')"
|
||||||
|
:rules="[{ required: true, message: t('system.config.auth.testLoginPasswordNotNull') }]"
|
||||||
|
asterisk-position="end"
|
||||||
|
>
|
||||||
|
<a-input-password
|
||||||
|
v-model:model-value="LDAPForm.password"
|
||||||
|
:placeholder="t('system.config.auth.testLoginPasswordPlaceholder')"
|
||||||
|
autocomplete="new-password"
|
||||||
|
/>
|
||||||
|
</a-form-item>
|
||||||
|
</a-form>
|
||||||
|
<template #footer>
|
||||||
|
<a-button type="secondary" :disabled="LDAPTestLoading" @click="handleTestLoginModalClose">
|
||||||
|
{{ t('system.config.auth.testLoginCancel') }}
|
||||||
|
</a-button>
|
||||||
|
<a-button type="primary" :loading="LDAPTestLoading" @click="testLogin">
|
||||||
|
{{ t('system.config.auth.testLogin') }}
|
||||||
|
</a-button>
|
||||||
|
</template>
|
||||||
|
</a-modal>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
|
@ -498,6 +542,8 @@
|
||||||
updateAuth,
|
updateAuth,
|
||||||
updateAuthStatus,
|
updateAuthStatus,
|
||||||
deleteAuth,
|
deleteAuth,
|
||||||
|
testLdapConnect,
|
||||||
|
testLdapLogin,
|
||||||
} from '@/api/modules/setting/config';
|
} from '@/api/modules/setting/config';
|
||||||
import MsFormItemSub from '@/components/business/ms-form-item-sub/index.vue';
|
import MsFormItemSub from '@/components/business/ms-form-item-sub/index.vue';
|
||||||
import { scrollIntoView } from '@/utils/dom';
|
import { scrollIntoView } from '@/utils/dom';
|
||||||
|
@ -890,8 +936,86 @@
|
||||||
activeAuthForm.value = { ...defaultAuth };
|
activeAuthForm.value = { ...defaultAuth };
|
||||||
}
|
}
|
||||||
|
|
||||||
async function testLink() {}
|
const LDAPTestLoading = ref(false);
|
||||||
async function testLogin() {}
|
const testLoginModalVisible = ref(false);
|
||||||
|
const LDAPForm = ref({
|
||||||
|
username: '',
|
||||||
|
password: '',
|
||||||
|
});
|
||||||
|
const LDAPFormRef = ref<FormInstance>();
|
||||||
|
|
||||||
|
function handleTestLoginModalClose() {
|
||||||
|
LDAPFormRef.value?.resetFields();
|
||||||
|
testLoginModalVisible.value = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
function testLink() {
|
||||||
|
authFormRef.value?.validateField(
|
||||||
|
['configuration.url', 'configuration.dn', 'configuration.password'],
|
||||||
|
async (res) => {
|
||||||
|
if (!res) {
|
||||||
|
try {
|
||||||
|
LDAPTestLoading.value = true;
|
||||||
|
await testLdapConnect({
|
||||||
|
ldapUrl: activeAuthForm.value.configuration.url,
|
||||||
|
ldapDn: activeAuthForm.value.configuration.dn,
|
||||||
|
ldapPassword: activeAuthForm.value.configuration.password,
|
||||||
|
});
|
||||||
|
Message.success(t('system.config.auth.testLinkSuccess'));
|
||||||
|
} catch (error) {
|
||||||
|
console.log(error);
|
||||||
|
} finally {
|
||||||
|
LDAPTestLoading.value = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
function testLogin() {
|
||||||
|
LDAPFormRef.value?.validate(async (res) => {
|
||||||
|
if (!res) {
|
||||||
|
try {
|
||||||
|
LDAPTestLoading.value = true;
|
||||||
|
await testLdapLogin({
|
||||||
|
ldapUrl: activeAuthForm.value.configuration.url,
|
||||||
|
ldapDn: activeAuthForm.value.configuration.dn,
|
||||||
|
ldapPassword: activeAuthForm.value.configuration.password,
|
||||||
|
username: LDAPForm.value.username,
|
||||||
|
password: LDAPForm.value.password,
|
||||||
|
ldapUserFilter: activeAuthForm.value.configuration.filter,
|
||||||
|
ldapUserOu: activeAuthForm.value.configuration.ou,
|
||||||
|
ldapUserMapping: activeAuthForm.value.configuration.mapping,
|
||||||
|
});
|
||||||
|
Message.success(t('system.config.auth.testLinkSuccess'));
|
||||||
|
} catch (error) {
|
||||||
|
console.log(error);
|
||||||
|
} finally {
|
||||||
|
LDAPTestLoading.value = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function beforeTestLogin() {
|
||||||
|
authFormRef.value?.validateField(
|
||||||
|
[
|
||||||
|
'configuration.url',
|
||||||
|
'configuration.dn',
|
||||||
|
'configuration.password',
|
||||||
|
'configuration.filter',
|
||||||
|
'configuration.ou',
|
||||||
|
'configuration.mapping',
|
||||||
|
],
|
||||||
|
async (errors: Record<string, ValidatedError> | undefined) => {
|
||||||
|
if (!errors) {
|
||||||
|
testLoginModalVisible.value = true;
|
||||||
|
} else {
|
||||||
|
scrollIntoView(document.querySelector('.arco-form-item-message'), { block: 'center' });
|
||||||
|
}
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 保存认证信息
|
* 保存认证信息
|
||||||
|
@ -984,7 +1108,7 @@
|
||||||
if (!errors) {
|
if (!errors) {
|
||||||
saveAuth(isContinue);
|
saveAuth(isContinue);
|
||||||
} else {
|
} else {
|
||||||
scrollIntoView(document.querySelector('.arco-form-item-message'), { block: 'center' });
|
scrollIntoView(authFormRef.value?.$el.querySelector('.arco-form-item-message'), { block: 'center' });
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
@ -149,9 +149,9 @@
|
||||||
v-model:model-value="emailConfigForm.password"
|
v-model:model-value="emailConfigForm.password"
|
||||||
:max-length="250"
|
:max-length="250"
|
||||||
:placeholder="t('system.config.email.passwordPlaceholder')"
|
:placeholder="t('system.config.email.passwordPlaceholder')"
|
||||||
autocomplete="off"
|
autocomplete="new-password"
|
||||||
allow-clear
|
allow-clear
|
||||||
></a-input-password>
|
/>
|
||||||
</a-form-item>
|
</a-form-item>
|
||||||
<a-form-item :label="t('system.config.email.from')" field="from" asterisk-position="end" :rules="[emailRule]">
|
<a-form-item :label="t('system.config.email.from')" field="from" asterisk-position="end" :rules="[emailRule]">
|
||||||
<a-input
|
<a-input
|
||||||
|
@ -391,7 +391,7 @@
|
||||||
{ paramKey: 'smtp.host', paramValue: host, type: 'text' },
|
{ paramKey: 'smtp.host', paramValue: host, type: 'text' },
|
||||||
{ paramKey: 'smtp.port', paramValue: port, type: 'text' },
|
{ paramKey: 'smtp.port', paramValue: port, type: 'text' },
|
||||||
{ paramKey: 'smtp.account', paramValue: account, type: 'text' },
|
{ paramKey: 'smtp.account', paramValue: account, type: 'text' },
|
||||||
{ paramKey: 'smtp.password', paramValue: password, type: 'text' },
|
{ paramKey: 'smtp.password', paramValue: password, type: 'password' },
|
||||||
{ paramKey: 'smtp.from', paramValue: from, type: 'text' },
|
{ paramKey: 'smtp.from', paramValue: from, type: 'text' },
|
||||||
{ paramKey: 'smtp.recipient', paramValue: recipient, type: 'text' },
|
{ paramKey: 'smtp.recipient', paramValue: recipient, type: 'text' },
|
||||||
{ paramKey: 'smtp.ssl', paramValue: ssl?.toString(), type: 'text' },
|
{ paramKey: 'smtp.ssl', paramValue: ssl?.toString(), type: 'text' },
|
||||||
|
|
|
@ -194,6 +194,15 @@ export default {
|
||||||
'system.config.auth.LDAPPropertyMapPlaceholder': 'Please enter',
|
'system.config.auth.LDAPPropertyMapPlaceholder': 'Please enter',
|
||||||
'system.config.auth.LDAPPropertyMapTip':
|
'system.config.auth.LDAPPropertyMapTip':
|
||||||
'The left key is the MeterSphere user attribute, and the right value is the authentication platform user attribute',
|
'The left key is the MeterSphere user attribute, and the right value is the authentication platform user attribute',
|
||||||
'system.config.auth.testLink': 'Test connection',
|
'system.config.auth.testLink': 'Test Connection',
|
||||||
'system.config.auth.testLogin': 'Test login',
|
'system.config.auth.testLinkSuccess': 'LDAP connection succeeded',
|
||||||
|
'system.config.auth.testLogin': 'Test Login',
|
||||||
|
'system.config.auth.testLoginName': 'Test login username',
|
||||||
|
'system.config.auth.testLoginNamePlaceholder': 'Please enter LDAP login username',
|
||||||
|
'system.config.auth.testLoginNameNotNull': 'LDAP login username cannot be empty',
|
||||||
|
'system.config.auth.testLoginPassword': 'Test login password',
|
||||||
|
'system.config.auth.testLoginPasswordPlaceholder': 'Please enter LDAP login password',
|
||||||
|
'system.config.auth.testLoginPasswordNotNull': 'LDAP login password cannot be empty',
|
||||||
|
'system.config.auth.testLoginSuccess': 'LDAP login successful',
|
||||||
|
'system.config.auth.testLoginCancel': 'Cancel',
|
||||||
};
|
};
|
||||||
|
|
|
@ -191,5 +191,14 @@ export default {
|
||||||
'system.config.auth.LDAPPropertyMapPlaceholder': '请输入',
|
'system.config.auth.LDAPPropertyMapPlaceholder': '请输入',
|
||||||
'system.config.auth.LDAPPropertyMapTip': '左侧键为 MeterSphere 用户属性,右侧值为认证平台用户属性',
|
'system.config.auth.LDAPPropertyMapTip': '左侧键为 MeterSphere 用户属性,右侧值为认证平台用户属性',
|
||||||
'system.config.auth.testLink': '测试连接',
|
'system.config.auth.testLink': '测试连接',
|
||||||
|
'system.config.auth.testLinkSuccess': 'LDAP 连接成功',
|
||||||
'system.config.auth.testLogin': '测试登录',
|
'system.config.auth.testLogin': '测试登录',
|
||||||
|
'system.config.auth.testLoginName': '测试登录用户名',
|
||||||
|
'system.config.auth.testLoginNamePlaceholder': '请输入 LDAP 登录用户名',
|
||||||
|
'system.config.auth.testLoginNameNotNull': 'LDAP 登录用户名不能为空',
|
||||||
|
'system.config.auth.testLoginPassword': '测试登录密码',
|
||||||
|
'system.config.auth.testLoginPasswordPlaceholder': '请输入 LDAP 登录密码',
|
||||||
|
'system.config.auth.testLoginPasswordNotNull': 'LDAP 登录密码不能为空',
|
||||||
|
'system.config.auth.testLoginCancel': '取消测试',
|
||||||
|
'system.config.auth.testLoginSuccess': 'LDAP 登录成功',
|
||||||
};
|
};
|
||||||
|
|
|
@ -97,7 +97,14 @@
|
||||||
import MsCard from '@/components/pure/ms-card/index.vue';
|
import MsCard from '@/components/pure/ms-card/index.vue';
|
||||||
import { useI18n } from '@/hooks/useI18n';
|
import { useI18n } from '@/hooks/useI18n';
|
||||||
import usePathMap from '@/hooks/usePathMap';
|
import usePathMap from '@/hooks/usePathMap';
|
||||||
import { getLogList, getLogOptions, getLogUsers } from '@/api/modules/setting/log';
|
import {
|
||||||
|
getSystemLogList,
|
||||||
|
getSystemLogOptions,
|
||||||
|
getSystemLogUsers,
|
||||||
|
getOrgLogList,
|
||||||
|
getOrgLogOptions,
|
||||||
|
getOrgLogUsers,
|
||||||
|
} from '@/api/modules/setting/log';
|
||||||
import MsCascader from '@/components/business/ms-cascader/index.vue';
|
import MsCascader from '@/components/business/ms-cascader/index.vue';
|
||||||
import useTableStore from '@/store/modules/ms-table';
|
import useTableStore from '@/store/modules/ms-table';
|
||||||
import { TableKeyEnum } from '@/enums/tableEnum';
|
import { TableKeyEnum } from '@/enums/tableEnum';
|
||||||
|
@ -106,23 +113,51 @@
|
||||||
import MsButton from '@/components/pure/ms-button/index.vue';
|
import MsButton from '@/components/pure/ms-button/index.vue';
|
||||||
import { MENU_LEVEL } from '@/config/pathMap';
|
import { MENU_LEVEL } from '@/config/pathMap';
|
||||||
import MsSearchSelect from '@/components/business/ms-search-select/index';
|
import MsSearchSelect from '@/components/business/ms-search-select/index';
|
||||||
|
import useAppStore from '@/store/modules/app';
|
||||||
|
|
||||||
import type { CascaderOption, SelectOptionData } from '@arco-design/web-vue';
|
import type { CascaderOption, SelectOptionData } from '@arco-design/web-vue';
|
||||||
import type { MsTableColumn } from '@/components/pure/ms-table/type';
|
import type { MsTableColumn } from '@/components/pure/ms-table/type';
|
||||||
import type { LogItem } from '@/models/setting/log';
|
import type { LogItem, LogOptions, UserItem } from '@/models/setting/log';
|
||||||
|
import type { CommonList } from '@/models/common';
|
||||||
|
|
||||||
const props = defineProps<{
|
const props = defineProps<{
|
||||||
mode: (typeof MENU_LEVEL)[number]; // 日志展示模式,系统/组织/项目
|
mode: (typeof MENU_LEVEL)[number]; // 日志展示模式,系统/组织/项目
|
||||||
}>();
|
}>();
|
||||||
const { t } = useI18n();
|
const { t } = useI18n();
|
||||||
|
const appStore = useAppStore();
|
||||||
|
|
||||||
|
const requestFuncMap: Record<
|
||||||
|
(typeof MENU_LEVEL)[number],
|
||||||
|
{
|
||||||
|
listFunc: (data: any) => Promise<CommonList<LogItem>>;
|
||||||
|
optionsFunc: (id: any) => Promise<LogOptions>;
|
||||||
|
usersFunc: any;
|
||||||
|
}
|
||||||
|
> = {
|
||||||
|
[MENU_LEVEL[0]]: {
|
||||||
|
listFunc: getSystemLogList,
|
||||||
|
optionsFunc: getSystemLogOptions,
|
||||||
|
usersFunc: getSystemLogUsers,
|
||||||
|
},
|
||||||
|
[MENU_LEVEL[1]]: {
|
||||||
|
listFunc: getOrgLogList,
|
||||||
|
optionsFunc: getOrgLogOptions,
|
||||||
|
usersFunc: getOrgLogUsers,
|
||||||
|
},
|
||||||
|
[MENU_LEVEL[2]]: {
|
||||||
|
listFunc: getOrgLogList,
|
||||||
|
optionsFunc: getOrgLogOptions,
|
||||||
|
usersFunc: getOrgLogUsers,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
const operUser = ref(''); // 操作人
|
const operUser = ref(''); // 操作人
|
||||||
const userList = ref<SelectOptionData[]>([]); // 操作人列表
|
const userList = ref<SelectOptionData[]>([]); // 操作人列表
|
||||||
|
|
||||||
async function initUserList() {
|
async function initUserList() {
|
||||||
try {
|
try {
|
||||||
const res = await getLogUsers();
|
const res = await requestFuncMap[props.mode].usersFunc(appStore.currentOrgId);
|
||||||
userList.value = res.map((e) => ({
|
userList.value = res.map((e: UserItem) => ({
|
||||||
id: e.id,
|
id: e.id,
|
||||||
value: e.id,
|
value: e.id,
|
||||||
label: e.name,
|
label: e.name,
|
||||||
|
@ -133,8 +168,8 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const defaultLevelIndex = MENU_LEVEL.findIndex((e) => e === props.mode); // 默认操作范围级别索引,根据传入的 mode 确定
|
const defaultRange = props.mode === MENU_LEVEL[0] ? props.mode : MENU_LEVEL[2];
|
||||||
const operateRange = ref<(string | number | Record<string, any>)[]>([MENU_LEVEL[defaultLevelIndex]]); // 操作范围
|
const operateRange = ref<(string | number | Record<string, any>)[]>([defaultRange]); // 操作范围
|
||||||
const rangeOptions = ref<CascaderOption[]>( // 系统级别才展示系统级别选项
|
const rangeOptions = ref<CascaderOption[]>( // 系统级别才展示系统级别选项
|
||||||
props.mode === 'SYSTEM'
|
props.mode === 'SYSTEM'
|
||||||
? [
|
? [
|
||||||
|
@ -157,9 +192,9 @@
|
||||||
async function initRangeOptions() {
|
async function initRangeOptions() {
|
||||||
try {
|
try {
|
||||||
rangeLoading.value = true;
|
rangeLoading.value = true;
|
||||||
const res = await getLogOptions();
|
const res = await requestFuncMap[props.mode].optionsFunc(appStore.currentOrgId);
|
||||||
if (props.mode === 'SYSTEM' || props.mode === 'ORGANIZATION') {
|
if (props.mode === 'SYSTEM') {
|
||||||
// 系统和组织级别才展示,项目级别不展示
|
// 系统级别才展示,组织和项目级别不展示
|
||||||
rangeOptions.value.push({
|
rangeOptions.value.push({
|
||||||
value: {
|
value: {
|
||||||
level: 0,
|
level: 0,
|
||||||
|
@ -200,7 +235,7 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const level = ref<(typeof MENU_LEVEL)[number]>('SYSTEM'); // 操作范围级别,系统/组织/项目
|
const level = ref<(typeof MENU_LEVEL)[number]>(defaultRange); // 操作范围级别,系统/组织/项目
|
||||||
const type = ref(''); // 操作类型
|
const type = ref(''); // 操作类型
|
||||||
const _module = ref(''); // 操作对象
|
const _module = ref(''); // 操作对象
|
||||||
const content = ref(''); // 名称
|
const content = ref(''); // 名称
|
||||||
|
@ -375,12 +410,15 @@
|
||||||
];
|
];
|
||||||
const tableStore = useTableStore();
|
const tableStore = useTableStore();
|
||||||
tableStore.initColumn(TableKeyEnum.SYSTEM_LOG, columns, 'drawer');
|
tableStore.initColumn(TableKeyEnum.SYSTEM_LOG, columns, 'drawer');
|
||||||
const { propsRes, propsEvent, loadList, setLoadListParams, resetPagination } = useTable(getLogList, {
|
const { propsRes, propsEvent, loadList, setLoadListParams, resetPagination } = useTable(
|
||||||
tableKey: TableKeyEnum.SYSTEM_LOG,
|
requestFuncMap[props.mode].listFunc,
|
||||||
columns,
|
{
|
||||||
selectable: false,
|
tableKey: TableKeyEnum.SYSTEM_LOG,
|
||||||
showSelectAll: false,
|
columns,
|
||||||
});
|
selectable: false,
|
||||||
|
showSelectAll: false,
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
function searchLog() {
|
function searchLog() {
|
||||||
const ranges = operateRange.value.map((e) => e);
|
const ranges = operateRange.value.map((e) => e);
|
||||||
|
|
|
@ -163,7 +163,7 @@
|
||||||
import MsTableMoreAction from '@/components/pure/ms-table-more-action/index.vue';
|
import MsTableMoreAction from '@/components/pure/ms-table-more-action/index.vue';
|
||||||
import type { ActionsItem } from '@/components/pure/ms-table-more-action/types';
|
import type { ActionsItem } from '@/components/pure/ms-table-more-action/types';
|
||||||
import { getPluginList, deletePluginReq, updatePlugin, getScriptDetail } from '@/api/modules/setting/pluginManger';
|
import { getPluginList, deletePluginReq, updatePlugin, getScriptDetail } from '@/api/modules/setting/pluginManger';
|
||||||
import { getAllOrgList } from '@/api/modules/setting/orgnization';
|
import { getSystemOrgOption } from '@/api/modules/setting/system/organizationAndProject';
|
||||||
import MsButton from '@/components/pure/ms-button/index.vue';
|
import MsButton from '@/components/pure/ms-button/index.vue';
|
||||||
import UploadModel from './uploadModel.vue';
|
import UploadModel from './uploadModel.vue';
|
||||||
import UpdatePluginModal from './updatePluginModal.vue';
|
import UpdatePluginModal from './updatePluginModal.vue';
|
||||||
|
@ -385,7 +385,7 @@
|
||||||
const originizeList = ref<SelectOptionData>([]);
|
const originizeList = ref<SelectOptionData>([]);
|
||||||
onBeforeMount(async () => {
|
onBeforeMount(async () => {
|
||||||
loadData();
|
loadData();
|
||||||
originizeList.value = await getAllOrgList();
|
originizeList.value = await getSystemOrgOption();
|
||||||
});
|
});
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
|
|
@ -231,7 +231,8 @@
|
||||||
v-model:model-value="form.testResourceDTO.token"
|
v-model:model-value="form.testResourceDTO.token"
|
||||||
:placeholder="t('system.resourcePool.testResourceDTO.tokenPlaceholder')"
|
:placeholder="t('system.resourcePool.testResourceDTO.tokenPlaceholder')"
|
||||||
:max-length="250"
|
:max-length="250"
|
||||||
></a-input-password>
|
autocomplete="new-password"
|
||||||
|
/>
|
||||||
</a-form-item>
|
</a-form-item>
|
||||||
<a-form-item
|
<a-form-item
|
||||||
:label="t('system.resourcePool.testResourceDTO.nameSpaces')"
|
:label="t('system.resourcePool.testResourceDTO.nameSpaces')"
|
||||||
|
@ -345,7 +346,7 @@
|
||||||
import { downloadStringFile, sleep } from '@/utils';
|
import { downloadStringFile, sleep } from '@/utils';
|
||||||
import { scrollIntoView } from '@/utils/dom';
|
import { scrollIntoView } from '@/utils/dom';
|
||||||
import { addPool, getPoolInfo, updatePoolInfo } from '@/api/modules/setting/resourcePool';
|
import { addPool, getPoolInfo, updatePoolInfo } from '@/api/modules/setting/resourcePool';
|
||||||
import { getAllOrgList } from '@/api/modules/setting/orgnization';
|
import { getSystemOrgOption } from '@/api/modules/setting/system/organizationAndProject';
|
||||||
import useAppStore from '@/store/modules/app';
|
import useAppStore from '@/store/modules/app';
|
||||||
|
|
||||||
import type { MsBatchFormInstance, FormItemModel } from '@/components/business/ms-batch-form/types';
|
import type { MsBatchFormInstance, FormItemModel } from '@/components/business/ms-batch-form/types';
|
||||||
|
@ -404,7 +405,7 @@
|
||||||
const defaultGrid = 'http://selenium-hub:4444';
|
const defaultGrid = 'http://selenium-hub:4444';
|
||||||
|
|
||||||
onBeforeMount(async () => {
|
onBeforeMount(async () => {
|
||||||
orgOptions.value = await getAllOrgList();
|
orgOptions.value = await getSystemOrgOption();
|
||||||
});
|
});
|
||||||
|
|
||||||
async function initPoolInfo() {
|
async function initPoolInfo() {
|
||||||
|
|
Loading…
Reference in New Issue