mirror of
https://github.com/Dokploy/dokploy
synced 2025-06-26 18:27:59 +00:00
fix(docker): fix for custom registry login
This commit is contained in:
parent
852895c382
commit
844d582147
@ -19,21 +19,25 @@ export const uploadImage = async (
|
|||||||
|
|
||||||
const finalURL = registryUrl;
|
const finalURL = registryUrl;
|
||||||
|
|
||||||
const registryTag = join(imagePrefix || "", imageName);
|
const registryTag =
|
||||||
|
`${registryUrl}/${join(imagePrefix || "", imageName)}`.replace(/\/+/g, "/");
|
||||||
|
|
||||||
try {
|
try {
|
||||||
writeStream.write(
|
writeStream.write(
|
||||||
`📦 [Enabled Registry] Uploading image to ${registry.registryType} | ${registryTag} | ${finalURL}\n`,
|
`📦 [Enabled Registry] Uploading image to ${registry.registryType} | ${imageName} | ${finalURL}\n`,
|
||||||
);
|
);
|
||||||
await spawnAsync(
|
const loginCommand = spawnAsync(
|
||||||
"docker",
|
"docker",
|
||||||
["login", finalURL, "-u", registry.username, "-p", registry.password],
|
["login", finalURL, "-u", registry.username, "--password-stdin"],
|
||||||
(data) => {
|
(data) => {
|
||||||
if (writeStream.writable) {
|
if (writeStream.writable) {
|
||||||
writeStream.write(data);
|
writeStream.write(data);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
);
|
);
|
||||||
|
loginCommand.child?.stdin?.write(registry.password);
|
||||||
|
loginCommand.child?.stdin?.end();
|
||||||
|
await loginCommand;
|
||||||
|
|
||||||
await spawnAsync("docker", ["tag", imageName, registryTag], (data) => {
|
await spawnAsync("docker", ["tag", imageName, registryTag], (data) => {
|
||||||
if (writeStream.writable) {
|
if (writeStream.writable) {
|
||||||
@ -73,17 +77,16 @@ export const uploadImageRemoteCommand = (
|
|||||||
try {
|
try {
|
||||||
const command = `
|
const command = `
|
||||||
echo "📦 [Enabled Registry] Uploading image to '${registry.registryType}' | '${registryTag}'" >> ${logPath};
|
echo "📦 [Enabled Registry] Uploading image to '${registry.registryType}' | '${registryTag}'" >> ${logPath};
|
||||||
docker login ${finalURL} -u ${registry.username} -p ${registry.password} >> ${logPath} 2>> ${logPath} || {
|
echo "${registry.password}" | docker login ${finalURL} -u ${registry.username} --password-stdin >> ${logPath} 2>> ${logPath} || {
|
||||||
echo "❌ DockerHub Failed" >> ${logPath};
|
echo "❌ DockerHub Failed" >> ${logPath};
|
||||||
exit 1;
|
exit 1;
|
||||||
}
|
}
|
||||||
echo "✅ DockerHub Login Success" >> ${logPath};
|
echo "✅ Registry Login Success" >> ${logPath};
|
||||||
docker tag ${imageName} ${registryTag} >> ${logPath} 2>> ${logPath} || {
|
docker tag ${imageName} ${registryTag} >> ${logPath} 2>> ${logPath} || {
|
||||||
echo "❌ Error tagging image" >> ${logPath};
|
echo "❌ Error tagging image" >> ${logPath};
|
||||||
exit 1;
|
exit 1;
|
||||||
}
|
}
|
||||||
echo "✅ Image Tagged" >> ${logPath};
|
echo "✅ Image Tagged" >> ${logPath};
|
||||||
|
|
||||||
docker push ${registryTag} 2>> ${logPath} || {
|
docker push ${registryTag} 2>> ${logPath} || {
|
||||||
echo "❌ Error pushing image" >> ${logPath};
|
echo "❌ Error pushing image" >> ${logPath};
|
||||||
exit 1;
|
exit 1;
|
||||||
|
@ -53,7 +53,7 @@ export const buildRemoteDocker = async (
|
|||||||
application: ApplicationNested,
|
application: ApplicationNested,
|
||||||
logPath: string,
|
logPath: string,
|
||||||
) => {
|
) => {
|
||||||
const { sourceType, dockerImage, username, password } = application;
|
const { registryUrl, dockerImage, username, password } = application;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
if (!dockerImage) {
|
if (!dockerImage) {
|
||||||
@ -65,7 +65,7 @@ echo "Pulling ${dockerImage}" >> ${logPath};
|
|||||||
|
|
||||||
if (username && password) {
|
if (username && password) {
|
||||||
command += `
|
command += `
|
||||||
if ! docker login --username ${username} --password ${password} https://index.docker.io/v1/ >> ${logPath} 2>&1; then
|
if ! echo "${password}" | docker login --username "${username}" --password-stdin "${registryUrl || ""}" >> ${logPath} 2>&1; then
|
||||||
echo "❌ Login failed" >> ${logPath};
|
echo "❌ Login failed" >> ${logPath};
|
||||||
exit 1;
|
exit 1;
|
||||||
fi
|
fi
|
||||||
|
Loading…
Reference in New Issue
Block a user