From 20a47afb8c704cd69a1069c032725c6620787abc Mon Sep 17 00:00:00 2001
From: ssongliu <73214554+ssongliu@users.noreply.github.com>
Date: Sun, 6 Aug 2023 21:02:00 +0800
Subject: [PATCH] =?UTF-8?q?fix:=20mysql=20=E6=95=B0=E6=8D=AE=E5=BA=93?=
=?UTF-8?q?=E8=BF=9E=E6=8E=A5=E4=BF=A1=E6=81=AF=E6=A0=B7=E5=BC=8F=E8=B0=83?=
=?UTF-8?q?=E6=95=B4=20(#1857)?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
backend/app/repo/databse_mysql.go | 6 ++--
backend/app/service/app_utils.go | 2 +-
.../src/views/database/mysql/conn/index.vue | 31 ++++++++++++-------
frontend/src/views/database/mysql/index.vue | 2 +-
4 files changed, 25 insertions(+), 16 deletions(-)
diff --git a/backend/app/repo/databse_mysql.go b/backend/app/repo/databse_mysql.go
index b0e3e2b0e..fcbb4cc1e 100644
--- a/backend/app/repo/databse_mysql.go
+++ b/backend/app/repo/databse_mysql.go
@@ -20,7 +20,7 @@ type IMysqlRepo interface {
Delete(ctx context.Context, opts ...DBOption) error
Update(id uint, vars map[string]interface{}) error
UpdateDatabaseInfo(id uint, vars map[string]interface{}) error
- DeleteAll(ctx context.Context) error
+ DeleteLocal(ctx context.Context) error
}
func NewIMysqlRepo() IMysqlRepo {
@@ -67,8 +67,8 @@ func (u *MysqlRepo) Delete(ctx context.Context, opts ...DBOption) error {
return getTx(ctx, opts...).Delete(&model.DatabaseMysql{}).Error
}
-func (u *MysqlRepo) DeleteAll(ctx context.Context) error {
- return getTx(ctx).Where("1 = 1").Delete(&model.DatabaseMysql{}).Error
+func (u *MysqlRepo) DeleteLocal(ctx context.Context) error {
+ return getTx(ctx).Where("`from` = ?", "local").Delete(&model.DatabaseMysql{}).Error
}
func (u *MysqlRepo) Update(id uint, vars map[string]interface{}) error {
diff --git a/backend/app/service/app_utils.go b/backend/app/service/app_utils.go
index 46c569d52..1e274bc5e 100644
--- a/backend/app/service/app_utils.go
+++ b/backend/app/service/app_utils.go
@@ -200,7 +200,7 @@ func deleteAppInstall(install model.AppInstall, deleteBackup bool, forceDelete b
_ = backupRepo.DeleteRecord(ctx, commonRepo.WithByType("app"), commonRepo.WithByName(install.App.Key), backupRepo.WithByDetailName(install.Name))
_ = backupRepo.DeleteRecord(ctx, commonRepo.WithByType(install.App.Key))
if install.App.Key == constant.AppMysql {
- _ = mysqlRepo.DeleteAll(ctx)
+ _ = mysqlRepo.DeleteLocal(ctx)
}
uploadDir := path.Join(global.CONF.System.BaseDir, fmt.Sprintf("1panel/uploads/app/%s/%s", install.App.Key, install.Name))
if _, err := os.Stat(uploadDir); err == nil {
diff --git a/frontend/src/views/database/mysql/conn/index.vue b/frontend/src/views/database/mysql/conn/index.vue
index c2b86010b..368a738d4 100644
--- a/frontend/src/views/database/mysql/conn/index.vue
+++ b/frontend/src/views/database/mysql/conn/index.vue
@@ -16,7 +16,7 @@
- {{ $t('database.localIP') + ':' + form.port }}
+ {{ form.systemIP + ':' + form.port }}
{{ $t('database.remoteConnHelper2') }}
@@ -81,6 +81,7 @@ import { GetAppConnInfo } from '@/api/modules/app';
import DrawerHeader from '@/components/drawer-header/index.vue';
import { MsgError, MsgSuccess } from '@/utils/message';
import { getRandomStr } from '@/utils/util';
+import { getSettingInfo } from '@/api/modules/setting';
import useClipboard from 'vue-clipboard3';
const { toClipboard } = useClipboard();
@@ -88,6 +89,7 @@ const loading = ref(false);
const dialogVisiable = ref(false);
const form = reactive({
+ systemIP: '',
password: '',
serviceName: '',
privilege: false,
@@ -112,11 +114,10 @@ interface DialogProps {
const acceptParams = (param: DialogProps): void => {
form.password = '';
form.from = param.from;
- if (form.from !== 'local') {
- loadRemoteInfo();
+ if (form.from === 'local') {
+ loadAccess();
}
loadPassword();
- loadAccess();
dialogVisiable.value = true;
};
@@ -142,18 +143,26 @@ const loadAccess = async () => {
form.privilege = res.data;
};
-const loadRemoteInfo = async () => {
- const res = await getRemoteDB(form.from);
- form.remoteIP = res.data.address;
- form.username = res.data.username;
- form.password = res.data.password;
+const loadSystemIP = async () => {
+ const res = await getSettingInfo();
+ form.systemIP = res.data.systemIP || i18n.global.t('database.localIP');
};
const loadPassword = async () => {
- const res = await GetAppConnInfo('mysql');
+ if (form.from === 'local') {
+ const res = await GetAppConnInfo('mysql');
+ form.password = res.data.password || '';
+ form.port = res.data.port || 3306;
+ form.serviceName = res.data.serviceName || '';
+ loadSystemIP();
+ return;
+ }
+ const res = await getRemoteDB(form.from);
form.password = res.data.password || '';
form.port = res.data.port || 3306;
- form.serviceName = res.data.serviceName || '';
+ form.username = res.data.username;
+ form.password = res.data.password;
+ form.remoteIP = res.data.address;
};
const onSubmit = async () => {
diff --git a/frontend/src/views/database/mysql/index.vue b/frontend/src/views/database/mysql/index.vue
index 1d8080e99..b1ae7d119 100644
--- a/frontend/src/views/database/mysql/index.vue
+++ b/frontend/src/views/database/mysql/index.vue
@@ -38,7 +38,7 @@
>
{{ $t('database.create') }}
-
+
{{ $t('database.databaseConnInfo') }}