2022-06-24 16:31:32 +02:00
|
|
|
import { join } from 'path'
|
|
|
|
import Piscina from 'piscina'
|
2023-07-31 14:34:36 +02:00
|
|
|
import { JOB_CONCURRENCY, WORKER_THREADS } from '@server/initializers/constants.js'
|
2023-10-19 14:18:22 +02:00
|
|
|
import type httpBroadcast from './workers/http-broadcast.js'
|
|
|
|
import type downloadImage from './workers/image-downloader.js'
|
|
|
|
import type processImage from './workers/image-processor.js'
|
|
|
|
import type getImageSize from './workers/get-image-size.js'
|
2023-10-24 10:45:17 +02:00
|
|
|
import type signJsonLDObject from './workers/sign-json-ld-object.js'
|
|
|
|
import type buildDigest from './workers/build-digest.js'
|
2023-10-25 09:43:35 +02:00
|
|
|
import type httpUnicast from './workers/http-unicast.js'
|
2022-06-24 16:31:32 +02:00
|
|
|
|
2022-06-28 09:09:03 +02:00
|
|
|
let downloadImageWorker: Piscina
|
2022-06-24 16:31:32 +02:00
|
|
|
|
2023-10-24 10:45:17 +02:00
|
|
|
export function downloadImageFromWorker (options: Parameters<typeof downloadImage>[0]): Promise<ReturnType<typeof downloadImage>> {
|
2022-06-28 09:09:03 +02:00
|
|
|
if (!downloadImageWorker) {
|
|
|
|
downloadImageWorker = new Piscina({
|
2023-07-31 14:34:36 +02:00
|
|
|
filename: new URL(join('workers', 'image-downloader.js'), import.meta.url).href,
|
2022-06-28 09:09:03 +02:00
|
|
|
concurrentTasksPerWorker: WORKER_THREADS.DOWNLOAD_IMAGE.CONCURRENCY,
|
|
|
|
maxThreads: WORKER_THREADS.DOWNLOAD_IMAGE.MAX_THREADS
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
return downloadImageWorker.run(options)
|
2022-06-24 16:31:32 +02:00
|
|
|
}
|
|
|
|
|
2022-06-27 11:53:12 +02:00
|
|
|
// ---------------------------------------------------------------------------
|
|
|
|
|
2022-06-28 09:09:03 +02:00
|
|
|
let processImageWorker: Piscina
|
2022-06-27 11:53:12 +02:00
|
|
|
|
2023-10-24 10:45:17 +02:00
|
|
|
export function processImageFromWorker (options: Parameters<typeof processImage>[0]): Promise<ReturnType<typeof processImage>> {
|
2022-06-28 09:09:03 +02:00
|
|
|
if (!processImageWorker) {
|
|
|
|
processImageWorker = new Piscina({
|
2023-07-31 14:34:36 +02:00
|
|
|
filename: new URL(join('workers', 'image-processor.js'), import.meta.url).href,
|
2022-06-28 09:09:03 +02:00
|
|
|
concurrentTasksPerWorker: WORKER_THREADS.PROCESS_IMAGE.CONCURRENCY,
|
|
|
|
maxThreads: WORKER_THREADS.PROCESS_IMAGE.MAX_THREADS
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2022-06-27 11:53:12 +02:00
|
|
|
return processImageWorker.run(options)
|
|
|
|
}
|
|
|
|
|
2022-09-08 12:26:46 +02:00
|
|
|
// ---------------------------------------------------------------------------
|
|
|
|
|
2023-10-19 14:18:22 +02:00
|
|
|
let getImageSizeWorker: Piscina
|
|
|
|
|
2023-10-24 10:45:17 +02:00
|
|
|
export function getImageSizeFromWorker (options: Parameters<typeof getImageSize>[0]): Promise<ReturnType<typeof getImageSize>> {
|
2023-10-19 14:18:22 +02:00
|
|
|
if (!getImageSizeWorker) {
|
|
|
|
getImageSizeWorker = new Piscina({
|
|
|
|
filename: new URL(join('workers', 'get-image-size.js'), import.meta.url).href,
|
|
|
|
concurrentTasksPerWorker: WORKER_THREADS.GET_IMAGE_SIZE.CONCURRENCY,
|
|
|
|
maxThreads: WORKER_THREADS.GET_IMAGE_SIZE.MAX_THREADS
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
return getImageSizeWorker.run(options)
|
|
|
|
}
|
|
|
|
|
|
|
|
// ---------------------------------------------------------------------------
|
|
|
|
|
2022-09-08 12:26:46 +02:00
|
|
|
let parallelHTTPBroadcastWorker: Piscina
|
|
|
|
|
2023-10-24 10:45:17 +02:00
|
|
|
export function parallelHTTPBroadcastFromWorker (options: Parameters<typeof httpBroadcast>[0]): Promise<ReturnType<typeof httpBroadcast>> {
|
2022-09-08 12:26:46 +02:00
|
|
|
if (!parallelHTTPBroadcastWorker) {
|
|
|
|
parallelHTTPBroadcastWorker = new Piscina({
|
2023-07-31 14:34:36 +02:00
|
|
|
filename: new URL(join('workers', 'http-broadcast.js'), import.meta.url).href,
|
2022-11-16 14:40:10 +01:00
|
|
|
// Keep it sync with job concurrency so the worker will accept all the requests sent by the parallelized jobs
|
|
|
|
concurrentTasksPerWorker: JOB_CONCURRENCY['activitypub-http-broadcast-parallel'],
|
|
|
|
maxThreads: 1
|
2022-09-08 12:26:46 +02:00
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
return parallelHTTPBroadcastWorker.run(options)
|
|
|
|
}
|
|
|
|
|
|
|
|
// ---------------------------------------------------------------------------
|
|
|
|
|
|
|
|
let sequentialHTTPBroadcastWorker: Piscina
|
|
|
|
|
2023-10-24 10:45:17 +02:00
|
|
|
export function sequentialHTTPBroadcastFromWorker (
|
|
|
|
options: Parameters<typeof httpBroadcast>[0]
|
|
|
|
): Promise<ReturnType<typeof httpBroadcast>> {
|
2022-09-08 12:26:46 +02:00
|
|
|
if (!sequentialHTTPBroadcastWorker) {
|
|
|
|
sequentialHTTPBroadcastWorker = new Piscina({
|
2023-07-31 14:34:36 +02:00
|
|
|
filename: new URL(join('workers', 'http-broadcast.js'), import.meta.url).href,
|
2022-11-16 14:40:10 +01:00
|
|
|
// Keep it sync with job concurrency so the worker will accept all the requests sent by the parallelized jobs
|
|
|
|
concurrentTasksPerWorker: JOB_CONCURRENCY['activitypub-http-broadcast'],
|
|
|
|
maxThreads: 1
|
2022-09-08 12:26:46 +02:00
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
return sequentialHTTPBroadcastWorker.run(options)
|
|
|
|
}
|
|
|
|
|
2023-10-24 10:45:17 +02:00
|
|
|
// ---------------------------------------------------------------------------
|
|
|
|
|
2023-10-25 09:43:35 +02:00
|
|
|
let httpUnicastWorker: Piscina
|
|
|
|
|
|
|
|
export function httpUnicastFromWorker (
|
|
|
|
options: Parameters<typeof httpUnicast>[0]
|
|
|
|
): Promise<ReturnType<typeof httpUnicast>> {
|
|
|
|
if (!httpUnicastWorker) {
|
|
|
|
httpUnicastWorker = new Piscina({
|
|
|
|
filename: new URL(join('workers', 'http-unicast.js'), import.meta.url).href,
|
|
|
|
// Keep it sync with job concurrency so the worker will accept all the requests sent by the parallelized jobs
|
|
|
|
concurrentTasksPerWorker: JOB_CONCURRENCY['activitypub-http-unicast'],
|
|
|
|
maxThreads: 1
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
return httpUnicastWorker.run(options)
|
|
|
|
}
|
|
|
|
|
|
|
|
// ---------------------------------------------------------------------------
|
|
|
|
|
2023-10-24 10:45:17 +02:00
|
|
|
let signJsonLDObjectWorker: Piscina
|
|
|
|
|
|
|
|
export function signJsonLDObjectFromWorker <T> (
|
|
|
|
options: Parameters<typeof signJsonLDObject<T>>[0]
|
|
|
|
): ReturnType<typeof signJsonLDObject<T>> {
|
|
|
|
if (!signJsonLDObjectWorker) {
|
|
|
|
signJsonLDObjectWorker = new Piscina({
|
|
|
|
filename: new URL(join('workers', 'sign-json-ld-object.js'), import.meta.url).href,
|
|
|
|
concurrentTasksPerWorker: WORKER_THREADS.SIGN_JSON_LD_OBJECT.CONCURRENCY,
|
|
|
|
maxThreads: WORKER_THREADS.SIGN_JSON_LD_OBJECT.MAX_THREADS
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
return signJsonLDObjectWorker.run(options)
|
|
|
|
}
|
|
|
|
|
|
|
|
// ---------------------------------------------------------------------------
|
|
|
|
|
|
|
|
let buildDigestWorker: Piscina
|
|
|
|
|
|
|
|
export function buildDigestFromWorker (
|
|
|
|
options: Parameters<typeof buildDigest>[0]
|
|
|
|
): Promise<ReturnType<typeof buildDigest>> {
|
|
|
|
if (!buildDigestWorker) {
|
|
|
|
buildDigestWorker = new Piscina({
|
|
|
|
filename: new URL(join('workers', 'build-digest.js'), import.meta.url).href,
|
|
|
|
// Keep it sync with job concurrency so the worker will accept all the requests sent by the parallelized jobs
|
|
|
|
concurrentTasksPerWorker: WORKER_THREADS.BUILD_DIGEST.CONCURRENCY,
|
|
|
|
maxThreads: WORKER_THREADS.BUILD_DIGEST.MAX_THREADS
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
return buildDigestWorker.run(options)
|
2022-06-24 16:31:32 +02:00
|
|
|
}
|