NIFI-3848:

- Allowing the revision check to be overridden when the state of a nodes connection to the cluster changes.

This closes #1811
This commit is contained in:
Matt Gilman 2017-05-16 14:37:38 -04:00 committed by Jeff Storck
parent 6b71b4cbb8
commit c50d516076
9 changed files with 39 additions and 8 deletions

View File

@ -174,7 +174,8 @@
// refresh the graph // refresh the graph
nfGraph.expireCaches(now); nfGraph.expireCaches(now);
nfGraph.set(processGroupFlow.flow, $.extend({ nfGraph.set(processGroupFlow.flow, $.extend({
'selectAll': false 'selectAll': false,
'overrideRevisionCheck': nfClusterSummary.didConnectedStateChange()
}, options)); }, options));
// update component visibility // update component visibility

View File

@ -2000,16 +2000,18 @@
set: function (connectionEntities, options) { set: function (connectionEntities, options) {
var selectAll = false; var selectAll = false;
var transition = false; var transition = false;
var overrideRevisionCheck = false;
if (nfCommon.isDefinedAndNotNull(options)) { if (nfCommon.isDefinedAndNotNull(options)) {
selectAll = nfCommon.isDefinedAndNotNull(options.selectAll) ? options.selectAll : selectAll; selectAll = nfCommon.isDefinedAndNotNull(options.selectAll) ? options.selectAll : selectAll;
transition = nfCommon.isDefinedAndNotNull(options.transition) ? options.transition : transition; transition = nfCommon.isDefinedAndNotNull(options.transition) ? options.transition : transition;
overrideRevisionCheck = nfCommon.isDefinedAndNotNull(options.overrideRevisionCheck) ? options.overrideRevisionCheck : overrideRevisionCheck;
} }
var set = function (proposedConnectionEntity) { var set = function (proposedConnectionEntity) {
var currentConnectionEntity = connectionMap.get(proposedConnectionEntity.id); var currentConnectionEntity = connectionMap.get(proposedConnectionEntity.id);
// set the connection if appropriate due to revision and wasn't previously removed // set the connection if appropriate due to revision and wasn't previously removed
if (nfClient.isNewerRevision(currentConnectionEntity, proposedConnectionEntity) && !removedCache.has(proposedConnectionEntity.id)) { if ((nfClient.isNewerRevision(currentConnectionEntity, proposedConnectionEntity) && !removedCache.has(proposedConnectionEntity.id)) || overrideRevisionCheck === true) {
connectionMap.set(proposedConnectionEntity.id, $.extend({ connectionMap.set(proposedConnectionEntity.id, $.extend({
type: 'Connection' type: 'Connection'
}, proposedConnectionEntity)); }, proposedConnectionEntity));

View File

@ -267,16 +267,18 @@
set: function (funnelEntities, options) { set: function (funnelEntities, options) {
var selectAll = false; var selectAll = false;
var transition = false; var transition = false;
var overrideRevisionCheck = false;
if (nfCommon.isDefinedAndNotNull(options)) { if (nfCommon.isDefinedAndNotNull(options)) {
selectAll = nfCommon.isDefinedAndNotNull(options.selectAll) ? options.selectAll : selectAll; selectAll = nfCommon.isDefinedAndNotNull(options.selectAll) ? options.selectAll : selectAll;
transition = nfCommon.isDefinedAndNotNull(options.transition) ? options.transition : transition; transition = nfCommon.isDefinedAndNotNull(options.transition) ? options.transition : transition;
overrideRevisionCheck = nfCommon.isDefinedAndNotNull(options.overrideRevisionCheck) ? options.overrideRevisionCheck : overrideRevisionCheck;
} }
var set = function (proposedFunnelEntity) { var set = function (proposedFunnelEntity) {
var currentFunnelEntity = funnelMap.get(proposedFunnelEntity.id); var currentFunnelEntity = funnelMap.get(proposedFunnelEntity.id);
// set the funnel if appropriate due to revision and wasn't previously removed // set the funnel if appropriate due to revision and wasn't previously removed
if (nfClient.isNewerRevision(currentFunnelEntity, proposedFunnelEntity) && !removedCache.has(proposedFunnelEntity.id)) { if ((nfClient.isNewerRevision(currentFunnelEntity, proposedFunnelEntity) && !removedCache.has(proposedFunnelEntity.id)) || overrideRevisionCheck === true) {
funnelMap.set(proposedFunnelEntity.id, $.extend({ funnelMap.set(proposedFunnelEntity.id, $.extend({
type: 'Funnel', type: 'Funnel',
dimensions: dimensions dimensions: dimensions

View File

@ -460,16 +460,18 @@
set: function (labelEntities, options) { set: function (labelEntities, options) {
var selectAll = false; var selectAll = false;
var transition = false; var transition = false;
var overrideRevisionCheck = false;
if (nfCommon.isDefinedAndNotNull(options)) { if (nfCommon.isDefinedAndNotNull(options)) {
selectAll = nfCommon.isDefinedAndNotNull(options.selectAll) ? options.selectAll : selectAll; selectAll = nfCommon.isDefinedAndNotNull(options.selectAll) ? options.selectAll : selectAll;
transition = nfCommon.isDefinedAndNotNull(options.transition) ? options.transition : transition; transition = nfCommon.isDefinedAndNotNull(options.transition) ? options.transition : transition;
overrideRevisionCheck = nfCommon.isDefinedAndNotNull(options.overrideRevisionCheck) ? options.overrideRevisionCheck : overrideRevisionCheck;
} }
var set = function (proposedLabelEntity) { var set = function (proposedLabelEntity) {
var currentLabelEntity = labelMap.get(proposedLabelEntity.id); var currentLabelEntity = labelMap.get(proposedLabelEntity.id);
// set the processor if appropriate due to revision and wasn't previously removed // set the processor if appropriate due to revision and wasn't previously removed
if (nfClient.isNewerRevision(currentLabelEntity, proposedLabelEntity) && !removedCache.has(proposedLabelEntity.id)) { if ((nfClient.isNewerRevision(currentLabelEntity, proposedLabelEntity) && !removedCache.has(proposedLabelEntity.id)) || overrideRevisionCheck === true) {
labelMap.set(proposedLabelEntity.id, $.extend({ labelMap.set(proposedLabelEntity.id, $.extend({
type: 'Label' type: 'Label'
}, proposedLabelEntity)); }, proposedLabelEntity));

View File

@ -606,9 +606,11 @@
set: function (portEntities, options) { set: function (portEntities, options) {
var selectAll = false; var selectAll = false;
var transition = false; var transition = false;
var overrideRevisionCheck = false;
if (nfCommon.isDefinedAndNotNull(options)) { if (nfCommon.isDefinedAndNotNull(options)) {
selectAll = nfCommon.isDefinedAndNotNull(options.selectAll) ? options.selectAll : selectAll; selectAll = nfCommon.isDefinedAndNotNull(options.selectAll) ? options.selectAll : selectAll;
transition = nfCommon.isDefinedAndNotNull(options.transition) ? options.transition : transition; transition = nfCommon.isDefinedAndNotNull(options.transition) ? options.transition : transition;
overrideRevisionCheck = nfCommon.isDefinedAndNotNull(options.overrideRevisionCheck) ? options.overrideRevisionCheck : overrideRevisionCheck;
} }
// determine the appropriate dimensions for this port // determine the appropriate dimensions for this port
@ -621,7 +623,7 @@
var currentPortEntity = portMap.get(proposedPortEntity.id); var currentPortEntity = portMap.get(proposedPortEntity.id);
// set the port if appropriate due to revision and wasn't previously removed // set the port if appropriate due to revision and wasn't previously removed
if (nfClient.isNewerRevision(currentPortEntity, proposedPortEntity) && !removedCache.has(proposedPortEntity.id)) { if ((nfClient.isNewerRevision(currentPortEntity, proposedPortEntity) && !removedCache.has(proposedPortEntity.id)) || overrideRevisionCheck === true) {
// add the port // add the port
portMap.set(proposedPortEntity.id, $.extend({ portMap.set(proposedPortEntity.id, $.extend({
type: 'Port', type: 'Port',

View File

@ -1097,16 +1097,18 @@
set: function (processGroupEntities, options) { set: function (processGroupEntities, options) {
var selectAll = false; var selectAll = false;
var transition = false; var transition = false;
var overrideRevisionCheck = false;
if (nfCommon.isDefinedAndNotNull(options)) { if (nfCommon.isDefinedAndNotNull(options)) {
selectAll = nfCommon.isDefinedAndNotNull(options.selectAll) ? options.selectAll : selectAll; selectAll = nfCommon.isDefinedAndNotNull(options.selectAll) ? options.selectAll : selectAll;
transition = nfCommon.isDefinedAndNotNull(options.transition) ? options.transition : transition; transition = nfCommon.isDefinedAndNotNull(options.transition) ? options.transition : transition;
overrideRevisionCheck = nfCommon.isDefinedAndNotNull(options.overrideRevisionCheck) ? options.overrideRevisionCheck : overrideRevisionCheck;
} }
var set = function (proposedProcessGroupEntity) { var set = function (proposedProcessGroupEntity) {
var currentProcessGroupEntity = processGroupMap.get(proposedProcessGroupEntity.id); var currentProcessGroupEntity = processGroupMap.get(proposedProcessGroupEntity.id);
// set the process group if appropriate due to revision and wasn't previously removed // set the process group if appropriate due to revision and wasn't previously removed
if (nfClient.isNewerRevision(currentProcessGroupEntity, proposedProcessGroupEntity) && !removedCache.has(proposedProcessGroupEntity.id)) { if ((nfClient.isNewerRevision(currentProcessGroupEntity, proposedProcessGroupEntity) && !removedCache.has(proposedProcessGroupEntity.id)) || overrideRevisionCheck === true) {
processGroupMap.set(proposedProcessGroupEntity.id, $.extend({ processGroupMap.set(proposedProcessGroupEntity.id, $.extend({
type: 'ProcessGroup', type: 'ProcessGroup',
dimensions: dimensions dimensions: dimensions

View File

@ -944,16 +944,18 @@
set: function (processorEntities, options) { set: function (processorEntities, options) {
var selectAll = false; var selectAll = false;
var transition = false; var transition = false;
var overrideRevisionCheck = false;
if (nfCommon.isDefinedAndNotNull(options)) { if (nfCommon.isDefinedAndNotNull(options)) {
selectAll = nfCommon.isDefinedAndNotNull(options.selectAll) ? options.selectAll : selectAll; selectAll = nfCommon.isDefinedAndNotNull(options.selectAll) ? options.selectAll : selectAll;
transition = nfCommon.isDefinedAndNotNull(options.transition) ? options.transition : transition; transition = nfCommon.isDefinedAndNotNull(options.transition) ? options.transition : transition;
overrideRevisionCheck = nfCommon.isDefinedAndNotNull(options.overrideRevisionCheck) ? options.overrideRevisionCheck : overrideRevisionCheck;
} }
var set = function (proposedProcessorEntity) { var set = function (proposedProcessorEntity) {
var currentProcessorEntity = processorMap.get(proposedProcessorEntity.id); var currentProcessorEntity = processorMap.get(proposedProcessorEntity.id);
// set the processor if appropriate due to revision and wasn't previously removed // set the processor if appropriate due to revision and wasn't previously removed
if (nfClient.isNewerRevision(currentProcessorEntity, proposedProcessorEntity) && !removedCache.has(proposedProcessorEntity.id)) { if ((nfClient.isNewerRevision(currentProcessorEntity, proposedProcessorEntity) && !removedCache.has(proposedProcessorEntity.id)) || overrideRevisionCheck === true) {
processorMap.set(proposedProcessorEntity.id, $.extend({ processorMap.set(proposedProcessorEntity.id, $.extend({
type: 'Processor', type: 'Processor',
dimensions: dimensions dimensions: dimensions

View File

@ -931,16 +931,18 @@
set: function (remoteProcessGroupEntities, options) { set: function (remoteProcessGroupEntities, options) {
var selectAll = false; var selectAll = false;
var transition = false; var transition = false;
var overrideRevisionCheck = false;
if (nfCommon.isDefinedAndNotNull(options)) { if (nfCommon.isDefinedAndNotNull(options)) {
selectAll = nfCommon.isDefinedAndNotNull(options.selectAll) ? options.selectAll : selectAll; selectAll = nfCommon.isDefinedAndNotNull(options.selectAll) ? options.selectAll : selectAll;
transition = nfCommon.isDefinedAndNotNull(options.transition) ? options.transition : transition; transition = nfCommon.isDefinedAndNotNull(options.transition) ? options.transition : transition;
overrideRevisionCheck = nfCommon.isDefinedAndNotNull(options.overrideRevisionCheck) ? options.overrideRevisionCheck : overrideRevisionCheck;
} }
var set = function (proposedRemoteProcessGroupEntity) { var set = function (proposedRemoteProcessGroupEntity) {
var currentRemoteProcessGroupEntity = remoteProcessGroupMap.get(proposedRemoteProcessGroupEntity.id); var currentRemoteProcessGroupEntity = remoteProcessGroupMap.get(proposedRemoteProcessGroupEntity.id);
// set the remote process group if appropriate due to revision and wasn't previously removed // set the remote process group if appropriate due to revision and wasn't previously removed
if (nfClient.isNewerRevision(currentRemoteProcessGroupEntity, proposedRemoteProcessGroupEntity) && !removedCache.has(proposedRemoteProcessGroupEntity.id)) { if ((nfClient.isNewerRevision(currentRemoteProcessGroupEntity, proposedRemoteProcessGroupEntity) && !removedCache.has(proposedRemoteProcessGroupEntity.id)) || overrideRevisionCheck === true) {
remoteProcessGroupMap.set(proposedRemoteProcessGroupEntity.id, $.extend({ remoteProcessGroupMap.set(proposedRemoteProcessGroupEntity.id, $.extend({
type: 'RemoteProcessGroup', type: 'RemoteProcessGroup',
dimensions: dimensions dimensions: dimensions

View File

@ -31,6 +31,7 @@
}(this, function ($) { }(this, function ($) {
var clustered = false; var clustered = false;
var connectedToCluster = false; var connectedToCluster = false;
var connectedStateChanged = false;
var config = { var config = {
urls: { urls: {
@ -54,6 +55,11 @@
var clusterSummaryResponse = clusterSummaryResult; var clusterSummaryResponse = clusterSummaryResult;
var clusterSummary = clusterSummaryResponse.clusterSummary; var clusterSummary = clusterSummaryResponse.clusterSummary;
// see if the connected state changes
if (connectedToCluster !== clusterSummary.connectedToCluster) {
connectedStateChanged = true;
}
// establish the initial cluster state // establish the initial cluster state
clustered = clusterSummary.clustered; clustered = clusterSummary.clustered;
connectedToCluster = clusterSummary.connectedToCluster; connectedToCluster = clusterSummary.connectedToCluster;
@ -76,6 +82,16 @@
*/ */
isConnectedToCluster: function () { isConnectedToCluster: function () {
return connectedToCluster === true; return connectedToCluster === true;
},
/**
* Returns whether the connected state has changed since the last time
* didConnectedStateChange was invoked.
*/
didConnectedStateChange: function () {
var stateChanged = connectedStateChanged;
connectedStateChanged = false;
return stateChanged;
} }
}; };
})); }));