DefinitelyTyped/types/superagent/index.d.ts

175 lines
6.7 KiB
TypeScript

// Type definitions for SuperAgent 4.1
// Project: https://github.com/visionmedia/superagent
// Definitions by: Nico Zelaya <https://github.com/NicoZelaya>
// Michael Ledin <https://github.com/mxl>
// Pap Lőrinc <https://github.com/paplorinc>
// Shrey Jain <https://github.com/shreyjain1994>
// Alec Zopf <https://github.com/zopf>
// Adam Haglund <https://github.com/beeequeue>
// Lukas Elmer <https://github.com/lukaselmer>
// Jesse Rogers <https://github.com/theQuazz>
// Definitions: https://github.com/DefinitelyTyped/DefinitelyTyped
// TypeScript Version: 2.2
/// <reference types="node" />
import * as fs from 'fs';
import * as https from 'https';
import * as stream from 'stream';
import * as cookiejar from 'cookiejar';
type CallbackHandler = (err: any, res: request.Response) => void;
type Serializer = (obj: any) => string;
type BrowserParser = (str: string) => any;
type NodeParser = (res: request.Response, callback: (err: Error | null, body: any) => void) => void;
type Parser = BrowserParser | NodeParser;
type MultipartValueSingle = Blob | Buffer | fs.ReadStream | string | boolean | number;
type MultipartValue = MultipartValueSingle | MultipartValueSingle[];
declare const request: request.SuperAgentStatic;
declare namespace request {
interface SuperAgentRequest extends Request {
agent(agent?: https.Agent): this;
cookies: string;
method: string;
url: string;
}
interface SuperAgentStatic extends SuperAgent<SuperAgentRequest> {
(url: string): SuperAgentRequest;
// tslint:disable-next-line:unified-signatures
(method: string, url: string): SuperAgentRequest;
agent(): this & Request;
serialize: { [type: string]: Serializer };
parse: { [type: string]: Parser };
}
interface SuperAgent<Req extends SuperAgentRequest> extends stream.Stream {
jar: cookiejar.CookieJar;
attachCookies(req: Req): void;
checkout(url: string, callback?: CallbackHandler): Req;
connect(url: string, callback?: CallbackHandler): Req;
copy(url: string, callback?: CallbackHandler): Req;
del(url: string, callback?: CallbackHandler): Req;
delete(url: string, callback?: CallbackHandler): Req;
get(url: string, callback?: CallbackHandler): Req;
head(url: string, callback?: CallbackHandler): Req;
lock(url: string, callback?: CallbackHandler): Req;
merge(url: string, callback?: CallbackHandler): Req;
mkactivity(url: string, callback?: CallbackHandler): Req;
mkcol(url: string, callback?: CallbackHandler): Req;
move(url: string, callback?: CallbackHandler): Req;
notify(url: string, callback?: CallbackHandler): Req;
options(url: string, callback?: CallbackHandler): Req;
patch(url: string, callback?: CallbackHandler): Req;
post(url: string, callback?: CallbackHandler): Req;
propfind(url: string, callback?: CallbackHandler): Req;
proppatch(url: string, callback?: CallbackHandler): Req;
purge(url: string, callback?: CallbackHandler): Req;
put(url: string, callback?: CallbackHandler): Req;
report(url: string, callback?: CallbackHandler): Req;
saveCookies(res: Response): void;
search(url: string, callback?: CallbackHandler): Req;
subscribe(url: string, callback?: CallbackHandler): Req;
trace(url: string, callback?: CallbackHandler): Req;
unlock(url: string, callback?: CallbackHandler): Req;
unsubscribe(url: string, callback?: CallbackHandler): Req;
}
interface ResponseError extends Error {
status: number;
text: string;
method: string;
path: string;
}
interface Response extends NodeJS.ReadableStream {
accepted: boolean;
badRequest: boolean;
body: any;
charset: string;
clientError: boolean;
error: ResponseError;
files: any;
forbidden: boolean;
get(header: string): string;
get(header: 'Set-Cookie'): string[];
header: any;
info: boolean;
links: object;
noContent: boolean;
notAcceptable: boolean;
notFound: boolean;
ok: boolean;
redirect: boolean;
serverError: boolean;
status: number;
statusType: number;
text: string;
type: string;
unauthorized: boolean;
xhr: XMLHttpRequest;
redirects: string[];
}
interface Request extends Promise<Response> {
abort(): void;
accept(type: string): this;
attach(field: string, file: MultipartValueSingle, options?: string | { filename?: string; contentType?: string }): this;
auth(user: string, pass: string, options?: { type: 'basic' | 'auto' }): this;
auth(token: string, options: { type: 'bearer' }): this;
buffer(val?: boolean): this;
ca(cert: Buffer): this;
cert(cert: Buffer | string): this;
clearTimeout(): this;
end(callback?: CallbackHandler): void;
field(name: string, val: MultipartValue): this;
field(fields: { [fieldName: string]: MultipartValue }): this;
get(field: string): string;
key(cert: Buffer | string): this;
ok(callback: (res: Response) => boolean): this;
on(name: 'error', handler: (err: any) => void): this;
on(name: 'progress', handler: (event: ProgressEvent) => void): this;
on(name: string, handler: (event: any) => void): this;
parse(parser: Parser): this;
part(): this;
pfx(cert: Buffer | string | { pfx: Buffer, passphrase: string }): this;
pipe(stream: NodeJS.WritableStream, options?: object): stream.Writable;
query(val: object | string): this;
redirects(n: number): this;
responseType(type: string): this;
retry(count?: number, callback?: CallbackHandler): this;
send(data?: string | object): this;
serialize(serializer: Serializer): this;
set(field: object): this;
set(field: string, val: string): this;
set(field: 'Cookie', val: string[]): this;
timeout(ms: number | { deadline?: number, response?: number }): this;
type(val: string): this;
unset(field: string): this;
use(fn: Plugin): this;
withCredentials(): this;
write(data: string | Buffer, encoding?: string): this;
maxResponseSize(size: number): this;
}
type Plugin = (req: SuperAgentRequest) => void;
interface ProgressEvent {
direction: 'download' | 'upload';
loaded: number;
percent?: number;
total?: number;
}
}
export = request;