1
0
mirror of https://github.com/nolanlawson/pinafore synced 2025-01-23 10:24:29 +01:00
Pinafore-Web-Client-Frontend/bin/run-mastodon.js

57 lines
1.5 KiB
JavaScript
Raw Normal View History

2018-03-06 05:51:42 +01:00
import { restoreMastodonData } from './restore-mastodon-data'
import childProcessPromise from 'child-process-promise'
import fs from 'fs'
2018-03-06 18:21:17 +01:00
import { waitForMastodonUiToStart, waitForMastodonApiToStart } from './wait-for-mastodon-to-start'
import cloneMastodon from './clone-mastodon'
import installMastodon from './install-mastodon'
import { mastodonDir, env } from './mastodon-config'
2018-03-06 05:51:42 +01:00
const spawn = childProcessPromise.spawn
let childProc
2018-02-19 00:30:42 +01:00
async function runMastodon () {
console.log('Running mastodon...')
2019-08-03 22:49:37 +02:00
const cwd = mastodonDir
const promise = spawn('foreman', ['start'], { cwd, env })
// don't bother writing to mastodon.log in CI; we can't read the file anyway
const logFile = process.env.CIRCLECI ? '/dev/null' : 'mastodon.log'
const log = fs.createWriteStream(logFile, { flags: 'a' })
childProc = promise.childProcess
childProc.stdout.pipe(log)
childProc.stderr.pipe(log)
2018-04-11 04:43:36 +02:00
promise.catch(err => {
console.error('foreman start failed, see mastodon.log for details')
console.error(err)
shutdownMastodon()
process.exit(1)
})
2018-02-18 19:42:27 +01:00
}
2018-02-19 00:30:42 +01:00
async function main () {
await cloneMastodon()
await installMastodon()
await runMastodon()
2018-03-06 06:21:28 +01:00
await waitForMastodonApiToStart()
2018-03-06 18:04:09 +01:00
await restoreMastodonData()
2018-03-06 06:58:29 +01:00
await waitForMastodonUiToStart()
}
2018-03-07 08:57:06 +01:00
function shutdownMastodon () {
if (childProc) {
console.log('killing child process')
childProc.kill()
}
2018-03-06 18:03:59 +01:00
}
process.on('SIGINT', function () {
shutdownMastodon()
process.exit(0)
})
2018-02-18 19:42:27 +01:00
main().catch(err => {
console.error(err)
2018-03-06 18:03:59 +01:00
shutdownMastodon()
2018-02-18 19:42:27 +01:00
process.exit(1)
})