- Search in repositories (thanks to @SaraVieira).
- Custom Dockerfile - you be able to deploy ANY applications! 🎉
- Basic repository scanner for Nextjs and React. It will setup the default commands and buildpack if it detects some defined parameters.
- UI/UX fixes:
- Github loading screen instead of standard loading screen.
- Info tooltips which provide some explanations of the input fields.
24 lines
845 B
JavaScript
24 lines
845 B
JavaScript
const fs = require('fs').promises
|
|
const { streamEvents, docker } = require('../libs/docker')
|
|
const buildImageNodeDocker = (configuration) => {
|
|
return [
|
|
'FROM node:lts',
|
|
'WORKDIR /usr/src/app',
|
|
`COPY ${configuration.build.directory} ./`,
|
|
configuration.build.command.installation && `RUN ${configuration.build.command.installation}`,
|
|
`RUN ${configuration.build.command.build}`
|
|
].join('\n')
|
|
}
|
|
async function buildImage (configuration) {
|
|
await fs.writeFile(`${configuration.general.workdir}/Dockerfile`, buildImageNodeDocker(configuration))
|
|
const stream = await docker.engine.buildImage(
|
|
{ src: ['.'], context: configuration.general.workdir },
|
|
{ t: `${configuration.build.container.name}:${configuration.build.container.tag}` }
|
|
)
|
|
await streamEvents(stream, configuration)
|
|
}
|
|
|
|
module.exports = {
|
|
buildImage
|
|
}
|