This migrates the passthrough code to using the openstacksdk instead. This should also have the added benefit of improving the security posture of this dashboard. There is a bug in openstacksdk for Designate floating IPs which will be solved in [1], for now we workaround that so that older versions of openstacksdk is supported. This also fixes the 6 year old bug of supporting pagination for the designate dashboard. [1] https://review.opendev.org/c/openstack/openstacksdk/+/903879 Closes-Bug: 1729261 Change-Id: Id5ebdc5849d46dc10ab864a54afe37eb9c8f71b7
Team and repository tags
designate dashboard
Designate Horizon UI bits
- Free software: Apache license
Features
- TODO
Howto
Package the designatedashboard by running:
python setup.py sdistThis will create a python egg in the dist folder, which can be used to install on the horizon machine or within horizon's python virtual environment.
-- or --
Install directly from source by running "python setup.py --install"
Note: On some systems python may throw an error like
- 'Exception: Versioning for this project requires either an sdist tarball, or access
-
to an upstream git repository'
this seems to be a result of mismatched pbr versioning. A hacking workaround for development purposes is replacing the pbr call with a hard-coded version (e.g. '1.0.1') in designatedashboard/__init__.py.
Copy panel plugin files into your Horizon config. These files can be found in designatedashboard/enabled and should be copied to /usr/share/openstack-dashboard/openstack_dashboard/local/enabled or the equivalent directory for your openstack-dashboard install.
Copy default config file into your Horizon config. The file can be found in designatedashboard/local_settings.d and should be copied to /etc/openstack-dashboard/local_settings.d or the equivalent directory for your openstack-dashboard install.
Make sure your keystone catalog contains endpoints for service type 'dns'. If no such endpoints are found, the designatedashboard panels will not render.
(Optional) Copy the designate policy file into horizon's policy files folder.
Test
How to run JS tests:
- Install npm and nodejs=4.8.4
$
sudo apt-get install npm$curl -sL https://deb.nodesource.com/setup_4.x | sudo -E bash -$sudo apt-get install nodejsnpm install(to create virtual environment and install all dependencies in package.json)npm run lintfor eslintnpm run testfor JS unit tests