Skip to content

👨🏻‍💻 Codeblocks

The codeblock is a versatile block that can be used to write code in different languages. In this case, we will use it to make requests.

🏳️ Flags

Flags are the way to specify the parameters of our request and also the format in which we want our response.

Flag Default
url
method GET
body
headers
show ALL
format {}
req-id req-general
disabled
req-repeat 1t@1s
notify-if
save-to
properties
render false
res-type
maketable

url

Is the only required flag. It specifies the endpoint of the request. Variables defined in the frontmatter can be used.

```req 
url: https://jsonplaceholder.typicode.com/users/{{this.id}}
```

Where {{this.id}} is a variable (id) defined in the frontmatter.

method

Specifies the request method. The default value is GET and the available values are:

  • GET
  • POST
  • PUT
  • DELETE
```req 
url: https://jsonplaceholder.typicode.com/posts
method: post
```

body

Specifies the body of the request. The default value is an empty object. The data should be in JSON format with double quotes separating the keys and values with a colon and space. Variables defined in the frontmatter can be used.

```req 
url: https://jsonplaceholder.typicode.com/posts
method: post
body: {"title": {{this.title}}, "body": "bar", "userId": 1}
```

Where {{this.title}} is a variable (title) defined in the frontmatter.

headers

Specifies the headers of the request. The default value is an empty object. The data should be in JSON format with double quotes separating the keys and values with a colon and space. Variables defined in the frontmatter can be used.

```req 
url: https://jsonplaceholder.typicode.com/posts
method: post
headers: {"Content-type": "application/json; charset=UTF-8"}
```

show

Specifies the response data to display. Accessing nested objects is done using a right arrow ->. The default value is ALL.

```req
url: https://api.chess.com/pub/player/hikaru/stats
show: chess_daily -> last -> rating
```

Multiple outputs can be displayed by separating them with a comma.

```req
url: https://api.chess.com/pub/player/hikaru/stats
show: chess_daily -> last -> rating, chess_daily -> best -> rating
format: <p>Last game: {}</p> <strong>Best game: {}</strong>
render
```

Looping over an array is also possible using {..}. The following example retrieves the city from all users.

```req 
url: https://jsonplaceholder.typicode.com/users
show: {..} -> address -> city
```

Looping over a specified number of elements of the array is also possible using {n..n}.

```req 
url: https://jsonplaceholder.typicode.com/users
show: {0..2} -> address -> city
```

It's also possible to loop over a specified range of indexes of the array using {n-n-n}.

```req 
url: https://jsonplaceholder.typicode.com/users
show: {0-2-1} -> address -> city
```

You can access the last element using {-1}...

```req
url:https://api.modrinth.com/v2/project/distanthorizons
show: game_versions -> {-1}
```

... or get the length of the array using {len}.

```req
url:https://api.modrinth.com/v2/project/distanthorizons
show: game_versions -> {len}
```

To access multiple elements at the same time when using {..} use & to separate the keys and use . to access the values.

```req 
url: http://ws.audioscrobbler.com/2.0/?method=user.getrecenttracks&user=rooyca&api_key=API_KEY&format=json&limit=4
show: recenttracks -> track -> {..} -> name & artist.#text & streamable
maketable: name, artist, stream
```

format

Specifies the format in which the response should be displayed. The default value is {}. It can be any string (including markdown and html). If more than one output is specified, more then one format should be specified, otherwise, the same format will be applied to all outputs.

```req 
url: https://jsonplaceholder.typicode.com/posts/1
show: title, body
format: <h1>{}</h1> <p>{}</p>
render
```

In this example, first {} will be replaced by the title, and second {} will be replaced by the body.

req-id

Specifies the id of the request. The default value is req-general. This is useful when we want to store the response in localStorage and use it in other blocks or notes.

```req 
url: https://jsonplaceholder.typicode.com/users/1
show: name
req-id: name
```

Stored responses can be accessed using the req-id with the disabled flag (which won't trigger a new request).

```req 
url: https://jsonplaceholder.typicode.com/users/1
req-id: name
disabled
```

Responses can also be accessed using dataview.

```dataview
dv.paragraph(localStorage.getItem("req-name"))
```

Is mandatory to use req- before whatever you defined in req-id flag.

To remove responses from localStorage, run:

```dataview
localStorage.removeItem("req-name")
```

To remove all responses, go to settings and click on the Clear ID's button.

disabled

Disables the request. If a req-id is specified, APIR will check for the response in localStorage. If it's not found, it will make a new request and store it. After that, APIR will use the stored response.

```req 
url: https://jsonplaceholder.typicode.com/users/1
show: name
req-id: name
disabled
```

req-repeat

This only works with JSON responses

Specifies the number of times the request should be repeated and the interval between each repetition. The default value is 1@1 (read as X time(s) every X second(s)).

```req 
url: api.coincap.io/v2/rates/bitcoin
req-repeat: 5@5
render
```

notify-if

This only works with JSON responses

Specifies the condition to trigger a notification. Can be used to monitor a specific value. The path syntax used to access nested objects varies from the show flag, here dots are used instead of arrows and not spaces are allowed in the path.

```req 
url: api.coincap.io/v2/rates/bitcoin
req-repeat: 5@5
notify-if: data.rateUsd < 69889
render
```

In the example above, a notification will be triggered everytime the value of data.rateUsd is less than 69889.

save-to

Specifies the path to save the response. It'll save the entire response. A file extension is required. It won't create directories.

```req 
url: https://jsonplaceholder.typicode.com/posts/1
save-to: posts/1.json
```

properties

To use this flag you need a JSON response and the show flag

Specifies the frontmatter properties to update with the response. The data should be strings separated by commas. To set internal links use the [[..]] syntax.

```req 
url: https://jsonplaceholder.typicode.com/posts/1
show: id, title
properties: id, title
```

render

If present the response will be rendered as HTML. It's useful when the response is an image or a table. The HTML is sanitized to prevent XSS attacks.

```req 
url: https://jsonplaceholder.typicode.com/photos/1
show: url
format: ![img]({})
render
```

res-type

Specifies the type of the response. If this flag is not present the plugin will try to guess the type based on the response content-type. This could be used as an optional fallback feature.

```req 
url: https://jsonplaceholder.typicode.com/posts/1
res-type: json
```

maketable

Converts the response into a table. It's useful when the response is an array of objects. This flags expects a list of titles separated by commas.

```req 
url: http://ws.audioscrobbler.com/2.0/?method=user.getrecenttracks&user=rooyca&api_key=API_KEY&format=json&limit=4
show: recenttracks -> track -> {..} -> name & artist.#text & streamable
maketable: name, artist, stream
```

In the example above, the response will be converted into a table with the titles name, artist, and stream.