mirror of
https://github.com/frappe/bench.git
synced 2025-01-24 23:48:24 +00:00
Merge branch 'develop' into staging
This commit is contained in:
commit
b186126629
@ -1,16 +0,0 @@
|
|||||||
version = 1
|
|
||||||
|
|
||||||
exclude_patterns = [
|
|
||||||
".*"
|
|
||||||
]
|
|
||||||
|
|
||||||
test_patterns = [
|
|
||||||
"bench/tests/**"
|
|
||||||
]
|
|
||||||
|
|
||||||
[[analyzers]]
|
|
||||||
name = "python"
|
|
||||||
enabled = true
|
|
||||||
dependency_file_paths = [
|
|
||||||
"requirements.txt"
|
|
||||||
]
|
|
16
README.md
16
README.md
@ -87,7 +87,7 @@ Download the Easy Install script and execute it:
|
|||||||
|
|
||||||
```sh
|
```sh
|
||||||
$ wget https://raw.githubusercontent.com/frappe/bench/develop/easy-install.py
|
$ wget https://raw.githubusercontent.com/frappe/bench/develop/easy-install.py
|
||||||
$ python3 easy-install.py --prod
|
$ python3 easy-install.py --prod --email your@email.tld
|
||||||
```
|
```
|
||||||
|
|
||||||
This script will install docker on your system and will fetch the required containers, setup bench and a default ERPNext instance.
|
This script will install docker on your system and will fetch the required containers, setup bench and a default ERPNext instance.
|
||||||
@ -107,14 +107,12 @@ usage: easy-install.py [-h] [-p] [-d] [-s SITENAME] [-n PROJECT] [--email EMAIL]
|
|||||||
Install Frappe with Docker
|
Install Frappe with Docker
|
||||||
|
|
||||||
options:
|
options:
|
||||||
-h, --help show this help message and exit
|
-h, --help show this help message and exit
|
||||||
-p, --prod Setup Production System
|
-p, --prod Setup Production System
|
||||||
-d, --dev Setup Development System
|
-d, --dev Setup Development System
|
||||||
-s SITENAME, --sitename SITENAME
|
-s SITENAME, --sitename SITENAME The Site Name for your production site
|
||||||
The Site Name for your production site
|
-n PROJECT, --project PROJECT Project Name
|
||||||
-n PROJECT, --project PROJECT
|
--email EMAIL Add email for the SSL.
|
||||||
Project Name
|
|
||||||
--email EMAIL Add email for the SSL.
|
|
||||||
```
|
```
|
||||||
|
|
||||||
#### Troubleshooting
|
#### Troubleshooting
|
||||||
|
@ -60,6 +60,7 @@ def execute_cmd(check_for_update=True, command: str = None, logger: Logger = Non
|
|||||||
|
|
||||||
|
|
||||||
def cli():
|
def cli():
|
||||||
|
setup_clear_cache()
|
||||||
global from_command_line, bench_config, is_envvar_warn_set, verbose
|
global from_command_line, bench_config, is_envvar_warn_set, verbose
|
||||||
|
|
||||||
from_command_line = True
|
from_command_line = True
|
||||||
@ -75,7 +76,6 @@ def cli():
|
|||||||
change_working_directory()
|
change_working_directory()
|
||||||
logger = setup_logging()
|
logger = setup_logging()
|
||||||
logger.info(command)
|
logger.info(command)
|
||||||
setup_clear_cache()
|
|
||||||
|
|
||||||
bench_config = get_config(".")
|
bench_config = get_config(".")
|
||||||
|
|
||||||
|
@ -71,14 +71,21 @@ def get_from_env(dir, file) -> Dict:
|
|||||||
return env_vars
|
return env_vars
|
||||||
|
|
||||||
|
|
||||||
def write_to_env(wd: str, site: str, db_pass: str, admin_pass: str, email: str) -> None:
|
def write_to_env(
|
||||||
|
wd: str,
|
||||||
|
site: str,
|
||||||
|
db_pass: str,
|
||||||
|
admin_pass: str,
|
||||||
|
email: str,
|
||||||
|
erpnext_version: str = None,
|
||||||
|
) -> None:
|
||||||
site_name = site or ""
|
site_name = site or ""
|
||||||
example_env = get_from_env(wd, "example.env")
|
example_env = get_from_env(wd, "example.env")
|
||||||
|
erpnext_version = erpnext_version or example_env["ERPNEXT_VERSION"]
|
||||||
with open(os.path.join(wd, ".env"), "w") as f:
|
with open(os.path.join(wd, ".env"), "w") as f:
|
||||||
f.writelines(
|
f.writelines(
|
||||||
[
|
[
|
||||||
f"FRAPPE_VERSION={example_env['FRAPPE_VERSION']}\n", # Defaults to latest version of Frappe
|
f"ERPNEXT_VERSION={erpnext_version}\n", # defaults to latest version of ERPNext
|
||||||
f"ERPNEXT_VERSION={example_env['ERPNEXT_VERSION']}\n", # defaults to latest version of ERPNext
|
|
||||||
f"DB_PASSWORD={db_pass}\n",
|
f"DB_PASSWORD={db_pass}\n",
|
||||||
"DB_HOST=db\n",
|
"DB_HOST=db\n",
|
||||||
"DB_PORT=3306\n",
|
"DB_PORT=3306\n",
|
||||||
@ -107,7 +114,7 @@ def check_repo_exists() -> bool:
|
|||||||
return os.path.exists(os.path.join(os.getcwd(), "frappe_docker"))
|
return os.path.exists(os.path.join(os.getcwd(), "frappe_docker"))
|
||||||
|
|
||||||
|
|
||||||
def setup_prod(project: str, sitename: str, email: str) -> None:
|
def setup_prod(project: str, sitename: str, email: str, version: str = None) -> None:
|
||||||
if check_repo_exists():
|
if check_repo_exists():
|
||||||
compose_file_name = os.path.join(os.path.expanduser("~"), f"{project}-compose.yml")
|
compose_file_name = os.path.join(os.path.expanduser("~"), f"{project}-compose.yml")
|
||||||
docker_repo_path = os.path.join(os.getcwd(), "frappe_docker")
|
docker_repo_path = os.path.join(os.getcwd(), "frappe_docker")
|
||||||
@ -122,7 +129,7 @@ def setup_prod(project: str, sitename: str, email: str) -> None:
|
|||||||
if not os.path.exists(os.path.join(docker_repo_path, ".env")):
|
if not os.path.exists(os.path.join(docker_repo_path, ".env")):
|
||||||
admin_pass = generate_pass()
|
admin_pass = generate_pass()
|
||||||
db_pass = generate_pass(9)
|
db_pass = generate_pass(9)
|
||||||
write_to_env(docker_repo_path, sitename, db_pass, admin_pass, email)
|
write_to_env(docker_repo_path, sitename, db_pass, admin_pass, email, version)
|
||||||
cprint(
|
cprint(
|
||||||
"\nA .env file is generated with basic configs. Please edit it to fit to your needs \n",
|
"\nA .env file is generated with basic configs. Please edit it to fit to your needs \n",
|
||||||
level=3,
|
level=3,
|
||||||
@ -150,8 +157,6 @@ def setup_prod(project: str, sitename: str, email: str) -> None:
|
|||||||
"overrides/compose.redis.yaml",
|
"overrides/compose.redis.yaml",
|
||||||
# "-f", "overrides/compose.noproxy.yaml", TODO: Add support for local proxying without HTTPs
|
# "-f", "overrides/compose.noproxy.yaml", TODO: Add support for local proxying without HTTPs
|
||||||
"-f",
|
"-f",
|
||||||
"overrides/compose.erpnext.yaml",
|
|
||||||
"-f",
|
|
||||||
"overrides/compose.https.yaml",
|
"overrides/compose.https.yaml",
|
||||||
"--env-file",
|
"--env-file",
|
||||||
".env",
|
".env",
|
||||||
@ -202,6 +207,7 @@ def setup_prod(project: str, sitename: str, email: str) -> None:
|
|||||||
"bench",
|
"bench",
|
||||||
"new-site",
|
"new-site",
|
||||||
sitename,
|
sitename,
|
||||||
|
"--no-mariadb-socket",
|
||||||
"--db-root-password",
|
"--db-root-password",
|
||||||
db_pass,
|
db_pass,
|
||||||
"--admin-password",
|
"--admin-password",
|
||||||
@ -220,7 +226,7 @@ def setup_prod(project: str, sitename: str, email: str) -> None:
|
|||||||
else:
|
else:
|
||||||
install_docker()
|
install_docker()
|
||||||
clone_frappe_docker_repo()
|
clone_frappe_docker_repo()
|
||||||
setup_prod(project, sitename, email) # Recursive
|
setup_prod(project, sitename, email, version) # Recursive
|
||||||
|
|
||||||
|
|
||||||
def setup_dev_instance(project: str):
|
def setup_dev_instance(project: str):
|
||||||
@ -306,6 +312,9 @@ if __name__ == "__main__":
|
|||||||
parser.add_argument(
|
parser.add_argument(
|
||||||
"--email", help="Add email for the SSL.", required="--prod" in sys.argv
|
"--email", help="Add email for the SSL.", required="--prod" in sys.argv
|
||||||
)
|
)
|
||||||
|
parser.add_argument(
|
||||||
|
"-v", "--version", help="ERPNext version to install, defaults to latest stable"
|
||||||
|
)
|
||||||
args = parser.parse_args()
|
args = parser.parse_args()
|
||||||
if args.dev:
|
if args.dev:
|
||||||
cprint("\nSetting Up Development Instance\n", level=2)
|
cprint("\nSetting Up Development Instance\n", level=2)
|
||||||
@ -317,6 +326,6 @@ if __name__ == "__main__":
|
|||||||
if "example.com" in args.email:
|
if "example.com" in args.email:
|
||||||
cprint("Emails with example.com not acceptable", level=1)
|
cprint("Emails with example.com not acceptable", level=1)
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
setup_prod(args.project, args.sitename, args.email)
|
setup_prod(args.project, args.sitename, args.email, args.version)
|
||||||
else:
|
else:
|
||||||
parser.print_help()
|
parser.print_help()
|
||||||
|
@ -20,7 +20,7 @@ classifiers = [
|
|||||||
]
|
]
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"Click>=7.0",
|
"Click>=7.0",
|
||||||
"GitPython~=2.1.15",
|
"GitPython~=3.1.30",
|
||||||
"honcho",
|
"honcho",
|
||||||
"Jinja2~=3.0.3",
|
"Jinja2~=3.0.3",
|
||||||
"python-crontab~=2.6.0",
|
"python-crontab~=2.6.0",
|
||||||
|
Loading…
x
Reference in New Issue
Block a user