1
0
mirror of https://github.com/1Panel-dev/1Panel.git synced 2025-01-19 16:29:17 +08:00

feat: host 模式应用增加提示 (#2792)

This commit is contained in:
zhengkunwang 2023-11-03 15:39:38 +08:00 committed by GitHub
parent 0d9fc1ccee
commit 5ff23f44d5
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
13 changed files with 48 additions and 15 deletions

View File

@ -31,6 +31,7 @@ type AppContainerConfig struct {
AllowPort bool `json:"allowPort"` AllowPort bool `json:"allowPort"`
EditCompose bool `json:"editCompose"` EditCompose bool `json:"editCompose"`
DockerCompose string `json:"dockerCompose"` DockerCompose string `json:"dockerCompose"`
HostMode bool `json:"hostMode"`
} }
type AppInstalledSearch struct { type AppInstalledSearch struct {

View File

@ -47,9 +47,10 @@ type AppInstalledCheck struct {
type AppDetailDTO struct { type AppDetailDTO struct {
model.AppDetail model.AppDetail
Enable bool `json:"enable"` Enable bool `json:"enable"`
Params interface{} `json:"params"` Params interface{} `json:"params"`
Image string `json:"image"` Image string `json:"image"`
HostMode bool `json:"hostMode"`
} }
type IgnoredApp struct { type IgnoredApp struct {

View File

@ -222,6 +222,8 @@ func (a AppService) GetAppDetail(appID uint, version, appType string) (response.
appDetailDTO.Params = paramMap appDetailDTO.Params = paramMap
} }
appDetailDTO.HostMode = isHostModel(appDetailDTO.DockerCompose)
app, err := appRepo.GetFirst(commonRepo.WithByID(detail.AppId)) app, err := appRepo.GetFirst(commonRepo.WithByID(detail.AppId))
if err != nil { if err != nil {
return appDetailDTO, err return appDetailDTO, err
@ -243,6 +245,7 @@ func (a AppService) GetAppDetailByID(id uint) (*response.AppDetailDTO, error) {
return nil, err return nil, err
} }
res.Params = paramMap res.Params = paramMap
res.HostMode = isHostModel(appDetail.DockerCompose)
return res, nil return res, nil
} }

View File

@ -675,6 +675,7 @@ func (a *AppInstallService) GetParams(id uint) (*response.AppConfig, error) {
config.ContainerName = install.ContainerName config.ContainerName = install.ContainerName
} }
res.AppContainerConfig = config res.AppContainerConfig = config
res.HostMode = isHostModel(install.DockerCompose)
return &res, nil return &res, nil
} }

View File

@ -1196,3 +1196,19 @@ func getAppCommonConfig(envs map[string]interface{}) request.AppContainerConfig
return config return config
} }
func isHostModel(dockerCompose string) bool {
composeMap := make(map[string]interface{})
_ = yaml.Unmarshal([]byte(dockerCompose), &composeMap)
services, serviceValid := composeMap["services"].(map[string]interface{})
if !serviceValid {
return false
}
for _, service := range services {
serviceValue := service.(map[string]interface{})
if value, ok := serviceValue["network_mode"]; ok && value == "host" {
return true
}
}
return false
}

View File

