2
0
mirror of https://github.com/frappe/bench.git synced 2025-01-24 23:48:24 +00:00

[fix] create user in installer

This commit is contained in:
Anand Doshi 2016-05-25 16:17:48 +05:30
parent efb31eab04
commit f62eb6c6d5
9 changed files with 99 additions and 58 deletions

View File

@ -1,8 +1,8 @@
--- ---
- hosts: localhost - hosts: localhost
vars: vars:
bench_repo_path: "/usr/local/frappe/bench-repo" bench_repo_path: "/home/{{ ansible_user_id }}/.bench"
bench_path: "/home/{{ ansible_user_id }}/frappe/frappe-bench" bench_path: "/home/{{ ansible_user_id }}/frappe-bench"
mysql_config_template: "templates/simple_mariadb_config.cnf" mysql_config_template: "templates/simple_mariadb_config.cnf"
mysql_conf_dir: /etc/my.cnf.d/ mysql_conf_dir: /etc/my.cnf.d/
wkhtmltopdf_version: 0.12.2.1 wkhtmltopdf_version: 0.12.2.1
@ -17,9 +17,6 @@
- name: install prequisites - name: install prequisites
yum: pkg={{ item }} state=present yum: pkg={{ item }} state=present
with_items: with_items:
# Install epel-release
- epel-release
# basic installs # basic installs
- redis - redis
- nodejs - nodejs
@ -45,9 +42,6 @@
- libtiff-devel - libtiff-devel
- tcl-devel - tcl-devel
- tk-devel - tk-devel
# To ensure that ansible_lsb is set
- redhat-lsb-core
become: yes become: yes
become_user: root become_user: root
@ -65,4 +59,4 @@
# setup development environment # setup development environment
- include: includes/setup_dev_env.yml - include: includes/setup_dev_env.yml
when: not setup_production when: not production

View File

@ -0,0 +1,22 @@
---
- hosts: localhost
tasks:
- name: Create user
user:
name: '{{ frappe_user }}'
generate_ssh_key: yes
- name: Set home folder perms
file:
path: '/home/{{ frappe_user }}'
mode: 'o+rx'
when: ansible_distribution == 'Ubuntu' or ansible_distribution == 'CentOS'
- name: Set home folder perms
file:
path: '/Users/{{ frappe_user }}'
mode: 'o+rx'
when: ansible_distribution == 'MacOSX'
- name: Set /tmp/.bench folder perms
command: 'chown -R {{ frappe_user }}:{{ frappe_user }} /tmp/.bench'

View File

@ -1,4 +1,18 @@
--- ---
- name: Check if /tmp/.bench exists
stat:
path: /tmp/.bench
register: tmp_bench
- name: Check if bench_repo_path exists
stat:
path: '{{ bench_repo_path }}'
register: bench_repo_register
- name: move /tmp/.bench if it exists
command: 'cp -R /tmp/.bench {{ bench_repo_path }}'
when: tmp_bench.stat.exists and not bench_repo_register.stat.exists
- name: install bench - name: install bench
pip: name={{ bench_repo_path }} extra_args='-e' pip: name={{ bench_repo_path }} extra_args='-e'
become: yes become: yes

View File

@ -10,9 +10,11 @@
host: '{{ item }}' host: '{{ item }}'
password: '{{ mysql_root_password }}' password: '{{ mysql_root_password }}'
state: present state: present
login_user: root
with_items: with_items:
- localhost - localhost
- 127.0.0.1
- ::1
become: yes become: yes
become_user: root become_user: root
# when you have already defined mysql root password # when you have already defined mysql root password
@ -30,11 +32,11 @@
become_user: root become_user: root
when: ansible_os_family == 'RedHat' or ansible_os_family == 'Debian' when: ansible_os_family == 'RedHat' or ansible_os_family == 'Debian'
- name: Set root password on CentOS # - name: Set root password on CentOS
command: mysqladmin -u root password '{{ mysql_root_password }}' # command: mysqladmin -u root password '{{ mysql_root_password }}'
become: yes # become: yes
become_user: root # become_user: root
when: mysql_root_password is defined and ansible_distribution == 'CentOS' # when: mysql_root_password is defined and ansible_distribution == 'CentOS'
- name: add launchagents folder mac - name: add launchagents folder mac
file: path=~/Library/LaunchAgents state=directory file: path=~/Library/LaunchAgents state=directory

