Adding identity ng-roles panel

This patch adds an angular roles table.

To be added in subsequent patches:
 - Actions
 - filterFacets
 - Integration to Searchlight

To test, v3 needs to be enabled in local_settings.py and
 set 'roles_panel' to True in settings.py

Change-Id: Ie0eb168774f15536c778917abeb293e79d3b34e8
Co-Authored-By: Allen <chen.qiaomin@99cloud.net>
Co-Authored-By: kenji-i <ken-ishii@sx.jp.nec.com>
Co-Authored-By: Richard Jones <r1chardj0n3s@gmail.com>
Partially-implements: blueprint ng-roles
This commit is contained in:
chen.qiaomin@99cloud.net 2016-07-22 11:32:09 +08:00 committed by Cindy Lu
parent e5dac64cb0
commit 001c2a1879
8 changed files with 201 additions and 8 deletions

View File

@ -12,13 +12,23 @@
# License for the specific language governing permissions and limitations
# under the License.
from django.conf import settings
from django.conf.urls import url
from django.utils.translation import ugettext_lazy as _
from horizon.browsers.views import AngularIndexView
from openstack_dashboard.dashboards.identity.roles import views
urlpatterns = [
url(r'^$', views.IndexView.as_view(), name='index'),
url(r'^(?P<role_id>[^/]+)/update/$',
views.UpdateView.as_view(), name='update'),
url(r'^create/$', views.CreateView.as_view(), name='create'),
]
if settings.ANGULAR_FEATURES.get('roles_panel', False):
# New angular panel
title = _('Roles')
urlpatterns = [
url(r'^$', AngularIndexView.as_view(title=title), name='index'),
]
else:
urlpatterns = [
url(r'^$', views.IndexView.as_view(), name='index'),
url(r'^(?P<role_id>[^/]+)/update/$',
views.UpdateView.as_view(), name='update'),
url(r'^create/$', views.CreateView.as_view(), name='create'),
]

View File

@ -27,7 +27,19 @@
angular
.module('horizon.dashboard.identity', [
'horizon.dashboard.identity.users',
'horizon.dashboard.identity.projects'
]);
'horizon.dashboard.identity.projects',
'horizon.dashboard.identity.roles'
])
.config(config);
config.$inject = [
'$provide',
'$windowProvider'
];
function config($provide, $windowProvider) {
var path = $windowProvider.$get().STATIC_URL + 'dashboard/identity/';
$provide.constant('horizon.dashboard.identity.basePath', path);
}
})();

View File

@ -0,0 +1,41 @@
/**
* Copyright 2015 IBM Corp.
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may
* not use this file except in compliance with the License. You may obtain
* a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*/
(function() {
'use strict';
describe('horizon.dashboard.identity', function() {
it('should exist', function() {
expect(angular.module('horizon.dashboard.identity')).toBeDefined();
});
});
describe('horizon.dashboard.identity.basePath constant', function() {
var identityBasePath, staticUrl;
beforeEach(module('horizon.app.core.openstack-service-api'));
beforeEach(module('horizon.dashboard.identity'));
beforeEach(module('horizon.framework'));
beforeEach(inject(function($injector) {
identityBasePath = $injector.get('horizon.dashboard.identity.basePath');
staticUrl = $injector.get('$window').STATIC_URL;
}));
it('should equal to "/static/dashboard/identity/"', function() {
expect(identityBasePath).toEqual(staticUrl + 'dashboard/identity/');
});
});
})();

View File

@ -0,0 +1,4 @@
<hz-resource-panel resource-type-name="OS::Keystone::Role">
<hz-resource-table resource-type-name="OS::Keystone::Role">
</hz-resource-table>
</hz-resource-panel>

View File

@ -0,0 +1,84 @@
/**
* Copyright 2016 99Cloud
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may
* not use this file except in compliance with the License. You may obtain
* a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*/
(function() {
'use strict';
/**
* @ngdoc overview
* @ngname horizon.dashboard.identity.roles
*
* @description
* Provides all of the services and widgets required
* to support and display roles related content.
*/
angular
.module('horizon.dashboard.identity.roles', [
'ngRoute'
])
.constant('horizon.dashboard.identity.roles.resourceType', 'OS::Keystone::Role')
.run(run)
.config(config);
run.$inject = [
'horizon.framework.conf.resource-type-registry.service',
'horizon.app.core.openstack-service-api.keystone',
'horizon.dashboard.identity.roles.resourceType'
];
function run(registry, keystone, roleResourceType) {
registry.getResourceType(roleResourceType)
.setNames(gettext('Role'), gettext('Roles'))
.setProperties(roleProperties())
.setListFunction(listFunction)
.tableColumns
.append({
id: 'name',
priority: 1,
sortDefault: true
})
.append({
id: 'id',
priority: 1
});
function listFunction() {
return keystone.getRoles();
}
function roleProperties() {
return {
name: { label: gettext('Name'), filters: ['noName'] },
id: { label: gettext('ID'), filters: ['noValue'] }
};
}
}
config.$inject = [
'$provide',
'$windowProvider',
'$routeProvider'
];
function config($provide, $windowProvider, $routeProvider) {
var path = $windowProvider.$get().STATIC_URL + 'dashboard/identity/roles/';
$provide.constant('horizon.dashboard.identity.roles.basePath', path);
$routeProvider.when('/identity/roles', {
templateUrl: path + 'panel.html'
});
}
})();

View File

@ -0,0 +1,40 @@
/**
* Copyright 2016 99Cloud
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may
* not use this file except in compliance with the License. You may obtain
* a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*/
(function () {
'use strict';
describe('horizon.dashboard.identity.roles', function () {
it('should exist', function () {
expect(angular.module('horizon.dashboard.identity.roles')).toBeDefined();
});
});
describe('horizon.dashboard.identity.roles.basePath constant', function() {
var rolesBasePath, staticUrl;
beforeEach(module('horizon.app.core.openstack-service-api'));
beforeEach(module('horizon.dashboard.identity'));
beforeEach(module('horizon.framework'));
beforeEach(inject(function($injector) {
rolesBasePath = $injector.get('horizon.dashboard.identity.roles.basePath');
staticUrl = $injector.get('$window').STATIC_URL;
}));
it('should equal to "/static/dashboard/identity/roles"', function() {
expect(rolesBasePath).toEqual(staticUrl + 'dashboard/identity/roles/');
});
});
})();

View File

@ -323,6 +323,7 @@ ANGULAR_FEATURES = {
'images_panel': True,
'flavors_panel': False,
'users_panel': False,
'roles_panel': False
}
# Notice all customizable configurations should be above this line

View File

@ -101,6 +101,7 @@ HORIZON_CONFIG = {
ANGULAR_FEATURES = {
'images_panel': False, # Use the legacy panel so unit tests are still run
'flavors_panel': False,
'roles_panel': False,
}
STATICFILES_DIRS = settings_utils.get_xstatic_dirs(