52 lines
2.1 KiB
Python
52 lines
2.1 KiB
Python
import frappe, subprocess, os
|
|
from six.moves import input
|
|
|
|
def setup_database(force, source_sql, verbose):
|
|
root_conn = get_root_connection()
|
|
root_conn.commit()
|
|
root_conn.sql("DROP DATABASE IF EXISTS `{0}`".format(frappe.conf.db_name))
|
|
root_conn.sql("DROP USER IF EXISTS {0}".format(frappe.conf.db_name))
|
|
root_conn.sql("CREATE DATABASE `{0}`".format(frappe.conf.db_name))
|
|
root_conn.sql("CREATE user {0} password '{1}'".format(frappe.conf.db_name,
|
|
frappe.conf.db_password))
|
|
root_conn.sql("GRANT ALL PRIVILEGES ON DATABASE `{0}` TO {0}".format(frappe.conf.db_name))
|
|
|
|
# we can't pass psql password in arguments in postgresql as mysql. So
|
|
# set password connection parameter in environment variable
|
|
subprocess_env = os.environ.copy()
|
|
subprocess_env['PGPASSWORD'] = str(frappe.conf.db_password)
|
|
# bootstrap db
|
|
subprocess.check_output([
|
|
'psql', frappe.conf.db_name, '-h', frappe.conf.db_host or 'localhost', '-U',
|
|
frappe.conf.db_name, '-f',
|
|
os.path.join(os.path.dirname(__file__), 'framework_postgres.sql')
|
|
], env=subprocess_env)
|
|
|
|
frappe.connect()
|
|
|
|
def setup_help_database(help_db_name):
|
|
root_conn = get_root_connection()
|
|
root_conn.sql("DROP DATABASE IF EXISTS `{0}`".format(help_db_name))
|
|
root_conn.sql("DROP USER IF EXISTS {0}".format(help_db_name))
|
|
root_conn.sql("CREATE DATABASE `{0}`".format(help_db_name))
|
|
root_conn.sql("CREATE user {0} password '{1}'".format(help_db_name, help_db_name))
|
|
root_conn.sql("GRANT ALL PRIVILEGES ON DATABASE `{0}` TO {0}".format(help_db_name))
|
|
|
|
def get_root_connection(root_login=None, root_password=None):
|
|
import getpass
|
|
if not frappe.local.flags.root_connection:
|
|
if not root_login:
|
|
root_login = frappe.conf.get("root_login") or None
|
|
|
|
if not root_login:
|
|
root_login = input("Enter postgres super user: ")
|
|
|
|
if not root_password:
|
|
root_password = frappe.conf.get("root_password") or None
|
|
|
|
if not root_password:
|
|
root_password = getpass.getpass("Postgres super user password: ")
|
|
|
|
frappe.local.flags.root_connection = frappe.database.get_db(user=root_login, password=root_password)
|
|
|
|
return frappe.local.flags.root_connection
|