Nodes
Fetch#
The Fetch node allows you to make HTTP requests to external APIs and services from within your Magick spell. It supports common HTTP methods like GET, POST, PUT, DELETE, and PATCH, and allows you to configure headers, request body, and authentication.
Inputs#
url(string, required): The URL to make the request to.method(string, optional): The HTTP method to use for the request. Choices include:GET(default)POSTPUTDELETEPATCH
headers(object, optional): An object containing the headers to send with the request. Defaults to{}.body(object, optional): The request body to send. Defaults to{}.authToken(string, optional): An authentication token to include in the request.authTokenHeader(string, optional): The name of the header to use for theauthToken.flow(flow): The input flow to trigger the node.
Outputs#
response(object): The response from the API, including the response body, status code, and headers.flow(flow): The output flow to trigger the next node in the spell.
Configuration#
This node has no additional configuration options.
Usage#
- Add a Fetch node to your spell.
 - Connect the input flow to trigger the node when desired.
 - Enter the 
urlof the API endpoint you want to call. - Select the appropriate HTTP 
methodfor your request. - If needed, provide:
headersobject for any custom headersbodyobject for POST/PUT/PATCH requestsauthTokenandauthTokenHeaderfor authenticated requests
 - Connect the 
responseoutput to downstream nodes to use the API response. - Connect the output 
flowto trigger the next action. 
Example#
Here's an example of using the Fetch node to make a GET request to the JSONPlaceholder API:
Trigger -> Fetch -> LogFetch node configuration:
url:https://jsonplaceholder.typicode.com/posts/1method:GET
Log node configuration:
message:{{flow.response.body}}
When the spell is triggered, it will make a GET request to the specified URL and log the response body to the console.
Best Practices#
- Always specify the full URL, including the protocol (https://)
 - Use the appropriate HTTP method for your request semantics
 - Include all required headers, such as 
Content-Typeand authentication headers - Validate and sanitize any user-provided inputs that are used to construct the request
 - Handle errors gracefully by checking the response status code
 - Use the Debugger node to inspect the 
responseobject if needed 
Common Issues#
- Forgetting to include the protocol (https://) in the 
url - Using the wrong HTTP 
methodfor the intended action - Omitting required headers like 
Content-Typeor authentication tokens - Not handling non-2xx response status codes
 - Expecting the response body to be a string instead of an object
 
If you run into issues, double check your configuration and use the Debugger node to inspect the response object and identify any problems with the request or response.