function generateLogsContent(errorInfoJson) {
/*
content = '
'
for (i=0; i < errorInfoJson['progress'].length; i++) {
var subTxnId = errorInfoJson['progress'][i]['subTxnId'];
var state = errorInfoJson['progress'][i]['state'];
var desc = errorInfoJson['progress'][i]['description'];
var stateClass = 'ProgressLogsSubTxnState' + state;
var subTxnDiv = '
';
for (hostName in errorInfoJson['logs'][subTxnId]['nodeLogs']) {
var nodeReport = errorInfoJson['logs'][subTxnId]['nodeLogs'][hostName];
var hostState = nodeReport['overall'];
var hostStateClass = 'ProgressLogsSubTxnNodeState' + hostState;
var reportContainer = '
'
+ '
'
+ globalYui.JSON.stringify(nodeReport.message)
+ '
'
+ '
' + '
'
subTxnDiv += reportContainer;
}
subTxnDiv += '
' + '
';
content += subTxnDiv;
}
content += '
';
return content;
*/
return '' +
globalYui.JSON.stringify( errorInfoJson.logs, null, 4 ) +
'
';
}
function renderDeployProgress (deployProgressInfo) {
hideLoadingImg();
/* At this point, our users are done with the installation wizard
* and have asked for a deploy, so there's no going back - remove
* all traces of #installationWizardProgressBarDivId.
*/
var installationWizardProgressBarDiv = globalYui.one('#installationWizardProgressBarDivId');
/* But be safe and perform this removal only if #installationWizardProgressBarDivId
* actually exists on the page - this .js file is now being used in more
* than one place, so this robustness is needed.
*/
if (installationWizardProgressBarDiv) {
installationWizardProgressBarDiv.setStyle('display', 'none')
}
var hmcRestartMsg = '';
if (deployProgressInfo.nagiosGangliaCoHosted != null
&& deployProgressInfo.nagiosGangliaCoHosted) {
hmcRestartMsg = 'Note: You need to restart HMC as'
+ ' Nagios/Ganglia are co-hosted on this server.
Please restart'
+ ' HMC using \"service hmc restart\".
After that is done, ';
} else {
hmcRestartMsg = 'Please ';
}
hmcRestartMsg +=
'' +
'click here to start managing your cluster.' +
'';
var deployProgressStatusMessage = {
success:
'' +
'Your cluster is ready!
' + hmcRestartMsg +
'
',
failure:
'' +
'Failed to finish setting up the cluster.
Take a look at the ' +
'deploy logs' +
' to find out what might have gone wrong.' +
'' +
'Reinstall Cluster' +
'' +
'
'
};
var deployProgressPostCompletionFixup = {
success: function( txnProgressWidget ) {
globalYui.one("#clustersListLinkId").on( "click", function(e) {
document.location.href = generateHMCUrl();
});
},
failure: function( txnProgressWidget ) {
globalYui.one("#restartInstallationWizardLinkId").on( "click", function(e) {
document.location.href = 'installFailed.php';
});
/* Create the panel that'll display our error info. */
var errorInfoPanel =
createInformationalPanel( '#informationalPanelContainerDivId', 'Deploy Logs' );
/* Prime the panel to start off showing our stock loading image. */
var errorInfoPanelBodyContent =
'
';
/* Make the call to our backend to fetch the report for this txnId. */
globalYui.io('../php/frontend/fetchTxnLogs.php?clusterName=' +
txnProgressWidget.txnProgressContext.clusterName + '&txnId=' + txnProgressWidget.txnProgressContext.txnId, {
timeout: 10000,
on: {
success: function (x,o) {
globalYui.log("RAW JSON DATA: " + o.responseText);
var errorInfoJson = null;
// Process the JSON data returned from the server
try {
errorInfoJson = globalYui.JSON.parse(o.responseText);
}
catch (e) {
alert("JSON Parse failed!");
return;
}
/* TODO XXX Remove some of the noise from this to allow
* for better corelation - for now, just dump a
* pretty-printed version of the returned JSON.
*/
errorInfoPanelBodyContent = generateLogsContent(errorInfoJson);
/* Update the contents of errorInfoPanel (which was, till
* now, showing the loading image).
*/
errorInfoPanel.set( 'bodyContent', errorInfoPanelBodyContent );
},
failure: function (x,o) {
alert("Async call failed!");
}
}
});
/* Register a click-handler for #showDeployTxnLogsLinkId to render
* the contents inside errorInfoPanel (and make it visible).
*/
globalYui.one("#showDeployTxnLogsLinkId").on( "click", function(e) {
errorInfoPanel.set( 'centered', true );
errorInfoPanel.set( 'bodyContent', errorInfoPanelBodyContent );
errorInfoPanel.show();
});
}
};
var deployProgressWidget = new TxnProgressWidget
( deployProgressInfo, 'Cluster Deploy', deployProgressStatusMessage, deployProgressPostCompletionFixup );
deployProgressWidget.show();
}