Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
D
dataease
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
图表
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
zhu
dataease
Commits
626f9793
提交
626f9793
authored
5月 25, 2022
作者:
taojinlong
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix: 优化驱动管理
上级
e0b380f1
隐藏空白字符变更
内嵌
并排
正在显示
13 个修改的文件
包含
65 行增加
和
21 行删除
+65
-21
DriverMgmController.java
...o/dataease/controller/datasource/DriverMgmController.java
+1
-1
JdbcProvider.java
...in/java/io/dataease/provider/datasource/JdbcProvider.java
+3
-0
DatasourceService.java
...ava/io/dataease/service/datasource/DatasourceService.java
+6
-0
DriverService.java
...in/java/io/dataease/service/datasource/DriverService.java
+16
-5
messages_en_US.properties
backend/src/main/resources/i18n/messages_en_US.properties
+3
-0
messages_zh_CN.properties
backend/src/main/resources/i18n/messages_zh_CN.properties
+2
-0
messages_zh_TW.properties
backend/src/main/resources/i18n/messages_zh_TW.properties
+3
-0
en.js
frontend/src/lang/en.js
+2
-1
tw.js
frontend/src/lang/tw.js
+2
-1
zh.js
frontend/src/lang/zh.js
+2
-1
DriverForm.vue
frontend/src/views/system/datasource/DriverForm.vue
+13
-7
DsForm.vue
frontend/src/views/system/datasource/DsForm.vue
+3
-3
DsTree.vue
frontend/src/views/system/datasource/DsTree.vue
+9
-2
没有找到文件。
backend/src/main/java/io/dataease/controller/datasource/DriverMgmController.java
浏览文件 @
626f9793
...
@@ -45,7 +45,7 @@ public class DriverMgmController {
...
@@ -45,7 +45,7 @@ public class DriverMgmController {
value
=
"id"
value
=
"id"
)
)
public
void
delete
(
@RequestBody
DeDriver
deDriver
)
throws
Exception
{
public
void
delete
(
@RequestBody
DeDriver
deDriver
)
throws
Exception
{
driverService
.
delete
(
deDriver
.
getId
()
);
driverService
.
delete
(
deDriver
);
}
}
@RequiresPermissions
(
"datasource:read"
)
@RequiresPermissions
(
"datasource:read"
)
...
...
backend/src/main/java/io/dataease/provider/datasource/JdbcProvider.java
浏览文件 @
626f9793
...
@@ -449,6 +449,9 @@ public class JdbcProvider extends DefaultJdbcProvider {
...
@@ -449,6 +449,9 @@ public class JdbcProvider extends DefaultJdbcProvider {
driverClassName
=
defaultDriver
;
driverClassName
=
defaultDriver
;
jdbcClassLoader
=
extendedJdbcClassLoader
;
jdbcClassLoader
=
extendedJdbcClassLoader
;
}
else
{
}
else
{
if
(
deDriver
==
null
){
deDriver
=
deDriverMapper
.
selectByPrimaryKey
(
customDriver
);
}
driverClassName
=
deDriver
.
getDriverClass
();
driverClassName
=
deDriver
.
getDriverClass
();
jdbcClassLoader
=
getCustomJdbcClassLoader
(
deDriver
);
jdbcClassLoader
=
getCustomJdbcClassLoader
(
deDriver
);
}
}
...
...
backend/src/main/java/io/dataease/service/datasource/DatasourceService.java
浏览文件 @
626f9793
...
@@ -406,6 +406,12 @@ public class DatasourceService {
...
@@ -406,6 +406,12 @@ public class DatasourceService {
return
ApiProvider
.
checkApiDefinition
(
apiDefinition
,
response
);
return
ApiProvider
.
checkApiDefinition
(
apiDefinition
,
response
);
}
}
public
List
<
Datasource
>
listByType
(
String
type
){
DatasourceExample
example
=
new
DatasourceExample
();
example
.
createCriteria
().
andTypeEqualTo
(
type
);
return
datasourceMapper
.
selectByExampleWithBLOBs
(
example
);
}
private
void
checkAndUpdateDatasourceStatus
(
Datasource
datasource
){
private
void
checkAndUpdateDatasourceStatus
(
Datasource
datasource
){
try
{
try
{
Provider
datasourceProvider
=
ProviderFactory
.
getProvider
(
datasource
.
getType
());
Provider
datasourceProvider
=
ProviderFactory
.
getProvider
(
datasource
.
getType
());
...
...
backend/src/main/java/io/dataease/service/datasource/DriverService.java
浏览文件 @
626f9793
package
io
.
dataease
.
service
.
datasource
;
package
io
.
dataease
.
service
.
datasource
;
import
com.google.gson.Gson
;
import
io.dataease.commons.utils.BeanUtils
;
import
io.dataease.commons.utils.BeanUtils
;
import
io.dataease.commons.utils.DeFileUtils
;
import
io.dataease.commons.utils.DeFileUtils
;
import
io.dataease.dto.DriverDTO
;
import
io.dataease.dto.DriverDTO
;
import
io.dataease.dto.datasource.SqlServerConfiguration
;
import
io.dataease.i18n.Translator
;
import
io.dataease.plugins.common.base.domain.Datasource
;
import
io.dataease.plugins.common.base.domain.DeDriver
;
import
io.dataease.plugins.common.base.domain.DeDriver
;
import
io.dataease.plugins.common.base.domain.DeDriverDetails
;
import
io.dataease.plugins.common.base.domain.DeDriverDetails
;
import
io.dataease.plugins.common.base.domain.DeDriverDetailsExample
;
import
io.dataease.plugins.common.base.domain.DeDriverDetailsExample
;
import
io.dataease.plugins.common.base.mapper.DeDriverDetailsMapper
;
import
io.dataease.plugins.common.base.mapper.DeDriverDetailsMapper
;
import
io.dataease.plugins.common.base.mapper.DeDriverMapper
;
import
io.dataease.plugins.common.base.mapper.DeDriverMapper
;
import
io.dataease.plugins.datasource.entity.JdbcConfiguration
;
import
io.dataease.plugins.datasource.provider.ExtendedJdbcClassLoader
;
import
io.dataease.plugins.datasource.provider.ExtendedJdbcClassLoader
;
import
org.apache.commons.lang3.StringUtils
;
import
org.springframework.stereotype.Service
;
import
org.springframework.stereotype.Service
;
import
org.springframework.transaction.annotation.Transactional
;
import
org.springframework.transaction.annotation.Transactional
;
import
org.springframework.web.multipart.MultipartFile
;
import
org.springframework.web.multipart.MultipartFile
;
...
@@ -55,13 +61,18 @@ public class DriverService {
...
@@ -55,13 +61,18 @@ public class DriverService {
return
driverDTOS
;
return
driverDTOS
;
}
}
public
void
delete
(
String
driverId
)
{
public
void
delete
(
DeDriver
deDriver
)
{
deDriverMapper
.
deleteByPrimaryKey
(
driverId
);
for
(
Datasource
datasource
:
datasourceService
.
listByType
(
deDriver
.
getType
()))
{
JdbcConfiguration
configuration
=
new
Gson
().
fromJson
(
datasource
.
getConfiguration
(),
JdbcConfiguration
.
class
);
if
(
StringUtils
.
isNotEmpty
(
configuration
.
getCustomDriver
())
&&
configuration
.
getCustomDriver
().
equalsIgnoreCase
(
deDriver
.
getId
())){
throw
new
RuntimeException
(
Translator
.
get
(
"I18N_DRIVER_NOT_DELETE"
));
}
}
deDriverMapper
.
deleteByPrimaryKey
(
deDriver
.
getId
());
DeDriverDetailsExample
example
=
new
DeDriverDetailsExample
();
DeDriverDetailsExample
example
=
new
DeDriverDetailsExample
();
example
.
createCriteria
().
andDeDriverIdEqualTo
(
d
riverId
);
example
.
createCriteria
().
andDeDriverIdEqualTo
(
d
eDriver
.
getId
()
);
deDriverDetailsMapper
.
deleteByExample
(
example
);
deDriverDetailsMapper
.
deleteByExample
(
example
);
DeFileUtils
.
deleteFile
(
DRIVER_PATH
+
d
riverId
+
"/"
);
DeFileUtils
.
deleteFile
(
DRIVER_PATH
+
d
eDriver
.
getId
()
+
"/"
);
}
}
public
DeDriver
save
(
DeDriver
deDriver
)
{
public
DeDriver
save
(
DeDriver
deDriver
)
{
...
...
backend/src/main/resources/i18n/messages_en_US.properties
浏览文件 @
626f9793
...
@@ -149,3 +149,5 @@ SOURCE_TYPE_VIEW=VIEW
...
@@ -149,3 +149,5 @@ SOURCE_TYPE_VIEW=VIEW
SOURCE_TYPE_USER
=
USER
SOURCE_TYPE_USER
=
USER
SOURCE_TYPE_DEPT
=
ORG
SOURCE_TYPE_DEPT
=
ORG
SOURCE_TYPE_ROLE
=
ROLE
SOURCE_TYPE_ROLE
=
ROLE
I18N_DRIVER_NOT_DELETE
=
Drivers in use cannot be deleted
\ No newline at end of file
backend/src/main/resources/i18n/messages_zh_CN.properties
浏览文件 @
626f9793
...
@@ -152,3 +152,5 @@ I18N_OPERATE_TYPE=操作类型
...
@@ -152,3 +152,5 @@ I18N_OPERATE_TYPE=操作类型
I18N_DETAIL
=
操作详情
I18N_DETAIL
=
操作详情
I18N_USER
=
操作人
I18N_USER
=
操作人
I18N_TIME
=
操作时间
I18N_TIME
=
操作时间
I18N_DRIVER_NOT_DELETE
=
使用中的驱动不允许删除
backend/src/main/resources/i18n/messages_zh_TW.properties
浏览文件 @
626f9793
...
@@ -148,3 +148,5 @@ SOURCE_TYPE_VIEW=視圖
...
@@ -148,3 +148,5 @@ SOURCE_TYPE_VIEW=視圖
SOURCE_TYPE_USER
=
用戶
SOURCE_TYPE_USER
=
用戶
SOURCE_TYPE_DEPT
=
組織
SOURCE_TYPE_DEPT
=
組織
SOURCE_TYPE_ROLE
=
角色
SOURCE_TYPE_ROLE
=
角色
I18N_DRIVER_NOT_DELETE
=
使用中的驅動不允許删除
\ No newline at end of file
frontend/src/lang/en.js
浏览文件 @
626f9793
...
@@ -1337,7 +1337,8 @@ export default {
...
@@ -1337,7 +1337,8 @@ export default {
modify
:
'Modify'
,
modify
:
'Modify'
,
show_info
:
'Driver info'
,
show_info
:
'Driver info'
,
file_name
:
'File name'
,
file_name
:
'File name'
,
version
:
'version'
version
:
'version'
,
please_set_driverClass
:
'Please specify driver class'
},
},
datasource
:
{
datasource
:
{
auth_method
:
'Auth method'
,
auth_method
:
'Auth method'
,
...
...
frontend/src/lang/tw.js
浏览文件 @
626f9793
...
@@ -1337,7 +1337,8 @@ export default {
...
@@ -1337,7 +1337,8 @@ export default {
modify
:
'修改'
,
modify
:
'修改'
,
show_info
:
'驅動信息'
,
show_info
:
'驅動信息'
,
file_name
:
'文件名'
,
file_name
:
'文件名'
,
version
:
'版本'
version
:
'版本'
,
please_set_driverClass
:
'請指定驅動類'
},
},
datasource
:
{
datasource
:
{
auth_method
:
'認證方式'
,
auth_method
:
'認證方式'
,
...
...
frontend/src/lang/zh.js
浏览文件 @
626f9793
...
@@ -1339,7 +1339,8 @@ export default {
...
@@ -1339,7 +1339,8 @@ export default {
modify
:
'修改'
,
modify
:
'修改'
,
show_info
:
'驱动信息'
,
show_info
:
'驱动信息'
,
file_name
:
'文件名'
,
file_name
:
'文件名'
,
version
:
'版本'
version
:
'版本'
,
please_set_driverClass
:
'请指定驱动类'
,
},
},
datasource
:
{
datasource
:
{
auth_method
:
'认证方式'
,
auth_method
:
'认证方式'
,
...
...
frontend/src/views/system/datasource/DriverForm.vue
浏览文件 @
626f9793
...
@@ -26,7 +26,7 @@
...
@@ -26,7 +26,7 @@
<el-form-item
:label=
"$t('commons.name')"
prop=
"name"
>
<el-form-item
:label=
"$t('commons.name')"
prop=
"name"
>
<el-input
v-model=
"driverForm.name"
autocomplete=
"off"
/>
<el-input
v-model=
"driverForm.name"
autocomplete=
"off"
/>
</el-form-item>
</el-form-item>
<el-form-item
:label=
"$t('commons.description')"
prop=
"desc"
>
<el-form-item
:label=
"$t('commons.description')"
>
<el-input
v-model=
"driverForm.desc"
autocomplete=
"off"
/>
<el-input
v-model=
"driverForm.desc"
autocomplete=
"off"
/>
</el-form-item>
</el-form-item>
<el-form-item
:label=
"$t('datasource.type')"
prop=
"type"
>
<el-form-item
:label=
"$t('datasource.type')"
prop=
"type"
>
...
@@ -62,7 +62,7 @@
...
@@ -62,7 +62,7 @@
<!-- </el-select>-->
<!-- </el-select>-->
<!-- </el-form-item>-->
<!-- </el-form-item>-->
<el-form-item
:label=
"$t('driver.driver')"
>
<el-form-item
:label=
"$t('driver.driver')"
prop=
"driverClass"
>
<el-input
v-model=
"driverForm.driverClass"
autocomplete=
"off"
/>
<el-input
v-model=
"driverForm.driverClass"
autocomplete=
"off"
/>
</el-form-item>
</el-form-item>
...
@@ -90,7 +90,7 @@
...
@@ -90,7 +90,7 @@
</el-upload>
</el-upload>
<fu-table
:data=
"driverFiles"
>
<fu-table
:data=
"driverFiles"
>
<el-table-column
prop=
"fileName"
:label=
"$t('driver.file_name')"
/>
<el-table-column
prop=
"fileName"
:label=
"$t('driver.file_name')"
/>
<el-table-column
prop=
"version"
:label=
"$t('driver.version')"
/
>
<!-- <el-table-column prop="version" :label="$t('driver.version')"/>--
>
<fu-table-operations
:buttons=
"buttons"
:label=
"$t('commons.operating')"
fix
/>
<fu-table-operations
:buttons=
"buttons"
:label=
"$t('commons.operating')"
fix
/>
</fu-table>
</fu-table>
...
@@ -151,7 +151,8 @@ export default {
...
@@ -151,7 +151,8 @@ export default {
{
min
:
2
,
max
:
50
,
message
:
i18n
.
t
(
'datasource.input_limit_2_25'
,
[
2
,
25
]),
trigger
:
'blur'
}],
{
min
:
2
,
max
:
50
,
message
:
i18n
.
t
(
'datasource.input_limit_2_25'
,
[
2
,
25
]),
trigger
:
'blur'
}],
desc
:
[{
required
:
true
,
message
:
i18n
.
t
(
'datasource.input_name'
),
trigger
:
'blur'
},
desc
:
[{
required
:
true
,
message
:
i18n
.
t
(
'datasource.input_name'
),
trigger
:
'blur'
},
{
min
:
2
,
max
:
200
,
message
:
i18n
.
t
(
'datasource.input_limit_2_25'
,
[
2
,
25
]),
trigger
:
'blur'
}],
{
min
:
2
,
max
:
200
,
message
:
i18n
.
t
(
'datasource.input_limit_2_25'
,
[
2
,
25
]),
trigger
:
'blur'
}],
type
:
[{
required
:
true
,
message
:
i18n
.
t
(
'datasource.please_choose_type'
),
trigger
:
'blur'
}]
type
:
[{
required
:
true
,
message
:
i18n
.
t
(
'datasource.please_choose_type'
),
trigger
:
'blur'
}],
driverClass
:
[{
required
:
true
,
message
:
i18n
.
t
(
'driver.please_set_driverClass'
),
trigger
:
'blur'
}]
},
},
canEdit
:
false
,
canEdit
:
false
,
driverFiles
:
[],
driverFiles
:
[],
...
@@ -231,9 +232,14 @@ export default {
...
@@ -231,9 +232,14 @@ export default {
this
.
disabled
=
this
.
params
&&
this
.
params
.
id
&&
this
.
params
.
showModel
&&
this
.
params
.
showModel
===
'show'
&&
!
this
.
canEdit
this
.
disabled
=
this
.
params
&&
this
.
params
.
id
&&
this
.
params
.
showModel
&&
this
.
params
.
showModel
===
'show'
&&
!
this
.
canEdit
},
},
save
(){
save
(){
updateDriver
(
this
.
driverForm
).
then
(
res
=>
{
this
.
$refs
.
driverForm
.
validate
(
valid
=>
{
this
.
$success
(
i18n
.
t
(
'commons.success'
))
if
(
!
valid
)
{
this
.
canEdit
=
false
return
false
}
updateDriver
(
this
.
driverForm
).
then
(
res
=>
{
this
.
$success
(
i18n
.
t
(
'commons.success'
))
this
.
canEdit
=
false
})
})
})
},
},
reset
()
{
reset
()
{
...
...
frontend/src/views/system/datasource/DsForm.vue
浏览文件 @
626f9793
...
@@ -137,7 +137,7 @@ export default {
...
@@ -137,7 +137,7 @@ export default {
acquireIncrement
:
5
,
acquireIncrement
:
5
,
idleConnectionTestPeriod
:
5
,
idleConnectionTestPeriod
:
5
,
connectTimeout
:
5
,
connectTimeout
:
5
,
customDriver
:
''
customDriver
:
'
default
'
},
},
apiConfiguration
:
[]
apiConfiguration
:
[]
},
},
...
@@ -286,7 +286,7 @@ export default {
...
@@ -286,7 +286,7 @@ export default {
acquireIncrement
:
5
,
acquireIncrement
:
5
,
idleConnectionTestPeriod
:
5
,
idleConnectionTestPeriod
:
5
,
connectTimeout
:
5
,
connectTimeout
:
5
,
customDriver
:
'
'
customDriver
:
'default
'
}
}
},
},
...
@@ -525,7 +525,7 @@ export default {
...
@@ -525,7 +525,7 @@ export default {
if
(
this
.
dsTypes
[
i
].
type
===
this
.
form
.
type
)
{
if
(
this
.
dsTypes
[
i
].
type
===
this
.
form
.
type
)
{
if
(
this
.
form
.
type
!==
'api'
&&
!
init
){
if
(
this
.
form
.
type
!==
'api'
&&
!
init
){
this
.
form
.
configuration
.
extraParams
=
this
.
dsTypes
[
i
].
extraParams
this
.
form
.
configuration
.
extraParams
=
this
.
dsTypes
[
i
].
extraParams
this
.
form
.
configuration
.
customDriver
=
''
this
.
form
.
configuration
.
customDriver
=
'
default
'
}
}
this
.
datasourceType
=
this
.
dsTypes
[
i
]
this
.
datasourceType
=
this
.
dsTypes
[
i
]
if
(
this
.
datasourceType
.
isJdbc
){
if
(
this
.
datasourceType
.
isJdbc
){
...
...
frontend/src/views/system/datasource/DsTree.vue
浏览文件 @
626f9793
...
@@ -111,7 +111,7 @@
...
@@ -111,7 +111,7 @@
<el-form-item
:label=
"$t('commons.name')"
prop=
"name"
>
<el-form-item
:label=
"$t('commons.name')"
prop=
"name"
>
<el-input
v-model=
"driverForm.name"
/>
<el-input
v-model=
"driverForm.name"
/>
</el-form-item>
</el-form-item>
<el-form-item
:label=
"$t('commons.description')"
prop=
"desc"
>
<el-form-item
:label=
"$t('commons.description')"
>
<el-input
v-model=
"driverForm.desc"
/>
<el-input
v-model=
"driverForm.desc"
/>
</el-form-item>
</el-form-item>
<el-form-item
:label=
"$t('datasource.type')"
prop=
"type"
>
<el-form-item
:label=
"$t('datasource.type')"
prop=
"type"
>
...
@@ -123,7 +123,7 @@
...
@@ -123,7 +123,7 @@
filterable
filterable
>
>
<el-option
<el-option
v-for=
"item in dsTypes"
v-for=
"item in dsTypes
ForDriver
"
:key=
"item.type"
:key=
"item.type"
:label=
"item.name"
:label=
"item.name"
:value=
"item.type"
:value=
"item.type"
...
@@ -156,6 +156,7 @@ import {
...
@@ -156,6 +156,7 @@ import {
delDriver
,
delDriver
,
listDriverByType
listDriverByType
}
from
'@/api/system/datasource'
}
from
'@/api/system/datasource'
import
{
ApplicationContext
}
from
"@/utils/ApplicationContext"
;
export
default
{
export
default
{
name
:
'DsTree'
,
name
:
'DsTree'
,
...
@@ -170,6 +171,7 @@ export default {
...
@@ -170,6 +171,7 @@ export default {
expandedArray
:
[],
expandedArray
:
[],
tData
:
[],
tData
:
[],
dsTypes
:
[],
dsTypes
:
[],
dsTypesForDriver
:
[],
showSearchInput
:
false
,
showSearchInput
:
false
,
key
:
''
,
key
:
''
,
showView
:
'Datasource'
,
showView
:
'Datasource'
,
...
@@ -242,6 +244,11 @@ export default {
...
@@ -242,6 +244,11 @@ export default {
datasourceTypes
()
{
datasourceTypes
()
{
listDatasourceType
().
then
(
res
=>
{
listDatasourceType
().
then
(
res
=>
{
this
.
dsTypes
=
res
.
data
this
.
dsTypes
=
res
.
data
this
.
dsTypes
.
forEach
(
item
=>
{
if
(
item
.
isJdbc
){
this
.
dsTypesForDriver
.
push
(
item
)
}
})
})
})
},
},
refreshType
(
datasource
)
{
refreshType
(
datasource
)
{
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论