Skip to content

Commit

Permalink
fix: batched v2 http api fetch & fix deployment update
Browse files Browse the repository at this point in the history
  • Loading branch information
robot9706 committed Dec 16, 2024
1 parent 3616c8d commit 7cc0752
Show file tree
Hide file tree
Showing 5 changed files with 35 additions and 17 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,9 @@ const EditDeploymentCard = (props: EditDeploymentCardProps) => {
t,
onSubmit: async (values, { setFieldError }) => {
const body: UpdateDeployment = {
...values,
note: values.note,
prefix: values.prefix,
protected: values.protected,
configBundles: values.configBundles.map(it => it.id),
}

Expand Down
12 changes: 10 additions & 2 deletions web/crux-ui/src/components/projects/versions/use-version-state.ts
Original file line number Diff line number Diff line change
Expand Up @@ -104,6 +104,7 @@ export interface VersionStateOptions {
projectId: string
version: VersionDetails
initialSection: VersionSectionsState
fetchTagInfo?: boolean
setSaveState?: (saveState: WebSocketSaveState) => void
}

Expand Down Expand Up @@ -180,11 +181,18 @@ export const useVersionState = (options: VersionStateOptions): [VerionState, Ver
const editor = useEditorState(versionSock)

const registriesSock = useWebSocket(routes.registry.socket(), {
onOpen: () =>
onOpen: () => {
// TODO(@robot9706): Not sure why we fetch all the tags here,
// it is super slow with our 8+ images / version, where each image has 200+ tags, so disable it
if (options.fetchTagInfo === false) {
return
}

refreshImageTags(
registriesSock,
version.images.filter(it => it.registry.type !== 'unchecked'),
),
)
},
})

registriesSock.on(WS_TYPE_REGISTRY_IMAGE_TAGS, (message: RegistryImageTagsMessage) => {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ const VersionlessProjectSections = (props: VersionlessProjectSectionsProps) => {
version,
projectId: project.id,
initialSection,
fetchTagInfo: false,
setSaveState,
})

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,7 @@ const VersionDetailsPage = (props: VersionDetailsPageProps) => {
initialSection,
projectId: project.id,
version,
fetchTagInfo: false,
})

const onVersionEdited = async (newVersion: EditableVersion) => {
Expand Down
34 changes: 20 additions & 14 deletions web/crux/src/app/registry/registry-clients/registry-api-client.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
import { RegistryImageTag, RegistryImageTags } from '../registry.message'

const TAG_INFO_BATCH_SIZE = 5

export interface RegistryApiClient {
catalog(text: string): Promise<string[]>
tags(image: string): Promise<RegistryImageTags>
Expand All @@ -12,20 +14,24 @@ export const fetchInfoForTags = async (
tags: string[],
client: RegistryApiClient,
): Promise<Record<string, RegistryImageTag>> => {
const tagsWithInfoPromise = tags.map(async it => {
const info = await client.tagInfo(image, it)
const map: Record<string, RegistryImageTag> = {}

for (let batch = 0; batch < Math.ceil(tags.length / TAG_INFO_BATCH_SIZE); batch++) {
const start = batch * TAG_INFO_BATCH_SIZE
const end = Math.min(tags.length, start + TAG_INFO_BATCH_SIZE)
const promises = tags.slice(start, end).map(async it => {
const info = await client.tagInfo(image, it)

return {
tag: it,
info,
}
})

return {
tag: it,
info,
}
})
// eslint-disable-next-line no-await-in-loop
const results = await Promise.all(promises)
results.forEach(it => map[it.tag] = it.info)
}

return (await Promise.all(tagsWithInfoPromise)).reduce(
(map, it) => {
map[it.tag] = it.info
return map
},
{} as Record<string, RegistryImageTag>,
)
return map
}

0 comments on commit 7cc0752

Please sign in to comment.