forked from Doik/sailfish-sms-exporter
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathconverter.py
executable file
·120 lines (102 loc) · 4.06 KB
/
converter.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
#!/usr/bin/env python3
"""
Convert sailfish sms and call history to xml to be imported to android phones.
Reads a sailfish commhistory.db (which can be found in `/home/nemo/.local/share/commhistory`)
and creates a xml-file of all contained sms that is understood by the Android Application
"SMS Backup and Restore" (which can be obtained here:
https://play.google.com/store/apps/details?id=com.riteshsahu.SMSBackupRestore)
"""
import sqlite3
from datetime import datetime
jolla_db_filename = 'commhistory.db'
sms_filename = 'sms.xml'
calls_filename = 'calls.xml'
def encode_xml(text):
"""Escape the text for xml."""
text = text.replace("&", "&")
text = text.replace("\"", """)
text = text.replace("'", "'")
text = text.replace("<", "<")
text = text.replace(">", ">")
return text
cols = ["id", "type", "startTime", "endTime", "direction", "isDraft", "isRead", "isMissedCall", "isEmergencyCall", "status", "bytesReceived", "localUid", "remoteUid", "parentId", "subject", "freeText", "groupId", "messageToken", "lastModified", "vCardFileName", "vCardLabel", "isDeleted", "reportDelivery", "validityPeriod", "contentLocation", "messageParts", "headers", "readStatus", "reportRead", "reportedReadRequested", "mmsId", "isAction", "hasExtraProperties", "hasMessageParts"]
connection = sqlite3.connect(jolla_db_filename)
cursor = connection.cursor()
cursor.execute("SELECT * FROM Events WHERE type=2")
entries = cursor.fetchall()
date = datetime.now()
out = """<?xml version='1.0' encoding='UTF-8' standalone='yes' ?>
<!--File Created on {date}-->
<?xml-stylesheet type="text/xsl" href="sms.xsl"?>
<smses count="{count}">""".format(count=len(entries), date=date.strftime("%d/%m/%y %H:%M:%S"))
for entry in entries:
direction = entry[cols.index('direction')]
# if direction == 2 and not entry[cols.index('remoteUid')]:
# continue
sentdate = datetime.fromtimestamp(entry[cols.index('startTime')])
out += """<sms
protocol="{protocol}"
address="{address}"
date="{date}"
type="{type}"
subject="{subject}"
body="{body}"
toa="{toa}"
sc_toa="{sc_toa}"
service_center="{service_center}"
read="{read}"
status="{status}"
locked="{locked}"
date_sent="{date_sent}"
readable_date="{readable_date}"
contact_name="{contact_name}" />\n""".format(
protocol=0,
address=entry[cols.index('remoteUid')],
date=entry[cols.index('startTime')] * 1000,
type=direction,
subject=entry[cols.index('subject')] or "null",
body=encode_xml(entry[cols.index('freeText')]),
toa="null",
sc_toa="null",
service_center="null",
read=1,
status=-1,
locked=0,
date_sent=(0 if direction == 2 else entry[cols.index('startTime')] * 1000),
readable_date=sentdate.strftime("%d.%m.%Y %H:%M:%S"),
contact_name=""
)
out += "\n</smses>"
with open(sms_filename, 'w', encoding="utf-8") as fp:
fp.write(out)
cursor = connection.cursor()
cursor.execute("SELECT * FROM Events WHERE type=3")
entries = cursor.fetchall()
out = """<?xml version='1.0' encoding='UTF-8' standalone='yes' ?>
<!--File Created on {date}-->
<?xml-stylesheet type="text/xsl" href="calls.xsl"?>
<calls count="{count}">""".format(count=len(entries), date=date.strftime("%d/%m/%y %H:%M:%S"))
for entry in entries:
if entry[cols.index('isMissedCall')]:
calltype = 3
else:
calltype = entry[cols.index('direction')]
date = datetime.fromtimestamp(entry[cols.index('startTime')])
out += """<call
type="{type}"
number="{number}"
contact_name="{name}"
date="{date}"
readable_date="{readble_date}"
duration="{duration}"/>\n""".format(
type=calltype,
number=entry[cols.index('remoteUid')],
name="",
date=entry[cols.index('startTime')] * 1000,
readble_date=date.strftime("%d.%m.%Y %H:%M:%S"),
duration=entry[cols.index('endTime')] - entry[cols.index('startTime')]
)
out += "\n</calls>"
with open(calls_filename, 'w', encoding="utf-8") as fp:
fp.write(out)
print("Done")