71 lines
2.7 KiB
TypeScript
71 lines
2.7 KiB
TypeScript
/// <reference types="node" resolution-mode="require"/>
|
|
/// <reference types="node" resolution-mode="require"/>
|
|
import type { extname as ExtnameT, resolve as ResolveT } from "node:path";
|
|
import type { readdir as ReaddirT } from "node:fs/promises";
|
|
import { Document } from "@langchain/core/documents";
|
|
import { BaseDocumentLoader } from "../base.js";
|
|
export declare const UnknownHandling: {
|
|
readonly Ignore: "ignore";
|
|
readonly Warn: "warn";
|
|
readonly Error: "error";
|
|
};
|
|
/**
|
|
* An enumeration of possible handling strategies for unknown file types.
|
|
*/
|
|
export type UnknownHandling = (typeof UnknownHandling)[keyof typeof UnknownHandling];
|
|
/**
|
|
* A mapping of file extensions to loader functions. Each loader function
|
|
* takes a file path as a parameter and returns a `BaseDocumentLoader`
|
|
* instance.
|
|
*/
|
|
export interface LoadersMapping {
|
|
[extension: string]: (filePath: string) => BaseDocumentLoader;
|
|
}
|
|
/**
|
|
* A document loader that loads documents from a directory. It extends the
|
|
* `BaseDocumentLoader` class and implements the `load()` method.
|
|
* @example
|
|
* ```typescript
|
|
*
|
|
* const directoryLoader = new DirectoryLoader(
|
|
* "src/document_loaders/example_data/",
|
|
* {
|
|
* ".pdf": (path: string) => new PDFLoader(path),
|
|
* },
|
|
* );
|
|
*
|
|
* const docs = await directoryLoader.load();
|
|
* console.log({ docs });
|
|
*
|
|
* ```
|
|
*/
|
|
export declare class DirectoryLoader extends BaseDocumentLoader {
|
|
directoryPath: string;
|
|
loaders: LoadersMapping;
|
|
recursive: boolean;
|
|
unknown: UnknownHandling;
|
|
constructor(directoryPath: string, loaders: LoadersMapping, recursive?: boolean, unknown?: UnknownHandling);
|
|
/**
|
|
* Loads the documents from the directory. If a file is a directory and
|
|
* `recursive` is `true`, it recursively loads documents from the
|
|
* subdirectory. If a file is a file, it checks if there is a
|
|
* corresponding loader function for the file extension in the `loaders`
|
|
* mapping. If there is, it loads the documents. If there is no
|
|
* corresponding loader function and `unknown` is set to `Warn`, it logs a
|
|
* warning message. If `unknown` is set to `Error`, it throws an error.
|
|
* @returns A promise that resolves to an array of loaded documents.
|
|
*/
|
|
load(): Promise<Document[]>;
|
|
/**
|
|
* Imports the necessary functions from the `node:path` and
|
|
* `node:fs/promises` modules. It is used to dynamically import the
|
|
* functions when needed. If the import fails, it throws an error
|
|
* indicating that the modules failed to load.
|
|
* @returns A promise that resolves to an object containing the imported functions.
|
|
*/
|
|
static imports(): Promise<{
|
|
readdir: typeof ReaddirT;
|
|
extname: typeof ExtnameT;
|
|
resolve: typeof ResolveT;
|
|
}>;
|
|
}
|