rubick/joker/__init__.py
Oleg Gelbukh e56d947303 Multiple fixes for PEP8 and unittests
Fix multiple PEP8-related issues.
Fix unittests for config schema registry.
Delete broken joker unittests.
Ignore F401,F403,E501,H306 in flake8 section of tox.ini:
  * allow non-alphabetical ordering of imports
  * ignore line length limit of 80
  * allow wildcard imports
  * allow importing unused modules for future use

Change-Id: Iac1bb030900c009e39a73fb98b5d76c24372920d
2013-11-15 17:54:05 +00:00

98 lines
2.7 KiB
Python

from nodes import Node
import os
TMP_PATH = "/tmp/joker_%s_%d"
class Joker():
def __init__(self, default_key, *args, **kwargs):
self.useKey = False
self.discoverQueue = []
self.discoveryResult = []
self.cleanUp = []
self.name = "EntryPoint"
self.seenNodes = {}
self.default_key = None
if (default_key):
try:
with open(default_key) as f:
self.default_key = f.read()
except Exception:
self.default_key = default_key
self.useKey = True
# keys temporary files
def __del__(self):
for filePath in self.cleanUp:
if os.path.exists(filePath):
os.remove(filePath)
def addNode(self, name, host, port=22, user='root', password=None):
node = Node(name, host, port)
node.assignCredential(user, self.default_key, password)
self.discoverQueue.append(node)
if (self.useKey):
self.cleanUp.append(node.keyPath)
return node
def addResult(self, hostname, ip, user, key, proxyCommand=None, port=22):
return self.discoveryResult.append(
self.dkOutput(hostname, ip, user, key, proxyCommand, port))
def dkOutput(self, hostname, ip, user, key, proxyCommand=None, port=22):
return {
"name": hostname,
"ip": ip,
"user": user,
"key": key,
"port": port,
"proxy_command": proxyCommand
}
def discover(self):
while self.discoverQueue:
point = self.discoverQueue.pop()
nodes = point.discover()
# this host can't be discovered by ssh method
if nodes is None:
continue
self.addResult(
hostname=point.hostName, ip=point.hostName, user=point.user,
key=point.origKey, proxyCommand=point.proxyCommandTxt,
port=point.accessPort)
# merge already seen nodes with new discovered nodes
self.seenNodes = dict(self.seenNodes.items() + point.link.items())
for node in nodes:
if node['hwAddr'] not in self.seenNodes:
# add to discovering queue
newNode = self.addNode(
name=node['ip'],
host=node['ip'],
user=point.user)
# new node connection channel working through master node
newNode.setProxyCommand(
point.hostName,
point.accessPort,
point.user,
point.keyPath
)
return self.discoveryResult