-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathupdate_pgjson.py
executable file
·53 lines (48 loc) · 2.31 KB
/
update_pgjson.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
#!/usr/bin/python
import psycopg2
import logging
import textwrap
import config as con
from docker import Client
import config as con
def add_new():
sqlcmd=textwrap.dedent("""\
insert into updated_containers select
trim(leading '/' from data->>'Name':: text) as container,
TRUE as active,
a.data->'HostConfig'->'PortBindings'->'5432/tcp'->0->>'HostPort'::text as port,
a.data->'Config'->'Labels'->>'BACKUP_FREQ'::text as backup_freq,
a.data->'Config'->'Labels'->>'BACKUP_LIFE'::text as backup_life,
a.data->'Config'->'Labels'->>'BACKUP_WINDOW'::text as backup_window,
a.data->'Config'->'Labels'->>'CONNECTIONS'::text as connections,
a.data->'Config'->'Labels'->>'CONTACT'::text as contact,
a.data->'Config'->'Labels'->>'DESCRIPTION'::text as description,
a.data->'Config'->'Labels'->>'LIFE'::text as life,
a.data->'Config'->'Labels'->>'MAINTAIN'::text as maintain,
a.data->'Config'->'Labels'->>'OWNER'::text as owner,
a.data->'Config'->'Labels'->>'PHI'::text as phi,
a.data->'Config'->'Labels'->>'PITR'::text as pitr,
a.data->'Config'->'Labels'->>'SIZE'::text as size,
a.data->'Config'->'Labels'->>'SUPPORT'::text as support
from containers as a left join
updated_containers as b
on trim (leading '/' from a.data->>'Name') = b.container where b.container is null;
""")
cli=Client(base_url=con.fig.base_url)
jsonport=cli.inspect_container('pgjson')['HostConfig']['PortBindings']['5432/tcp'][0]['HostPort']
jsonpw = [password for password in str(cli.inspect_container('pgjson')['Config']['Env']).split() \
if 'PGPASSWORD' in password][0].split('=')[1][:-2]
conn_string="dbname=pgjson user=pgjson host=" + con.fig.container_host +\
" port=" + jsonport + " password=" + jsonpw
try:
connection=psycopg2.connect(conn_string)
cur=connection.cursor()
cur.execute(sqlcmd)
connection.commit()
except Exception, e:
logging.error("An error occurred connecting to %s: message %s; connect string:", con, e, connect)
if __name__ == "__main__":
FORMAT = "%(asctime)s %(module)s:%(levelname)s: %(message)s"
logging.basicConfig(level=logging.INFO, format=FORMAT, filename=con.fig.admindb_log)
add_new()
logging.info("admindb updated")