2023-12-13 13:07:48 +01:00
const fs = require ( 'fs' ) ;
2022-09-23 14:30:23 +02:00
const path = require ( 'path' ) ;
2022-10-06 15:32:08 +07:00
const util = require ( 'util' ) ;
const exec = util . promisify ( require ( 'child_process' ) . exec ) ;
2023-11-15 09:55:10 +01:00
const chalk = require ( 'chalk' ) ;
2022-09-23 14:30:23 +02:00
const concurrently = require ( 'concurrently' ) ;
2023-06-08 14:33:42 +02: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 08:16:46 +02:00
const config = require ( '../../ghost/core/core/shared/config/loader' ) . loadNconf ( {
customConfigPath : path . join ( _ _dirname , '../../ghost/core' )
2022-10-06 15:58:51 +07:00
} ) ;
2023-12-13 13:07:48 +01: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 14:30:23 +02:00
const liveReloadBaseUrl = config . getSubdir ( ) || '/ghost/' ;
2022-10-06 15:32:08 +07:00
const siteUrl = config . getSiteUrl ( ) ;
2022-09-23 14:30:23 +02: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 15:57:41 +01:00
// Note: if this isn't working for you, please use Node 18 and above
2023-07-13 11:14:08 +02:00
command : 'nx run ghost:dev' ,
2023-07-05 08:16:46 +02:00
cwd : path . resolve ( _ _dirname , '../../ghost/core' ) ,
2022-09-23 14:30:23 +02:00
prefixColor : 'blue' ,
2023-09-26 17:29:17 +02:00
env : {
// In development mode, we allow self-signed certificates (for sending webmentions and oembeds)
NODE _TLS _REJECT _UNAUTHORIZED : '0' ,
}
2022-09-23 14:30:23 +02:00
} ;
const COMMAND _ADMIN = {
name : 'admin' ,
2023-09-18 15:11:45 +02:00
command : ` nx run ghost-admin:dev --live-reload-base-url= ${ liveReloadBaseUrl } --live-reload-port=4201 ` ,
2023-07-05 08:16:46 +02:00
cwd : path . resolve ( _ _dirname , '../../ghost/admin' ) ,
2022-09-23 14:30:23 +02:00
prefixColor : 'green' ,
env : { }
} ;
2024-09-12 15:55:47 +01: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 13:42:39 +02:00
const COMMAND _TYPESCRIPT = {
name : 'ts' ,
2023-12-13 13:07:48 +01:00
command : ` while [ 1 ]; do nx watch --projects= ${ tsPackages } -- nx run \\ $ NX_PROJECT_NAME:build:ts; done ` ,
2023-07-12 13:42:39 +02:00
cwd : path . resolve ( _ _dirname , '../../' ) ,
prefixColor : 'cyan' ,
env : { }
} ;
2024-04-25 09:44:29 +01:00
const adminXApps = '@tryghost/admin-x-demo,@tryghost/admin-x-settings,@tryghost/admin-x-activitypub' ;
2023-11-20 13:30:15 +00:00
2023-11-08 12:33:18 +00:00
const COMMANDS _ADMINX = [ {
2023-11-14 13:50:08 +00:00
name : 'adminXDeps' ,
2024-12-11 16:55:58 +02: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 12:33:18 +00:00
cwd : path . resolve ( _ _dirname , '../..' ) ,
2024-08-20 12:25:54 +02:00
prefixColor : '#C72AF7' ,
2023-11-08 12:33:18 +00:00
env : { }
} , {
2023-09-28 12:36:17 +02:00
name : 'adminX' ,
2023-12-13 10:26:33 +01:00
command : ` nx run-many --projects= ${ adminXApps } --parallel= ${ adminXApps . length } --targets=dev ` ,
2024-04-25 09:44:29 +01:00
cwd : path . resolve ( _ _dirname , '../../apps/admin-x-settings' , '../../apps/admin-x-activitypub' ) ,
2024-08-20 12:25:54 +02:00
prefixColor : '#C72AF7' ,
2023-09-28 12:36:17 +02:00
env : { }
2023-11-08 12:33:18 +00:00
} ] ;
2023-09-28 12:36:17 +02:00
2022-09-23 14:30:23 +02:00
if ( DASH _DASH _ARGS . includes ( 'ghost' ) ) {
2023-07-12 13:42:39 +02:00
commands = [ COMMAND _GHOST , COMMAND _TYPESCRIPT ] ;
2022-09-23 14:30:23 +02:00
} else if ( DASH _DASH _ARGS . includes ( 'admin' ) ) {
2023-11-08 12:33:18 +00:00
commands = [ COMMAND _ADMIN , ... COMMANDS _ADMINX ] ;
2024-09-12 15:55:47 +01:00
} else if ( DASH _DASH _ARGS . includes ( 'browser-tests' ) ) {
2024-10-30 12:39:41 -07:00
commands = [ COMMAND _BROWSERTESTS ] ;
2022-09-23 14:30:23 +02:00
} else {
2023-11-08 12:33:18 +00:00
commands = [ COMMAND _GHOST , COMMAND _TYPESCRIPT , COMMAND _ADMIN , ... COMMANDS _ADMINX ] ;
2023-05-19 10:32:13 +02:00
}
2023-04-27 00:55:03 +01:00
if ( DASH _DASH _ARGS . includes ( 'portal' ) || DASH _DASH _ARGS . includes ( 'all' ) ) {
2022-10-05 11:51:06 +07:00
commands . push ( {
name : 'portal' ,
2023-11-15 09:54:09 +01:00
command : 'nx run @tryghost/portal:dev' ,
2023-07-05 08:16:46 +02:00
cwd : path . resolve ( _ _dirname , '../../apps/portal' ) ,
2022-10-06 15:32:08 +07:00
prefixColor : 'magenta' ,
env : { }
2022-10-05 11:51:06 +07:00
} ) ;
2023-07-05 17:04:39 +02: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-05 11:51:06 +07:00
}
2023-06-01 10:20:37 +02:00
if ( DASH _DASH _ARGS . includes ( 'signup' ) || DASH _DASH _ARGS . includes ( 'all' ) ) {
commands . push ( {
name : 'signup-form' ,
2023-11-15 09:54:09 +01:00
command : DASH _DASH _ARGS . includes ( 'signup' ) ? 'nx run @tryghost/signup-form:dev' : 'nx run @tryghost/signup-form:preview' ,
2023-07-05 08:16:46 +02:00
cwd : path . resolve ( _ _dirname , '../../apps/signup-form' ) ,
2023-06-01 10:20:37 +02:00
prefixColor : 'magenta' ,
env : { }
} ) ;
COMMAND _GHOST . env [ 'signupForm__url' ] = 'http://localhost:6174/signup-form.min.js' ;
}
2023-05-22 15:23:17 +02: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 09:54:09 +01:00
command : 'nx run @tryghost/announcement-bar:dev' ,
2023-07-05 08:16:46 +02:00
cwd : path . resolve ( _ _dirname , '../../apps/announcement-bar' ) ,
2023-05-22 15:23:17 +02:00
prefixColor : '#DC9D00' ,
env : { }
} ) ;
2023-07-27 09:09:01 +02:00
COMMAND _GHOST . env [ 'announcementBar__url' ] = 'http://localhost:4177/announcement-bar.min.js' ;
2023-05-22 15:23:17 +02:00
}
2023-04-27 00:55:03 +01:00
if ( DASH _DASH _ARGS . includes ( 'search' ) || DASH _DASH _ARGS . includes ( 'all' ) ) {
2023-03-17 11:51:42 +01:00
commands . push ( {
name : 'search' ,
2023-11-15 09:54:09 +01:00
command : 'nx run @tryghost/sodo-search:dev' ,
2023-07-05 08:16:46 +02:00
cwd : path . resolve ( _ _dirname , '../../apps/sodo-search' ) ,
2023-03-17 11:51:42 +01:00
prefixColor : '#23de43' ,
env : { }
} ) ;
2023-07-27 09:09:01 +02: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 11:51:42 +01:00
}
2023-05-18 15:14:36 +02:00
if ( DASH _DASH _ARGS . includes ( 'lexical' ) ) {
2023-06-23 10:47:35 +02: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 15:30:59 +02:00
// https://localhost:41730 {
2023-06-27 14:51:37 +02:00
// reverse_proxy http://127.0.0.1:4173
2023-06-23 10:47:35 +02:00
// }
2023-10-02 21:32:05 +02:00
COMMAND _ADMIN . env [ 'EDITOR_URL' ] = 'https://localhost:41730/' ;
2023-06-23 10:47:35 +02:00
} else {
2023-10-02 21:32:05 +02:00
COMMAND _ADMIN . env [ 'EDITOR_URL' ] = 'http://localhost:4173/' ;
2023-06-23 10:47:35 +02:00
}
2023-05-18 15:14:36 +02:00
}
2023-06-22 10:22:14 +02:00
if ( DASH _DASH _ARGS . includes ( 'comments' ) || DASH _DASH _ARGS . includes ( 'all' ) ) {
2023-06-27 14:51:37 +02: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 10:22:14 +02:00
commands . push ( {
name : 'comments' ,
2023-11-15 09:54:09 +01:00
command : 'nx run @tryghost/comments-ui:dev' ,
2023-07-05 08:16:46 +02:00
cwd : path . resolve ( _ _dirname , '../../apps/comments-ui' ) ,
2023-06-22 10:22:14 +02:00
prefixColor : '#E55137' ,
env : { }
} ) ;
2023-06-21 16:41:00 +02:00
}
2023-04-27 00:55:03 +01:00
async function handleStripe ( ) {
if ( DASH _DASH _ARGS . includes ( 'stripe' ) || DASH _DASH _ARGS . includes ( 'all' ) ) {
2024-09-23 17:27:41 +02:00
if ( DASH _DASH _ARGS . includes ( 'offline' ) || DASH _DASH _ARGS . includes ( 'browser-tests' ) ) {
2023-04-27 00:55:03 +01:00
return ;
}
2022-10-06 16:47:54 +07:00
2022-10-06 15:32:08 +07: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 15:42:19 +07:00
return ;
2022-10-06 15:32:08 +07: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-27 00:55:03 +01:00
}
( async ( ) => {
await handleStripe ( ) ;
2022-10-06 15:32:08 +07:00
if ( ! commands . length ) {
console . log ( ` No commands provided ` ) ;
process . exit ( 0 ) ;
}
2024-09-17 11:47:23 +02:00
process . env . NX _DISABLE _DB = "true" ;
await exec ( "yarn nx reset --onlyDaemon" ) ;
await exec ( "yarn nx daemon --start" ) ;
2023-11-15 09:55:10 +01:00
console . log ( ` Running projects: ${ commands . map ( c => chalk . green ( c . name ) ) . join ( ', ' ) } ` ) ;
2022-09-23 14:30:23 +02:00
const { result } = concurrently ( commands , {
prefix : 'name' ,
2024-10-24 17:22:37 -07:00
killOthers : [ 'failure' , 'success' ] ,
successCondition : 'first'
2022-09-23 14:30:23 +02:00
} ) ;
try {
await result ;
} catch ( err ) {
2023-11-15 10:23:57 +01: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 17:22:37 -07:00
process . exit ( 1 ) ;
2022-09-23 14:30:23 +02:00
}
} ) ( ) ;