View File

@ -3,7 +3,9 @@
- include: macosx.yml - include: macosx.yml
when: ansible_distribution == 'MacOSX' when: ansible_distribution == 'MacOSX'
- include: ubuntu.yml - include: ubuntu.yml
when: ansible_distribution == 'Ubuntu' when: ansible_distribution == 'Ubuntu'
- include: centos.yml - include: centos.yml
when: ansible_distribution == 'CentOS' when: ansible_distribution == 'CentOS'

View File

@ -1,8 +1,8 @@
--- ---
- hosts: localhost - hosts: localhost
vars: vars:
bench_repo_path: "/usr/local/frappe/bench-repo" bench_repo_path: "/Users/{{ ansible_user_id }}/.bench"
bench_path: "/Users/{{ ansible_user_id }}/frappe/frappe-bench" bench_path: "/Users/{{ ansible_user_id }}/frappe-bench"
mysql_config_template: "templates/simple_mariadb_config.cnf" mysql_config_template: "templates/simple_mariadb_config.cnf"
mysql_conf_dir: /usr/local/etc/my.cnf.d mysql_conf_dir: /usr/local/etc/my.cnf.d
@ -31,4 +31,4 @@
# setup development environment # setup development environment
- include: includes/setup_dev_env.yml - include: includes/setup_dev_env.yml
when: not setup_production when: not production

View File

@ -1,8 +1,8 @@
--- ---
- hosts: localhost - hosts: localhost
vars: vars:
bench_repo_path: "/usr/local/frappe/bench-repo" bench_repo_path: "/home/{{ ansible_user_id }}/.bench"
bench_path: "/home/{{ ansible_user_id }}/frappe/frappe-bench" bench_path: "/home/{{ ansible_user_id }}/frappe-bench"
mysql_config_template: "templates/simple_mariadb_config.cnf" mysql_config_template: "templates/simple_mariadb_config.cnf"
mysql_conf_dir: /etc/mysql/conf.d/ mysql_conf_dir: /etc/mysql/conf.d/
wkhtmltopdf_version: 0.12.2.1 wkhtmltopdf_version: 0.12.2.1
@ -73,4 +73,4 @@
# setup development environment # setup development environment
- include: includes/setup_dev_env.yml - include: includes/setup_dev_env.yml
when: not setup_production when: not production

View File

