import type { HTTPQueryOptions, HTTPTransactionOptions, NeonQueryFunction } from '@neondatabase/serverless'; import type { BatchItem, BatchResponse } from "../batch.js"; import { entityKind } from "../entity.js"; import type { Logger } from "../logger.js"; import { PgDatabase } from "../pg-core/db.js"; import { PgDialect } from "../pg-core/dialect.js"; import type { RelationalSchemaConfig, TablesRelationalConfig } from "../relations.js"; import { type DrizzleConfig } from "../utils.js"; import { type NeonHttpClient, type NeonHttpQueryResultHKT, NeonHttpSession } from "./session.js"; export interface NeonDriverOptions { logger?: Logger; } export declare class NeonHttpDriver { private client; private dialect; private options; static readonly [entityKind]: string; constructor(client: NeonHttpClient, dialect: PgDialect, options?: NeonDriverOptions); createSession(schema: RelationalSchemaConfig | undefined): NeonHttpSession, TablesRelationalConfig>; initMappers(): void; } export declare class NeonHttpDatabase = Record> extends PgDatabase { static readonly [entityKind]: string; $withAuth(token: Exclude['authToken'], undefined>): Omit>; batch, T extends Readonly<[U, ...U[]]>>(batch: T): Promise>; } export declare function drizzle = Record, TClient extends NeonQueryFunction = NeonQueryFunction>(...params: [ TClient | string ] | [ TClient | string, DrizzleConfig ] | [ (DrizzleConfig & ({ connection: string | ({ connectionString: string; } & HTTPTransactionOptions); } | { client: TClient; })) ]): NeonHttpDatabase & { $client: TClient; }; export declare namespace drizzle { function mock = Record>(config?: DrizzleConfig): NeonHttpDatabase & { $client: '$client is not available on drizzle.mock()'; }; }