summaryrefslogtreecommitdiff
path: root/jpilot2keepass
diff options
context:
space:
mode:
authorPeter Palfrader <peter@palfrader.org>2012-03-28 18:55:54 +0000
committerweasel <weasel@bc3d92e2-beff-0310-a7cd-cc87d7ac0ede>2012-03-28 18:55:54 +0000
commitc74801223e17e5d5c114d127c6ba85504c474ce2 (patch)
treee0807b12fb3b7cbbecb542788be6a04321cf592c /jpilot2keepass
parentbb23bf94bc0584e09d5cc7a5f9ea9ee75b6c19b0 (diff)
add jpilot2keepass
git-svn-id: svn+ssh://asteria.noreply.org/svn/weaselutils/trunk@512 bc3d92e2-beff-0310-a7cd-cc87d7ac0ede
Diffstat (limited to 'jpilot2keepass')
-rwxr-xr-xjpilot2keepass96
1 files changed, 96 insertions, 0 deletions
diff --git a/jpilot2keepass b/jpilot2keepass
new file mode 100755
index 0000000..e90ce6e
--- /dev/null
+++ b/jpilot2keepass
@@ -0,0 +1,96 @@
+#!/usr/bin/python
+
+# convert a jpilot with keyring plugin export to keepassx .xml format.
+
+# Copyright (C) 2012 Peter Palfrader
+#
+# Permission is hereby granted, free of charge, to any person obtaining
+# a copy of this software and associated documentation files (the
+# "Software"), to deal in the Software without restriction, including
+# without limitation the rights to use, copy, modify, merge, publish,
+# distribute, sublicense, and/or sell copies of the Software, and to
+# permit persons to whom the Software is furnished to do so, subject to
+# the following conditions:
+#
+# The above copyright notice and this permission notice shall be
+# included in all copies or substantial portions of the Software.
+#
+# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
+# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
+# LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
+# OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
+# WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
+
+
+import csv
+import optparse
+import string
+import sys
+
+
+parser = optparse.OptionParser()
+parser.set_usage("%prog <IN> <OUT>")
+
+(options, args) = parser.parse_args()
+
+if len(args) > 2:
+ parser.print_help()
+ sys.exit(1)
+
+outf = open(args[1], "w") if len(args) >= 2 else sys.stdout
+inf = open(args[0], "r") if len(args) >= 1 else sys.stdin
+
+pws = {}
+
+c = csv.DictReader(inf, delimiter=',', quotechar='"')
+for row in c:
+ cat = row['Category']
+ if cat not in pws: pws[cat] = []
+ pws[cat].append(row)
+
+
+dbheader = string.Template("""
+<!DOCTYPE KEEPASSX_DATABASE>
+<database>
+""")
+dbfooter = string.Template("""
+</database>
+""")
+groupheader = string.Template("""
+ <group>
+ <title>$Category</title>
+ <icon>1</icon>
+""")
+groupfooter = string.Template("""
+ </group>
+""")
+entry = string.Template("""
+ <entry>
+ <title>$Name</title>
+ <username>$Account</username>
+ <password>$Password</password>
+ <url></url>
+ <comment>$Note</comment>
+ <icon>1</icon>
+ <creation></creation>
+ <lastaccess></lastaccess>
+ <lastmod></lastmod>
+ <expire>Never</expire>
+ </entry>
+""")
+
+
+groups = pws.keys()
+groups.sort()
+print >> outf, dbheader.substitute()
+for g in groups:
+ print >> outf, groupheader.substitute({'Category': g})
+ for e in pws[g]:
+ print >> outf, entry.substitute(e)
+ print >> outf, groupfooter.substitute({'Category': g})
+print >> outf, dbfooter.substitute()
+# vim:set et:
+# vim:set ts=4:
+# vim:set shiftwidth=4: