Skip to content

Commit

Permalink
Merge pull request #960 from Dokploy/fix/add-latest-cases
Browse files Browse the repository at this point in the history
refactor: update digest
  • Loading branch information
Siumauricio authored Dec 21, 2024
2 parents 6e2b2d5 + b2661e4 commit a953e59
Show file tree
Hide file tree
Showing 2 changed files with 33 additions and 25 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -49,12 +49,12 @@ interface AdditionalPort {
/**
* ManageTraefikPorts is a component that provides a modal interface for managing
* additional port mappings for Traefik in a Docker Swarm environment.
*
*
* Features:
* - Add, remove, and edit port mappings
* - Configure target port, published port, and publish mode for each mapping
* - Persist port configurations through API calls
*
*
* @component
* @example
* ```tsx
Expand Down Expand Up @@ -121,7 +121,10 @@ export const ManageTraefikPorts = ({ children, serverId }: Props) => {
</DialogHeader>
<div className="grid gap-4 py-4">
{additionalPorts.map((port, index) => (
<div key={index} className="grid grid-cols-[120px_120px_minmax(120px,1fr)_80px] gap-4 items-end">
<div
key={index}
className="grid grid-cols-[120px_120px_minmax(120px,1fr)_80px] gap-4 items-end"
>
<div className="space-y-2">
<Label htmlFor={`target-port-${index}`}>
{t("settings.server.webServer.traefik.targetPort")}
Expand All @@ -132,7 +135,9 @@ export const ManageTraefikPorts = ({ children, serverId }: Props) => {
value={port.targetPort}
onChange={(e) => {
const newPorts = [...additionalPorts];
newPorts[index].targetPort = Number.parseInt(

// @ts-ignore
newPorts?.[index].targetPort = Number.parseInt(
e.target.value,
);
setAdditionalPorts(newPorts);
Expand All @@ -150,7 +155,8 @@ export const ManageTraefikPorts = ({ children, serverId }: Props) => {
value={port.publishedPort}
onChange={(e) => {
const newPorts = [...additionalPorts];
newPorts[index].publishedPort = Number.parseInt(
// @ts-ignore
newPorts?.[index].publishedPort = Number.parseInt(
e.target.value,
);
setAdditionalPorts(newPorts);
Expand All @@ -166,11 +172,15 @@ export const ManageTraefikPorts = ({ children, serverId }: Props) => {
value={port.publishMode}
onValueChange={(value: "ingress" | "host") => {
const newPorts = [...additionalPorts];
newPorts[index].publishMode = value;
// @ts-ignore
newPorts?.[index].publishMode = value;
setAdditionalPorts(newPorts);
}}
>
<SelectTrigger id={`publish-mode-${index}`} className="w-full">
<SelectTrigger
id={`publish-mode-${index}`}
className="w-full"
>
<SelectValue />
</SelectTrigger>
<SelectContent>
Expand Down
34 changes: 16 additions & 18 deletions packages/server/src/services/settings.ts
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,6 @@ export const getUpdateData = async (): Promise<IUpdateData> => {
const baseUrl = "https://hub.docker.com/v2/repositories/dokploy/dokploy/tags";
let url: string | null = `${baseUrl}?page_size=100`;
let allResults: { digest: string; name: string }[] = [];

while (url) {
const response = await fetch(url, {
method: "GET",
Expand All @@ -81,30 +80,29 @@ export const getUpdateData = async (): Promise<IUpdateData> => {
url = data?.next;
}

const latestTagDigest = allResults.find(
(t) => t.name === getDokployImageTag(),
)?.digest;
const imageTag = getDokployImageTag();
const searchedDigest = allResults.find((t) => t.name === imageTag)?.digest;

if (!latestTagDigest) {
if (!searchedDigest) {
return DEFAULT_UPDATE_DATA;
}

const versionedTag = allResults.find(
(t) => t.digest === latestTagDigest && t.name.startsWith("v"),
);

if (!versionedTag) {
return DEFAULT_UPDATE_DATA;
}
if (imageTag === "latest") {
const versionedTag = allResults.find(
(t) => t.digest === searchedDigest && t.name.startsWith("v"),
);

const { name: latestVersion, digest } = versionedTag;
const updateAvailable = digest !== currentDigest;
if (!versionedTag) {
return DEFAULT_UPDATE_DATA;
}

return { latestVersion, updateAvailable };
};
const { name: latestVersion, digest } = versionedTag;
const updateAvailable = digest !== currentDigest;

export const getDokployVersion = () => {
// return packageInfo.version;
return { latestVersion, updateAvailable };
}
const updateAvailable = searchedDigest !== currentDigest;
return { latestVersion: imageTag, updateAvailable };
};

interface TreeDataItem {
Expand Down

0 comments on commit a953e59

Please sign in to comment.