123 lines
3.3 KiB
Python
123 lines
3.3 KiB
Python
import os
|
|
import sys
|
|
import subprocess
|
|
import psycopg2
|
|
import urllib2
|
|
import re
|
|
|
|
|
|
ckan_ini = os.environ.get('CKAN_INI', '/srv/app/production.ini')
|
|
|
|
RETRY = 5
|
|
|
|
def check_db_connection(retry=None):
|
|
|
|
if retry is None:
|
|
retry = RETRY
|
|
elif retry == 0:
|
|
print '[prerun] Giving up after 5 tries...'
|
|
sys.exit(1)
|
|
|
|
conn_str = os.environ.get('CKAN_SQLALCHEMY_URL', '')
|
|
try:
|
|
connection = psycopg2.connect(conn_str)
|
|
|
|
except psycopg2.Error as e:
|
|
print str(e)
|
|
print '[prerun] Unable to connect to the database...try again in a while.'
|
|
import time
|
|
time.sleep(10)
|
|
check_db_connection(retry = retry - 1)
|
|
else:
|
|
connection.close()
|
|
|
|
def check_solr_connection(retry=None):
|
|
|
|
if retry is None:
|
|
retry = RETRY
|
|
elif retry == 0:
|
|
print '[prerun] Giving up after 5 tries...'
|
|
sys.exit(1)
|
|
|
|
url = os.environ.get('CKAN_SOLR_URL', '')
|
|
search_url = '{url}/select/?q=*&wt=json'.format(url=url)
|
|
|
|
try:
|
|
connection = urllib2.urlopen(search_url)
|
|
except urllib2.URLError as e:
|
|
print str(e)
|
|
print '[prerun] Unable to connect to solr...try again in a while.'
|
|
import time
|
|
time.sleep(10)
|
|
check_solr_connection(retry = retry - 1)
|
|
else:
|
|
eval(connection.read())
|
|
|
|
|
|
def init_db():
|
|
|
|
db_command = ['paster', '--plugin=ckan', 'db',
|
|
'init', '-c', ckan_ini]
|
|
print '[prerun] Initializing or upgrading db - start'
|
|
try:
|
|
subprocess.check_output(db_command, stderr=subprocess.STDOUT)
|
|
print '[prerun] Initializing or upgrading db - end'
|
|
except subprocess.CalledProcessError, e:
|
|
if 'OperationalError' in e.output:
|
|
print e.output
|
|
print '[prerun] Database not ready, waiting a bit before exit...'
|
|
import time
|
|
time.sleep(5)
|
|
sys.exit(1)
|
|
else:
|
|
print e.output
|
|
raise e
|
|
|
|
|
|
def create_sysadmin():
|
|
|
|
name = os.environ.get('CKAN_SYSADMIN_NAME')
|
|
password = os.environ.get('CKAN_SYSADMIN_PASSWORD')
|
|
email = os.environ.get('CKAN_SYSADMIN_EMAIL')
|
|
|
|
if name and password and email:
|
|
|
|
# Check if user exists
|
|
command = ['paster', '--plugin=ckan', 'user', name, '-c', ckan_ini]
|
|
|
|
out = subprocess.check_output(command)
|
|
if 'User:None' not in re.sub(r'\s', '', out):
|
|
print '[prerun] Sysadmin user exists, skipping creation'
|
|
return
|
|
|
|
# Create user
|
|
command = ['paster', '--plugin=ckan', 'user', 'add',
|
|
name,
|
|
'password=' + password,
|
|
'email=' + email,
|
|
'-c', ckan_ini]
|
|
|
|
subprocess.call(command)
|
|
print '[prerun] Created user {0}'.format(name)
|
|
|
|
# Make it sysadmin
|
|
command = ['paster', '--plugin=ckan', 'sysadmin', 'add',
|
|
name,
|
|
'-c', ckan_ini]
|
|
|
|
subprocess.call(command)
|
|
print '[prerun] Made user {0} a sysadmin'.format(name)
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
maintenance = os.environ.get('MAINTENANCE_MODE', '').lower() == 'true'
|
|
|
|
if maintenance:
|
|
print '[prerun] Maintenance mode, skipping setup...'
|
|
else:
|
|
check_db_connection()
|
|
check_solr_connection()
|
|
init_db()
|
|
create_sysadmin()
|