-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathqueries.py
117 lines (108 loc) · 3.13 KB
/
queries.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
def create_query(type, my_number, start=None, end=None):
if type == 'range':
return range_query(my_number, start, end)
else:
return default_query(my_number)
def default_query(my_number):
query = f"""
SELECT
datetime(message.date / 1000000000 + strftime ("%s", "2001-01-01"), "unixepoch", "localtime") AS message_date,
message.text,
CASE message.is_from_me
WHEN 0 THEN '{my_number}'
WHEN 1 THEN chat.chat_identifier
ELSE 'Unknown'
END as sms_from,
CASE message.is_from_me
WHEN 0 THEN chat.chat_identifier
WHEN 1 THEN '{my_number}'
ELSE 'Unknown'
END as sms_to,
CASE message.is_emote
WHEN 0 THEN 'iMessage'
WHEN 1 THEN 'SMS'
ELSE 'Unknown'
END as message_type
FROM
chat
JOIN chat_message_join ON chat."ROWID" = chat_message_join.chat_id
JOIN message ON chat_message_join.message_id = message."ROWID"
ORDER BY
message_date DESC;
"""
return query
def range_query(my_number, start, end):
query = f"""
SELECT
datetime(message.date / 1000000000 + strftime ("%s", "2001-01-01"), "unixepoch", "localtime") AS message_date,
message.text,
CASE message.is_from_me
WHEN 0 THEN '{my_number}'
WHEN 1 THEN chat.chat_identifier
ELSE 'Unknown'
END as sms_from,
CASE message.is_from_me
WHEN 0 THEN chat.chat_identifier
WHEN 1 THEN '{my_number}'
ELSE 'Unknown'
END as sms_to,
CASE message.is_emote
WHEN 0 THEN 'iMessage'
WHEN 1 THEN 'SMS'
ELSE 'Unknown'
END as message_type
FROM
chat
JOIN chat_message_join ON chat."ROWID" = chat_message_join.chat_id
JOIN message ON chat_message_join.message_id = message."ROWID"
WHERE
datetime(message.date / 1000000000 + strftime ("%s", "2001-01-01"), "unixepoch", "localtime") BETWEEN '{start}' AND '{end}'
ORDER BY
message_date DESC;
"""
return query
def startup_script():
script = """#!/bin/bash
cwdir() {
DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" >/dev/null 2>&1 && pwd )"
cd $DIR
}
check_env() {
if [ ! -f .env ]; then
echo "Error: .env does not exist. Please copy .env.example and create .env file."
exit 1
fi
source .env
}
create_venv() {
if [ ! -d "$VENV_NAME" ]; then
python3 -m venv $VENV_NAME || { echo "Error: Couldn't create virtual environment. Try running the script as sudo."; exit 1; }
fi
source $VENV_NAME/bin/activate || { echo "Error: Couldn't activate virtual environment."; exit 1; }
}
check_requirements() {
if [ ! -f requirements.txt ]; then
cat > requirements.txt <<EOL
blinker==1.6.2
click==8.1.3
Flask==2.3.2
Flask-SSLify==0.1.5
itsdangerous==2.1.2
Jinja2==3.1.2
MarkupSafe==2.1.3
python-dotenv==1.0.0
Werkzeug==2.3.6
EOL
fi
pip install -r requirements.txt
}
run_server() {
python3 server.py
}
cwdir
check_env
create_venv
check_requirements
run_server
"""
return script