Source code for djangocms_installer.main

import logging
import os
import sys

from . import config, django, install


[docs]def execute(): # Log info and above to console logging.basicConfig(format="%(levelname)s: %(message)s", level=logging.INFO) config_data = config.parse(sys.argv[1:]) try: if config_data.plugins: config.show_plugins() elif config_data.dump_reqs: config.show_requirements(config_data) else: sys.stdout.write( "Creating the project\n" "Please wait while I install dependencies\n" "If I am stuck for a long time, please check for connectivity / PyPi issues\n" ) if not config_data.no_deps: if config_data.requirements_file: install.requirements( config_data.requirements_file, config_data.pip_options, True, verbose=config_data.verbose, ) else: install.requirements( config_data.requirements, config_data.pip_options, verbose=config_data.verbose, ) sys.stdout.write("Dependencies installed\nCreating the project\n") install.check_install(config_data) django.create_project(config_data) django.patch_settings(config_data) django.copy_files(config_data) if not config_data.no_sync: django.setup_database(config_data) if config_data.starting_page: django.load_starting_page(config_data) if not config_data.requirements_file: install.write_requirements(config_data) sys.stdout.write("All done!\n") sys.stdout.write( 'Get into "{}" directory and type "python manage.py runserver" to start your ' "project\n".format(os.path.abspath(config_data.project_directory)) ) except Exception: # Clean up your own mess install.cleanup_directory(config_data) doc_message = "Check documentation at https://djangocms-installer.readthedocs.io" exception_message = "\n\n{0}\n\n{1}\n\n{0}\n\n".format("*" * len(doc_message), doc_message) sys.stdout.write(exception_message) raise