fix: Coolify image pulls

This commit is contained in:
Andras Bacsai
2022-02-24 10:37:37 +01:00
parent d6225cbde3
commit c9b52f1310
2 changed files with 7 additions and 36 deletions

View File

@@ -30,7 +30,6 @@
<script> <script>
export let teams; export let teams;
export let selectedTeamId; export let selectedTeamId;
import { fade } from 'svelte/transition';
import '../tailwind.css'; import '../tailwind.css';
import { SvelteToast, toast } from '@zerodevx/svelte-toast'; import { SvelteToast, toast } from '@zerodevx/svelte-toast';
@@ -44,7 +43,6 @@
let isUpdateAvailable = false; let isUpdateAvailable = false;
let updateStatus = { let updateStatus = {
loading: false, loading: false,
checking: false,
success: null success: null
}; };
let latestVersion = 'latest'; let latestVersion = 'latest';
@@ -59,18 +57,14 @@
return errorNotification(error); return errorNotification(error);
} }
if ($session.teamId === '0') { if ($session.teamId === '0') {
updateStatus.checking = true;
try { try {
const data = await get(`/update.json`); const data = await get(`/update.json`);
if (overrideVersion || data?.isUpdateAvailable) { if (overrideVersion || data?.isUpdateAvailable) {
latestVersion = overrideVersion || data.latestVersion; latestVersion = overrideVersion || data.latestVersion;
isUpdateAvailable = overrideVersion ? true : data?.isUpdateAvailable; isUpdateAvailable = overrideVersion ? true : data?.isUpdateAvailable;
await post(`/update.json`, { type: 'pull', latestVersion }); await post(`/update.json`, { type: 'pull', latestVersion, overrideVersion });
} }
} catch (error) { } catch (error) {}
} finally {
updateStatus.checking = false;
}
} }
} }
}); });
@@ -311,32 +305,7 @@
<div class="flex flex-col space-y-4 py-2"> <div class="flex flex-col space-y-4 py-2">
{#if $session.teamId === '0'} {#if $session.teamId === '0'}
{#if updateStatus.checking} {#if isUpdateAvailable}
<button
disabled
in:fade={{ duration: 150 }}
class="icons tooltip-right bg-gradient-to-r from-purple-500 via-pink-500 to-red-500 text-white duration-75 hover:scale-105"
data-tooltip="Checking for updates..."
><svg
xmlns="http://www.w3.org/2000/svg"
class="h-9 w-8 animate-spin"
viewBox="0 0 24 24"
stroke-width="1.5"
stroke="currentColor"
fill="none"
stroke-linecap="round"
stroke-linejoin="round"
>
<path stroke="none" d="M0 0h24v24H0z" fill="none" />
<path d="M9 4.55a8 8 0 0 1 6 14.9m0 -4.45v5h5" />
<line x1="5.63" y1="7.16" x2="5.63" y2="7.17" />
<line x1="4.06" y1="11" x2="4.06" y2="11.01" />
<line x1="4.63" y1="15.1" x2="4.63" y2="15.11" />
<line x1="7.16" y1="18.37" x2="7.16" y2="18.38" />
<line x1="11" y1="19.94" x2="11" y2="19.95" />
</svg></button
>
{:else if isUpdateAvailable}
<button <button
disabled={updateStatus.success === false} disabled={updateStatus.success === false}
data-tooltip="Update available" data-tooltip="Update available"
@@ -346,7 +315,7 @@
{#if updateStatus.loading} {#if updateStatus.loading}
<svg <svg
xmlns="http://www.w3.org/2000/svg" xmlns="http://www.w3.org/2000/svg"
class="w-8 h-9 lds-heart" class="lds-heart h-9 w-8"
viewBox="0 0 24 24" viewBox="0 0 24 24"
stroke-width="1.5" stroke-width="1.5"
stroke="currentColor" stroke="currentColor"

View File

@@ -26,10 +26,12 @@ export const get: RequestHandler = async () => {
}; };
export const post: RequestHandler = async (event) => { export const post: RequestHandler = async (event) => {
const { type, latestVersion } = await event.request.json(); const { type, latestVersion, overrideVersion = false } = await event.request.json();
if (type === 'pull') { if (type === 'pull') {
try { try {
if (!dev) { if (!dev) {
if (!overrideVersion)
await asyncExecShell(`docker image inspect coollabsio/coolify:${latestVersion}`);
await asyncExecShell(`docker pull coollabsio/coolify:${latestVersion}`); await asyncExecShell(`docker pull coollabsio/coolify:${latestVersion}`);
return { return {
status: 200, status: 200,