UNPKG

astro

Version:

Astro is a modern site builder with web best practices, performance, and DX front-of-mind.

42 lines (41 loc) 2.06 kB
import type { FSWatcher } from 'vite'; import type { ZodSchema } from 'zod'; import type { AstroIntegrationLogger } from '../../core/logger/core.js'; import type { AstroConfig } from '../../types/public/config.js'; import type { DataStore, MetaStore } from '../mutable-data-store.js'; export type { DataStore, MetaStore }; export interface ParseDataOptions<TData extends Record<string, unknown>> { /** The ID of the entry. Unique per collection */ id: string; /** The raw, unvalidated data of the entry */ data: TData; /** An optional file path, where the entry represents a local file. */ filePath?: string; } export interface LoaderContext { /** The unique name of the collection */ collection: string; /** A database to store the actual data */ store: DataStore; /** A simple KV store, designed for things like sync tokens */ meta: MetaStore; logger: AstroIntegrationLogger; /** Astro config, with user config and merged defaults */ config: AstroConfig; /** Validates and parses the data according to the collection schema */ parseData<TData extends Record<string, unknown>>(props: ParseDataOptions<TData>): Promise<TData>; /** Generates a non-cryptographic content digest. This can be used to check if the data has changed */ generateDigest(data: Record<string, unknown> | string): string; /** When running in dev, this is a filesystem watcher that can be used to trigger updates */ watcher?: FSWatcher; /** If the loader has been triggered by an integration, this may optionally contain extra data set by that integration */ refreshContextData?: Record<string, unknown>; } export interface Loader { /** Unique name of the loader, e.g. the npm package name */ name: string; /** Do the actual loading of the data */ load: (context: LoaderContext) => Promise<void>; /** Optionally, define the schema of the data. Will be overridden by user-defined schema */ schema?: ZodSchema | Promise<ZodSchema> | (() => ZodSchema | Promise<ZodSchema>); }