- 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.
27 lines
1.1 KiB
JavaScript
27 lines
1.1 KiB
JavaScript
const fs = require('fs').promises
|
|
const { buildImage } = require('../helpers')
|
|
const { streamEvents, docker } = require('../../libs/docker')
|
|
|
|
const publishNodejsDocker = (configuration) => {
|
|
return [
|
|
'FROM node:lts',
|
|
'WORKDIR /usr/src/app',
|
|
configuration.build.command.build
|
|
? `COPY --from=${configuration.build.container.name}:${configuration.build.container.tag} /usr/src/app/${configuration.publish.directory} ./`
|
|
: `COPY ${configuration.build.directory} ./`,
|
|
configuration.build.command.installation && `RUN ${configuration.build.command.installation}`,
|
|
`EXPOSE ${configuration.publish.port}`,
|
|
'CMD [ "yarn", "start" ]'
|
|
].join('\n')
|
|
}
|
|
|
|
module.exports = async function (configuration) {
|
|
if (configuration.build.command.build) await buildImage(configuration)
|
|
await fs.writeFile(`${configuration.general.workdir}/Dockerfile`, publishNodejsDocker(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)
|
|
}
|