public function editAction() { $this->view->headTitle('Configuration Management'); $this->view->headLink()->appendStylesheet("/css/template/form.css"); $this->view->headLink()->appendStylesheet("/css/pages/configs_edit.css"); $projects = new GD_Model_ProjectsMapper(); $project_slug = $this->_getParam("project"); if ($project_slug != "") { $project = $projects->getProjectBySlug($project_slug); } $this->view->project = $project; $configs_map = new GD_Model_ConfigsMapper(); $config = new GD_Model_Config(); $config_id = $this->_getParam("id"); $configs_servers_map = new GD_Model_ConfigsServersMapper(); $config_server_ids = array(); $servers_map = new GD_Model_ServersMapper(); $servers = $servers_map->getServersByProject($project->getId()); $this->view->servers = $servers; $user = GD_Auth_Database::GetLoggedInUser(); if ($config_id > 0) { $configs_map->find($config_id, $config); $config_servers = $configs_servers_map->getAllServersForConfig($config->getId()); foreach ($config_servers as $cs) { $config_server_ids[] = $cs->getServersId(); } } else { $config->setProjectsId($project->getId()); $config->setDateAdded(date("Y-m-d H:i:s")); $config->setAddedUsersId($user->getId()); foreach ($servers as $server) { $config_server_ids[] = $server->getId(); } } $this->view->config_server_ids = $config_server_ids; if ($this->getRequest()->isPost()) { // First save the config file itself $config->setFilename($this->_getParam("filename", "")); $config->setContent($this->_getParam("configContent", "")); $config->setUpdatedUsersId($user->getId()); $configs_map->save($config); // Then loop through the config_servers and update $configs_servers_map->deleteAllServersForConfig($config->getId()); $add_to_servers = $this->_getParam("servers", array()); foreach ($add_to_servers as $server_id) { $cs = new GD_Model_ConfigServer(); $cs->setConfigsId($config->getId()); $cs->setServersId($server_id); $configs_servers_map->save($cs); } $this->_redirect($this->getFrontController()->getBaseUrl() . "/project/" . $this->_getParam("project") . "/configs"); } else { $this->view->config = $config; } }
/** * Implement this by setting $obj values (e.g. $obj->setId($row->Id) from a DB row * @param GD_Model_ConfigServer $obj * @param Zend_Db_Table_Row_Abstract $row */ protected function populateObjectFromRow(&$obj, Zend_Db_Table_Row_Abstract $row) { $obj->setId($row->id)->setServersId($row->servers_id)->setConfigsId($row->configs_id); $s_map = new GD_Model_ServersMapper(); $server = new GD_Model_Server(); $s_map->populateObjectFromRow($server, $row->findParentRow('GD_Model_DbTable_Servers')); $obj->setServer($server); $c_map = new GD_Model_ConfigsMapper(); $config = new GD_Model_Config(); $c_map->populateObjectFromRow($config, $row->findParentRow('GD_Model_DbTable_Configs')); $obj->setConfig($config); }
public function executeDeploymentStartAction() { // session_start blocks other requests, so close the session for the // status AJAX request to work Zend_Session::writeClose(); ob_start(); GD_Debug::StartDeploymentLog($this->_getParam("id")); GD_Debug::Log("Setting time limit... ", GD_Debug::DEBUG_BASIC, false); set_time_limit(0); GD_Debug::Log("done.", GD_Debug::DEBUG_BASIC, true, false); // Project information GD_Debug::Log("Loading project... ", GD_Debug::DEBUG_BASIC, false); $projects = new GD_Model_ProjectsMapper(); $project_slug = $this->_getParam("project"); if ($project_slug != "") { $project = $projects->getProjectBySlug($project_slug); } if (is_null($project)) { throw new GD_Exception("Project '{$project_slug}' was not set up."); } GD_Debug::Log("done.", GD_Debug::DEBUG_BASIC, true, false); // Deployment information GD_Debug::Log("Loading deployment information... ", GD_Debug::DEBUG_BASIC, false); $deployments = new GD_Model_DeploymentsMapper(); $deployment = new GD_Model_Deployment(); $deployments->find($this->_getParam('id'), $deployment); GD_Debug::Log("done.", GD_Debug::DEBUG_BASIC, true, false); // Server information GD_Debug::Log("Loading server information... ", GD_Debug::DEBUG_BASIC, false); $servers = new GD_Model_ServersMapper(); $server = new GD_Model_Server(); $servers->find($deployment->getServersId(), $server); GD_Debug::Log("done.", GD_Debug::DEBUG_BASIC, true, false); // Update the deployment status to show we're now running GD_Debug::Log("Updating deployment status to running... ", GD_Debug::DEBUG_BASIC, false); $deployment->setDeploymentStatusesId(2); // Running $deployments->save($deployment); GD_Debug::Log("done.", GD_Debug::DEBUG_BASIC, true, false); // Perform a git pull to check we're up to date $git = GD_Git::FromProject($project); $git->gitPull(); // File list to action GD_Debug::Log("Getting file list... ", GD_Debug::DEBUG_BASIC, false); $deployment_files = new GD_Model_DeploymentFilesMapper(); $deployment_files_statuses = new GD_Model_DeploymentFileStatusesMapper(); $file_list = $deployment_files->getDeploymentFilesByDeployment($deployment->getId()); GD_Debug::Log("done.", GD_Debug::DEBUG_BASIC, true, false); // Check out the revision we want to upload from GD_Debug::Log("Checking out revision {$deployment->getToRevision()}... ", GD_Debug::DEBUG_BASIC, false); $previous_ref = $git->getCurrentBranch(true); $res = $git->gitCheckout($deployment->getToRevision()); if (!$res) { GD_Debug::Log("FAILED.", GD_Debug::DEBUG_BASIC, true, false); } else { GD_Debug::Log("done.", GD_Debug::DEBUG_BASIC, true, false); } $errors = false; // Do the upload GD_Debug::Log("Actioning files now.", GD_Debug::DEBUG_BASIC); $ftp = GD_Ftp::FromServer($server); try { $ftp->connect(); } catch (GD_Exception $ex) { GD_Debug::Log("FTP Connect failed: {$ex->getMessage()}", GD_Debug::DEBUG_BASIC); } $config_map = new GD_Model_ConfigsMapper(); foreach ($file_list as $file) { GD_Debug::Log("Actioning '{$file->getDetails()}'... ", GD_Debug::DEBUG_BASIC, false); $file->setDeploymentFileStatusesId($deployment_files_statuses->getDeploymentFileStatusByCode('IN_PROGRESS')->getId()); $deployment_files->save($file); $matches = array(); $is_config_file = preg_match('/^!CFG!(\\d+)!(.*)$/', $file->getDetails(), $matches); try { if ($is_config_file == 1) { // Configuration file - store in temp dir from DB then upload $tmpfile = tempnam(sys_get_temp_dir(), 'gdcfg'); $config = new GD_Model_Config(); $config_map->find($matches[1], $config); file_put_contents($tmpfile, $config->getContent()); GD_Debug::Log(" >> to '{$matches[2]}'", GD_Debug::DEBUG_BASIC, false, false); $ftp->upload($tmpfile, $matches[2]); } else { // Regular file - upload as normal switch ($file->getDeploymentFileAction()->getGitStatus()) { case 'A': case 'M': $ftp->upload($git->getGitDir() . $file->getDetails(), $file->getDetails()); break; case 'D': $ftp->delete($file->getDetails()); break; default: throw GD_Exception("Warning, unhandled action: '" . $file->getDeploymentFileAction()->getGitStatus() . "' ({$file->getDetails()}"); break; } } $file->setDeploymentFileStatusesId($deployment_files_statuses->getDeploymentFileStatusByCode('COMPLETE')->getId()); GD_Debug::Log("done.", GD_Debug::DEBUG_BASIC, true, false); } catch (GD_Exception $ex) { // Only fail the whole deployment if we're not a delete action if ($file->getDeploymentFileAction()->getGitStatus() != 'D') { $errors = true; } $file->setDeploymentFileStatusesId($deployment_files_statuses->getDeploymentFileStatusByCode('FAILED')->getId()); GD_Debug::Log("FAILED [" . $ex->getMessage() . "].", GD_Debug::DEBUG_BASIC, true, false); } $deployment_files->save($file); } // Revert to previous revision GD_Debug::Log("Checking out revision {$previous_ref}... ", GD_Debug::DEBUG_BASIC, false); $res = $git->gitCheckout($previous_ref); if (!$res) { GD_Debug::Log("FAILED.", GD_Debug::DEBUG_BASIC, true, false); } else { GD_Debug::Log("done.", GD_Debug::DEBUG_BASIC, true, false); } GD_Debug::Log("Setting deployment status " . ($errors ? "[errors]" : "[success]") . "... ", GD_Debug::DEBUG_BASIC, false); if ($errors) { $deployment->setDeploymentStatusesId(4); // Failed $deployments->save($deployment); } else { $deployment->setDeploymentStatusesId(3); // Complete $deployments->save($deployment); } GD_Debug::Log("done.", GD_Debug::DEBUG_BASIC, true, false); GD_Debug::Log("All finished.", GD_Debug::DEBUG_BASIC); $buf = ob_get_contents(); if ($buf) { GD_Debug::Log("Extra content:\n\n{$buf}", GD_Debug::DEBUG_BASIC); } GD_Debug::EndDeploymentLog(); ob_end_clean(); flush(); die; }