89 lines
1.9 KiB
Python
Raw Normal View History

2014-06-05 11:59:23 +01:00
#!/usr/bin/python
2014-06-05 11:59:23 +01:00
import sys
from charmhelpers.core.hookenv import (
Hooks,
UnregisteredHookError,
config,
2014-06-05 11:59:23 +01:00
log,
relation_set,
)
from charmhelpers.core.host import (
restart_on_change
)
from charmhelpers.fetch import (
apt_install, apt_update
)
from neutron_ovs_utils import (
2015-02-02 15:28:26 +00:00
configure_ovs,
2014-06-05 11:59:23 +01:00
determine_packages,
2015-02-02 13:31:39 +00:00
determine_dvr_packages,
get_shared_secret,
2014-06-05 11:59:23 +01:00
register_configs,
restart_map,
)
hooks = Hooks()
CONFIGS = register_configs()
@hooks.hook()
def install():
apt_update()
pkgs = determine_packages()
for pkg in pkgs:
apt_install(pkg, fatal=True)
2014-06-05 11:59:23 +01:00
2014-06-19 10:56:25 +01:00
@hooks.hook('neutron-network-service-relation-changed')
2014-06-17 15:31:03 +01:00
@hooks.hook('neutron-plugin-relation-changed')
@hooks.hook('neutron-plugin-api-relation-changed')
@hooks.hook('config-changed')
2014-06-10 17:56:10 +00:00
@restart_on_change(restart_map())
2014-06-17 15:31:03 +01:00
def config_changed():
2015-02-02 13:31:39 +00:00
if determine_dvr_packages():
2015-02-05 09:57:47 +00:00
apt_update()
2015-02-02 13:31:39 +00:00
apt_install(determine_dvr_packages(), fatal=True)
2015-02-03 14:17:30 +00:00
configure_ovs()
2014-06-05 11:59:23 +01:00
CONFIGS.write_all()
2014-06-19 10:56:25 +01:00
@hooks.hook('neutron-plugin-relation-joined')
def neutron_plugin_joined(relation_id=None):
rel_data = {
'metadata-shared-secret': get_shared_secret()
}
relation_set(relation_id=relation_id, **rel_data)
@hooks.hook('amqp-relation-joined')
def amqp_joined(relation_id=None):
relation_set(relation_id=relation_id,
username=config('rabbit-user'),
vhost=config('rabbit-vhost'))
@hooks.hook('amqp-relation-changed')
@hooks.hook('amqp-relation-departed')
@restart_on_change(restart_map())
def amqp_changed():
if 'amqp' not in CONFIGS.complete_contexts():
log('amqp relation incomplete. Peer not ready?')
return
CONFIGS.write_all()
2014-06-05 11:59:23 +01:00
2014-06-19 10:56:25 +01:00
2014-06-05 11:59:23 +01:00
def main():
try:
hooks.execute(sys.argv)
except UnregisteredHookError as e:
log('Unknown hook {} - skipping.'.format(e))
if __name__ == '__main__':
main()