This repository has been archived by the owner on Jun 24, 2020. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathsetup.py
147 lines (139 loc) · 4.52 KB
/
setup.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
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
import asyncio
import json
import asyncpg
import config
async def safe_table_create(connection, table_exec: str):
try:
print(await connection.execute(table_exec))
except asyncpg.DuplicateTableError:
print(
"That table already exists! If you're upgrading you can safely ignore this, if not, please drop that table and run this script again."
)
async def main():
print(
"I will now attempt to connect to database {} on host {} as user {}".format(
config.sql_db, config.sql_host, config.sql_user
)
)
conn = None
try:
conn = await asyncpg.connect(config.postgresql)
except asyncpg.ConnectionFailureError:
print(
"Could not connect. Are you sure the database {} exists?\nExiting.".format(
config.sql_db
)
)
exit(1)
else:
print("Connected!")
print("Creating table dnd_chars...")
await safe_table_create(
conn,
"""
CREATE TABLE dnd_chars (\
character_id serial PRIMARY KEY,\
name varchar NOT NULL,\
strength smallint NOT NULL,\
dexterity smallint NOT NULL,\
constitution smallint NOT NULL,\
intelligence smallint NOT NULL,\
wisdom smallint NOT NULL,\
charisma smallint NOT NULL,\
race varchar NOT NULL,\
discord_id varchar NOT NULL,\
levels integer[],\
classes varchar[])
""",
)
print("Creating table role_table...")
await safe_table_create(
conn,
"""
CREATE TABLE role_table(
internal serial PRIMARY KEY,
server_id bigint NOT NULL,
available bigint[] NOT NULL,
special bigint[] NOT NULL
)
""",
)
print("Attempting to import old role.json")
try:
with open("role.json", "r") as role:
data = json.load(role)
for key, value in data.items():
await conn.execute(
"INSERT INTO role_table(server_id, available, special) VALUES($1, $2, $3)",
int(key),
value["available"],
value["special"],
)
except FileNotFoundError:
print("No role.json found!")
else:
print("Imported role.json.")
print("Creating table guild_table...")
await safe_table_create(
conn,
"""
CREATE TABLE guild_table(
internal serial PRIMARY KEY,
guild_id bigint NOT NULL,
default_permission jsonb,
esrb varchar(5)
)
""",
)
print("Creating table timetable...")
await safe_table_create(
conn,
"""
CREATE TABLE timetable(
member bigint NOT NULL,
guild bigint NOT NULl,
seconds numeric NOT NULL DEFAULT 0,
PRIMARY KEY(member, guild)
)
""",
)
print("Creating table timekeeper...")
await safe_table_create(
conn,
"""
CREATE TABLE timekeeper(
member bigint NOT NULL,
guild bigint NOT NULL,
time_in decimal,
PRIMARY KEY(member, guild)
)
""",
)
print("Setting unique constraints and defaults...")
# dnd table
await conn.execute("""ALTER TABLE dnd_chars ADD UNIQUE (discord_id)""")
for col in [
"strength",
"dexterity",
"constitution",
"intelligence",
"wisdom",
"charisma",
]:
await conn.execute(
"""ALTER TABLE dnd_chars ALTER COLUMN {} SET DEFAULT 0""".format(col)
)
await conn.execute(
"ALTER TABLE dnd_chars ALTER COLUMN levels SET DEFAULT '{1}'"
)
# role table
await conn.execute("""ALTER TABLE role_table ADD UNIQUE (server_id)""")
await conn.execute(
"ALTER TABLE role_table ALTER COLUMN available SET DEFAULT '{0}'"
)
await conn.execute(
"ALTER TABLE role_table ALTER COLUMN special SET DEFAULT '{0}'"
)
print("Done!")
if __name__ == "__main__":
asyncio.get_event_loop().run_until_complete(main())