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

64 lines
2.2 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');
// do not overwrite arguments set from the calling C++ code
if (!global.UPGRADE_ARGS) {
global.UPGRADE_ARGS = {};
}
// merge in our arguments
global.UPGRADE_ARGS.isCluster = true;
global.UPGRADE_ARGS.isCoordinator = true;
global.UPGRADE_ARGS.isRelaunch = false;
// run the local upgrade-database script
var res = internal.loadStartup('server/bootstrap/local-database.js');
// Wait for synchronous replication to settle:
// We do not do this for performance reasons and because it should not
// be necessary. We leave the code here in case we need it again.
//var db = require('internal').db;
//var dbName = db._name();
//if (dbName !== '_system') {
// // for _system we run this already at bootstrap
// var colls = db._collections();
// colls = colls.filter(c => c.name()[0] === '_');
// require('@arangodb/cluster').waitForSyncRepl(dbName, colls);
//}
return res;
}());