2015-05-13 23:42:35 +00:00
|
|
|
/*****************************************************************************
|
|
|
|
* Open MCT Web, Copyright (c) 2014-2015, United States Government
|
|
|
|
* as represented by the Administrator of the National Aeronautics and Space
|
|
|
|
* Administration. All rights reserved.
|
|
|
|
*
|
|
|
|
* Open MCT Web is licensed under the Apache License, Version 2.0 (the
|
|
|
|
* "License"); you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0.
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
|
|
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
|
|
* License for the specific language governing permissions and limitations
|
|
|
|
* under the License.
|
|
|
|
*
|
|
|
|
* Open MCT Web includes source code licensed under additional open source
|
|
|
|
* licenses. See the Open Source Licenses file (LICENSES.md) included with
|
|
|
|
* this source code distribution or the Licensing information page available
|
|
|
|
* at runtime from the About dialog for additional information.
|
|
|
|
*****************************************************************************/
|
2014-12-15 18:37:16 +00:00
|
|
|
/*global define*/
|
|
|
|
|
|
|
|
define(
|
|
|
|
[],
|
|
|
|
function () {
|
|
|
|
"use strict";
|
|
|
|
|
2014-12-16 21:36:40 +00:00
|
|
|
// Set of connection states; changing among these states will be
|
|
|
|
// reflected in the indicator's appearance.
|
|
|
|
// CONNECTED: Everything nominal, expect to be able to read/write.
|
|
|
|
// DISCONNECTED: HTTP failed; maybe misconfigured, disconnected.
|
|
|
|
// SEMICONNECTED: Connected to the database, but it reported an error.
|
|
|
|
// PENDING: Still trying to connect, and haven't failed yet.
|
2014-12-15 20:34:16 +00:00
|
|
|
var CONNECTED = {
|
|
|
|
text: "Connected",
|
2014-12-16 21:36:40 +00:00
|
|
|
glyphClass: "ok",
|
|
|
|
description: "Connected to the domain object database."
|
2014-12-15 20:34:16 +00:00
|
|
|
},
|
|
|
|
DISCONNECTED = {
|
|
|
|
text: "Disconnected",
|
2014-12-16 21:36:40 +00:00
|
|
|
glyphClass: "err",
|
|
|
|
description: "Unable to connect to the domain object database."
|
|
|
|
},
|
|
|
|
SEMICONNECTED = {
|
|
|
|
text: "Unavailable",
|
|
|
|
glyphClass: "caution",
|
|
|
|
description: "Database does not exist or is unavailable."
|
2014-12-15 20:34:16 +00:00
|
|
|
},
|
|
|
|
PENDING = {
|
|
|
|
text: "Checking connection..."
|
|
|
|
};
|
|
|
|
|
2014-12-16 21:36:40 +00:00
|
|
|
/**
|
|
|
|
* Indicator for the current CouchDB connection. Polls CouchDB
|
|
|
|
* at a regular interval (defined by bundle constants) to ensure
|
|
|
|
* that the database is available.
|
2015-08-07 18:44:54 +00:00
|
|
|
* @constructor
|
|
|
|
* @memberof platform/persistence/couch
|
2014-12-16 21:36:40 +00:00
|
|
|
*/
|
2014-12-15 18:37:16 +00:00
|
|
|
function CouchIndicator($http, $interval, PATH, INTERVAL) {
|
2014-12-16 21:36:40 +00:00
|
|
|
// Track the current connection state
|
2014-12-15 20:34:16 +00:00
|
|
|
var state = PENDING;
|
|
|
|
|
2014-12-16 21:36:40 +00:00
|
|
|
// Callback if the HTTP request to Couch fails
|
2014-12-15 20:34:16 +00:00
|
|
|
function handleError(err) {
|
|
|
|
state = DISCONNECTED;
|
|
|
|
}
|
|
|
|
|
2014-12-16 21:36:40 +00:00
|
|
|
// Callback if the HTTP request succeeds. CouchDB may
|
|
|
|
// report an error, so check for that.
|
2014-12-15 20:34:16 +00:00
|
|
|
function handleResponse(response) {
|
|
|
|
var data = response.data;
|
2014-12-16 22:06:19 +00:00
|
|
|
state = data.error ? SEMICONNECTED : CONNECTED;
|
2014-12-15 18:37:16 +00:00
|
|
|
}
|
|
|
|
|
2014-12-16 21:36:40 +00:00
|
|
|
// Try to connect to CouchDB, and update the indicator.
|
2014-12-15 20:34:16 +00:00
|
|
|
function updateIndicator() {
|
|
|
|
$http.get(PATH).then(handleResponse, handleError);
|
|
|
|
}
|
|
|
|
|
2014-12-16 21:36:40 +00:00
|
|
|
// Update the indicator initially, and start polling.
|
2014-12-15 20:34:16 +00:00
|
|
|
updateIndicator();
|
2014-12-15 18:37:16 +00:00
|
|
|
$interval(updateIndicator, INTERVAL);
|
|
|
|
|
|
|
|
return {
|
2014-12-16 21:36:40 +00:00
|
|
|
/**
|
|
|
|
* Get the glyph (single character used as an icon)
|
|
|
|
* to display in this indicator. This will return "D",
|
|
|
|
* which should appear as a database icon.
|
|
|
|
* @returns {string} the character of the database icon
|
2015-08-07 18:44:54 +00:00
|
|
|
* @memberof platform/persistence/couch.CouchIndicator#
|
2014-12-16 21:36:40 +00:00
|
|
|
*/
|
2014-12-15 18:37:16 +00:00
|
|
|
getGlyph: function () {
|
|
|
|
return "D";
|
2014-12-15 20:34:16 +00:00
|
|
|
},
|
2014-12-16 21:36:40 +00:00
|
|
|
/**
|
|
|
|
* Get the name of the CSS class to apply to the glyph.
|
|
|
|
* This is used to color the glyph to match its
|
|
|
|
* state (one of ok, caution or err)
|
|
|
|
* @returns {string} the CSS class to apply to this glyph
|
2015-08-07 18:44:54 +00:00
|
|
|
* @memberof platform/persistence/couch.CouchIndicator#
|
2014-12-16 21:36:40 +00:00
|
|
|
*/
|
2014-12-15 20:34:16 +00:00
|
|
|
getGlyphClass: function () {
|
|
|
|
return state.glyphClass;
|
|
|
|
},
|
2014-12-16 21:36:40 +00:00
|
|
|
/**
|
|
|
|
* Get the text that should appear in the indicator.
|
|
|
|
* @returns {string} brief summary of connection status
|
2015-08-07 18:44:54 +00:00
|
|
|
* @memberof platform/persistence/couch.CouchIndicator#
|
2014-12-16 21:36:40 +00:00
|
|
|
*/
|
2014-12-15 20:34:16 +00:00
|
|
|
getText: function () {
|
|
|
|
return state.text;
|
2014-12-16 21:43:51 +00:00
|
|
|
},
|
|
|
|
/**
|
|
|
|
* Get a longer-form description of the current connection
|
|
|
|
* space, suitable for display in a tooltip
|
|
|
|
* @returns {string} longer summary of connection status
|
2015-08-07 18:44:54 +00:00
|
|
|
* @memberof platform/persistence/couch.CouchIndicator#
|
2014-12-16 21:43:51 +00:00
|
|
|
*/
|
|
|
|
getDescription: function () {
|
|
|
|
return state.description;
|
2014-12-15 18:37:16 +00:00
|
|
|
}
|
2014-12-15 20:34:16 +00:00
|
|
|
};
|
2014-12-15 18:37:16 +00:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
return CouchIndicator;
|
|
|
|
}
|
2015-08-07 18:44:54 +00:00
|
|
|
);
|