def am_createsite(annroot, userhome, options): """ Create Annalist empty site data. annroot is the root directory for the Annalist software installation. userhome is the home directory for the host system user issuing the command. options contains options parsed from the command line. returns 0 if all is well, or a non-zero status code. This value is intended to be used as an exit status code for the calling program. """ status = am_errors.AM_SUCCESS sitesettings = am_get_site_settings(annroot, userhome, options) if not sitesettings: print("Settings not found (%s)"%(options.configuration), file=sys.stderr) return am_errors.AM_NOSETTINGS if len(options.args) > 0: print( "Unexpected arguments for %s: (%s)"% (options.command, " ".join(options.args)), file=sys.stderr ) return am_errors.AM_UNEXPECTEDARGS site_layout = layout.Layout(sitesettings.BASE_DATA_DIR) sitebasedir = site_layout.SITE_PATH sitebaseurl = "/annalist/" # @@TODO: figure more robust way to define this # --- If old site exists and --force option given, remove it if os.path.exists(os.path.join(sitebasedir, site_layout.SITEDATA_DIR)): if options.force: print("Removing old Annalist site at %s"%(sitebasedir)) log.info("rmtree: %s"%(sitebasedir)) removetree(sitebasedir) else: print( "Old data already exists at %s (use --force or -f to overwrite)"% (sitebasedir), file=sys.stderr ) return am_errors.AM_EXISTS # --- Initialize empty site data in target directory print("Initializing Annalist site in %s"%(sitebasedir)) site = Site.create_empty_site_data( sitebaseurl, sitebasedir, label="Annalist site (%s configuration)"%options.configuration, description="Annalist %s site metadata and site-wide values."%options.configuration ) sitedata = site.site_data_collection() Site.create_site_readme(site) site_data_src = os.path.join(annroot, "annalist/data/sitedata") # @@TODO: more robust definition site_data_tgt, site_data_file = sitedata._dir_path() print("Copy Annalist site data") print("from %s"%site_data_src) for sdir in layout.COLL_DIRS: print("- %s -> %s"%(sdir, site_data_tgt)) Site.replace_site_data_dir(sitedata, sdir, site_data_src) print("Generating %s"%(site_layout.SITEDATA_CONTEXT_DIR)) sitedata.generate_coll_jsonld_context() print("Now run 'annalist-manager initialize' to create site admin database") return status
def am_createsite(annroot, userhome, options): """ Create Annalist empty site data. annroot is the root directory for the Annalist software installation. userhome is the home directory for the host system user issuing the command. options contains options parsed from the command line. returns 0 if all is well, or a non-zero status code. This value is intended to be used as an exit status code for the calling program. """ status = am_errors.AM_SUCCESS sitesettings = am_get_site_settings(annroot, userhome, options) if not sitesettings: print("Settings not found (%s)"%(options.configuration), file=sys.stderr) return am_errors.AM_NOSETTINGS if len(options.args) > 0: print( "Unexpected arguments for %s: (%s)"% (options.command, " ".join(options.args)), file=sys.stderr ) return am_errors.AM_UNEXPECTEDARGS site_layout = layout.Layout(sitesettings.BASE_DATA_DIR, sitesettings.SITE_DIR_NAME) sitebasedir = site_layout.SITE_PATH #@@@@@ sitebaseurl = "/annalist/" # @@TODO: figure more robust way to define this sitebaseurl = sitesettings.STATIC_URL # --- If old site exists and --force option given, remove it if os.path.exists(os.path.join(sitebasedir, site_layout.SITEDATA_DIR)): if options.force: print("Removing old Annalist site at %s"%(sitebasedir)) log.info("rmtree: %s"%(sitebasedir)) removetree(sitebasedir) else: print( "Old data already exists at %s (use '--force' or '-f' to overwrite)."% (sitebasedir), file=sys.stderr ) print( "NOTE: using '--force' or '-f' "+ "removes old site user permissions and namespace data "+ "and requires re-initialization of Django database with local usernames; "+ "consider using 'annalist-manager updatesite'." ) return am_errors.AM_EXISTS # --- Initialize empty site data in target directory print("Initializing Annalist site in %s"%(sitebasedir)) site = Site.create_site_metadata( sitebaseurl, sitebasedir, label="Annalist site (%s configuration)"%options.configuration, description="Annalist %s site metadata and site-wide values."%options.configuration ) sitedata = site.site_data_collection() Site.create_site_readme(site) site_data_src = os.path.join(annroot, "annalist/data/sitedata") # @@TODO: more robust definition site_data_tgt, site_data_file = sitedata._dir_path() print("Copy Annalist site data") print("from %s"%site_data_src) for sdir in layout.COLL_DIRS: print("- %s -> %s"%(sdir, site_data_tgt)) Site.replace_site_data_dir(sitedata, sdir, site_data_src) # @@TODO: filename logic copied from EntityRoot and Collection - create separate method for getting this (sitedata_dir, sitedata_file) = sitedata._dir_path() context_dir = os.path.join(sitedata_dir, layout.META_COLL_BASE_REF) context_file = os.path.join(context_dir, layout.COLL_CONTEXT_FILE) #@@ print("Generating %s"%(context_file)) sitedata.generate_coll_jsonld_context() # --- Copy provider data to site config provider directory provider_dir_src = os.path.join(annroot, "annalist/data/identity_providers") provider_dir_tgt = os.path.join(sitesettings.CONFIG_BASE, "providers") print("Copy identity provider data:") print("- from: %s"%(provider_dir_src,)) print("- to: %s"%(provider_dir_tgt,)) ensure_dir(provider_dir_tgt) updatetree(provider_dir_src, provider_dir_tgt) # --- Copy sample system configuration files to config directory config_dir_src = os.path.join(annroot, "annalist/data/config_examples") config_dir_tgt = os.path.join(sitesettings.CONFIG_BASE, "config") print("Copy system configuration sample files:") print("- from: %s"%(config_dir_src,)) print("- to: %s"%(config_dir_tgt,)) ensure_dir(config_dir_tgt) updatetree(config_dir_src, config_dir_tgt) # --- Created print("Now run 'annalist-manager initialize' to create site admin database") return status
def am_createsite(annroot, userhome, options): """ Create Annalist empty site data. annroot is the root directory for the Annalist software installation. userhome is the home directory for the host system user issuing the command. options contains options parsed from the command line. returns 0 if all is well, or a non-zero status code. This value is intended to be used as an exit status code for the calling program. """ status = am_errors.AM_SUCCESS sitesettings = am_get_site_settings(annroot, userhome, options) if not sitesettings: print("Settings not found (%s)" % (options.configuration), file=sys.stderr) return am_errors.AM_NOSETTINGS if len(options.args) > 0: print("Unexpected arguments for %s: (%s)" % (options.command, " ".join(options.args)), file=sys.stderr) return am_errors.AM_UNEXPECTEDARGS site_layout = layout.Layout(sitesettings.BASE_DATA_DIR) sitebasedir = site_layout.SITE_PATH sitebaseurl = "/annalist/" # @@TODO: figure more robust way to define this # --- If old site exists and --force option given, remove it if os.path.exists(os.path.join(sitebasedir, site_layout.SITEDATA_DIR)): if options.force: print("Removing old Annalist site at %s" % (sitebasedir)) log.info("rmtree: %s" % (sitebasedir)) removetree(sitebasedir) else: print( "Old data already exists at %s (use --force or -f to overwrite)" % (sitebasedir), file=sys.stderr) return am_errors.AM_EXISTS # --- Initialize empty site data in target directory print("Initializing Annalist site in %s" % (sitebasedir)) site = Site.create_empty_site_data( sitebaseurl, sitebasedir, label="Annalist site (%s configuration)" % options.configuration, description="Annalist %s site metadata and site-wide values." % options.configuration) sitedata = site.site_data_collection() Site.create_site_readme(site) site_data_src = os.path.join( annroot, "annalist/data/sitedata") # @@TODO: more robust definition site_data_tgt, site_data_file = sitedata._dir_path() print("Copy Annalist site data") print("from %s" % site_data_src) for sdir in layout.COLL_DIRS: print("- %s -> %s" % (sdir, site_data_tgt)) Site.replace_site_data_dir(sitedata, sdir, site_data_src) print("Generating %s" % (site_layout.SITEDATA_CONTEXT_DIR)) sitedata.generate_coll_jsonld_context() print( "Now run 'annalist-manager initialize' to create site admin database") return status
def am_createsite(annroot, userhome, options): """ Create Annalist empty site data. annroot is the root directory for the Annalist software installation. userhome is the home directory for the host system user issuing the command. options contains options parsed from the command line. returns 0 if all is well, or a non-zero status code. This value is intended to be used as an exit status code for the calling program. """ status = am_errors.AM_SUCCESS sitesettings = am_get_site_settings(annroot, userhome, options) if not sitesettings: print("Settings not found (%s)" % (options.configuration), file=sys.stderr) return am_errors.AM_NOSETTINGS if len(options.args) > 0: print("Unexpected arguments for %s: (%s)" % (options.command, " ".join(options.args)), file=sys.stderr) return am_errors.AM_UNEXPECTEDARGS site_layout = layout.Layout(sitesettings.BASE_DATA_DIR) sitebasedir = site_layout.SITE_PATH sitebaseurl = "/annalist/" # @@TODO: figure more robust way to define this # --- If old site exists and --force option given, remove it if os.path.exists(os.path.join(sitebasedir, site_layout.SITEDATA_DIR)): if options.force: print("Removing old Annalist site at %s" % (sitebasedir)) log.info("rmtree: %s" % (sitebasedir)) removetree(sitebasedir) else: print( "Old data already exists at %s (use '--force' or '-f' to overwrite)." % (sitebasedir), file=sys.stderr) print( "NOTE: using '--force' or '-f' " + "removes old site user permissions and namespace data " + "and requires re-initialization of Django database with local usernames; " + "consider using 'annalist-manager updatesite'.") return am_errors.AM_EXISTS # --- Initialize empty site data in target directory print("Initializing Annalist site in %s" % (sitebasedir)) site = Site.create_site_metadata( sitebaseurl, sitebasedir, label="Annalist site (%s configuration)" % options.configuration, description="Annalist %s site metadata and site-wide values." % options.configuration) sitedata = site.site_data_collection() Site.create_site_readme(site) site_data_src = os.path.join( annroot, "annalist/data/sitedata") # @@TODO: more robust definition site_data_tgt, site_data_file = sitedata._dir_path() print("Copy Annalist site data") print("from %s" % site_data_src) for sdir in layout.COLL_DIRS: print("- %s -> %s" % (sdir, site_data_tgt)) Site.replace_site_data_dir(sitedata, sdir, site_data_src) # @@TODO: filename logic copied from EntityRoot and Collection - create separate method for getting this (sitedata_dir, sitedata_file) = sitedata._dir_path() context_dir = os.path.join(sitedata_dir, layout.META_COLL_BASE_REF) context_file = os.path.join(context_dir, layout.COLL_CONTEXT_FILE) #@@ print("Generating %s" % (context_file)) sitedata.generate_coll_jsonld_context() # --- Copy provider data to site config provider directory provider_dir_src = os.path.join(annroot, "annalist/data/identity_providers") provider_dir_tgt = os.path.join(sitesettings.CONFIG_BASE, "providers") print("Copy identity provider data:") print("- from: %s" % (provider_dir_src, )) print("- to: %s" % (provider_dir_tgt, )) ensure_dir(provider_dir_tgt) updatetree(provider_dir_src, provider_dir_tgt) # --- Created print( "Now run 'annalist-manager initialize' to create site admin database") return status