/* |-------------------------------------------------------------------------- | Http server |-------------------------------------------------------------------------- | | This file bootstraps Adonisjs to start the HTTP server. You are free to | customize the process of booting the http server. | | """ Loading ace commands """ | At times you may want to load ace commands when starting the HTTP server. | Same can be done by chaining `loadCommands()` method after | | """ Preloading files """ | Also you can preload files by calling `preLoad('path/to/file')` method. | Make sure to pass a relative path from the project root. */ const fold = require('@adonisjs/fold'); const { Ignitor } = require('@adonisjs/ignitor'); const fs = require('fs-extra'); const path = require('path'); const { LOCAL_HOSTNAME } = require('../config'); const { isWindows } = require('../environment'); process.env.ENV_PATH = path.join(__dirname, 'env.ini'); module.exports = async (userPath, port) => { const dbPath = path.join(userPath, 'server.sqlite'); const dbTemplatePath = path.join(__dirname, 'database', 'template.sqlite'); if (!fs.existsSync(dbPath)) { // Manually copy file // We can't use copyFile here as it will cause the file to be readonly on Windows const dbTemplate = await fs.readFile(dbTemplatePath); await fs.writeFile(dbPath, dbTemplate); // Change permissions to ensure to file is not read-only if (isWindows) { // eslint-disable-next-line no-bitwise fs.chmodSync(dbPath, fs.statSync(dbPath).mode | 146); } } // Note: These env vars are used by adonis as env vars process.env.DB_PATH = dbPath; process.env.USER_PATH = userPath; process.env.HOST = LOCAL_HOSTNAME; process.env.PORT = port; new Ignitor(fold).appRoot(__dirname).fireHttpServer().catch(console.error); // eslint-disable-line no-console };