-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathnumberer.py
71 lines (59 loc) · 2.89 KB
/
numberer.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
#!/usr/bin/python3
# -*- coding: utf-8 -*-
import os
import csv
import sqlite3
from time import sleep
from lib.authenticator import Authenticator
from lib.api import Cosplay2API, Requester
from lib.config import read_config
num_row = 'num'
voting_number_row = 'voting_number'
config = read_config()
db_path = config['db_path']
event_name = config["event_name"]
api = Cosplay2API(event_name)
c2_login = config['admin_cs2_name']
c2_password = config['admin_cs2_password'] if 'admin_cs2_password' in config else None
numberer_table_path = config['numberer_table_path'] if 'numberer_table_path' in config else None
reset_numbers_mode = not numberer_table_path
with sqlite3.connect(db_path, isolation_level=None) as db:
c = db.cursor()
c.execute('PRAGMA encoding = "UTF-8"')
c.execute("SELECT number, requests.id, voting_number, default_duration FROM list, requests WHERE list.id = topic_id")
requests = {num: {"id": r_id, "voting_number": '' if voting_number is None else str(voting_number), "scene": default_duration > 0} for num, r_id, voting_number, default_duration in c.fetchall()}
if numberer_table_path:
with open(numberer_table_path, 'r', encoding='utf-8') as f:
reader = csv.reader(f)
head = reader.__next__()
voting_numbers = {int(row[head.index(num_row)]): int(row[head.index(voting_number_row)]) for row in reader if row[head.index(num_row)] and row[head.index(voting_number_row)]}
def set_number(r, request, target_voting_number, force=False):
already_ok = not force and request['voting_number'] == target_voting_number
action_symbol = '==' if already_ok else '->'
print('https://%s.cosplay2.ru/orgs/requests/request/%s | %s %s %s' % (event_name, request['id'], request['voting_number'], action_symbol, target_voting_number))
if not already_ok:
r.request(api.save_data_POST, {"field": "voting_number", "request_id": request['id'], "data": target_voting_number})
pass
a = Authenticator(event_name, c2_login, c2_password)
if not a.sign_in():
exit()
r = Requester(a.cookie)
known_requests = [num for (num, req) in requests.items() if reset_numbers_mode or req["scene"]]
if reset_numbers_mode:
print("resetting voting_number in all requesrs (scene + offline)")
for i, num in known_requests:
print('[', i+1, '/', len(requests), ']', end=" ")
set_number(r, requests[num], '', True)
for i, num in known_requests:
req = requests[num]
print('[', i+1, '/', len(requests), ']', end=" ")
set_number(r, req, str(num), True)
else:
print("setting voting_number only in scene requesrs")
for i, num in known_requests:
print('[', i+1, '/', len(requests), ']', end=" ")
set_number(r, requests[num], '', True)
for i, (num, v_num) in enumerate(voting_numbers.items()):
req = requests[num]
print('[', i+1, '/', len(voting_numbers), ']', end=" ")
set_number(r, req, v_num)