def _execute(self, options, args): """Run the deployment.""" self.logger = get_logger(CommandGitHubDeploy.name) # Check if ghp-import is installed check_ghp_import_installed() # Build before deploying build = main(['build']) if build != 0: self.logger.error('Build failed, not deploying to GitHub') return build # Clean non-target files only_on_output, _ = real_scan_files(self.site) for f in only_on_output: os.unlink(f) # Remove drafts and future posts if requested (Issue #2406) undeployed_posts = clean_before_deployment(self.site) if undeployed_posts: self.logger.notice( "Deleted {0} posts due to DEPLOY_* settings".format( len(undeployed_posts))) # Commit and push self._commit_and_push(options['commit_message']) return
def _execute(self, options, args): """Run the deployment.""" self.logger = get_logger(CommandGitHubDeploy.name, STDERR_HANDLER) # Check if ghp-import is installed check_ghp_import_installed() # Build before deploying build = main(['build']) if build != 0: self.logger.error('Build failed, not deploying to GitHub') return build # Clean non-target files only_on_output, _ = real_scan_files(self.site) for f in only_on_output: os.unlink(f) # Remove drafts and future posts if requested (Issue #2406) undeployed_posts = clean_before_deployment(self.site) if undeployed_posts: self.logger.notice("Deleted {0} posts due to DEPLOY_* settings".format(len(undeployed_posts))) # Commit and push self._commit_and_push(options['commit_message']) return
def _execute(self, command, args): """Execute the deploy command.""" # Get last-deploy from persistent state last_deploy = self.site.state.get('last_deploy') if last_deploy is not None: last_deploy = dateutil.parser.parse(last_deploy) clean = False if self.site.config['COMMENT_SYSTEM'] and self.site.config[ 'COMMENT_SYSTEM_ID'] == 'nikolademo': self.logger.warning( "\nWARNING WARNING WARNING WARNING\n" "You are deploying using the nikolademo Disqus account.\n" "That means you will not be able to moderate the comments in your own site.\n" "And is probably not what you want to do.\n" "Think about it for 5 seconds, I'll wait :-)\n" "(press Ctrl+C to abort)\n") time.sleep(5) # Remove drafts and future posts if requested undeployed_posts = clean_before_deployment(self.site) if undeployed_posts: self.logger.warning( "Deleted {0} posts due to DEPLOY_* settings".format( len(undeployed_posts))) if args: presets = args else: presets = ['default'] # test for preset existence for preset in presets: try: self.site.config['DEPLOY_COMMANDS'][preset] except KeyError: self.logger.error('No such preset: {0}'.format(preset)) return 255 for preset in presets: self.logger.info("=> preset '{0}'".format(preset)) for command in self.site.config['DEPLOY_COMMANDS'][preset]: self.logger.info("==> {0}".format(command)) try: subprocess.check_call(command, shell=True) except subprocess.CalledProcessError as e: self.logger.error('Failed deployment -- command {0} ' 'returned {1}'.format( e.cmd, e.returncode)) return e.returncode self.logger.info("Successful deployment") new_deploy = datetime.utcnow() self._emit_deploy_event(last_deploy, new_deploy, clean, undeployed_posts) # Store timestamp of successful deployment self.site.state.set('last_deploy', new_deploy.isoformat()) if clean: self.logger.info( 'Looks like this is the first time you deployed this site. ' 'Let us know you are using Nikola ' 'at <https://users.getnikola.com/add/> if you want!')
def _execute(self, command, args): """Execute the deploy command.""" # Get last successful deploy date timestamp_path = os.path.join(self.site.config['CACHE_FOLDER'], 'lastdeploy') # Get last-deploy from persistent state last_deploy = self.site.state.get('last_deploy') if last_deploy is None: # If there is a last-deploy saved, move it to the new state persistence thing # FIXME: remove in Nikola 8 if os.path.isfile(timestamp_path): try: with io.open(timestamp_path, 'r', encoding='utf8') as inf: last_deploy = dateutil.parser.parse(inf.read()) clean = False except (IOError, Exception) as e: self.logger.debug("Problem when reading `{0}`: {1}".format(timestamp_path, e)) last_deploy = datetime(1970, 1, 1) clean = True os.unlink(timestamp_path) # Remove because from now on it's in state else: # Just a default last_deploy = datetime(1970, 1, 1) clean = True else: last_deploy = dateutil.parser.parse(last_deploy) clean = False if self.site.config['COMMENT_SYSTEM'] and self.site.config['COMMENT_SYSTEM_ID'] == 'nikolademo': self.logger.warn("\nWARNING WARNING WARNING WARNING\n" "You are deploying using the nikolademo Disqus account.\n" "That means you will not be able to moderate the comments in your own site.\n" "And is probably not what you want to do.\n" "Think about it for 5 seconds, I'll wait :-)\n" "(press Ctrl+C to abort)\n") time.sleep(5) # Remove drafts and future posts if requested undeployed_posts = clean_before_deployment(self.site) if undeployed_posts: self.logger.notice("Deleted {0} posts due to DEPLOY_* settings".format(len(undeployed_posts))) if args: presets = args else: presets = ['default'] # test for preset existence for preset in presets: try: self.site.config['DEPLOY_COMMANDS'][preset] except KeyError: self.logger.error('No such preset: {0}'.format(preset)) return 255 for preset in presets: self.logger.info("=> preset '{0}'".format(preset)) for command in self.site.config['DEPLOY_COMMANDS'][preset]: self.logger.info("==> {0}".format(command)) try: subprocess.check_call(command, shell=True) except subprocess.CalledProcessError as e: self.logger.error('Failed deployment -- command {0} ' 'returned {1}'.format(e.cmd, e.returncode)) return e.returncode self.logger.info("Successful deployment") new_deploy = datetime.utcnow() self._emit_deploy_event(last_deploy, new_deploy, clean, undeployed_posts) # Store timestamp of successful deployment self.site.state.set('last_deploy', new_deploy.isoformat()) if clean: self.logger.info( 'Looks like this is the first time you deployed this site. ' 'Let us know you are using Nikola ' 'at <https://users.getnikola.com/add/> if you want!')