Initial commit of ovsdb-manager interface
This commit is contained in:
commit
58cc18fe40
2
.gitignore
vendored
Normal file
2
.gitignore
vendored
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
bin
|
||||||
|
.settings
|
9
copyright
Normal file
9
copyright
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
Format: http://www.debian.org/doc/packaging-manuals/copyright-format/1.0
|
||||||
|
|
||||||
|
Files: *
|
||||||
|
Copyright: 2015, Canonical Ltd.
|
||||||
|
License: GPL-3
|
||||||
|
|
||||||
|
License: GPL-3
|
||||||
|
On Debian GNU/Linux system you can find the complete text of the
|
||||||
|
GPL-3 license in '/usr/share/common-licenses/GPL-3'
|
3
interface.yaml
Normal file
3
interface.yaml
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
name: ovsdb-manager
|
||||||
|
summary: Interface for relating to the OVSDB manager aspect of OpenDayLight SDN
|
||||||
|
maintainer: James Page <james.page@ubuntu.com>
|
38
requires.py
Normal file
38
requires.py
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
from charmhelpers.core.reactive import hook
|
||||||
|
from charmhelpers.core.reactive import RelationBase
|
||||||
|
from charmhelpers.core.reactive import scopes
|
||||||
|
|
||||||
|
|
||||||
|
class OVSDBManagerRequires(RelationBase):
|
||||||
|
scope = scopes.GLOBAL
|
||||||
|
auto_accessors = ['protocol', 'private-address', 'host', 'port']
|
||||||
|
|
||||||
|
@hook('{requires:ovsdb-manager}-relation-{joined,changed,departed}')
|
||||||
|
def changed(self):
|
||||||
|
self.set_state('{relation_name}.connected')
|
||||||
|
if self.connection_string():
|
||||||
|
self.set_state('{relation_name}.access.available')
|
||||||
|
else:
|
||||||
|
self.remove_state('{relation_name}.access.available')
|
||||||
|
|
||||||
|
@hook('{requires:ovsdb-manager}-relation-broken')
|
||||||
|
def broken(self):
|
||||||
|
self.remove_state('{relation_name}.connected')
|
||||||
|
self.remove_state('{relation_name}.access.available')
|
||||||
|
|
||||||
|
def connection_string(self):
|
||||||
|
"""Open vSwitch connection string
|
||||||
|
|
||||||
|
Returns the connection string to use for Open vSwitch or None
|
||||||
|
if the remote ODL controller has not presented this data
|
||||||
|
yet.
|
||||||
|
"""
|
||||||
|
data = {
|
||||||
|
'host': self.host() or self.private_address(),
|
||||||
|
'port': self.port() or '6640',
|
||||||
|
'protocol': self.protocol(),
|
||||||
|
}
|
||||||
|
if all(data.values()):
|
||||||
|
return "{protocol}:{host}:{port}".format(**data)
|
||||||
|
else:
|
||||||
|
return None
|
Loading…
Reference in New Issue
Block a user