51 lines
1.5 KiB
TypeScript
Raw Normal View History

2024-05-21 00:57:24 +02:00
import type { Readable } from 'stream';
2023-07-12 00:32:17 +02:00
import * as plugins from './smartmime.plugins.js';
2020-03-04 14:21:44 +00:00
2024-05-21 00:57:24 +02:00
import { binaryMimeTypes } from './binary.js';
2020-03-04 14:21:44 +00:00
export type IFileTypeResult = plugins.fileType.FileTypeResult;
2024-05-21 00:57:24 +02:00
// TODO: evaluate where this is actually used
2021-08-10 11:49:39 +02:00
export const supportedFileTypes = ['json', 'html', 'svg', 'jpg', 'ts', 'js'];
2020-03-04 14:21:44 +00:00
2024-05-21 00:57:24 +02:00
export const detectMimeType = async (optionsArg: {
path?: string;
buffer?: Uint8Array;
stream?: Readable;
}): Promise<plugins.fileType.FileTypeResult> => {
if (optionsArg.path) {
return {
mime: plugins.mime.getType(optionsArg.path),
ext: plugins.path.extname(optionsArg.path),
} as plugins.fileType.FileTypeResult;
} else if (optionsArg.buffer) {
return plugins.fileType.fileTypeFromBuffer(optionsArg.buffer);
} else if (optionsArg.stream) {
return plugins.fileType.fileTypeFromStream(optionsArg.stream);
}
2020-03-04 14:21:44 +00:00
};
2024-05-21 00:57:24 +02:00
export const isBinary = async (optionsArg: {
path?: string;
buffer?: Uint8Array;
stream?: Readable;
}) => {
const mimeType = await detectMimeType(optionsArg);
return binaryMimeTypes.includes(mimeType.mime);
2021-08-10 11:49:39 +02:00
};
2020-03-04 15:47:15 +00:00
2024-05-21 00:57:24 +02:00
export const getEncoding = async (optionsArg: {
path?: string;
buffer?: Uint8Array;
stream?: Readable;
}) => {
return (await isBinary(optionsArg)) ? 'binary' : 'utf8';
2021-08-10 11:49:39 +02:00
};
2024-05-28 11:52:26 +02:00
/**
* Synchronous version to get encoding based on the file extension
*/
2024-05-28 12:42:25 +02:00
export const getEncodingForPathSync = (path: string): 'binary' | 'utf8' => {
2024-05-28 11:52:26 +02:00
const mimeType = plugins.mime.getType(path);
return binaryMimeTypes.includes(mimeType) ? 'binary' : 'utf8';
};