ExifTool (13.11) powered by WebAssembly to extract metadata from files in browsers and Node.js environments using zeroperl.
npm install @uswriting/exiftool
This package provides a WebAssembly-based implementation of ExifTool that works in both browser and Node.js environments. It leverages zeroperl to execute ExifTool without requiring any native binaries or system dependencies.
import { parseMetadata } from '@uswriting/exiftool';
// Browser usage with File API
document.querySelector('input[type="file"]').addEventListener('change', async (event) => {
const file = event.target.files[0];
const result = await parseMetadata(file);
if (result.success) {
console.log(result.data);
} else {
console.error('Error:', result.error);
}
});
import { parseMetadata } from '@uswriting/exiftool';
const result = await parseMetadata(file, {
args: ['-Author', '-CreateDate', '-Make', '-Model']
});
if (result.success) {
console.log(result.data);
}
import { parseMetadata } from '@uswriting/exiftool';
const result = await parseMetadata(file, {
args: ['-json', '-n'],
transform: (data) => JSON.parse(data)
});
if (result.success) {
// Typed access to properties
console.log(result.data); // { ... }
}
- In browser environments, pass the
File
object directly from file inputs. Do not convert it to an ArrayBuffer or Uint8Array. - This package uses asynchronous web APIs for file processing which allows handling files over 2GB without loading them entirely into memory.
- ExifTool is executed entirely within the browser or Node.js environment - no server requests are made for metadata extraction.
async function parseMetadata<TReturn = string>(
file: Binaryfile | File,
options: ExifToolOptions<TReturn> = {}
): Promise<ExifToolOutput<TReturn>>
file
: Either a browserFile
object or aBinaryfile
object withname
anddata
properties.options
: Configuration options for the metadata extraction.
interface ExifToolOptions<TReturn> {
// Additional command-line arguments to pass to ExifTool
args?: string[];
// Custom fetch implementation for loading the WASM module
fetch?: (...args: any[]) => Promise<Response>;
// Transform the raw ExifTool output into a different format
transform?: (data: string) => TReturn;
}
Returns a Promise that resolves to an ExifToolOutput
object:
type ExifToolOutput<TOutput> =
| {
success: true;
data: TOutput;
error: string;
exitCode: 0;
}
| {
success: false;
data: undefined;
error: string;
exitCode: number | undefined;
};
Apache License, Version 2.0