@ -1,12 +1,8 @@
# wget setup_frappe.py | python # wget setup_frappe.py | python
import os import os, sys, subprocess, getpass, json, multiprocessing, shutil
import sys
import subprocess
import getpass
import json, multiprocessing
from distutils.spawn import find_executable from distutils.spawn import find_executable
bench_repo = '/usr/local/frappe/bench-repo' tmp_bench_repo = '/tmp/.bench'
def install_bench(args): def install_bench(args):
# pre-requisites for bench repo cloning # pre-requisites for bench repo cloning
@ -17,7 +13,7 @@ def install_bench(args):
], ],
'yum': [ 'yum': [
'sudo yum groupinstall -y "Development tools"', 'sudo yum groupinstall -y "Development tools"',
'sudo yum install -y git python-setuptools python-devel openssl-devel libffi-devel' 'sudo yum install -y epel-release redhat-lsb-core git python-setuptools python-devel openssl-devel libffi-devel'
], ],
# epel-release is required to install redis, so installing it before the playbook-run. # epel-release is required to install redis, so installing it before the playbook-run.
# redhat-lsb-core is required, so that ansible can set ansible_lsb variable # redhat-lsb-core is required, so that ansible can set ansible_lsb variable
@ -56,17 +52,26 @@ def install_bench(args):
if not success: if not success:
could_not_install('Ansible') could_not_install('Ansible')
if is_sudo_user():
raise Exception('Please run this script as a non-root user with sudo privileges, but without using sudo')
# clone bench repo # clone bench repo
clone_bench_repo() clone_bench_repo(args)
if is_sudo_user() and not args.user and not args.production:
raise Exception('Please run this script as a non-root user with sudo privileges, but without using sudo or pass --user=USER')
# create user if not exists
run_playbook('develop/create_user.yml', user=args.user, extra_args=vars(args))
# args is namespace, but we would like to use it as dict in calling function, so use vars() # args is namespace, but we would like to use it as dict in calling function, so use vars()
if args.develop: if args.develop:
run_playbook('develop/install.yml', sudo=True, extra_args=vars(args)) run_playbook('develop/install.yml', sudo=True, user=args.user, extra_args=vars(args))
elif args.setup_production:
run_playbook('production/install.yml', sudo=True, extra_args=vars(args)) elif args.production:
if not args.user:
args.user = 'frappe'
run_playbook('production/install.yml', sudo=True, user=args.user, extra_args=vars(args))
shutil.rmtree(tmp_bench_repo)
def install_python27(): def install_python27():
version = (sys.version_info[0], sys.version_info[1]) version = (sys.version_info[0], sys.version_info[1])
@ -89,25 +94,16 @@ def install_python27():
# replace current python with python2.7 # replace current python with python2.7
os.execvp('python2.7', ([] if is_sudo_user() else ['sudo']) + ['python2.7', __file__] + sys.argv[1:]) os.execvp('python2.7', ([] if is_sudo_user() else ['sudo']) + ['python2.7', __file__] + sys.argv[1:])
def clone_bench_repo(): def clone_bench_repo(args):
'''Clones the bench repository in the user folder''' '''Clones the bench repository in the user folder'''
if os.path.exists(tmp_bench_repo):
if os.path.exists(bench_repo):
return 0 return 0
run_os_command({ branch = args.bench_branch or 'develop'
'brew': 'mkdir -p /usr/local/frappe',
'apt-get': 'sudo mkdir -p /usr/local/frappe',
'yum': 'sudo mkdir -p /usr/local/frappe',
})
# change user
run_os_command({
'ls': 'sudo chown -R {user}:{user} /usr/local/frappe'.format(user=getpass.getuser()),
})
success = run_os_command( success = run_os_command(
{'git': 'git clone https://github.com/frappe/bench {bench_repo} --depth 1 --branch develop'.format(bench_repo=bench_repo)} {'git': 'git clone https://github.com/frappe/bench {bench_repo} --depth 1 --branch {branch}'.format(
bench_repo=tmp_bench_repo, branch=branch)}
) )
return success return success
@ -167,7 +163,7 @@ def get_passwords(run_travis=False):
} }
def get_extra_vars_json(extra_args, run_travis=False): def get_extra_vars_json(extra_args, run_travis=False):
# We need to pass setup_production as extra_vars to the playbook to execute conditionals in the # We need to pass production as extra_vars to the playbook to execute conditionals in the
# playbook. Extra variables can passed as json or key=value pair. Here, we will use JSON. # playbook. Extra variables can passed as json or key=value pair. Here, we will use JSON.
json_path = os.path.join(os.path.abspath(os.path.expanduser('~')), 'extra_vars.json') json_path = os.path.join(os.path.abspath(os.path.expanduser('~')), 'extra_vars.json')
extra_vars = dict(extra_args.items()) extra_vars = dict(extra_args.items())
@ -177,7 +173,7 @@ def get_extra_vars_json(extra_args, run_travis=False):
extra_vars.update(get_passwords(run_travis)) extra_vars.update(get_passwords(run_travis))
# Decide for branch to be cloned depending upon whether we setting up production # Decide for branch to be cloned depending upon whether we setting up production
branch = 'master' if extra_args.get('setup_production') else 'develop' branch = 'master' if extra_args.get('production') else 'develop'
extra_vars.update(branch=branch) extra_vars.update(branch=branch)
# Get max worker_connections in nginx. # Get max worker_connections in nginx.
@ -190,17 +186,23 @@ def get_extra_vars_json(extra_args, run_travis=False):
return ('@' + json_path) return ('@' + json_path)
def run_playbook(playbook_name, sudo=False, extra_args=None): def run_playbook(playbook_name, sudo=False, user=None, extra_args=None):
user = user or getpass.getuser()
if user == 'root':
raise Exception('--user cannot be root')
extra_args['frappe_user'] = user
extra_vars = get_extra_vars_json(extra_args) extra_vars = get_extra_vars_json(extra_args)
args = ['ansible-playbook', '-c', 'local', playbook_name, '-e', extra_vars] args = ['ansible-playbook', '-c', 'local', playbook_name, '-e', extra_vars]
if sudo: if sudo:
args.extend(['--become', '--become-user=frappe']) args.extend(['--become', '--become-user={0}'.format(user)])
if extra_args.get('verbosity'): if extra_args.get('verbosity'):
args.append('-vvvv') args.append('-vvvv')
success = subprocess.check_call(args, cwd=os.path.join(bench_repo, 'playbooks')) success = subprocess.check_call(args, cwd=os.path.join(tmp_bench_repo, 'playbooks'))
return success return success
def parse_commandline_args(): def parse_commandline_args():
@ -208,14 +210,14 @@ def parse_commandline_args():
parser = argparse.ArgumentParser(description='Frappe Installer') parser = argparse.ArgumentParser(description='Frappe Installer')
# Arguments develop and setup-production are mutually exclusive both can't be specified together. # Arguments develop and production are mutually exclusive both can't be specified together.
# Hence, we need to create a group for discouraging use of both options at the same time. # Hence, we need to create a group for discouraging use of both options at the same time.
args_group = parser.add_mutually_exclusive_group() args_group = parser.add_mutually_exclusive_group()
args_group.add_argument('--develop', dest='develop', action='store_true', default=False, args_group.add_argument('--develop', dest='develop', action='store_true', default=False,
help='Install developer setup') help='Install developer setup')
args_group.add_argument('--setup-production', dest='setup_production', action='store_true', args_group.add_argument('--production', dest='production', action='store_true',
default=False, help='Setup Production environment for bench') default=False, help='Setup Production environment for bench')
parser.add_argument('--site', dest='site', action='store', default='site1.local', parser.add_argument('--site', dest='site', action='store', default='site1.local',
@ -224,6 +226,10 @@ def parse_commandline_args():
parser.add_argument('--verbose', dest='verbosity', action='store_true', default=False, parser.add_argument('--verbose', dest='verbosity', action='store_true', default=False,
help='Run the script in verbose mode') help='Run the script in verbose mode')
parser.add_argument('--user', dest='user', help='Install frappe-bench for this user')
parser.add_argument('--bench-branch', dest='bench_branch', help='Clone a particular branch of bench repository')
# To enable testing of script using Travis, this should skip the prompt # To enable testing of script using Travis, this should skip the prompt
parser.add_argument('--run-travis', dest='run_travis', action='store_true', default=False, parser.add_argument('--run-travis', dest='run_travis', action='store_true', default=False,
help=argparse.SUPPRESS) help=argparse.SUPPRESS)

View File

@ -1,7 +1,7 @@
--- ---
- hosts: localhost - hosts: localhost
vars: vars:
bench_path: "/home/{{ ansible_user_id }}/frappe/frappe-bench" bench_path: "/home/{{ ansible_user_id }}/frappe-bench"
tasks: tasks:
@ -34,11 +34,12 @@
- name: Change permissions for frappe home folder - name: Change permissions for frappe home folder
file: file:
dest: /home/{{ ansible_user_id }} dest: '{{ ansible_env.HOME }}'
owner: '{{ ansible_user_id }}' owner: '{{ ansible_user_id }}'
group: '{{ ansible_user_id }}' group: '{{ ansible_user_id }}'
mode: 0755 mode: 0755
recurse: yes recurse: yes
state: directory
- name: Setup production - name: Setup production
become: yes become: yes