'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; }());