- Remove ObservableWrapper/EventEmitter from Http. - Temporarily use complete Rx build w/ all operators.
54 lines
1.6 KiB
TypeScript
54 lines
1.6 KiB
TypeScript
import {ReadyStates, RequestMethods, ResponseTypes} from './enums';
|
|
import {Headers} from './headers';
|
|
import {BaseException, WrappedException} from 'angular2/src/core/facade/exceptions';
|
|
import {EventEmitter} from 'angular2/src/core/facade/async';
|
|
import {Request} from './static_request';
|
|
import {URLSearchParams} from './url_search_params';
|
|
|
|
/**
|
|
* Abstract class from which real backends are derived.
|
|
*
|
|
* The primary purpose of a `ConnectionBackend` is to create new connections to fulfill a given
|
|
* {@link Request}.
|
|
*/
|
|
export abstract class ConnectionBackend {
|
|
constructor() {}
|
|
abstract createConnection(request: any): Connection;
|
|
}
|
|
|
|
/**
|
|
* Abstract class from which real connections are derived.
|
|
*/
|
|
export abstract class Connection {
|
|
readyState: ReadyStates;
|
|
request: Request;
|
|
response: any; // TODO: generic of <Response>;
|
|
}
|
|
|
|
/**
|
|
* Interface for options to construct a Request, based on
|
|
* [RequestInit](https://fetch.spec.whatwg.org/#requestinit) from the Fetch spec.
|
|
*/
|
|
export type RequestOptionsArgs = {
|
|
url?: string;
|
|
method?: string | RequestMethods;
|
|
search?: string | URLSearchParams;
|
|
headers?: Headers;
|
|
// TODO: Support Blob, ArrayBuffer, JSON, URLSearchParams, FormData
|
|
body?: string;
|
|
}
|
|
|
|
/**
|
|
* Interface for options to construct a Response, based on
|
|
* [ResponseInit](https://fetch.spec.whatwg.org/#responseinit) from the Fetch spec.
|
|
*/
|
|
export type ResponseOptionsArgs = {
|
|
// TODO: Support Blob, ArrayBuffer, JSON
|
|
body?: string | Object | FormData;
|
|
status?: number;
|
|
statusText?: string;
|
|
headers?: Headers;
|
|
type?: ResponseTypes;
|
|
url?: string;
|
|
}
|