Merge branch 'main' into dockerfile-typing
This commit is contained in:
		| @@ -11,7 +11,7 @@ WORKDIR /app | ||||
|  | ||||
| LABEL coolify.managed true | ||||
|  | ||||
| RUN apk add --no-cache git openssh-client curl jq cmake sqlite | ||||
| RUN apk add --no-cache git git-lfs openssh-client curl jq cmake sqlite | ||||
|  | ||||
| RUN curl -f https://get.pnpm.io/v6.16.js | node - add --global pnpm@6 | ||||
| RUN pnpm add -g pnpm | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| { | ||||
| 	"name": "coolify", | ||||
| 	"description": "An open-source & self-hostable Heroku / Netlify alternative.", | ||||
| 	"version": "2.3.2", | ||||
| 	"version": "2.3.3", | ||||
| 	"license": "AGPL-3.0", | ||||
| 	"scripts": { | ||||
| 		"dev": "docker-compose -f docker-compose-dev.yaml up -d && cross-env NODE_ENV=development & svelte-kit dev", | ||||
|   | ||||
| @@ -46,11 +46,16 @@ const customConfig: Config = { | ||||
| export const version = currentVersion; | ||||
| export const asyncExecShell = util.promisify(child.exec); | ||||
| export const asyncSleep = (delay) => new Promise((resolve) => setTimeout(resolve, delay)); | ||||
|  | ||||
| export const sentry = Sentry; | ||||
|  | ||||
| export const uniqueName = () => uniqueNamesGenerator(customConfig); | ||||
|  | ||||
| export const saveBuildLog = async ({ line, buildId, applicationId }) => { | ||||
| 	if (line.includes('ghs_')) { | ||||
| 		const regex = /ghs_.*@/g; | ||||
| 		line = line.replace(regex, '<SENSITIVE_DATA_DELETED>@'); | ||||
| 	} | ||||
| 	const addTimestamp = `${generateTimestamp()} ${line}`; | ||||
| 	return await buildLogQueue.add(buildId, { buildId, line: addTimestamp, applicationId }); | ||||
| }; | ||||
|   | ||||
| @@ -15,7 +15,6 @@ export default async function ({ | ||||
| 	branch, | ||||
| 	buildId | ||||
| }): Promise<any> { | ||||
| 	try { | ||||
| 	const url = htmlUrl.replace('https://', '').replace('http://', ''); | ||||
| 	await saveBuildLog({ line: 'GitHub importer started.', buildId, applicationId }); | ||||
| 	const { privateKey, appId, installationId } = await db.getUniqueGithubApp({ githubAppId }); | ||||
| @@ -43,12 +42,8 @@ export default async function ({ | ||||
| 		applicationId | ||||
| 	}); | ||||
| 	await asyncExecShell( | ||||
| 			`git clone -q -b ${branch} https://x-access-token:${token}@${url}/${repository}.git ${workdir}/ && cd ${workdir} && git submodule update --init --recursive && cd ..` | ||||
| 		`git clone -q -b ${branch} https://x-access-token:${token}@${url}/${repository}.git ${workdir}/ && cd ${workdir} && git submodule update --init --recursive && git lfs pull && cd .. ` | ||||
| 	); | ||||
| 	const { stdout: commit } = await asyncExecShell(`cd ${workdir}/ && git rev-parse HEAD`); | ||||
| 	return commit.replace('\n', ''); | ||||
| 	} catch (error) { | ||||
| 		console.log({ error }); | ||||
| 		return ErrorHandler(error); | ||||
| 	} | ||||
| } | ||||
|   | ||||
| @@ -22,7 +22,7 @@ export default async function ({ | ||||
| 	}); | ||||
|  | ||||
| 	await asyncExecShell( | ||||
| 		`git clone -q -b ${branch} git@${url}:${repository}.git --config core.sshCommand="ssh -q -i ${repodir}id.rsa -o StrictHostKeyChecking=no" ${workdir}/ && cd ${workdir}/ && git submodule update --init --recursive && cd ..` | ||||
| 		`git clone -q -b ${branch} git@${url}:${repository}.git --config core.sshCommand="ssh -q -i ${repodir}id.rsa -o StrictHostKeyChecking=no" ${workdir}/ && cd ${workdir}/ && git submodule update --init --recursive && git lfs pull && cd .. ` | ||||
| 	); | ||||
| 	const { stdout: commit } = await asyncExecShell(`cd ${workdir}/ && git rev-parse HEAD`); | ||||
| 	return commit.replace('\n', ''); | ||||
|   | ||||
| @@ -61,7 +61,7 @@ export default async function (job) { | ||||
| 	await asyncSleep(500); | ||||
| 	await db.prisma.build.updateMany({ | ||||
| 		where: { | ||||
| 			status: 'queued', | ||||
| 			status: { in: ['queued', 'running'] }, | ||||
| 			id: { not: buildId }, | ||||
| 			applicationId, | ||||
| 			createdAt: { lt: new Date(new Date().getTime() - 60 * 60 * 1000) } | ||||
|   | ||||
| @@ -118,10 +118,14 @@ buildWorker.on('completed', async (job: Bullmq.Job) => { | ||||
| 	try { | ||||
| 		await prisma.build.update({ where: { id: job.data.build_id }, data: { status: 'success' } }); | ||||
| 	} catch (error) { | ||||
| 		setTimeout(async () => { | ||||
| 			await prisma.build.update({ where: { id: job.data.build_id }, data: { status: 'success' } }); | ||||
| 		}, 1234); | ||||
| 		console.log(error); | ||||
| 	} finally { | ||||
| 		const workdir = `/tmp/build-sources/${job.data.repository}/${job.data.build_id}`; | ||||
| 		if (!dev) await asyncExecShell(`rm -fr ${workdir}`); | ||||
| 		await prisma.build.update({ where: { id: job.data.build_id }, data: { status: 'success' } }); | ||||
| 	} | ||||
| 	return; | ||||
| }); | ||||
| @@ -130,10 +134,14 @@ buildWorker.on('failed', async (job: Bullmq.Job, failedReason) => { | ||||
| 	try { | ||||
| 		await prisma.build.update({ where: { id: job.data.build_id }, data: { status: 'failed' } }); | ||||
| 	} catch (error) { | ||||
| 		setTimeout(async () => { | ||||
| 			await prisma.build.update({ where: { id: job.data.build_id }, data: { status: 'failed' } }); | ||||
| 		}, 1234); | ||||
| 		console.log(error); | ||||
| 	} finally { | ||||
| 		const workdir = `/tmp/build-sources/${job.data.repository}`; | ||||
| 		if (!dev) await asyncExecShell(`rm -fr ${workdir}`); | ||||
| 		await prisma.build.update({ where: { id: job.data.build_id }, data: { status: 'failed' } }); | ||||
| 	} | ||||
| 	await saveBuildLog({ | ||||
| 		line: 'Failed to deploy!', | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Dominic Bachmann
					Dominic Bachmann