brotherton-erpnext/install_erpnext.py
2013-06-21 17:55:43 +05:30

170 lines
4.5 KiB
Python

#!/usr/bin/python
from __future__ import unicode_literals
import os, commands, sys
def install():
# get required details
root_pwd = get_root_password()
db_name, db_pwd = get_new_db_details()
# install path
install_path = os.getcwd()
setup_folders(install_path)
setup_conf(install_path, db_name, db_pwd)
# setup paths
sys.path.append('.')
sys.path.append('lib')
sys.path.append('app')
setup_db(install_path, root_pwd, db_name)
apply_patches(install_path)
show_remaining_steps()
def setup_folders(path):
execute_in_shell("git clone git://github.com/webnotes/wnframework.git lib", verbose=1)
execute_in_shell("git clone git://github.com/webnotes/erpnext.git app", verbose=1)
public = os.path.join(path, "public")
os.mkdir(public)
os.mkdir(os.path.join(public, "files"))
os.mkdir(os.path.join(public, "backups"))
os.mkdir(os.path.join(path, "logs"))
def setup_conf(path, db_name, db_pwd):
# read template conf file
with open(os.path.join(path, 'lib', 'conf', 'conf.py'), 'r') as template:
content = template.read()
# manipulate content
import re
# set new_dbname, new_dbpassword, files_path, backup_path, log_file_name
content = re.sub("db_name.*", "db_name = '%s'" % db_name, content)
content = re.sub("db_password.*", "db_password = '%s'" % db_pwd, content)
# write conf file
with open(os.path.join(path, 'conf.py'), 'w') as new_conf:
new_conf.write(content)
def setup_db(path, root_pwd, db_name):
source = os.path.join(path, 'app', "master.sql")
execute_in_shell("gunzip -c %s.gz > %s" % (source, source), verbose=1)
from webnotes.install_lib.install import Installer
inst = Installer('root', root_pwd)
inst.import_from_db(db_name, source_path=source, verbose = 1)
execute_in_shell("rm %s" % source)
def apply_patches(path):
# need to build before patches, once, so that all-web.js and all-web.css exists
execute_in_shell("./lib/wnf.py -b", verbose=1)
execute_in_shell("./lib/wnf.py --patch_sync_build", verbose=1)
# set filemode false
execute_in_shell("cd app && git config core.filemode false", verbose=1)
execute_in_shell("cd lib && git config core.filemode false", verbose=1)
def get_root_password():
# ask for root mysql password
import getpass
root_pwd = None
while not root_pwd:
root_pwd = getpass.getpass("MySQL Root user's Password: ")
test_root_connection(root_pwd)
return root_pwd
def test_root_connection(root_pwd):
err, out = execute_in_shell("mysql -u root -p%s -e 'exit'" % \
root_pwd.replace('$', '\$').replace(' ', '\ '))
if "access denied" in out.lower():
raise Exception("Incorrect MySQL Root user's password")
def get_new_db_details():
return get_input("New ERPNext Database Name: "), \
get_input("New ERPNext Database's Password: ")
def get_input(msg):
val = None
while not val:
val = raw_input(msg)
return val
def show_remaining_steps():
steps_remaining = """
Notes:
------
sample apache conf file
#-----------------------------------------------------------
SetEnv PYTHON_EGG_CACHE /var/www
# you can change 99 to any other port
Listen 99
NameVirtualHost *:99
<VirtualHost *:99>
ServerName localhost
DocumentRoot {path to erpnext's folder}/public
AddHandler cgi-script .cgi .xml .py
<Directory {path to erpnext's folder}/public/>
# directory specific options
Options -Indexes +FollowSymLinks +ExecCGI
# directory's index file
DirectoryIndex web.py
# rewrite rule
RewriteEngine on
# condition 1:
# ignore login-page.html, app.html, blank.html, unsupported.html
RewriteCond %{REQUEST_URI} ^((?!app\.html|blank\.html|unsupported\.html).)*$
# condition 2: if there are no slashes
# and file is .html or does not containt a .
RewriteCond %{REQUEST_URI} ^(?!.+/)((.+\.html)|([^.]+))$
# rewrite if both of the above conditions are true
RewriteRule ^(.+)$ web.py?page=$1 [NC,L]
AllowOverride all
Order Allow,Deny
Allow from all
</Directory>
</VirtualHost>
#-----------------------------------------------------------
To Do:
* Configure apache/http conf file to point to public folder
* chown recursively all files in your folder to apache user
* login using: user="Administrator" and password="admin"
"""
print steps_remaining
def execute_in_shell(cmd, verbose=0):
# using Popen instead of os.system - as recommended by python docs
from subprocess import Popen, PIPE
p = Popen(cmd, shell=True, stdout=PIPE, stderr=PIPE)
# get err and output
err, out = p.stderr.read(), p.stdout.read()
if verbose:
if err: print err
if out: print out
return err, out
if __name__=="__main__":
install()