1
0
Fork 0
arangodb/js/apps/system/_admin/aardvark/APP/cluster.js

93 lines
2.9 KiB
JavaScript

'use strict';
////////////////////////////////////////////////////////////////////////////////
/// DISCLAIMER
///
/// Copyright 2010-2013 triAGENS GmbH, Cologne, Germany
/// Copyright 2016 ArangoDB GmbH, Cologne, Germany
///
/// 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.
///
/// Copyright holder is ArangoDB GmbH, Cologne, Germany
///
/// @author Michael Hackstein
/// @author Alan Plum
////////////////////////////////////////////////////////////////////////////////
const internal = require('internal');
const cluster = require('@arangodb/cluster');
const createRouter = require('@arangodb/foxx/router');
const router = createRouter();
module.exports = router;
router.use((req, res, next) => {
if (internal.authenticationEnabled()) {
if (!req.arangoUser) {
res.throw('unauthorized');
}
}
next();
});
router.get('/amICoordinator', function(req, res) {
res.json(cluster.isCoordinator());
})
.summary('Ask the server whether it is a coordinator')
.description('This will return true if and only if the server is a coordinator.');
if (cluster.isCluster()) {
router.get('/DBServers', function(req, res) {
const list = global.ArangoClusterInfo.getDBServers();
res.json(list.map(n => {
var r = { "id": n.serverId, "name": n.serverName, "role": "primary" };
r.status = "ok";
const endpoint = global.ArangoClusterInfo.getServerEndpoint(r.id);
const proto = endpoint.substr(0, 6);
if (proto === "tcp://") {
r.protocol = "http";
r.address = endpoint.substr(6);
} else if (proto === "ssl://") {
r.protocol = "https";
r.address = endpoint.substr(6);
} else {
r.endpoint = endpoint;
}
return r;
}));
})
.summary('Get all DBServers')
.description('Get a list of all running and expected DBServers within the cluster');
router.get('/Coordinators', function(req, res) {
const list = global.ArangoClusterInfo.getCoordinators();
res.json(list.map(n => {
var r = { "id": n, "role": "coordinator" };
r.status = "ok";
const endpoint = global.ArangoClusterInfo.getServerEndpoint(n);
const proto = endpoint.substr(0, 6);
if (proto === "tcp://") {
r.protocol = "http";
r.address = endpoint.substr(6);
} else if (proto === "ssl://") {
r.protocol = "https";
r.address = endpoint.substr(6);
} else {
r.endpoint = endpoint;
}
return r;
}));
});
}