@ -44,6 +44,7 @@ export namespace App {
params: AppParams; params: AppParams;
dockerCompose: string; dockerCompose: string;
image: string; image: string;
hostMode?: boolean;
} }
export interface AppReq extends ReqPage { export interface AppReq extends ReqPage {
@ -201,6 +202,7 @@ export namespace App {
containerName: string; containerName: string;
allowPort: boolean; allowPort: boolean;
dockerCompose: string; dockerCompose: string;
hostMode?: boolean;
} }
export interface IgnoredApp { export interface IgnoredApp {

View File

@ -1,10 +1,5 @@
import router from '@/routers'; import router from '@/routers';
export function canEditPort(appKey: string): boolean {
const apps = ['openresty', 'php', 'frpc', 'frps', 'ddns-go', 'home-assistant'];
return !apps.includes(appKey);
}
export function toFolder(folder: string) { export function toFolder(folder: string) {
router.push({ path: '/hosts/files', query: { path: folder } }); router.push({ path: '/hosts/files', query: { path: folder } });
} }

View File

@ -1413,6 +1413,8 @@ const message = {
downloadLogHelper2: downloadLogHelper2:
'The latest {1} logs of {0} application are about to be downloaded. Do you want to continue? ', 'The latest {1} logs of {0} application are about to be downloaded. Do you want to continue? ',
syncAllAppHelper: 'All applications are about to be synchronized. Do you want to continue? ', syncAllAppHelper: 'All applications are about to be synchronized. Do you want to continue? ',
hostModeHelper:
'The current application network mode is host mode. If you need to open the port, please open it manually on the firewall page.',
}, },
website: { website: {
website: 'Website', website: 'Website',

View File

@ -1338,6 +1338,7 @@ const message = {
downloadLogHelper1: '即將下載 {0} 套用所有日誌是否繼續 ', downloadLogHelper1: '即將下載 {0} 套用所有日誌是否繼續 ',
downloadLogHelper2: '即將下載 {0} 應用最近 {1} 條日誌是否繼續 ', downloadLogHelper2: '即將下載 {0} 應用最近 {1} 條日誌是否繼續 ',
syncAllAppHelper: '即將同步所有應用是否繼續 ', syncAllAppHelper: '即將同步所有應用是否繼續 ',
hostModeHelper: '目前應用網路模式為 host 模式如需放開端口請在防火牆頁面手動放開',
}, },
website: { website: {
website: '網站', website: '網站',

View File

@ -1338,6 +1338,7 @@ const message = {
downloadLogHelper1: '即将下载 {0} 应用所有日志是否继续', downloadLogHelper1: '即将下载 {0} 应用所有日志是否继续',
downloadLogHelper2: '即将下载 {0} 应用最近 {1} 条日志是否继续', downloadLogHelper2: '即将下载 {0} 应用最近 {1} 条日志是否继续',
syncAllAppHelper: '即将同步所有应用是否继续', syncAllAppHelper: '即将同步所有应用是否继续',
hostModeHelper: '当前应用网络模式为 host 模式如需放开端口请在防火墙页面手动放开',
}, },
website: { website: {
website: '网站', website: '网站',

View File

@ -16,7 +16,14 @@
class="common-prompt" class="common-prompt"
:closable="false" :closable="false"
type="error" type="error"
v-if="canEditPort(installData.app.key)" v-if="!isHostMode"
/>
<el-alert
:title="$t('app.hostModeHelper')"
class="common-prompt"
:closable="false"
type="warning"
v-else
/> />
<el-form <el-form
@submit.prevent @submit.prevent
@ -92,7 +99,7 @@
{{ $t('container.limitHelper', [limits.memory]) }}{{ req.memoryUnit }}B {{ $t('container.limitHelper', [limits.memory]) }}{{ req.memoryUnit }}B
</span> </span>
</el-form-item> </el-form-item>
<el-form-item prop="allowPort" v-if="canEditPort(installData.app.key)"> <el-form-item prop="allowPort" v-if="!isHostMode">
<el-checkbox v-model="req.allowPort" :label="$t('app.allowPort')" size="large" /> <el-checkbox v-model="req.allowPort" :label="$t('app.allowPort')" size="large" />
<span class="input-help">{{ $t('app.allowPortHelper') }}</span> <span class="input-help">{{ $t('app.allowPortHelper') }}</span>
</el-form-item> </el-form-item>
@ -135,7 +142,6 @@
import { App } from '@/api/interface/app'; import { App } from '@/api/interface/app';
import { GetApp, GetAppDetail, InstallApp } from '@/api/modules/app'; import { GetApp, GetAppDetail, InstallApp } from '@/api/modules/app';
import { Rules, checkNumberRange } from '@/global/form-rules'; import { Rules, checkNumberRange } from '@/global/form-rules';
import { canEditPort } from '@/global/business';
import { FormInstance, FormRules } from 'element-plus'; import { FormInstance, FormRules } from 'element-plus';
import { onMounted, reactive, ref } from 'vue'; import { onMounted, reactive, ref } from 'vue';
import { useRouter } from 'vue-router'; import { useRouter } from 'vue-router';
@ -202,6 +208,7 @@ const handleClose = () => {
} }
}; };
const paramKey = ref(1); const paramKey = ref(1);
const isHostMode = ref(false);
const changeUnit = () => { const changeUnit = () => {
if (req.memoryUnit == 'M') { if (req.memoryUnit == 'M') {
@ -216,6 +223,7 @@ const resetForm = () => {
paramForm.value.clearValidate(); paramForm.value.clearValidate();
paramForm.value.resetFields(); paramForm.value.resetFields();
} }
isHostMode.value = false;
Object.assign(req, initData()); Object.assign(req, initData());
}; };
@ -245,6 +253,8 @@ const getAppDetail = async (version: string) => {
const res = await GetAppDetail(installData.value.app.id, version, 'app'); const res = await GetAppDetail(installData.value.app.id, version, 'app');
req.appDetailId = res.data.id; req.appDetailId = res.data.id;
req.dockerCompose = res.data.dockerCompose; req.dockerCompose = res.data.dockerCompose;
isHostMode.value = res.data.hostMode;
console.log(res.data);
installData.value.params = res.data.params; installData.value.params = res.data.params;
paramKey.value++; paramKey.value++;
} catch (error) { } catch (error) {
@ -269,7 +279,7 @@ const submit = async (formEl: FormInstance | undefined) => {
if (req.memoryLimit < 0) { if (req.memoryLimit < 0) {
req.memoryLimit = 0; req.memoryLimit = 0;
} }
if (canEditPort(installData.value.app.key) && !req.allowPort) { if (!isHostMode.value && !req.allowPort) {
ElMessageBox.confirm(i18n.global.t('app.installWarn'), i18n.global.t('app.checkTitle'), { ElMessageBox.confirm(i18n.global.t('app.installWarn'), i18n.global.t('app.checkTitle'), {
confirmButtonText: i18n.global.t('commons.button.confirm'), confirmButtonText: i18n.global.t('commons.button.confirm'),
cancelButtonText: i18n.global.t('commons.button.cancel'), cancelButtonText: i18n.global.t('commons.button.cancel'),

View File

@ -75,7 +75,7 @@
</el-input> </el-input>
<span class="input-help">{{ $t('container.limitHelper') }}</span> <span class="input-help">{{ $t('container.limitHelper') }}</span>
</el-form-item> </el-form-item>
<el-form-item prop="allowPort" v-if="canEditPort(paramData.app.key)"> <el-form-item prop="allowPort" v-if="!paramModel.isHostMode">
<el-checkbox v-model="paramModel.allowPort" :label="$t('app.allowPort')" size="large" /> <el-checkbox v-model="paramModel.allowPort" :label="$t('app.allowPort')" size="large" />
<span class="input-help">{{ $t('app.allowPortHelper') }}</span> <span class="input-help">{{ $t('app.allowPortHelper') }}</span>
</el-form-item> </el-form-item>
@ -122,7 +122,6 @@ import { FormInstance } from 'element-plus';
import { Rules, checkNumberRange } from '@/global/form-rules'; import { Rules, checkNumberRange } from '@/global/form-rules';
import { MsgSuccess } from '@/utils/message'; import { MsgSuccess } from '@/utils/message';
import i18n from '@/lang'; import i18n from '@/lang';
import { canEditPort } from '@/global/business';
import { Codemirror } from 'vue-codemirror'; import { Codemirror } from 'vue-codemirror';
import { javascript } from '@codemirror/lang-javascript'; import { javascript } from '@codemirror/lang-javascript';
import { oneDark } from '@codemirror/theme-one-dark'; import { oneDark } from '@codemirror/theme-one-dark';
@ -215,6 +214,7 @@ const get = async () => {
paramModel.value.containerName = res.data.containerName; paramModel.value.containerName = res.data.containerName;
paramModel.value.advanced = false; paramModel.value.advanced = false;
paramModel.value.dockerCompose = res.data.dockerCompose; paramModel.value.dockerCompose = res.data.dockerCompose;
paramModel.value.isHostMode = res.data.hostMode;
} catch (error) { } catch (error) {
} finally { } finally {
loading.value = false; loading.value = false;

View File

@ -259,7 +259,7 @@
</el-input> </el-input>
<span class="input-help">{{ $t('container.limitHelper') }}</span> <span class="input-help">{{ $t('container.limitHelper') }}</span>
</el-form-item> </el-form-item>
<el-form-item prop="allowPort"> <el-form-item prop="allowPort" v-if="website.type === 'deployment'">
<el-checkbox <el-checkbox
v-model="website.appinstall.allowPort" v-model="website.appinstall.allowPort"
:label="$t('app.allowPort')" :label="$t('app.allowPort')"