Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
suliangchun
dbeaver
提交
10fc817f
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,发现更多精彩内容 >>
提交
10fc817f
编写于
1月 15, 2017
作者:
S
Serge Rider
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
PG: permissions tab
Former-commit-id:
49b339ee
上级
3d95d226
变更
7
隐藏空白更改
内联
并排
Showing
7 changed file
with
313 addition
and
1 deletion
+313
-1
plugins/org.jkiss.dbeaver.ext.postgresql/plugin.properties
plugins/org.jkiss.dbeaver.ext.postgresql/plugin.properties
+1
-1
plugins/org.jkiss.dbeaver.ext.postgresql/plugin.xml
plugins/org.jkiss.dbeaver.ext.postgresql/plugin.xml
+5
-0
plugins/org.jkiss.dbeaver.ext.postgresql/src/org/jkiss/dbeaver/ext/postgresql/model/PostgreRole.java
...c/org/jkiss/dbeaver/ext/postgresql/model/PostgreRole.java
+5
-0
plugins/org.jkiss.dbeaver.ext.postgresql/src/org/jkiss/dbeaver/ext/postgresql/model/PostgreRolePrivilege.java
...ss/dbeaver/ext/postgresql/model/PostgreRolePrivilege.java
+82
-0
plugins/org.jkiss.dbeaver.ext.postgresql/src/org/jkiss/dbeaver/ext/postgresql/ui/editors/PostgresRolePrivilegesEditor.java
...t/postgresql/ui/editors/PostgresRolePrivilegesEditor.java
+219
-0
plugins/org.jkiss.dbeaver.model/icons/tree/permissions.png
plugins/org.jkiss.dbeaver.model/icons/tree/permissions.png
+0
-0
plugins/org.jkiss.dbeaver.model/src/org/jkiss/dbeaver/model/DBIcon.java
...iss.dbeaver.model/src/org/jkiss/dbeaver/model/DBIcon.java
+1
-0
未找到文件。
plugins/org.jkiss.dbeaver.ext.postgresql/plugin.properties
浏览文件 @
10fc817f
...
...
@@ -444,4 +444,4 @@ tree.roles.node.name=Roles
tree.role.member.node.name
=
Role
tree.role.members.node.name
=
Members
tree.role.belong.node.name
=
Role
tree.role.belongs.node.name
=
Belong
s
tree.role.belongs.node.name
=
Role
s
plugins/org.jkiss.dbeaver.ext.postgresql/plugin.xml
浏览文件 @
10fc817f
...
...
@@ -259,6 +259,11 @@
contributor=
"org.jkiss.dbeaver.ui.editors.sql.SQLEditorContributorNested"
type=
"folder"
>
<objectType
name=
"org.jkiss.dbeaver.ext.postgresql.model.PostgreTable"
/>
</editor>
<editor
id=
"postgresql.role.permissions"
class=
"org.jkiss.dbeaver.ext.postgresql.ui.editors.PostgresRolePrivilegesEditor"
label=
"Permissions"
description=
"Permissions"
icon=
"#permissions"
position=
"additions_middle"
contributor=
"org.jkiss.dbeaver.ui.editors.sql.SQLEditorContributorNested"
type=
"folder"
>
<objectType
name=
"org.jkiss.dbeaver.ext.postgresql.model.PostgreRole"
/>
</editor>
</extension>
<extension
point=
"org.eclipse.ui.editors"
>
...
...
plugins/org.jkiss.dbeaver.ext.postgresql/src/org/jkiss/dbeaver/ext/postgresql/model/PostgreRole.java
浏览文件 @
10fc817f
...
...
@@ -35,6 +35,7 @@ import java.sql.ResultSet;
import
java.sql.SQLException
;
import
java.util.Collection
;
import
java.util.Date
;
import
java.util.List
;
/**
* PostgreRole
...
...
@@ -212,6 +213,10 @@ public class PostgreRole implements PostgreObject {
return
belongsCache
.
getAllObjects
(
monitor
,
this
);
}
public
List
<
PostgreRolePrivilege
>
getPrivileges
(
DBRProgressMonitor
monitor
)
throws
DBException
{
return
null
;
}
@Override
public
String
toString
()
{
return
getName
();
...
...
plugins/org.jkiss.dbeaver.ext.postgresql/src/org/jkiss/dbeaver/ext/postgresql/model/PostgreRolePrivilege.java
0 → 100644
浏览文件 @
10fc817f
/*
* DBeaver - Universal Database Manager
* Copyright (C) 2010-2016 Serge Rieder (serge@jkiss.org)
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License (version 2)
* as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/
package
org.jkiss.dbeaver.ext.postgresql.model
;
import
org.jkiss.code.NotNull
;
import
org.jkiss.code.Nullable
;
import
org.jkiss.dbeaver.model.meta.Property
;
import
org.jkiss.dbeaver.model.struct.DBSObject
;
import
java.sql.ResultSet
;
import
java.sql.SQLException
;
/**
* PostgreRolePrivilege
*/
public
class
PostgreRolePrivilege
implements
DBSObject
{
private
final
PostgreDatabase
database
;
public
PostgreRolePrivilege
(
PostgreDatabase
database
,
ResultSet
dbResult
)
throws
SQLException
{
this
.
database
=
database
;
}
@Nullable
@Override
public
String
getDescription
()
{
return
null
;
}
@Nullable
@Override
public
DBSObject
getParentObject
()
{
return
database
;
}
@NotNull
@Override
public
PostgreDataSource
getDataSource
()
{
return
database
.
getDataSource
();
}
@Override
public
boolean
isPersisted
()
{
return
true
;
}
@NotNull
@Override
@Property
(
viewable
=
true
,
order
=
1
)
public
String
getName
()
{
return
""
;
}
@NotNull
public
PostgreDatabase
getDatabase
()
{
return
database
;
}
@Override
public
String
toString
()
{
return
getName
();
}
}
plugins/org.jkiss.dbeaver.ext.postgresql/src/org/jkiss/dbeaver/ext/postgresql/ui/editors/PostgresRolePrivilegesEditor.java
0 → 100644
浏览文件 @
10fc817f
/*
* DBeaver - Universal Database Manager
* Copyright (C) 2010-2016 Serge Rieder (serge@jkiss.org)
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License (version 2)
* as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/
package
org.jkiss.dbeaver.ext.postgresql.ui.editors
;
import
org.eclipse.swt.SWT
;
import
org.eclipse.swt.graphics.Font
;
import
org.eclipse.swt.layout.GridData
;
import
org.eclipse.swt.layout.GridLayout
;
import
org.eclipse.swt.widgets.Composite
;
import
org.jkiss.dbeaver.DBException
;
import
org.jkiss.dbeaver.Log
;
import
org.jkiss.dbeaver.ext.postgresql.model.PostgreRole
;
import
org.jkiss.dbeaver.ext.postgresql.model.PostgreRolePrivilege
;
import
org.jkiss.dbeaver.model.runtime.DBRProgressMonitor
;
import
org.jkiss.dbeaver.model.runtime.load.DatabaseLoadService
;
import
org.jkiss.dbeaver.ui.LoadingJob
;
import
org.jkiss.dbeaver.ui.UIUtils
;
import
org.jkiss.dbeaver.ui.controls.ProgressPageControl
;
import
org.jkiss.dbeaver.ui.editors.AbstractDatabaseObjectEditor
;
import
java.lang.reflect.InvocationTargetException
;
import
java.util.List
;
/**
* PostgresRolePrivilegesEditor
*/
public
class
PostgresRolePrivilegesEditor
extends
AbstractDatabaseObjectEditor
<
PostgreRole
>
{
private
static
final
Log
log
=
Log
.
getLog
(
PostgresRolePrivilegesEditor
.
class
);
private
PageControl
pageControl
;
private
Font
boldFont
;
private
boolean
isLoaded
;
@Override
public
void
createPartControl
(
Composite
parent
)
{
boldFont
=
UIUtils
.
makeBoldFont
(
parent
.
getFont
());
pageControl
=
new
PageControl
(
parent
);
Composite
container
=
UIUtils
.
createPlaceholder
(
pageControl
,
2
,
5
);
GridData
gd
=
new
GridData
(
GridData
.
FILL_BOTH
);
container
.
setLayoutData
(
gd
);
Composite
leftPane
=
UIUtils
.
createPlaceholder
(
container
,
2
);
leftPane
.
setLayoutData
(
new
GridData
(
GridData
.
FILL_BOTH
));
leftPane
.
setLayout
(
new
GridLayout
(
2
,
true
));
/*
{
Composite catalogGroup = UIUtils.createControlGroup(leftPane, MySQLMessages.editors_user_editor_privileges_group_catalogs, 1, GridData.FILL_BOTH, 0);
catalogsTable = new Table(catalogGroup, SWT.BORDER | SWT.SINGLE | SWT.H_SCROLL | SWT.V_SCROLL);
catalogsTable.setHeaderVisible(true);
gd = new GridData(GridData.FILL_BOTH);
catalogsTable.setLayoutData(gd);
catalogsTable.addSelectionListener(new SelectionAdapter() {
@Override
public void widgetSelected(SelectionEvent e) {
int selIndex = catalogsTable.getSelectionIndex();
if (selIndex <= 0) {
selectedCatalog = null;
} else {
selectedCatalog = (MySQLCatalog) catalogsTable.getItem(selIndex).getData();
}
showCatalogTables();
showGrants();
}
});
UIUtils.createTableColumn(catalogsTable, SWT.LEFT, MySQLMessages.editors_user_editor_privileges_column_catalog);
{
TableItem item = new TableItem(catalogsTable, SWT.NONE);
item.setText("% (All)"); //$NON-NLS-1$
item.setImage(DBeaverIcons.getImage(DBIcon.TREE_DATABASE));
}
for (MySQLCatalog catalog : getDatabaseObject().getDataSource().getCatalogs()) {
TableItem item = new TableItem(catalogsTable, SWT.NONE);
item.setText(catalog.getName());
item.setImage(DBeaverIcons.getImage(DBIcon.TREE_DATABASE));
item.setData(catalog);
}
UIUtils.packColumns(catalogsTable);
}
{
Composite tablesGroup = UIUtils.createControlGroup(leftPane, MySQLMessages.editors_user_editor_privileges_group_tables, 1, GridData.FILL_BOTH, 0);
tablesTable = new Table(tablesGroup, SWT.BORDER | SWT.SINGLE | SWT.H_SCROLL | SWT.V_SCROLL);
tablesTable.setHeaderVisible(true);
gd = new GridData(GridData.FILL_BOTH);
tablesTable.setLayoutData(gd);
tablesTable.addSelectionListener(new SelectionAdapter() {
@Override
public void widgetSelected(SelectionEvent e) {
int selIndex = tablesTable.getSelectionIndex();
if (selIndex <= 0) {
selectedTable = null;
} else {
selectedTable = (MySQLTableBase) tablesTable.getItem(selIndex).getData();
}
showGrants();
}
});
UIUtils.createTableColumn(tablesTable, SWT.LEFT, MySQLMessages.editors_user_editor_privileges_column_table);
UIUtils.packColumns(tablesTable);
}
Composite ph = UIUtils.createPlaceholder(container, 1);
ph.setLayoutData(new GridData(GridData.FILL_BOTH));
tablePrivilegesTable = new PrivilegeTableControl(ph, MySQLMessages.editors_user_editor_privileges_control_table_privileges);
gd = new GridData(GridData.FILL_BOTH);
tablePrivilegesTable.setLayoutData(gd);
otherPrivilegesTable = new PrivilegeTableControl(ph, MySQLMessages.editors_user_editor_privileges_control_other_privileges);
gd = new GridData(GridData.FILL_BOTH);
otherPrivilegesTable.setLayoutData(gd);
catalogsTable.setSelection(0);
showCatalogTables();
pageControl.createProgressPanel();
parent.addDisposeListener(new DisposeListener() {
@Override
public void widgetDisposed(DisposeEvent e)
{
UIUtils.dispose(boldFont);
}
});
addGrantListener(tablePrivilegesTable);
addGrantListener(otherPrivilegesTable);
*/
}
@Override
public
void
setFocus
()
{
}
@Override
public
synchronized
void
activatePart
()
{
if
(
isLoaded
)
{
return
;
}
isLoaded
=
true
;
LoadingJob
.
createService
(
new
DatabaseLoadService
<
List
<
PostgreRolePrivilege
>>(
"Load privileges"
,
getExecutionContext
())
{
@Override
public
List
<
PostgreRolePrivilege
>
evaluate
(
DBRProgressMonitor
monitor
)
throws
InvocationTargetException
,
InterruptedException
{
try
{
return
getDatabaseObject
().
getPrivileges
(
monitor
);
}
catch
(
DBException
e
)
{
throw
new
InvocationTargetException
(
e
);
}
}
},
pageControl
.
createPrivilegesLoadVisualizer
())
.
schedule
();
}
@Override
public
void
refreshPart
(
Object
source
,
boolean
force
)
{
// do nothing
}
private
class
PageControl
extends
ProgressPageControl
{
public
PageControl
(
Composite
parent
)
{
super
(
parent
,
SWT
.
NONE
);
}
public
ProgressPageControl
.
ProgressVisualizer
<
List
<
PostgreRolePrivilege
>>
createPrivilegesLoadVisualizer
()
{
return
new
ProgressPageControl
.
ProgressVisualizer
<
List
<
PostgreRolePrivilege
>>()
{
@Override
public
void
completeLoading
(
List
<
PostgreRolePrivilege
>
privs
)
{
super
.
completeLoading
(
privs
);
/*
List<MySQLPrivilege> otherPrivs = new ArrayList<>();
List<MySQLPrivilege> tablePrivs = new ArrayList<>();
for (MySQLPrivilege priv : privs) {
if (priv.getKind() == MySQLPrivilege.Kind.ADMIN) {
continue;
}
if (priv.getContext().contains("Table")) {
tablePrivs.add(priv);
} else {
otherPrivs.add(priv);
}
}
tablePrivilegesTable.fillPrivileges(tablePrivs);
otherPrivilegesTable.fillPrivileges(otherPrivs);
loadGrants();
*/
}
};
}
}
}
\ No newline at end of file
plugins/org.jkiss.dbeaver.model/icons/tree/permissions.png
0 → 100644
浏览文件 @
10fc817f
737 字节
plugins/org.jkiss.dbeaver.model/src/org/jkiss/dbeaver/model/DBIcon.java
浏览文件 @
10fc817f
...
...
@@ -67,6 +67,7 @@ public class DBIcon implements DBPImage
public
static
final
DBIcon
TREE_TRIGGER
=
new
DBIcon
(
"trigger"
,
"tree/trigger.png"
);
//$NON-NLS-1$ //$NON-NLS-2$
public
static
final
DBIcon
TREE_USER
=
new
DBIcon
(
"user"
,
"tree/user.png"
);
//$NON-NLS-1$ //$NON-NLS-2$
public
static
final
DBIcon
TREE_USER_GROUP
=
new
DBIcon
(
"user_group"
,
"tree/group.png"
);
//$NON-NLS-1$ //$NON-NLS-2$
public
static
final
DBIcon
TREE_PERMISSIONS
=
new
DBIcon
(
"permissions"
,
"tree/permissions.png"
);
//$NON-NLS-1$ //$NON-NLS-2$
public
static
final
DBIcon
TREE_PAGE
=
new
DBIcon
(
"page"
,
"tree/page.png"
);
//$NON-NLS-1$ //$NON-NLS-2$
public
static
final
DBIcon
TREE_INFO
=
new
DBIcon
(
"info"
,
"tree/info.png"
);
//$NON-NLS-1$ //$NON-NLS-2$
public
static
final
DBIcon
TREE_SESSIONS
=
new
DBIcon
(
"sessions"
,
"tree/sessions.png"
);
//$NON-NLS-1$ //$NON-NLS-2$
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录