mirror of
https://github.com/danielsogl/awesome-cordova-plugins.git
synced 2026-04-13 00:00:10 +08:00
366 lines
12 KiB
TypeScript
366 lines
12 KiB
TypeScript
import { Injectable } from '@angular/core';
|
|
import { Cordova, CordovaProperty, IonicNativePlugin, Plugin } from '@ionic-native/core';
|
|
|
|
export interface HTTPResponse {
|
|
/**
|
|
* The HTTP status number of the response or a negative internal error code.
|
|
*/
|
|
status: number;
|
|
/**
|
|
* The headers of the response.
|
|
*/
|
|
headers: { [key: string]: string };
|
|
/**
|
|
* The URL of the response. This property will be the final URL obtained after any redirects.
|
|
*/
|
|
url: string;
|
|
/**
|
|
* The data that is in the response. This property usually exists when a promise returned by a request method resolves.
|
|
*/
|
|
data?: any;
|
|
/**
|
|
* Error response from the server. This property usually exists when a promise returned by a request method rejects.
|
|
*/
|
|
error?: string;
|
|
}
|
|
|
|
/**
|
|
* @name HTTP
|
|
* @description
|
|
* Cordova / Phonegap plugin for communicating with HTTP servers. Supports iOS and Android.
|
|
*
|
|
* Advantages over Javascript requests:
|
|
* - SSL / TLS Pinning
|
|
* - CORS restrictions do not apply
|
|
* - Handling of HTTP code 401 - read more at [Issue CB-2415](https://issues.apache.org/jira/browse/CB-2415)
|
|
*
|
|
* @usage
|
|
* ```typescript
|
|
* import { HTTP } from '@ionic-native/http/ngx';
|
|
*
|
|
* constructor(private http: HTTP) {}
|
|
*
|
|
* ...
|
|
*
|
|
* this.http.get('http://ionic.io', {}, {})
|
|
* .then(data => {
|
|
*
|
|
* console.log(data.status);
|
|
* console.log(data.data); // data received by server
|
|
* console.log(data.headers);
|
|
*
|
|
* })
|
|
* .catch(error => {
|
|
*
|
|
* console.log(error.status);
|
|
* console.log(error.error); // error message as string
|
|
* console.log(error.headers);
|
|
*
|
|
* });
|
|
*
|
|
* ```
|
|
* @interfaces
|
|
* HTTPResponse
|
|
*/
|
|
@Plugin({
|
|
pluginName: 'HTTP',
|
|
plugin: 'cordova-plugin-advanced-http',
|
|
pluginRef: 'cordova.plugin.http',
|
|
repo: 'https://github.com/silkimen/cordova-plugin-advanced-http',
|
|
platforms: ['Android', 'iOS'],
|
|
})
|
|
@Injectable()
|
|
export class HTTP extends IonicNativePlugin {
|
|
/**
|
|
* This enum represents the internal error codes which can be returned in a HTTPResponse object.
|
|
* @readonly
|
|
*/
|
|
@CordovaProperty()
|
|
readonly ErrorCode: {
|
|
GENERIC: number;
|
|
SSL_EXCEPTION: number;
|
|
SERVER_NOT_FOUND: number;
|
|
TIMEOUT: number;
|
|
UNSUPPORTED_URL: number;
|
|
NOT_CONNECTED: number;
|
|
POST_PROCESSING_FAILED: number;
|
|
};
|
|
|
|
/**
|
|
* This returns an object representing a basic HTTP Authorization header of the form.
|
|
* @param username {string} Username
|
|
* @param password {string} Password
|
|
* @returns {Object} an object representing a basic HTTP Authorization header of the form {'Authorization': 'Basic base64EncodedUsernameAndPassword'}
|
|
*/
|
|
@Cordova({ sync: true })
|
|
getBasicAuthHeader(username: string, password: string): { Authorization: string } {
|
|
return;
|
|
}
|
|
|
|
/**
|
|
* This sets up all future requests to use Basic HTTP authentication with the given username and password.
|
|
* @param username {string} Username
|
|
* @param password {string} Password
|
|
*/
|
|
@Cordova({ sync: true })
|
|
useBasicAuth(username: string, password: string): void {}
|
|
|
|
/**
|
|
* Get all headers defined for a given hostname.
|
|
* @param host {string} The hostname
|
|
* @returns {string} return all headers defined for the hostname
|
|
*/
|
|
@Cordova({ sync: true })
|
|
getHeaders(host: string): string {
|
|
return;
|
|
}
|
|
|
|
/**
|
|
* Set a header for all future requests. Takes a hostname, a header and a value.
|
|
* @param host {string} The hostname to be used for scoping this header
|
|
* @param header {string} The name of the header
|
|
* @param value {string} The value of the header
|
|
*/
|
|
@Cordova({ sync: true })
|
|
setHeader(host: string, header: string, value: string): void {}
|
|
|
|
/**
|
|
* Get the name of the data serializer which will be used for all future POST and PUT requests.
|
|
* @returns {string} returns the name of the configured data serializer
|
|
*/
|
|
@Cordova({ sync: true })
|
|
getDataSerializer(): string {
|
|
return;
|
|
}
|
|
|
|
/**
|
|
* Set the data serializer which will be used for all future POST, PUT and PATCH requests. Takes a string representing the name of the serializer.
|
|
* @param serializer {string} The name of the serializer.
|
|
* @see https://github.com/silkimen/cordova-plugin-advanced-http#setdataserializer
|
|
*/
|
|
@Cordova({ sync: true })
|
|
setDataSerializer(serializer: 'urlencoded' | 'json' | 'utf8' | 'multipart' | 'raw'): void {}
|
|
|
|
/**
|
|
* Add a custom cookie.
|
|
* @param url {string} Scope of the cookie
|
|
* @param cookie {string} RFC compliant cookie string
|
|
*/
|
|
@Cordova({ sync: true })
|
|
setCookie(url: string, cookie: string): void {}
|
|
|
|
/**
|
|
* Clear all cookies.
|
|
*/
|
|
@Cordova({ sync: true })
|
|
clearCookies(): void {}
|
|
|
|
/**
|
|
* Remove cookies for given URL.
|
|
* @param url {string}
|
|
* @param cb
|
|
*/
|
|
@Cordova({ sync: true })
|
|
removeCookies(url: string, cb: () => void): void {}
|
|
|
|
/**
|
|
* Resolve cookie string for given URL.
|
|
* @param url {string}
|
|
*/
|
|
@Cordova({ sync: true })
|
|
getCookieString(url: string): string {
|
|
return;
|
|
}
|
|
|
|
/**
|
|
* Get global request timeout value in seconds.
|
|
* @returns {number} returns the global request timeout value
|
|
*/
|
|
@Cordova({ sync: true })
|
|
getRequestTimeout(): number {
|
|
return;
|
|
}
|
|
|
|
/**
|
|
* Set global request timeout value in seconds.
|
|
* @param timeout {number} The timeout in seconds. Default 60
|
|
*/
|
|
@Cordova({ sync: true })
|
|
setRequestTimeout(timeout: number): void {}
|
|
|
|
/**
|
|
* Resolve if it should follow redirects automatically.
|
|
* @returns {boolean} returns true if it is configured to follow redirects automatically
|
|
*/
|
|
@Cordova({ sync: true })
|
|
getFollowRedirect(): boolean {
|
|
return;
|
|
}
|
|
|
|
/**
|
|
* Configure if it should follow redirects automatically.
|
|
* @param follow {boolean} Set to false to disable following redirects automatically
|
|
*/
|
|
@Cordova({ sync: true })
|
|
setFollowRedirect(follow: boolean): void {}
|
|
|
|
/**
|
|
* Set server trust mode, being one of the following values:
|
|
* default: default SSL trustship and hostname verification handling using system's CA certs;
|
|
* legacy: use legacy default behavior (< 2.0.3), excluding user installed CA certs (only for Android);
|
|
* nocheck: disable SSL certificate checking and hostname verification, trusting all certs (meant to be used only for testing purposes);
|
|
* pinned: trust only provided certificates;
|
|
* @see https://github.com/silkimen/cordova-plugin-advanced-http#setservertrustmode
|
|
* @param {string} mode server trust mode
|
|
*/
|
|
@Cordova()
|
|
setServerTrustMode(mode: 'default' | 'legacy' | 'nocheck' | 'pinned'): Promise<void> {
|
|
return;
|
|
}
|
|
|
|
/**
|
|
* Make a POST request
|
|
* @param url {string} The url to send the request to
|
|
* @param body {Object} The body of the request
|
|
* @param headers {Object} The headers to set for this request
|
|
* @returns {Promise<HTTPResponse>} returns a promise that will resolve on success, and reject on failure
|
|
*/
|
|
@Cordova()
|
|
post(url: string, body: any, headers: any): Promise<HTTPResponse> {
|
|
return;
|
|
}
|
|
|
|
/**
|
|
* Make a GET request
|
|
* @param url {string} The url to send the request to
|
|
* @param parameters {Object} Parameters to send with the request
|
|
* @param headers {Object} The headers to set for this request
|
|
* @returns {Promise<HTTPResponse>} returns a promise that will resolve on success, and reject on failure
|
|
*/
|
|
@Cordova()
|
|
get(url: string, parameters: any, headers: any): Promise<HTTPResponse> {
|
|
return;
|
|
}
|
|
|
|
/**
|
|
* Make a PUT request
|
|
* @param url {string} The url to send the request to
|
|
* @param body {Object} The body of the request
|
|
* @param headers {Object} The headers to set for this request
|
|
* @returns {Promise<HTTPResponse>} returns a promise that will resolve on success, and reject on failure
|
|
*/
|
|
@Cordova()
|
|
put(url: string, body: any, headers: any): Promise<HTTPResponse> {
|
|
return;
|
|
}
|
|
|
|
/**
|
|
* Make a PATCH request
|
|
* @param url {string} The url to send the request to
|
|
* @param body {Object} The body of the request
|
|
* @param headers {Object} The headers to set for this request
|
|
* @returns {Promise<HTTPResponse>} returns a promise that will resolve on success, and reject on failure
|
|
*/
|
|
@Cordova()
|
|
patch(url: string, body: any, headers: any): Promise<HTTPResponse> {
|
|
return;
|
|
}
|
|
|
|
/**
|
|
* Make a DELETE request
|
|
* @param url {string} The url to send the request to
|
|
* @param parameters {Object} Parameters to send with the request
|
|
* @param headers {Object} The headers to set for this request
|
|
* @returns {Promise<HTTPResponse>} returns a promise that will resolve on success, and reject on failure
|
|
*/
|
|
@Cordova()
|
|
delete(url: string, parameters: any, headers: any): Promise<HTTPResponse> {
|
|
return;
|
|
}
|
|
|
|
/**
|
|
* Make a HEAD request
|
|
* @param url {string} The url to send the request to
|
|
* @param parameters {Object} Parameters to send with the request
|
|
* @param headers {Object} The headers to set for this request
|
|
* @returns {Promise<HTTPResponse>} returns a promise that will resolve on success, and reject on failure
|
|
*/
|
|
@Cordova()
|
|
head(url: string, parameters: any, headers: any): Promise<HTTPResponse> {
|
|
return;
|
|
}
|
|
|
|
/**
|
|
* Make an OPTIONS request
|
|
* @param url {string} The url to send the request to
|
|
* @param parameters {Object} Parameters to send with the request
|
|
* @param headers {Object} The headers to set for this request
|
|
* @returns {Promise<HTTPResponse>} returns a promise that will resolve on success, and reject on failure
|
|
*/
|
|
@Cordova()
|
|
options(url: string, parameters: any, headers: any): Promise<HTTPResponse> {
|
|
return;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param url {string} The url to send the request to
|
|
* @param body {Object} The body of the request
|
|
* @param headers {Object} The headers to set for this request
|
|
* @param filePath {string} The local path(s) of the file(s) to upload
|
|
* @param name {string} The name(s) of the parameter to pass the file(s) along as
|
|
* @returns {Promise<any>} returns a FileEntry promise that will resolve on success, and reject on failure
|
|
*/
|
|
@Cordova()
|
|
uploadFile(url: string, body: any, headers: any, filePath: string | string[], name: string | string[]): Promise<any> {
|
|
return;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param url {string} The url to send the request to
|
|
* @param body {Object} The body of the request
|
|
* @param headers {Object} The headers to set for this request
|
|
* @param filePath {string} The path to download the file to, including the file name.
|
|
* @returns {Promise<any>} returns a FileEntry promise that will resolve on success, and reject on failure
|
|
*/
|
|
@Cordova()
|
|
downloadFile(url: string, body: any, headers: any, filePath: string): Promise<any> {
|
|
return;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param url {string} The url to send the request to
|
|
* @param options {Object} options for individual request
|
|
* @param options.method {string} request method
|
|
* @param options.data {Object} payload to be send to the server (only applicable on post, put or patch methods)
|
|
* @param options.params {Object} query params to be appended to the URL (only applicable on get, head, delete, upload or download methods)
|
|
* @param options.serializer {string} data serializer to be used (only applicable on post, put or patch methods), defaults to global serializer value, see setDataSerializer for supported values
|
|
* @param options.timeout {number} timeout value for the request in seconds, defaults to global timeout value
|
|
* @param options.headers {Object} headers object (key value pair), will be merged with global values
|
|
* @param options.filePath {string} file path(s) to be used during upload and download see uploadFile and downloadFile for detailed information
|
|
* @param options.name {string} name(s) to be used during upload see uploadFile for detailed information
|
|
* @param options.responseType {string} response type, defaults to text
|
|
*
|
|
* @returns {Promise<HTTPResponse>} returns a promise that will resolve on success, and reject on failure
|
|
*/
|
|
@Cordova()
|
|
sendRequest(
|
|
url: string,
|
|
options: {
|
|
method: 'get' | 'post' | 'put' | 'patch' | 'head' | 'delete' | 'options' | 'upload' | 'download';
|
|
data?: { [index: string]: any };
|
|
params?: { [index: string]: string | number };
|
|
serializer?: 'json' | 'urlencoded' | 'utf8' | 'multipart';
|
|
timeout?: number;
|
|
headers?: { [index: string]: string };
|
|
filePath?: string | string[];
|
|
name?: string | string[];
|
|
responseType?: 'text' | 'arraybuffer' | 'blob' | 'json';
|
|
}
|
|
): Promise<HTTPResponse> {
|
|
return;
|
|
}
|
|
}
|