This repository has been archived by the owner on May 30, 2022. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathutil.py
70 lines (58 loc) · 1.88 KB
/
util.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
import contextlib
import json
import os.path
import sqlite3
import urllib.request
from typing import Any
from typing import Dict
from typing import Generator
from typing import NamedTuple
from typing import Optional
class Response(NamedTuple):
json: Any
links: Dict[str, str]
def _parse_link(lnk: Optional[str]) -> Dict[str, str]:
if lnk is None:
return {}
ret = {}
parts = lnk.split(',')
for part in parts:
link, _, rel = part.partition(';')
link, rel = link.strip(), rel.strip()
assert link.startswith('<') and link.endswith('>'), link
assert rel.startswith('rel="') and rel.endswith('"'), rel
link, rel = link[1:-1], rel[len('rel="'):-1]
ret[rel] = link
return ret
def req(url: str, **kwargs: Any) -> Response:
resp = urllib.request.urlopen(urllib.request.Request(url, **kwargs))
return Response(json.load(resp), _parse_link(resp.headers['link']))
@contextlib.contextmanager
def db_connect() -> Generator[sqlite3.Connection, None, None]:
data_table = '''\
CREATE TABLE IF NOT EXISTS data (
repo, filename, rev, account_type, star_count, checksum,
PRIMARY KEY (repo, filename)
)
'''
seen_table = '''\
CREATE TABLE IF NOT EXISTS seen (repo, PRIMARY KEY (repo))
'''
status_table = '''\
CREATE TABLE IF NOT EXISTS status (
checksum, value,
PRIMARY KEY (checksum)
)
'''
done_table = '''\
CREATE TABLE IF NOT EXISTS done (repo, PRIMARY KEY (repo))
'''
with contextlib.closing(sqlite3.connect('db.db')) as ctx, ctx as db:
db.execute(data_table)
db.execute(seen_table)
db.execute(status_table)
db.execute(done_table)
yield db
def get_token() -> str:
with open(os.path.expanduser('~/.github-auth.json')) as f:
return json.load(f)['token']