mirror of
https://github.com/labring/FastGPT.git
synced 2026-05-16 01:09:01 +08:00
c93c3937e1
* refactor: fastgpt object storage & global proxy (#6155) * feat: migrate to fastgpt storage sdk * chore: rename env variable * chore: move to sdk dir * docs: object storage * CHORE * chore: storage mocks * chore: update docker-compose * fix: global proxy agent * fix: update COS proxy * refactor: use fetch instead of http.request * fix: axios request base url * fix: axios proxy request behavior * fix: bumps axios * fix: patch axios for proxy * fix: replace axios with proxied axios * fix: upload txt file encoding * clean code * fix: use "minio" for minio adapter (#6205) * fix: use minio client to delete files when using minio vendor (#6206) * doc * feat: filter citations and add response button control (#6170) * feat: filter citations and add response button control * i18n * fix * fix test * perf: chat api code * fix: workflow edge overlap and auto-align in folded loop nodes (#6204) * fix: workflow edge overlap and auto-align in folded loop nodes * sort * fix * fix edge * fix icon * perf: s3 file name * perf: admin get app api * perf: catch user error * fix: refactor useOrg hook to use debounced search key (#6180) * chore: comment minio adapter (#6207) * chore: filename with suffix random id * perf: s3 storage code * fix: encode filename when copy object --------- Co-authored-by: archer <545436317@qq.com> * fix: node card link * json * perf: chat index; * index * chat item soft delete (#6216) * chat item soft delete * temp * fix * remove code * perf: delete chat item --------- Co-authored-by: archer <545436317@qq.com> * feat: select wheather filter sensitive info when export apps (#6222) * fix some bugs (#6210) * fix v4.14.5 bugs * type * fix * fix * custom feedback * fix * code * fix * remove invalid function --------- Co-authored-by: archer <545436317@qq.com> * perf: test * fix file default local upload (#6223) * docs: improve object storage introduction (#6224) * doc --------- Co-authored-by: roy <whoeverimf5@gmail.com> Co-authored-by: heheer <heheer@sealos.io> Co-authored-by: Finley Ge <32237950+FinleyGe@users.noreply.github.com>
79 lines
2.1 KiB
TypeScript
79 lines
2.1 KiB
TypeScript
import { getQueue, getWorker, QueueNames } from '../bullmq';
|
|
import { addLog } from '../system/log';
|
|
import path from 'path';
|
|
import { batchRun } from '@fastgpt/global/common/system/utils';
|
|
|
|
export type S3MQJobData = {
|
|
key?: string;
|
|
keys?: string[];
|
|
prefix?: string;
|
|
bucketName: string;
|
|
};
|
|
|
|
const jobOption = {
|
|
attempts: 10,
|
|
removeOnFail: {
|
|
count: 10000, // 保留10000个失败任务
|
|
age: 14 * 24 * 60 * 60 // 14 days
|
|
},
|
|
removeOnComplete: true,
|
|
backoff: {
|
|
delay: 2000,
|
|
type: 'exponential'
|
|
}
|
|
};
|
|
|
|
export const addS3DelJob = async (data: S3MQJobData): Promise<void> => {
|
|
const queue = getQueue<S3MQJobData>(QueueNames.s3FileDelete);
|
|
const jobId = (() => {
|
|
if (data.key) {
|
|
return data.key;
|
|
}
|
|
if (data.keys) {
|
|
return undefined;
|
|
}
|
|
if (data.prefix) {
|
|
return `${data.bucketName}:${data.prefix}`;
|
|
}
|
|
throw new Error('Invalid s3 delete job data');
|
|
})();
|
|
await queue.add('delete-s3-files', data, { jobId, ...jobOption });
|
|
};
|
|
|
|
export const startS3DelWorker = async () => {
|
|
return getWorker<S3MQJobData>(
|
|
QueueNames.s3FileDelete,
|
|
async (job) => {
|
|
let { prefix, bucketName, key, keys } = job.data;
|
|
const bucket = global.s3BucketMap[bucketName];
|
|
|
|
if (!bucket) {
|
|
addLog.error(`Bucket not found: ${bucketName}`);
|
|
return;
|
|
}
|
|
|
|
if (key) {
|
|
keys = [key];
|
|
}
|
|
if (keys) {
|
|
addLog.debug(`[S3 delete] delete keys: ${keys.length}`);
|
|
await bucket.client.deleteObjectsByMultiKeys({ keys });
|
|
|
|
await batchRun(keys, async (key) => {
|
|
if (key.includes('-parsed/')) return;
|
|
const fileParsedPrefix = `${path.dirname(key)}/${path.basename(key, path.extname(key))}-parsed`;
|
|
await bucket.client.deleteObjectsByPrefix({ prefix: fileParsedPrefix });
|
|
});
|
|
}
|
|
if (prefix) {
|
|
addLog.info(`[S3 delete] delete prefix: ${prefix}`);
|
|
bucket.client.deleteObjectsByPrefix({ prefix });
|
|
addLog.info(`[S3 delete] delete prefix: ${prefix} success`);
|
|
}
|
|
},
|
|
{
|
|
concurrency: 6
|
|
}
|
|
);
|
|
};
|