mirror of
https://github.com/gosticks/DefinitelyTyped.git
synced 2025-10-16 12:05:41 +00:00
The log attribute on PoolConfig allows you to attach a logger to debug what's going in inside the pg-pool.
240 lines
7.8 KiB
TypeScript
240 lines
7.8 KiB
TypeScript
// Type definitions for pg 7.11
|
|
// Project: http://github.com/brianc/node-postgres
|
|
// Definitions by: Phips Peter <https://github.com/pspeter3>, Ravi van Rooijen <https://github.com/HoldYourWaffle>
|
|
// Definitions: https://github.com/DefinitelyTyped/DefinitelyTyped
|
|
// TypeScript Version: 2.3
|
|
|
|
/// <reference types="node" />
|
|
|
|
import events = require("events");
|
|
import stream = require("stream");
|
|
import pgTypes = require("pg-types");
|
|
|
|
export interface ConnectionConfig {
|
|
user?: string;
|
|
database?: string;
|
|
password?: string;
|
|
port?: number;
|
|
host?: string;
|
|
connectionString?: string;
|
|
keepAlive?: boolean;
|
|
stream?: stream.Duplex;
|
|
statement_timeout?: false | number;
|
|
connectionTimeoutMillis?: number;
|
|
keepAliveInitialDelayMillis?: number;
|
|
}
|
|
|
|
export interface Defaults extends ConnectionConfig {
|
|
poolSize?: number;
|
|
poolIdleTimeout?: number;
|
|
reapIntervalMillis?: number;
|
|
binary?: boolean;
|
|
parseInt8?: boolean;
|
|
}
|
|
|
|
import { ConnectionOptions } from "tls";
|
|
|
|
export interface ClientConfig extends ConnectionConfig {
|
|
ssl?: boolean | ConnectionOptions;
|
|
}
|
|
|
|
export interface PoolConfig extends ClientConfig {
|
|
// properties from module 'node-pool'
|
|
max?: number;
|
|
min?: number;
|
|
connectionTimeoutMillis?: number;
|
|
idleTimeoutMillis?: number;
|
|
log?: (...messages: any[]) => void;
|
|
|
|
application_name?: string;
|
|
Promise?: PromiseConstructorLike;
|
|
}
|
|
|
|
export interface QueryConfig<I extends any[] = any[]> {
|
|
name?: string;
|
|
text: string;
|
|
values?: I;
|
|
}
|
|
|
|
export interface Submittable {
|
|
submit: (connection: Connection) => void;
|
|
}
|
|
|
|
export interface QueryArrayConfig<I extends any[] = any[]> extends QueryConfig<I> {
|
|
rowMode: 'array';
|
|
}
|
|
|
|
export interface FieldDef {
|
|
name: string;
|
|
tableID: number;
|
|
columnID: number;
|
|
dataTypeID: number;
|
|
dataTypeSize: number;
|
|
dataTypeModifier: number;
|
|
format: string;
|
|
}
|
|
|
|
export interface QueryResultBase {
|
|
command: string;
|
|
rowCount: number;
|
|
oid: number;
|
|
fields: FieldDef[];
|
|
}
|
|
|
|
export interface QueryResultRow {
|
|
[column: string]: any;
|
|
}
|
|
|
|
export interface QueryResult<R extends QueryResultRow = any> extends QueryResultBase {
|
|
rows: R[];
|
|
}
|
|
|
|
export interface QueryArrayResult<R extends any[] = any[]> extends QueryResultBase {
|
|
rows: R[];
|
|
}
|
|
|
|
export interface Notification {
|
|
processId: number;
|
|
channel: string;
|
|
payload?: string;
|
|
}
|
|
|
|
export interface ResultBuilder<R extends QueryResultRow = any> extends QueryResult<R> {
|
|
addRow(row: R): void;
|
|
}
|
|
|
|
export interface QueryParse {
|
|
name: string;
|
|
text: string;
|
|
types: string[];
|
|
}
|
|
|
|
export interface BindConfig {
|
|
portal?: string;
|
|
statement?: string;
|
|
binary?: string;
|
|
values?: Array<(Buffer | null | undefined | string)>;
|
|
}
|
|
|
|
export interface ExecuteConfig {
|
|
portal?: string;
|
|
rows?: string;
|
|
}
|
|
|
|
export interface MessageConfig {
|
|
type: string;
|
|
name?: string;
|
|
}
|
|
|
|
export class Connection extends events.EventEmitter {
|
|
readonly stream: stream.Duplex;
|
|
|
|
constructor(config?: ConnectionConfig);
|
|
|
|
bind(config: BindConfig | null, more: boolean): void;
|
|
execute(config: ExecuteConfig | null, more: boolean): void;
|
|
parse(query: QueryParse, more: boolean): void;
|
|
|
|
query(text: string): void;
|
|
|
|
describe(msg: MessageConfig, more: boolean): void;
|
|
close(msg: MessageConfig, more: boolean): void;
|
|
|
|
flush(): void;
|
|
sync(): void;
|
|
end(): void;
|
|
}
|
|
|
|
export class Pool extends events.EventEmitter {
|
|
// `new Pool('pg://user@localhost/mydb')` is not allowed.
|
|
// But it passes type check because of issue:
|
|
// https://github.com/Microsoft/TypeScript/issues/7485
|
|
constructor(config?: PoolConfig);
|
|
|
|
readonly totalCount: number;
|
|
readonly idleCount: number;
|
|
readonly waitingCount: number;
|
|
|
|
connect(): Promise<PoolClient>;
|
|
connect(callback: (err: Error, client: PoolClient, done: (release?: any) => void) => void): void;
|
|
|
|
end(): Promise<void>;
|
|
end(callback: () => void): void;
|
|
|
|
query<T extends Submittable>(queryStream: T): T;
|
|
// tslint:disable:no-unnecessary-generics
|
|
query<R extends any[] = any[], I extends any[] = any[]>(queryConfig: QueryArrayConfig<I>, values?: I): Promise<QueryArrayResult<R>>;
|
|
query<R extends QueryResultRow = any, I extends any[] = any[]>(queryConfig: QueryConfig<I>): Promise<QueryResult<R>>;
|
|
query<R extends QueryResultRow = any, I extends any[] = any[]>(queryTextOrConfig: string | QueryConfig<I>, values?: I): Promise<QueryResult<R>>;
|
|
query<R extends any[] = any[], I extends any[] = any[]>(queryConfig: QueryArrayConfig<I>, callback: (err: Error, result: QueryArrayResult<R>) => void): void;
|
|
query<R extends QueryResultRow = any, I extends any[] = any[]>(queryTextOrConfig: string | QueryConfig<I>, callback: (err: Error, result: QueryResult<R>) => void): void;
|
|
query<R extends QueryResultRow = any, I extends any[] = any[]>(queryText: string, values: I, callback: (err: Error, result: QueryResult<R>) => void): void;
|
|
// tslint:enable:no-unnecessary-generics
|
|
|
|
on(event: "error", listener: (err: Error, client: PoolClient) => void): this;
|
|
on(event: "connect" | "acquire" | "remove", listener: (client: PoolClient) => void): this;
|
|
}
|
|
|
|
export class ClientBase extends events.EventEmitter {
|
|
constructor(config?: string | ClientConfig);
|
|
|
|
connect(): Promise<void>;
|
|
connect(callback: (err: Error) => void): void;
|
|
|
|
query<T extends Submittable>(queryStream: T): T;
|
|
// tslint:disable:no-unnecessary-generics
|
|
query<R extends any[] = any[], I extends any[] = any[]>(queryConfig: QueryArrayConfig<I>, values?: I): Promise<QueryArrayResult<R>>;
|
|
query<R extends QueryResultRow = any, I extends any[] = any[]>(queryConfig: QueryConfig<I>): Promise<QueryResult<R>>;
|
|
query<R extends QueryResultRow = any, I extends any[] = any[]>(queryTextOrConfig: string | QueryConfig<I>, values?: I): Promise<QueryResult<R>>;
|
|
query<R extends any[] = any[], I extends any[] = any[]>(queryConfig: QueryArrayConfig<I>, callback: (err: Error, result: QueryArrayResult<R>) => void): void;
|
|
query<R extends QueryResultRow = any, I extends any[] = any[]>(queryTextOrConfig: string | QueryConfig<I>, callback: (err: Error, result: QueryResult<R>) => void): void;
|
|
query<R extends QueryResultRow = any, I extends any[] = any[]>(queryText: string, values: any[], callback: (err: Error, result: QueryResult<R>) => void): void;
|
|
// tslint:enable:no-unnecessary-generics
|
|
|
|
copyFrom(queryText: string): stream.Writable;
|
|
copyTo(queryText: string): stream.Readable;
|
|
|
|
pauseDrain(): void;
|
|
resumeDrain(): void;
|
|
|
|
escapeIdentifier(str: string): string;
|
|
escapeLiteral(str: string): string;
|
|
|
|
on(event: "drain", listener: () => void): this;
|
|
on(event: "error" | "notice", listener: (err: Error) => void): this;
|
|
on(event: "notification", listener: (message: Notification) => void): this;
|
|
// tslint:disable-next-line unified-signatures
|
|
on(event: "end", listener: () => void): this;
|
|
}
|
|
|
|
export class Client extends ClientBase {
|
|
constructor(config?: string | ClientConfig);
|
|
|
|
end(): Promise<void>;
|
|
end(callback: (err: Error) => void): void;
|
|
}
|
|
|
|
export interface PoolClient extends ClientBase {
|
|
release(err?: Error): void;
|
|
}
|
|
|
|
export class Query<R extends QueryResultRow = any, I extends any[] = any> extends events.EventEmitter implements Submittable {
|
|
constructor(queryTextOrConfig?: string | QueryConfig<I>, values?: I);
|
|
submit: (connection: Connection) => void;
|
|
on(event: "row", listener: (row: R, result?: ResultBuilder<R>) => void): this;
|
|
on(event: "error", listener: (err: Error) => void): this;
|
|
on(event: "end", listener: (result: ResultBuilder<R>) => void): this;
|
|
}
|
|
|
|
export class Events extends events.EventEmitter {
|
|
on(event: "error", listener: (err: Error, client: Client) => void): this;
|
|
}
|
|
|
|
export const types: typeof pgTypes;
|
|
|
|
export const defaults: Defaults & ClientConfig;
|
|
|
|
import * as Pg from '.';
|
|
|
|
export const native: typeof Pg | null;
|