Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
suliangchun
dbeaver
提交
554281ac
D
dbeaver
项目概览
suliangchun
/
dbeaver
与 Fork 源项目一致
从无法访问的项目Fork
通知
2
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
dbeaver
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
554281ac
编写于
4月 14, 2018
作者:
S
serge-rider
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
PG permission DDL refactoring
Former-commit-id:
59d8e169
上级
2328953a
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
46 addition
and
26 deletion
+46
-26
plugins/org.jkiss.dbeaver.ext.postgresql/src/org/jkiss/dbeaver/ext/postgresql/PostgreUtils.java
...ql/src/org/jkiss/dbeaver/ext/postgresql/PostgreUtils.java
+33
-4
plugins/org.jkiss.dbeaver.ext.postgresql/src/org/jkiss/dbeaver/ext/postgresql/edit/PostgreCommandGrantPrivilege.java
...ver/ext/postgresql/edit/PostgreCommandGrantPrivilege.java
+5
-13
plugins/org.jkiss.dbeaver.ext.postgresql/src/org/jkiss/dbeaver/ext/postgresql/model/PostgrePermissionsOwner.java
...dbeaver/ext/postgresql/model/PostgrePermissionsOwner.java
+2
-0
plugins/org.jkiss.dbeaver.ext.postgresql/src/org/jkiss/dbeaver/ext/postgresql/model/PostgreProcedure.java
.../jkiss/dbeaver/ext/postgresql/model/PostgreProcedure.java
+0
-9
plugins/org.jkiss.dbeaver.ext.postgresql/src/org/jkiss/dbeaver/ext/postgresql/model/PostgreRole.java
...c/org/jkiss/dbeaver/ext/postgresql/model/PostgreRole.java
+6
-0
未找到文件。
plugins/org.jkiss.dbeaver.ext.postgresql/src/org/jkiss/dbeaver/ext/postgresql/PostgreUtils.java
浏览文件 @
554281ac
...
...
@@ -36,6 +36,7 @@ import org.jkiss.dbeaver.model.exec.jdbc.JDBCPreparedStatement;
import
org.jkiss.dbeaver.model.exec.jdbc.JDBCResultSet
;
import
org.jkiss.dbeaver.model.exec.jdbc.JDBCSession
;
import
org.jkiss.dbeaver.model.impl.AbstractObjectCache
;
import
org.jkiss.dbeaver.model.impl.edit.SQLDatabasePersistAction
;
import
org.jkiss.dbeaver.model.impl.edit.SQLDatabasePersistActionComment
;
import
org.jkiss.dbeaver.model.impl.jdbc.JDBCUtils
;
import
org.jkiss.dbeaver.model.runtime.DBRProgressMonitor
;
...
...
@@ -491,14 +492,42 @@ public class PostgreUtils {
return
opt
.
toString
();
}
public
static
void
getObjectGrantPermissionActions
(
DBRProgressMonitor
monitor
,
PostgrePermissionsOwner
table
,
List
<
DBEPersistAction
>
actions
,
Map
<
String
,
Object
>
options
)
throws
DBException
{
public
static
String
getObjectTypeName
(
PostgrePermissionsOwner
object
)
{
if
(
object
instanceof
PostgreSequence
)
{
return
"SEQUENCE"
;
}
else
if
(
object
instanceof
PostgreProcedure
)
{
return
((
PostgreProcedure
)
object
).
getProcedureTypeName
();
}
else
{
return
"TABLE"
;
}
}
public
static
String
getObjectUniqueName
(
PostgrePermissionsOwner
object
)
{
if
(
object
instanceof
PostgreProcedure
)
{
return
((
PostgreProcedure
)
object
).
getFullQualifiedSignature
();
}
else
{
return
DBUtils
.
getObjectFullName
(
object
,
DBPEvaluationContext
.
DDL
);
}
}
public
static
void
getObjectGrantPermissionActions
(
DBRProgressMonitor
monitor
,
PostgrePermissionsOwner
object
,
List
<
DBEPersistAction
>
actions
,
Map
<
String
,
Object
>
options
)
throws
DBException
{
if
(
CommonUtils
.
getOption
(
options
,
PostgreConstants
.
OPTION_DDL_SHOW_PERMISSIONS
))
{
// Permissions
Collection
<
PostgrePermission
>
permissions
=
table
.
getPermissions
(
monitor
);
Collection
<
PostgrePermission
>
permissions
=
object
.
getPermissions
(
monitor
);
if
(!
CommonUtils
.
isEmpty
(
permissions
))
{
actions
.
add
(
new
SQLDatabasePersistActionComment
(
table
.
getDataSource
(),
"Permissions"
));
actions
.
add
(
new
SQLDatabasePersistActionComment
(
object
.
getDataSource
(),
"Permissions"
));
// Owner
PostgreRole
owner
=
object
.
getOwner
(
monitor
);
if
(
owner
!=
null
)
{
actions
.
add
(
new
SQLDatabasePersistAction
(
"Owner change"
,
"ALTER "
+
getObjectTypeName
(
object
)
+
" "
+
getObjectUniqueName
(
object
)
+
" OWNER TO "
+
DBUtils
.
getQuotedIdentifier
(
owner
)
));
}
for
(
PostgrePermission
permission
:
permissions
)
{
if
(
permission
.
hasAllPrivileges
(
table
))
{
if
(
permission
.
hasAllPrivileges
(
object
))
{
Collections
.
addAll
(
actions
,
new
PostgreCommandGrantPrivilege
(
permission
.
getOwner
(),
true
,
permission
,
new
PostgrePrivilegeType
[]
{
PostgrePrivilegeType
.
ALL
})
.
getPersistActions
(
options
));
...
...
plugins/org.jkiss.dbeaver.ext.postgresql/src/org/jkiss/dbeaver/ext/postgresql/edit/PostgreCommandGrantPrivilege.java
浏览文件 @
554281ac
...
...
@@ -17,13 +17,13 @@
package
org.jkiss.dbeaver.ext.postgresql.edit
;
import
org.jkiss.dbeaver.ext.postgresql.PostgreMessages
;
import
org.jkiss.dbeaver.ext.postgresql.PostgreUtils
;
import
org.jkiss.dbeaver.ext.postgresql.model.*
;
import
org.jkiss.dbeaver.model.DBPEvaluationContext
;
import
org.jkiss.dbeaver.model.DBUtils
;
import
org.jkiss.dbeaver.model.edit.DBEPersistAction
;
import
org.jkiss.dbeaver.model.edit.DBECommand
;
import
org.jkiss.dbeaver.model.
impl.edit.SQLDatabase
PersistAction
;
import
org.jkiss.dbeaver.model.
edit.DBE
PersistAction
;
import
org.jkiss.dbeaver.model.impl.edit.DBECommandAbstract
;
import
org.jkiss.dbeaver.model.impl.edit.SQLDatabasePersistAction
;
import
java.util.Map
;
...
...
@@ -70,22 +70,14 @@ public class PostgreCommandGrantPrivilege extends DBECommandAbstract<PostgrePerm
objectName
=
((
PostgreRolePermission
)
permission
).
getFullObjectName
();
}
else
{
roleName
=
DBUtils
.
getQuotedIdentifier
(
object
.
getDataSource
(),
((
PostgreObjectPermission
)
permission
).
getGrantee
());
if
(
object
instanceof
PostgreProcedure
)
{
objectName
=
((
PostgreProcedure
)
object
).
getFullQualifiedSignature
();
}
else
{
objectName
=
DBUtils
.
getObjectFullName
(
object
,
DBPEvaluationContext
.
DDL
);
}
objectName
=
PostgreUtils
.
getObjectUniqueName
(
object
);
}
String
objectType
;
if
(
permission
instanceof
PostgreRolePermission
)
{
objectType
=
((
PostgreRolePermission
)
permission
).
getKind
().
name
();
}
else
if
(
object
instanceof
PostgreSequence
)
{
objectType
=
"SEQUENCE"
;
}
else
if
(
object
instanceof
PostgreProcedure
)
{
objectType
=
"FUNCTION"
;
}
else
{
objectType
=
"TABLE"
;
objectType
=
PostgreUtils
.
getObjectTypeName
(
object
)
;
}
String
grantScript
=
"GRANT "
+
privName
+
//$NON-NLS-1$
" ON "
+
objectType
+
" "
+
objectName
+
//$NON-NLS-1$
...
...
plugins/org.jkiss.dbeaver.ext.postgresql/src/org/jkiss/dbeaver/ext/postgresql/model/PostgrePermissionsOwner.java
浏览文件 @
554281ac
...
...
@@ -30,6 +30,8 @@ public interface PostgrePermissionsOwner extends PostgreObject {
PostgreSchema
getSchema
();
PostgreRole
getOwner
(
DBRProgressMonitor
monitor
)
throws
DBException
;
Collection
<
PostgrePermission
>
getPermissions
(
DBRProgressMonitor
monitor
)
throws
DBException
;
}
plugins/org.jkiss.dbeaver.ext.postgresql/src/org/jkiss/dbeaver/ext/postgresql/model/PostgreProcedure.java
浏览文件 @
554281ac
...
...
@@ -300,15 +300,6 @@ public class PostgreProcedure extends AbstractProcedure<PostgreDataSource, Postg
procDDL
=
body
;
}
if
(
CommonUtils
.
getOption
(
options
,
PostgreConstants
.
OPTION_DDL_SHOW_PERMISSIONS
))
{
//
// ALTER FUNCTION public.__st_countagg_transfn(agg_count, raster, integer, boolean, double precision) OWNER TO postgres;
PostgreRole
owner
=
getOwner
(
monitor
);
if
(
owner
!=
null
)
{
procDDL
+=
"\n"
+
"ALTER FUNCTION "
+
getFullQualifiedSignature
()
+
" OWNER TO "
+
DBUtils
.
getQuotedIdentifier
(
owner
)
+
"\n"
;
}
List
<
DBEPersistAction
>
actions
=
new
ArrayList
<>();
PostgreUtils
.
getObjectGrantPermissionActions
(
monitor
,
this
,
actions
,
options
);
procDDL
+=
"\n"
+
SQLUtils
.
generateScript
(
getDataSource
(),
actions
.
toArray
(
new
DBEPersistAction
[
actions
.
size
()]),
false
);
...
...
plugins/org.jkiss.dbeaver.ext.postgresql/src/org/jkiss/dbeaver/ext/postgresql/model/PostgreRole.java
浏览文件 @
554281ac
...
...
@@ -281,6 +281,12 @@ public class PostgreRole implements PostgreObject, PostgrePermissionsOwner, DBPP
return
null
;
}
@Override
public
PostgreRole
getOwner
(
DBRProgressMonitor
monitor
)
throws
DBException
{
// Dummy implementation
return
this
;
}
@Override
public
Collection
<
PostgrePermission
>
getPermissions
(
DBRProgressMonitor
monitor
)
throws
DBException
{
try
(
JDBCSession
session
=
DBUtils
.
openMetaSession
(
monitor
,
getDataSource
(),
"Read role privileges"
))
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录