mirror of
https://github.com/kuaifan/dootask.git
synced 2026-04-23 02:08:51 +00:00
- 登录页放宽校验:登录模式允许任意账号格式,注册模式仍强制邮箱 - 登录属性新增 userPrincipalName 选项(AD 常用且通常是邮箱格式) - LDAP 用户缺少邮箱属性时返回明确错误提示,替代误导性的"请输入正确的邮箱地址" - LDAP 登录合并已有本地账号时记录 info 日志,便于审计 Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
144 lines
5.6 KiB
Vue
144 lines
5.6 KiB
Vue
<template>
|
||
<div class="setting-component-item">
|
||
<Form
|
||
ref="formData"
|
||
:model="formData"
|
||
:rules="ruleData"
|
||
v-bind="formOptions"
|
||
@submit.native.prevent>
|
||
<div class="block-setting-box">
|
||
<h3>LDAP</h3>
|
||
<div class="form-box">
|
||
<FormItem :label="$L('启用 LDAP 认证')" prop="ldap_open">
|
||
<RadioGroup v-model="formData.ldap_open">
|
||
<Radio label="open">{{ $L('开启') }}</Radio>
|
||
<Radio label="close">{{ $L('关闭') }}</Radio>
|
||
</RadioGroup>
|
||
<div class="form-tip">{{$L('开启后可以直接使用 LDAP 帐号密码登录')}}</div>
|
||
</FormItem>
|
||
<template v-if="formData.ldap_open === 'open'">
|
||
<FormItem :label="$L('LDAP 地址')" prop="ldap_host">
|
||
<Input v-model="formData.ldap_host"/>
|
||
<div class="form-tip">{{$L('例如')}}: 192.168.1.200、www.ldap.com</div>
|
||
</FormItem>
|
||
<FormItem :label="$L('LDAP 端口')" prop="ldap_port">
|
||
<Input v-model="formData.ldap_port" type="number" :placeholder="`${$L('默认')}: 389`"/>
|
||
</FormItem>
|
||
<FormItem label="Base DN" prop="ldap_base_dn">
|
||
<Input v-model="formData.ldap_base_dn"/>
|
||
</FormItem>
|
||
<FormItem label="User DN" prop="ldap_user_dn">
|
||
<Input v-model="formData.ldap_user_dn"/>
|
||
</FormItem>
|
||
<FormItem :label="$L('密码')" prop="ldap_password">
|
||
<Input v-model="formData.ldap_password" type="password"/>
|
||
</FormItem>
|
||
<FormItem :label="$L('登录属性')" prop="ldap_login_attr">
|
||
<RadioGroup v-model="formData.ldap_login_attr">
|
||
<Radio label="cn">cn</Radio>
|
||
<Radio label="uid">uid</Radio>
|
||
<Radio label="mail">mail</Radio>
|
||
<Radio label="sAMAccountName">sAMAccountName</Radio>
|
||
<Radio label="userPrincipalName">userPrincipalName</Radio>
|
||
</RadioGroup>
|
||
<div class="form-tip">{{$L('用于匹配登录用户名的 LDAP 属性,Active Directory 请选择 sAMAccountName')}}</div>
|
||
</FormItem>
|
||
<FormItem :label="$L('同步本地帐号')" prop="ldap_sync_local">
|
||
<RadioGroup v-model="formData.ldap_sync_local">
|
||
<Radio label="open">{{ $L('开启') }}</Radio>
|
||
<Radio label="close">{{ $L('关闭') }}</Radio>
|
||
</RadioGroup>
|
||
<div class="form-tip">{{$L('开启同步本地帐号登录后将同步到 LDAP 服务器')}}</div>
|
||
</FormItem>
|
||
<FormItem>
|
||
<Button :loading="testLoad" @click="checkTest">{{ $L('测试链接') }}</Button>
|
||
</FormItem>
|
||
</template>
|
||
</div>
|
||
</div>
|
||
</Form>
|
||
<div class="setting-footer">
|
||
<Button :loading="loadIng > 0" type="primary" @click="submitForm">{{ $L('提交') }}</Button>
|
||
<Button :loading="loadIng > 0" @click="resetForm" style="margin-left: 8px">{{ $L('重置') }}</Button>
|
||
</div>
|
||
</div>
|
||
</template>
|
||
|
||
<script>
|
||
import {mapState} from "vuex";
|
||
|
||
export default {
|
||
name: "SystemThirdAccess",
|
||
data() {
|
||
return {
|
||
loadIng: 0,
|
||
formData: {
|
||
|
||
},
|
||
ruleData: {},
|
||
|
||
testLoad: false,
|
||
}
|
||
},
|
||
|
||
mounted() {
|
||
this.systemSetting();
|
||
},
|
||
|
||
computed: {
|
||
...mapState(['formOptions']),
|
||
},
|
||
|
||
methods: {
|
||
submitForm() {
|
||
this.$refs.formData.validate((valid) => {
|
||
if (valid) {
|
||
this.systemSetting(true);
|
||
}
|
||
})
|
||
},
|
||
|
||
resetForm() {
|
||
this.formData = $A.cloneJSON(this.formDatum_bak);
|
||
},
|
||
|
||
systemSetting(save) {
|
||
this.loadIng++;
|
||
this.$store.dispatch("call", {
|
||
url: 'system/setting/thirdaccess?type=' + (save ? 'save' : 'all'),
|
||
data: this.formData,
|
||
}).then(({data}) => {
|
||
if (save) {
|
||
$A.messageSuccess('修改成功');
|
||
}
|
||
this.formData = data;
|
||
this.formDatum_bak = $A.cloneJSON(this.formData);
|
||
}).catch(({msg}) => {
|
||
if (save) {
|
||
$A.modalError(msg);
|
||
}
|
||
}).finally(_ => {
|
||
this.loadIng--;
|
||
});
|
||
},
|
||
|
||
checkTest() {
|
||
if (this.testLoad) {
|
||
return
|
||
}
|
||
this.testLoad = true
|
||
this.$store.dispatch("call", {
|
||
url: 'system/setting/thirdaccess?type=testldap',
|
||
data: this.formData,
|
||
}).then(({msg}) => {
|
||
$A.messageSuccess(msg);
|
||
}).catch(({msg}) => {
|
||
$A.modalError(msg);
|
||
}).finally(_ => {
|
||
this.testLoad = false;
|
||
});
|
||
}
|
||
}
|
||
}
|
||
</script>
|