/
IHttpClient.ts
72 lines (62 loc) · 2.09 KB
/
IHttpClient.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
import { HttpMethod } from './HttpMethod';
export type RestResponse<T> = {
ok: boolean,
status: number,
statusText: string,
body: T,
headers: Headers
};
export interface IHttpClient {
/**
* An operation used to modify a request prior to submission OR
* override the normal request process and return a response.
* @param request the original request
* @returns a modified request or a response
*/
OnRequestReceived?: (request: Request) => Promise<Request | Response>;
/**
* An operation to be performed just after a response is resolved from a request,
* but prior to the response being returned.
*/
OnResponseResolved?: (response: Response) => void;
/**
* Gets the headers which should be sent with each request.
*/
DefaultRequestHeaders: Record<string, string>;
/**
*
* @param uri
* @param method
* @param body
* @param additionalHeaders
*/
Request(uri: string, method: HttpMethod, body?: string, additionalHeaders?: Record<string, string>): Promise<Response>;
/**
* Send a GET request to the specified Uri as an asynchronous operation.
* @param uri
*/
Get<T>(uri: string, additionalHeaders?: Record<string, string>): Promise<RestResponse<T>>;
/**
* Send a PATCH request to the specified Uri as an asynchronous operation.
* @param uri
* @param body
*/
Patch<T>(uri: string, body?: string, additionalHeaders?: Record<string, string>): Promise<RestResponse<T>>;
/**
* Send a POST request to the specified Uri as an asynchronous operation.
* @param uri
* @param body
*/
Post<T>(uri: string, body?: string, additionalHeaders?: Record<string, string>): Promise<RestResponse<T>>;
/**
* Send a PUT request to the specified Uri as an asynchronous operation.
* @param uri
* @param body
*/
Put<T>(uri: string, body?: string, additionalHeaders?: Record<string, string>): Promise<RestResponse<T>>;
/**
* Send a DELETE request to the specified Uri as an asynchronous operation.
* @param uri
*/
Delete<T>(uri: string, additionalHeaders?: Record<string, string>): Promise<RestResponse<T>>;
}