2023-12-06 14:11:52 -05:00
const { spawn } = require ( 'child_process' ) ;
const fs = require ( 'fs' ) . promises ;
const path = require ( 'path' ) ;
const chalk = require ( 'chalk' ) ;
2024-01-05 08:42:30 -05:00
const inquirer = require ( 'inquirer' ) ;
2023-12-06 14:11:52 -05:00
/ * *
* Run a command and stream output to the console
*
* @ param { string } command
* @ param { string [ ] } args
* @ param { object } options
* /
async function runAndStream ( command , args , options ) {
return new Promise ( ( resolve , reject ) => {
const child = spawn ( command , args , {
stdio : 'inherit' ,
... options
} ) ;
child . on ( 'close' , ( code ) => {
if ( code === 0 ) {
resolve ( code ) ;
} else {
reject ( new Error ( ` ' ${ command } ${ args . join ( ' ' ) } ' exited with code ${ code } ` ) ) ;
}
} ) ;
} ) ;
}
( async ( ) => {
if ( process . env . NODE _ENV !== 'development' ) {
console . log ( chalk . yellow ( ` NODE_ENV is not development, skipping setup ` ) ) ;
return ;
}
2024-10-24 13:15:08 -05:00
if ( process . env . DEVCONTAINER === 'true' ) {
console . log ( chalk . yellow ( ` Devcontainer detected, skipping setup ` ) ) ;
return ;
}
2023-12-06 14:11:52 -05:00
const coreFolder = path . join ( _ _dirname , '../../ghost/core' ) ;
2024-01-05 08:42:30 -05:00
const rootFolder = path . join ( _ _dirname , '../..' ) ;
2023-12-06 14:11:52 -05:00
const config = require ( '../../ghost/core/core/shared/config/loader' ) . loadNconf ( {
customConfigPath : coreFolder
} ) ;
const dbClient = config . get ( 'database:client' ) ;
2024-01-05 08:42:30 -05:00
const isUsingDocker = config . get ( 'database:docker' ) ;
// Only reset data if we are using Docker
let resetData = false ;
2023-12-06 14:11:52 -05:00
if ( ! dbClient . includes ( 'mysql' ) ) {
let mysqlSetup = false ;
console . log ( chalk . blue ( ` Attempting to setup MySQL via Docker ` ) ) ;
try {
await runAndStream ( 'yarn' , [ 'docker:reset' ] , { cwd : path . join ( _ _dirname , '../../' ) } ) ;
mysqlSetup = true ;
} catch ( err ) {
console . error ( chalk . red ( 'Failed to run MySQL Docker container' ) , err ) ;
console . error ( chalk . red ( 'Hint: is Docker installed and running?' ) ) ;
}
if ( mysqlSetup ) {
2024-01-05 08:42:30 -05:00
resetData = true ;
2023-12-06 14:11:52 -05:00
console . log ( chalk . blue ( ` Adding MySQL credentials to config.local.json ` ) ) ;
const currentConfigPath = path . join ( coreFolder , 'config.local.json' ) ;
let currentConfig ;
try {
currentConfig = require ( currentConfigPath ) ;
} catch ( err ) {
currentConfig = { } ;
}
currentConfig . database = {
client : 'mysql' ,
2024-01-05 08:42:30 -05:00
docker : true ,
2023-12-06 14:11:52 -05:00
connection : {
host : '127.0.0.1' ,
user : 'root' ,
password : 'root' ,
database : 'ghost'
}
} ;
try {
await fs . writeFile ( currentConfigPath , JSON . stringify ( currentConfig , null , 4 ) ) ;
} catch ( err ) {
console . error ( chalk . red ( 'Failed to write config.local.json' ) , err ) ;
console . log ( chalk . yellow ( ` Please add the following to config.local.json: \n ` ) , JSON . stringify ( currentConfig , null , 4 ) ) ;
process . exit ( 1 ) ;
}
2024-01-05 08:42:30 -05:00
}
} else {
if ( isUsingDocker ) {
const yesAll = process . argv . includes ( '-y' ) ;
const noAll = process . argv . includes ( '-n' ) ;
const { confirmed } =
yesAll ? { confirmed : true }
: (
noAll ? { confirmed : false }
: await inquirer . prompt ( { name : 'confirmed' , type : 'confirm' , message : 'MySQL is running via Docker, do you want to reset the Docker container? This will delete all existing data.' , default : false } )
) ;
2023-12-06 14:11:52 -05:00
2024-01-05 08:42:30 -05:00
if ( confirmed ) {
console . log ( chalk . yellow ( ` Resetting Docker container ` ) ) ;
2023-12-06 14:11:52 -05:00
2024-01-05 08:42:30 -05:00
try {
await runAndStream ( 'yarn' , [ 'docker:reset' ] , { cwd : path . join ( _ _dirname , '../../' ) } ) ;
resetData = true ;
} catch ( err ) {
console . error ( chalk . red ( 'Failed to run MySQL Docker container' ) , err ) ;
console . error ( chalk . red ( 'Hint: is Docker installed and running?' ) ) ;
}
}
} else {
console . log ( chalk . green ( ` MySQL already configured locally. Stop your local database and delete your "database" configuration in config.local.json to switch to Docker. ` ) ) ;
2023-12-06 14:11:52 -05:00
}
2024-01-05 08:42:30 -05:00
}
console . log ( chalk . blue ( ` Running knex-migrator init ` ) ) ;
await runAndStream ( 'yarn' , [ 'knex-migrator' , 'init' ] , { cwd : coreFolder } ) ;
2024-02-15 07:48:08 -05:00
if ( process . argv . includes ( '--no-seed' ) ) {
console . log ( chalk . yellow ( ` Skipping seed data ` ) ) ;
console . log ( chalk . yellow ( ` Done ` ) ) ;
return ;
}
2024-01-05 08:42:30 -05:00
if ( resetData ) {
2024-01-16 05:20:33 -05:00
const xxl = process . argv . includes ( '--xxl' ) ;
if ( xxl ) {
console . log ( chalk . blue ( ` Resetting all data (with xxl) ` ) ) ;
await runAndStream ( 'yarn' , [ 'reset:data:xxl' ] , { cwd : rootFolder } ) ;
} else {
console . log ( chalk . blue ( ` Resetting all data ` ) ) ;
await runAndStream ( 'yarn' , [ 'reset:data' ] , { cwd : rootFolder } ) ;
}
2023-12-06 14:11:52 -05:00
}
} ) ( ) ;