1
0
Fork 0
arangodb/js/server/bootstrap/coordinator.js

59 lines
1.9 KiB
JavaScript

'use strict';
////////////////////////////////////////////////////////////////////////////////
/// @brief initialize a new database
///
/// @file
///
/// DISCLAIMER
///
/// Copyright 2014 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 Dr. Frank Celler
/// @author Copyright 2014, ArangoDB GmbH, Cologne, Germany
////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////
/// @brief initialize a new database
////////////////////////////////////////////////////////////////////////////////
(function () {
var internal = require("internal");
var console = require("console");
return function () {
// statistics can be turned off
if (internal.enableStatistics) {
require("@arangodb/statistics").startup();
}
// load all foxxes
internal.loadStartup("server/bootstrap/foxxes.js").foxxes();
// autoload all modules and reload routing information in all threads
internal.executeGlobalContextFunction("bootstrapCoordinator");
// start the queue manager once
require('@arangodb/foxx/queues/manager').run();
console.info("bootstraped coordinator %s", global.ArangoServerState.id());
return true;
};
}());