1
0
Fork 0
arangodb/Documentation/Books/Manual/Foxx/Guides/MakingRequests.md

42 lines
1.4 KiB
Markdown

Making requests
===============
ArangoDB is primarily a database, so Foxx doesn't offer the same level of
network access as more general-purpose JavaScript environments like Node.js.
However ArangoDB does provide the
[`@arangodb/request` module](../../Appendix/JavaScriptModules/Request.md)
for making HTTP (or HTTPS) requests:
```js
"use strict";
const request = require("@arangodb/request");
const response = request.get(
"https://pokeapi.co/api/v2/pokemon/25/"
);
if (response.status < 400) {
const pikachu = response.json;
console.log(pikachu);
}
```
{% hint 'warning' %}
Because
[Foxx services are always synchronous](../README.md#compatibility-caveats)
and network requests can be considerably slower than any other
database operation, you should avoid making requests in your service
if possible or use [queues](Scripts.md#queues) instead.
{% endhint %}
By using an absolute path instead of a full URL, you can also use the
request module to talk to ArangoDB itself,
for example in [integration tests](Testing.md#integration-testing):
```js
const response = request.get("/_db/_system/myfoxx/something");
```
**Note**: Although making local requests doesn't create the network overhead
as making requests to other servers, special care needs to be taken when
talking to services on the same server. If you want to connect services
in the same database [you should use dependencies instead](Dependencies.md).