http
Access the HTTP client written in Rust.
This package is also accessible with window.__TAURI__.http when build.withGlobalTauri in tauri.conf.json is set to true.
The APIs must be allowlisted on tauri.conf.json:
{
  "tauri": {
    "allowlist": {
      "http": {
        "all": true, // enable all http APIs
        "request": true // enable HTTP request API
      }
    }
  }
}
It is recommended to allowlist only the APIs you use for optimal bundle size and security.
Security
This API has a scope configuration that forces you to restrict the URLs and paths that can be accessed using glob patterns.
For instance, this scope configuration only allows making HTTP requests to the GitHub API for the tauri-apps organization:
{
  "tauri": {
    "allowlist": {
      "http": {
        "scope": ["https://api.github.com/repos/tauri-apps/*"]
      }
    }
  }
}
Trying to execute any API with a URL not configured on the scope results in a promise rejection due to denied access.
Enumerations
ResponseType
Since: 1.0.0
Enumeration Members
| Name | Type | Defined in | 
|---|---|---|
| 3 | http.ts:74 | |
| 1 | http.ts:72 | |
| 2 | http.ts:73 | 
Classes
Body
The body object to be used on POST and PUT requests.
Since: 1.0.0
Properties
payload
payload:
unknown
Defined in: http.ts:95
type
type:
string
Defined in: http.ts:94
Methods
bytes
Staticbytes(bytes:Iterable<number> |ArrayBuffer|ArrayLike<number>):Body
Creates a new byte array body.
Example
import { Body } from "@tauri-apps/api/http"
Body.bytes(new Uint8Array([1, 2, 3]));
Parameters
| Name | Type | Description | 
|---|---|---|
| bytes | Iterable<number> |ArrayBuffer|ArrayLike<number> | The body byte array. | 
Returns: Body
The body object ready to be used on the POST and PUT requests.
form
Creates a new form data body. The form data is an object where each key is the entry name, and the value is either a string or a file object.
By default it sets the application/x-www-form-urlencoded Content-Type header,
but you can set it to multipart/form-data if the Cargo feature http-multipart is enabled.
Note that a file path must be allowed in the fs allowlist scope.
Example
import { Body } from "@tauri-apps/api/http"
const body = Body.form({
  key: 'value',
  image: {
    file: '/path/to/file', // either a path or an array buffer of the file contents
    mime: 'image/jpeg', // optional
    fileName: 'image.jpg' // optional
  }
});
// alternatively, use a FormData:
const form = new FormData();
form.append('key', 'value');
form.append('image', file, 'image.png');
const formBody = Body.form(form);
Parameters
| Name | Type | Description | 
|---|---|---|
| data | Record<string,Part> |FormData | The body data. | 
Returns: Body
The body object ready to be used on the POST and PUT requests.
json
Creates a new JSON body.
Example
import { Body } from "@tauri-apps/api/http"
Body.json({
  registered: true,
  name: 'tauri'
});
Parameters
| Name | Type | Description | 
|---|---|---|
| data | Record<any,any> | The body JSON object. | 
Returns: Body
The body object ready to be used on the POST and PUT requests.
text
Statictext(value:string):Body
Creates a new UTF-8 string body.
Example
import { Body } from "@tauri-apps/api/http"
Body.text('The body content as a string');
Parameters
| Name | Type | Description | 
|---|---|---|
| value | string | The body string. | 
Returns: Body
The body object ready to be used on the POST and PUT requests.
Client
Since: 1.0.0
Properties
id
id:
number
Defined in: http.ts:303
Methods
delete
delete<
T>(url:string,options?:RequestOptions):Promise<Response<T>>
Makes a DELETE request.
Example
import { getClient } from '@tauri-apps/api/http';
const client = await getClient();
const response = await client.delete('http://localhost:3003/users/1');
Type parameters
- T
Parameters
| Name | Type | 
|---|---|
| url | string | 
| options? | RequestOptions | 
drop
drop():
Promise<void>
Drops the client instance.
Example
import { getClient } from '@tauri-apps/api/http';
const client = await getClient();
await client.drop();
Returns: Promise<void>
get
get<
T>(url:string,options?:RequestOptions):Promise<Response<T>>
Makes a GET request.
Example
import { getClient, ResponseType } from '@tauri-apps/api/http';
const client = await getClient();
const response = await client.get('http://localhost:3003/users', {
  timeout: 30,
  // the expected response type
  responseType: ResponseType.JSON
});
Type parameters
- T
Parameters
| Name | Type | 
|---|---|
| url | string | 
| options? | RequestOptions | 
patch
patch<
T>(url:string,options?:RequestOptions):Promise<Response<T>>
Makes a PATCH request.
Example
import { getClient, Body } from '@tauri-apps/api/http';
const client = await getClient();
const response = await client.patch('http://localhost:3003/users/1', {
  body: Body.json({ email: 'contact@tauri.app' })
});
Type parameters
- T
Parameters
| Name | Type | 
|---|---|
| url | string | 
| options? | RequestOptions | 
post
post<
T>(url:string,body?:Body,options?:RequestOptions):Promise<Response<T>>
Makes a POST request.
Example
import { getClient, Body, ResponseType } from '@tauri-apps/api/http';
const client = await getClient();
const response = await client.post('http://localhost:3003/users', {
  body: Body.json({
    name: 'tauri',
    password: 'awesome'
  }),
  // in this case the server returns a simple string
  responseType: ResponseType.Text,
});
Type parameters
- T
Parameters
| Name | Type | 
|---|---|
| url | string | 
| body? | Body | 
| options? | RequestOptions | 
put
put<
T>(url:string,body?:Body,options?:RequestOptions):Promise<Response<T>>
Makes a PUT request.
Example
import { getClient, Body } from '@tauri-apps/api/http';
const client = await getClient();
const response = await client.put('http://localhost:3003/users/1', {
  body: Body.form({
    file: {
      file: '/home/tauri/avatar.png',
      mime: 'image/png',
      fileName: 'avatar.png'
    }
  })
});
Type parameters
- T
Parameters
| Name | Type | 
|---|---|
| url | string | 
| body? | Body | 
| options? | RequestOptions | 
request
request<
T>(options:HttpOptions):Promise<Response<T>>
Makes an HTTP request.
Example
import { getClient } from '@tauri-apps/api/http';
const client = await getClient();
const response = await client.request({
  method: 'GET',
  url: 'http://localhost:3003/users',
});
Type parameters
- T
Parameters
| Name | Type | 
|---|---|
| options | HttpOptions | 
Response<T>
Response object.
Since: 1.0.0
Type parameters
- T
Properties
data
data:
T
The response data.
Defined in: http.ts:286
headers
headers:
Record<string,string>
The response headers.
Defined in: http.ts:282
ok
ok:
boolean
A boolean indicating whether the response was successful (status in the range 200–299) or not.
Defined in: http.ts:280
rawHeaders
rawHeaders:
Record<string,string[]>
The response raw headers.
Defined in: http.ts:284
status
status:
number
The response status code.
Defined in: http.ts:278
url
url:
string
The request URL.
Defined in: http.ts:276
Interfaces
ClientOptions
Since: 1.0.0
Properties
connectTimeout
OptionalconnectTimeout:number|Duration
Defined in: http.ts:65
maxRedirections
OptionalmaxRedirections:number
Defines the maximum number of redirects the client should follow. If set to 0, no redirects will be followed.
Defined in: http.ts:64
Duration
Since: 1.0.0
Properties
nanos
nanos:
number
Defined in: http.ts:53
secs
secs:
number
Defined in: http.ts:52
FilePart<T>
Since: 1.0.0
Type parameters
- T
Properties
file
file:
string|T
Defined in: http.ts:81
fileName
OptionalfileName:string
Defined in: http.ts:83
mime
Optionalmime:string
Defined in: http.ts:82
HttpOptions
Options object sent to the backend.
Since: 1.0.0
Properties
body
Optionalbody:Body
Defined in: http.ts:250
headers
Optionalheaders:Record<string,any>
Defined in: http.ts:248
method
method:
HttpVerb
Defined in: http.ts:246
query
Optionalquery:Record<string,any>
Defined in: http.ts:249
responseType
OptionalresponseType:ResponseType
Defined in: http.ts:252
timeout
Optionaltimeout:number|Duration
Defined in: http.ts:251
url
url:
string
Defined in: http.ts:247
Type Aliases
FetchOptions
FetchOptions:
Omit<HttpOptions,"url">
Options for the fetch API.
Defined in: http.ts:258
HttpVerb
HttpVerb:
"GET"|"POST"|"PUT"|"DELETE"|"PATCH"|"HEAD"|"OPTIONS"|"CONNECT"|"TRACE"
The request HTTP verb.
Defined in: http.ts:229
Part
Part:
string|Uint8Array|FilePart<Uint8Array>
Defined in: http.ts:86
RequestOptions
RequestOptions:
Omit<HttpOptions,"method"|"url">
Request options.
Defined in: http.ts:256
Functions
fetch
fetch<
T>(url:string,options?:FetchOptions):Promise<Response<T>>
Perform an HTTP request using the default client.
Example
import { fetch } from '@tauri-apps/api/http';
const response = await fetch('http://localhost:3003/users/2', {
  method: 'GET',
  timeout: 30,
});
Type parameters
- T
Parameters
| Name | Type | 
|---|---|
| url | string | 
| options? | FetchOptions | 
getClient
getClient(
options?:ClientOptions):Promise<Client>
Creates a new client using the specified options.
Example
import { getClient } from '@tauri-apps/api/http';
const client = await getClient();
Since: 1.0.0
Parameters
| Name | Type | Description | 
|---|---|---|
| options? | ClientOptions | Client configuration. | 
A promise resolving to the client instance.