2023-12-13 07:07:48 -05:00
const fs = require ( 'fs' ) ;
2022-09-23 07:30:23 -05:00
const path = require ( 'path' ) ;
2022-10-06 03:32:08 -05:00
const util = require ( 'util' ) ;
const exec = util . promisify ( require ( 'child_process' ) . exec ) ;
2023-11-15 03:55:10 -05:00
const chalk = require ( 'chalk' ) ;
2022-09-23 07:30:23 -05:00
const concurrently = require ( 'concurrently' ) ;
2023-06-08 07:33:42 -05:00
// check we're running on Node 18 and above
const nodeVersion = parseInt ( process . versions . node . split ( '.' ) [ 0 ] ) ;
if ( nodeVersion < 18 ) {
console . error ( '`yarn dev` requires Node v18 or above. Please upgrade your version of Node.' ) ;
process . exit ( 1 ) ;
}
2023-07-05 01:16:46 -05:00
const config = require ( '../../ghost/core/core/shared/config/loader' ) . loadNconf ( {
customConfigPath : path . join ( _ _dirname , '../../ghost/core' )
2022-10-06 03:58:51 -05:00
} ) ;
2023-12-13 07:07:48 -05:00
const tsPackages = fs . readdirSync ( path . resolve ( _ _dirname , '../../ghost' ) , { withFileTypes : true } )
. filter ( dirent => dirent . isDirectory ( ) )
. map ( dirent => dirent . name )
. filter ( packageFolder => {
try {
const packageJson = require ( path . resolve ( _ _dirname , ` ../../ghost/ ${ packageFolder } /package.json ` ) ) ;
return packageJson . scripts ? . [ 'build:ts' ] ;
} catch ( err ) {
return false ;
}
} )
. map ( packageFolder => ` ghost/ ${ packageFolder } ` )
. join ( ',' ) ;
2022-09-23 07:30:23 -05:00
const liveReloadBaseUrl = config . getSubdir ( ) || '/ghost/' ;
2022-10-06 03:32:08 -05:00
const siteUrl = config . getSiteUrl ( ) ;
2022-09-23 07:30:23 -05:00
const DASH _DASH _ARGS = process . argv . filter ( a => a . startsWith ( '--' ) ) . map ( a => a . slice ( 2 ) ) ;
let commands = [ ] ;
const COMMAND _GHOST = {
name : 'ghost' ,
2023-03-21 09:57:41 -05:00
// Note: if this isn't working for you, please use Node 18 and above
2023-07-13 04:14:08 -05:00
command : 'nx run ghost:dev' ,
2023-07-05 01:16:46 -05:00
cwd : path . resolve ( _ _dirname , '../../ghost/core' ) ,
2022-09-23 07:30:23 -05:00
prefixColor : 'blue' ,
2023-09-26 10:29:17 -05:00
env : {
// In development mode, we allow self-signed certificates (for sending webmentions and oembeds)
NODE _TLS _REJECT _UNAUTHORIZED : '0' ,
}
2022-09-23 07:30:23 -05:00
} ;
const COMMAND _ADMIN = {
name : 'admin' ,
2023-09-18 08:11:45 -05:00
command : ` nx run ghost-admin:dev --live-reload-base-url= ${ liveReloadBaseUrl } --live-reload-port=4201 ` ,
2023-07-05 01:16:46 -05:00
cwd : path . resolve ( _ _dirname , '../../ghost/admin' ) ,
2022-09-23 07:30:23 -05:00
prefixColor : 'green' ,
env : { }
} ;
2024-09-12 09:55:47 -05:00
const COMMAND _BROWSERTESTS = {
name : 'browser-tests' ,
command : 'nx run ghost:test:browser' ,
cwd : path . resolve ( _ _dirname , '../../ghost/core' ) ,
prefixColor : 'blue' ,
env : { }
} ;
2023-07-12 06:42:39 -05:00
const COMMAND _TYPESCRIPT = {
name : 'ts' ,
2023-12-13 07:07:48 -05:00
command : ` while [ 1 ]; do nx watch --projects= ${ tsPackages } -- nx run \\ $ NX_PROJECT_NAME:build:ts; done ` ,
2023-07-12 06:42:39 -05:00
cwd : path . resolve ( _ _dirname , '../../' ) ,
prefixColor : 'cyan' ,
env : { }
} ;
2024-12-19 06:01:08 -05:00
const adminXApps = '@tryghost/admin-x-demo,@tryghost/admin-x-settings,@tryghost/admin-x-activitypub,@tryghost/posts' ;
2023-11-20 08:30:15 -05:00
2023-11-08 07:33:18 -05:00
const COMMANDS _ADMINX = [ {
2023-11-14 08:50:08 -05:00
name : 'adminXDeps' ,
2024-12-11 09:55:58 -05:00
command : 'while [ 1 ]; do nx watch --projects=apps/admin-x-design-system,apps/admin-x-framework,apps/shade -- nx run \\$NX_PROJECT_NAME:build; done' ,
2023-11-08 07:33:18 -05:00
cwd : path . resolve ( _ _dirname , '../..' ) ,
2024-08-20 05:25:54 -05:00
prefixColor : '#C72AF7' ,
2023-11-08 07:33:18 -05:00
env : { }
} , {
2023-09-28 05:36:17 -05:00
name : 'adminX' ,
2023-12-13 04:26:33 -05:00
command : ` nx run-many --projects= ${ adminXApps } --parallel= ${ adminXApps . length } --targets=dev ` ,
2024-04-25 03:44:29 -05:00
cwd : path . resolve ( _ _dirname , '../../apps/admin-x-settings' , '../../apps/admin-x-activitypub' ) ,
2024-08-20 05:25:54 -05:00
prefixColor : '#C72AF7' ,
2023-09-28 05:36:17 -05:00
env : { }
2023-11-08 07:33:18 -05:00
} ] ;
2023-09-28 05:36:17 -05:00
2022-09-23 07:30:23 -05:00
if ( DASH _DASH _ARGS . includes ( 'ghost' ) ) {
2023-07-12 06:42:39 -05:00
commands = [ COMMAND _GHOST , COMMAND _TYPESCRIPT ] ;
2022-09-23 07:30:23 -05:00
} else if ( DASH _DASH _ARGS . includes ( 'admin' ) ) {
2023-11-08 07:33:18 -05:00
commands = [ COMMAND _ADMIN , ... COMMANDS _ADMINX ] ;
2024-09-12 09:55:47 -05:00
} else if ( DASH _DASH _ARGS . includes ( 'browser-tests' ) ) {
2024-10-30 14:39:41 -05:00
commands = [ COMMAND _BROWSERTESTS ] ;
2022-09-23 07:30:23 -05:00
} else {
2023-11-08 07:33:18 -05:00
commands = [ COMMAND _GHOST , COMMAND _TYPESCRIPT , COMMAND _ADMIN , ... COMMANDS _ADMINX ] ;
2023-05-19 03:32:13 -05:00
}
2023-04-26 18:55:03 -05:00
if ( DASH _DASH _ARGS . includes ( 'portal' ) || DASH _DASH _ARGS . includes ( 'all' ) ) {
2022-10-04 23:51:06 -05:00
commands . push ( {
name : 'portal' ,
2023-11-15 03:54:09 -05:00
command : 'nx run @tryghost/portal:dev' ,
2023-07-05 01:16:46 -05:00
cwd : path . resolve ( _ _dirname , '../../apps/portal' ) ,
2022-10-06 03:32:08 -05:00
prefixColor : 'magenta' ,
env : { }
2022-10-04 23:51:06 -05:00
} ) ;
2023-07-05 10:04:39 -05:00
if ( DASH _DASH _ARGS . includes ( 'https' ) ) {
// Safari needs HTTPS for it to work
// To make this work, you'll need a CADDY server running in front
// Note the port is different because of this extra layer. Use the following Caddyfile:
// https://localhost:4176 {
// reverse_proxy http://localhost:4175
// }
COMMAND _GHOST . env [ 'portal__url' ] = 'https://localhost:4176/portal.min.js' ;
} else {
COMMAND _GHOST . env [ 'portal__url' ] = 'http://localhost:4175/portal.min.js' ;
}
2022-10-04 23:51:06 -05:00
}
2023-06-01 03:20:37 -05:00
if ( DASH _DASH _ARGS . includes ( 'signup' ) || DASH _DASH _ARGS . includes ( 'all' ) ) {
commands . push ( {
name : 'signup-form' ,
2023-11-15 03:54:09 -05:00
command : DASH _DASH _ARGS . includes ( 'signup' ) ? 'nx run @tryghost/signup-form:dev' : 'nx run @tryghost/signup-form:preview' ,
2023-07-05 01:16:46 -05:00
cwd : path . resolve ( _ _dirname , '../../apps/signup-form' ) ,
2023-06-01 03:20:37 -05:00
prefixColor : 'magenta' ,
env : { }
} ) ;
COMMAND _GHOST . env [ 'signupForm__url' ] = 'http://localhost:6174/signup-form.min.js' ;
}
2023-05-22 08:23:17 -05:00
if ( DASH _DASH _ARGS . includes ( 'announcement-bar' ) || DASH _DASH _ARGS . includes ( 'announcementBar' ) || DASH _DASH _ARGS . includes ( 'announcementbar' ) || DASH _DASH _ARGS . includes ( 'all' ) ) {
commands . push ( {
name : 'announcement-bar' ,
2023-11-15 03:54:09 -05:00
command : 'nx run @tryghost/announcement-bar:dev' ,
2023-07-05 01:16:46 -05:00
cwd : path . resolve ( _ _dirname , '../../apps/announcement-bar' ) ,
2023-05-22 08:23:17 -05:00
prefixColor : '#DC9D00' ,
env : { }
} ) ;
2023-07-27 02:09:01 -05:00
COMMAND _GHOST . env [ 'announcementBar__url' ] = 'http://localhost:4177/announcement-bar.min.js' ;
2023-05-22 08:23:17 -05:00
}
2023-04-26 18:55:03 -05:00
if ( DASH _DASH _ARGS . includes ( 'search' ) || DASH _DASH _ARGS . includes ( 'all' ) ) {
2023-03-17 05:51:42 -05:00
commands . push ( {
name : 'search' ,
2023-11-15 03:54:09 -05:00
command : 'nx run @tryghost/sodo-search:dev' ,
2023-07-05 01:16:46 -05:00
cwd : path . resolve ( _ _dirname , '../../apps/sodo-search' ) ,
2023-03-17 05:51:42 -05:00
prefixColor : '#23de43' ,
env : { }
} ) ;
2023-07-27 02:09:01 -05:00
COMMAND _GHOST . env [ 'sodoSearch__url' ] = 'http://localhost:4178/sodo-search.min.js' ;
COMMAND _GHOST . env [ 'sodoSearch__styles' ] = 'http://localhost:4178/main.css' ;
2023-03-17 05:51:42 -05:00
}
2023-05-18 08:14:36 -05:00
if ( DASH _DASH _ARGS . includes ( 'lexical' ) ) {
2023-06-23 03:47:35 -05:00
if ( DASH _DASH _ARGS . includes ( 'https' ) ) {
// Safari needs HTTPS for it to work
// To make this work, you'll need a CADDY server running in front
// Note the port is different because of this extra layer. Use the following Caddyfile:
2023-08-18 08:30:59 -05:00
// https://localhost:41730 {
2023-06-27 07:51:37 -05:00
// reverse_proxy http://127.0.0.1:4173
2023-06-23 03:47:35 -05:00
// }
2023-10-02 14:32:05 -05:00
COMMAND _ADMIN . env [ 'EDITOR_URL' ] = 'https://localhost:41730/' ;
2023-06-23 03:47:35 -05:00
} else {
2023-10-02 14:32:05 -05:00
COMMAND _ADMIN . env [ 'EDITOR_URL' ] = 'http://localhost:4173/' ;
2023-06-23 03:47:35 -05:00
}
2023-05-18 08:14:36 -05:00
}
2023-06-22 03:22:14 -05:00
if ( DASH _DASH _ARGS . includes ( 'comments' ) || DASH _DASH _ARGS . includes ( 'all' ) ) {
2023-06-27 07:51:37 -05:00
if ( DASH _DASH _ARGS . includes ( 'https' ) ) {
// Safari needs HTTPS for it to work
// To make this work, you'll need a CADDY server running in front
// Note the port is different because of this extra layer. Use the following Caddyfile:
// https://localhost:7174 {
// reverse_proxy http://127.0.0.1:7173
// }
COMMAND _GHOST . env [ 'comments__url' ] = 'https://localhost:7174/comments-ui.min.js' ;
} else {
COMMAND _GHOST . env [ 'comments__url' ] = 'http://localhost:7173/comments-ui.min.js' ;
}
2023-06-22 03:22:14 -05:00
commands . push ( {
name : 'comments' ,
2023-11-15 03:54:09 -05:00
command : 'nx run @tryghost/comments-ui:dev' ,
2023-07-05 01:16:46 -05:00
cwd : path . resolve ( _ _dirname , '../../apps/comments-ui' ) ,
2023-06-22 03:22:14 -05:00
prefixColor : '#E55137' ,
env : { }
} ) ;
2023-06-21 09:41:00 -05:00
}
2023-04-26 18:55:03 -05:00
async function handleStripe ( ) {
if ( DASH _DASH _ARGS . includes ( 'stripe' ) || DASH _DASH _ARGS . includes ( 'all' ) ) {
2024-09-23 10:27:41 -05:00
if ( DASH _DASH _ARGS . includes ( 'offline' ) || DASH _DASH _ARGS . includes ( 'browser-tests' ) ) {
2023-04-26 18:55:03 -05:00
return ;
}
2022-10-06 04:47:54 -05:00
2022-10-06 03:32:08 -05:00
let stripeSecret ;
try {
stripeSecret = await exec ( 'stripe listen --print-secret' ) ;
} catch ( err ) {
console . error ( 'Failed to fetch Stripe secret token, do you need to connect Stripe CLI?' , err ) ;
2022-10-06 03:42:19 -05:00
return ;
2022-10-06 03:32:08 -05:00
}
if ( ! stripeSecret || ! stripeSecret . stdout ) {
console . error ( 'No Stripe secret was present' ) ;
return ;
}
COMMAND _GHOST . env [ 'WEBHOOK_SECRET' ] = stripeSecret . stdout . trim ( ) ;
commands . push ( {
name : 'stripe' ,
command : ` stripe listen --forward-to ${ siteUrl } members/webhooks/stripe/ ` ,
prefixColor : 'yellow' ,
env : { }
} ) ;
}
2023-04-26 18:55:03 -05:00
}
( async ( ) => {
await handleStripe ( ) ;
2022-10-06 03:32:08 -05:00
if ( ! commands . length ) {
console . log ( ` No commands provided ` ) ;
process . exit ( 0 ) ;
}
2024-09-17 04:47:23 -05:00
process . env . NX _DISABLE _DB = "true" ;
await exec ( "yarn nx reset --onlyDaemon" ) ;
await exec ( "yarn nx daemon --start" ) ;
2023-11-15 03:55:10 -05:00
console . log ( ` Running projects: ${ commands . map ( c => chalk . green ( c . name ) ) . join ( ', ' ) } ` ) ;
2022-09-23 07:30:23 -05:00
const { result } = concurrently ( commands , {
prefix : 'name' ,
2024-10-24 19:22:37 -05:00
killOthers : [ 'failure' , 'success' ] ,
successCondition : 'first'
2022-09-23 07:30:23 -05:00
} ) ;
try {
await result ;
} catch ( err ) {
2023-11-15 04:23:57 -05:00
console . error ( ) ;
console . error ( chalk . red ( ` Executing dev command failed: ` ) + ` \n ` ) ;
console . error ( chalk . red ( ` If you've recently done a \` yarn main \` , dependencies might be out of sync. Try running \` ${ chalk . green ( 'yarn fix' ) } \` to fix this. ` ) ) ;
console . error ( chalk . red ( ` If not, something else went wrong. Please report this to the Ghost team. ` ) ) ;
console . error ( ) ;
2024-10-24 19:22:37 -05:00
process . exit ( 1 ) ;
2022-09-23 07:30:23 -05:00
}
} ) ( ) ;