feat: 修改证书交互逻辑

This commit is contained in:
zhengkunwang223 2022-12-28 17:21:15 +08:00 committed by zhengkunwang223
parent e2403c9869
commit 4000f2db3d
4 changed files with 148 additions and 105 deletions

View file

@ -5,7 +5,7 @@ services:
container_name: 1panel_minio container_name: 1panel_minio
ports: ports:
- ${PANEL_APP_PORT_HTTP}:9000 - ${PANEL_APP_PORT_HTTP}:9000
- "9001:9001" - ${API_ROOT}:9001
restart: always restart: always
command: server /data --console-address ":9001" command: server /data --console-address ":9001"
environment: environment:

View file

@ -490,7 +490,22 @@ func (w WebsiteService) OpWebsiteHTTPS(ctx context.Context, req request.WebsiteH
websiteSSL model.WebsiteSSL websiteSSL model.WebsiteSSL
) )
res.Enable = req.Enable res.Enable = req.Enable
if req.Enable {
if !req.Enable {
website.Protocol = constant.ProtocolHTTP
website.WebsiteSSLID = 0
if err := deleteListenAndServerName(website, []int{443}, []string{}); err != nil {
return response.WebsiteHTTPS{}, err
}
if err := deleteNginxConfig(constant.NginxScopeServer, getKeysFromStaticFile(dto.SSL), &website); err != nil {
return response.WebsiteHTTPS{}, err
}
if err := websiteRepo.Save(ctx, &website); err != nil {
return response.WebsiteHTTPS{}, err
}
return res, nil
}
if req.Type == constant.SSLExisted { if req.Type == constant.SSLExisted {
websiteSSL, err = websiteSSLRepo.GetFirst(commonRepo.WithByID(req.WebsiteSSLID)) websiteSSL, err = websiteSSLRepo.GetFirst(commonRepo.WithByID(req.WebsiteSSLID))
if err != nil { if err != nil {
@ -533,16 +548,6 @@ func (w WebsiteService) OpWebsiteHTTPS(ctx context.Context, req request.WebsiteH
return response.WebsiteHTTPS{}, err return response.WebsiteHTTPS{}, err
} }
website.HttpConfig = req.HttpConfig website.HttpConfig = req.HttpConfig
} else {
website.Protocol = constant.ProtocolHTTP
website.WebsiteSSLID = 0
if err := deleteListenAndServerName(website, []int{443}, []string{}); err != nil {
return response.WebsiteHTTPS{}, err
}
if err := deleteNginxConfig(constant.NginxScopeServer, getKeysFromStaticFile(dto.SSL), &website); err != nil {
return response.WebsiteHTTPS{}, err
}
}
if websiteSSL.ID == 0 { if websiteSSL.ID == 0 {
if err := websiteSSLRepo.Create(ctx, &websiteSSL); err != nil { if err := websiteSSLRepo.Create(ctx, &websiteSSL); err != nil {

View file

@ -925,12 +925,15 @@ export default {
manualSSL: '手动导入证书', manualSSL: '手动导入证书',
select: '选择', select: '选择',
selectSSL: '选择证书', selectSSL: '选择证书',
privateKey: '密钥代码(pem格式)', privateKey: '密钥(KEY)',
certificate: '密钥代码(pem格式)', certificate: '证书(PEM格式)',
HTTPConfig: 'HTTP选项', HTTPConfig: 'HTTP选项',
HTTPSOnly: '禁止HTTTP', HTTPSOnly: '禁止HTTTP',
HTTPToHTTPS: '访问HTTP自动跳转到HTTPS', HTTPToHTTPS: '访问HTTP自动跳转到HTTPS',
HTTPAlso: 'HTTP可直接访问', HTTPAlso: 'HTTP可直接访问',
sslConfig: 'SSL 选项',
disbaleHTTTPS: '禁用 HTTPS',
disbaleHTTTPSHelper: '禁用 HTTPS会删除证书相关配置是否继续',
}, },
nginx: { nginx: {
serverNamesHashBucketSizeHelper: '服务器名字的hash表大小', serverNamesHashBucketSizeHelper: '服务器名字的hash表大小',

View file

@ -9,11 +9,10 @@
:rules="rules" :rules="rules"
:loading="loading" :loading="loading"
> >
<el-form-item prop="enable"> <el-form-item prop="enable" :label="$t('website.enableHTTPS')">
<el-checkbox v-model="form.enable"> <el-switch v-model="form.enable" @change="changeEnable"></el-switch>
{{ $t('website.enableHTTPS') }}
</el-checkbox>
</el-form-item> </el-form-item>
<div v-if="form.enable">
<el-form-item :label="$t('website.HTTPConfig')" prop="httpConfig"> <el-form-item :label="$t('website.HTTPConfig')" prop="httpConfig">
<el-select v-model="form.httpConfig" style="width: 240px"> <el-select v-model="form.httpConfig" style="width: 240px">
<el-option :label="$t('website.HTTPToHTTPS')" :value="'HTTPToHTTPS'"></el-option> <el-option :label="$t('website.HTTPToHTTPS')" :value="'HTTPToHTTPS'"></el-option>
@ -21,14 +20,19 @@
<el-option :label="$t('website.HTTPSOnly')" :value="'HTTPSOnly'"></el-option> <el-option :label="$t('website.HTTPSOnly')" :value="'HTTPSOnly'"></el-option>
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item :label="$t('website.ssl')" prop="type"> <el-form-item :label="$t('website.sslConfig')" prop="type">
<el-select v-model="form.type" @change="changeType(form.type)"> <el-select v-model="form.type" @change="changeType(form.type)">
<el-option :label="$t('website.oldSSL')" :value="'existed'"></el-option> <el-option :label="$t('website.oldSSL')" :value="'existed'"></el-option>
<el-option :label="$t('website.manualSSL')" :value="'manual'"></el-option> <el-option :label="$t('website.manualSSL')" :value="'manual'"></el-option>
<!-- <el-option :label="'自动生成证书'" :value="'auto'"></el-option> --> <!-- <el-option :label="'自动生成证书'" :value="'auto'"></el-option> -->
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item :label="$t('website.select')" prop="websiteSSLId" v-if="form.type === 'existed'"> <el-form-item
:label="$t('website.ssl')"
prop="websiteSSLId"
v-if="form.type === 'existed'"
:hide-required-asterisk="true"
>
<el-select <el-select
v-model="form.websiteSSLId" v-model="form.websiteSSLId"
:placeholder="$t('website.selectSSL')" :placeholder="$t('website.selectSSL')"
@ -68,6 +72,7 @@
{{ $t('commons.button.save') }} {{ $t('commons.button.save') }}
</el-button> </el-button>
</el-form-item> </el-form-item>
</div>
</el-form> </el-form>
</el-col> </el-col>
</el-row> </el-row>
@ -75,7 +80,7 @@
<script lang="ts" setup> <script lang="ts" setup>
import { Website } from '@/api/interface/website'; import { Website } from '@/api/interface/website';
import { GetHTTPSConfig, ListSSL, UpdateHTTPSConfig } from '@/api/modules/website'; import { GetHTTPSConfig, ListSSL, UpdateHTTPSConfig } from '@/api/modules/website';
import { ElMessage, FormInstance } from 'element-plus'; import { ElMessage, ElMessageBox, FormInstance } from 'element-plus';
import { computed, onMounted, reactive, ref } from 'vue'; import { computed, onMounted, reactive, ref } from 'vue';
import { dateFromat } from '@/utils/util'; import { dateFromat } from '@/utils/util';
import i18n from '@/lang'; import i18n from '@/lang';
@ -110,6 +115,7 @@ let rules = ref({
websiteSSLId: [Rules.requiredSelect], websiteSSLId: [Rules.requiredSelect],
httpConfig: [Rules.requiredSelect], httpConfig: [Rules.requiredSelect],
}); });
const resData = ref();
const listSSL = () => { const listSSL = () => {
ListSSL({}).then((res) => { ListSSL({}).then((res) => {
@ -134,11 +140,13 @@ const changeType = (type: string) => {
const get = () => { const get = () => {
GetHTTPSConfig(id.value).then((res) => { GetHTTPSConfig(id.value).then((res) => {
console.log(res);
if (res.data) { if (res.data) {
resData.value = res.data;
form.enable = res.data.enable; form.enable = res.data.enable;
if (res.data.httpConfig != '') {
form.httpConfig = res.data.httpConfig; form.httpConfig = res.data.httpConfig;
} }
}
if (res.data?.SSL && res.data?.SSL.id > 0) { if (res.data?.SSL && res.data?.SSL.id > 0) {
form.websiteSSLId = res.data.SSL.id; form.websiteSSLId = res.data.SSL.id;
websiteSSL.value = res.data.SSL; websiteSSL.value = res.data.SSL;
@ -164,6 +172,33 @@ const submit = async (formEl: FormInstance | undefined) => {
}); });
}; };
const changeEnable = (enable: boolean) => {
if (resData.value.enable && !enable) {
ElMessageBox.confirm(i18n.global.t('website.disbaleHTTTPSHelper'), i18n.global.t('website.disbaleHTTTPS'), {
confirmButtonText: i18n.global.t('commons.button.confirm'),
cancelButtonText: i18n.global.t('commons.button.cancel'),
type: 'error',
closeOnClickModal: false,
beforeClose: async (action, instance, done) => {
if (action !== 'confirm') {
form.enable = true;
done();
} else {
instance.confirmButtonLoading = true;
instance.cancelButtonLoading = true;
form.enable = false;
form.websiteId = id.value;
UpdateHTTPSConfig(form).then(() => {
done();
ElMessage.success(i18n.global.t('commons.msg.operationSuccess'));
get();
});
}
},
}).then(() => {});
}
};
onMounted(() => { onMounted(() => {
get(); get();
}); });