Skip to content

A slightly longer introduction#

This guide shows you how to automate a task using a workflow in n8n, explaining key concepts along the way. You will:

  • Create a workflow from scratch. You'll build a workflow that runs every week to get data from NASA, filters the data, and generates two reports.
  • Understand key concepts and skills, including:
    • Starting workflows with trigger nodes
    • Configuring credentials
    • Manipulating data
    • Representing logic in an n8n workflow
    • Using expressions

Step one: Install and run n8n#

Skip this section if you've already installed n8n or signed up for a Cloud account

n8n is available as a Cloud service, desktop app, npm module, and Docker image. For this quickstart, n8n recommends using the Desktop app.

Linux users

This guide uses the n8n desktop app, which is available for Windows and Mac. If you're on Linux, sign up for a free Cloud trial, or use npm or Docker.

  1. Download for Windows or Download for macOS.
  2. Once the download finishes, extract the files.
  3. Run the installer. It has no configuration steps.
  4. Once installation is complete, n8n opens automatically. There may be a small lag between installation completing and the app opening.

Step two: New workflow#

If you have no workflows, n8n takes you directly to the canvas, so you can start building. If you already built a workflow, n8n takes you to the Workflows list. Select Add workflow to create a new workflow for this tutorial.

Step three: Add a trigger node#

n8n provides two ways to start a workflow:

  • Manually, by selecting Execute workflow, or from the CLI if you installed n8n with npm or Docker.
  • Automatically, using a trigger node as the first node. The trigger node runs the workflow in response to an external event, or based on your settings.

For this tutorial, use the Schedule trigger. This allows you to run the workflow on a schedule:

  1. Select Add first step.
  2. Search for Schedule. n8n shows a list of nodes that match the search.
  3. Select Schedule Trigger to add the node to the canvas. n8n opens the node.
  4. For Trigger Interval, select Weeks.
  5. For Weeks Between Triggers, enter 1.
  6. Enter a time and day. For this example, select 9am in Hour, enter 0 in Minute, and select Monday in Trigger on Weekdays.
  7. Close the node details view to return to the canvas.

Step four: Add the NASA node and set up credentials#

The NASA node allows you to interact with NASA's public APIs. The API gives you data to work with in this tutorial.

  1. Select the Add node Add node icon connector on the Cron node.
  2. Search for NASA. n8n shows a list of nodes that match the search.
  3. Select NASA to add the node to the canvas. n8n opens the node.
  4. To access the NASA APIs, you need to set up credentials:
    1. Select the Credential for NASA API dropdown.
    2. Select - Create New -. n8n opens the credentials view.
    3. Go to NASA APIs and fill out the form in Generate API Key. NASA generates the key and displays it.
    4. Copy the key, and paste it into API Key in n8n.
    5. Select Save.
    6. Close the credentials screen. n8n returns to the node. The new credentials should be automatically selected in Credential for NASA API.
  5. In Resource, select DONKI Solar Flare. This resource returns a report about recent solar flares.
  6. By default, DONKI Solar Flare provides data for the past 30 days. To limit it to just the last week, use Additional Fields:

    1. Select Add field.
    2. Select Start date.
    3. To get a report starting from a week ago, you can use an expression: next to Start date, select the Expression tab. n8n opens the Edit Expression modal.
    4. In the Expression field, enter the following expression:
      1
      {{$today.minus({days: 7}).toFormat('yyyy-MM-dd')}}
      
      This generates a date in the correct format, seven days before the current date.

    Date and time in n8n

    n8n uses Luxon to work with date and time, and also provides two variables for convenience: $now and $today. For more information, refer to Expressions > Luxon.

  7. Close the Edit Expression modal to return to the NASA node.

  8. You can now check that the node is working and returning the expected date: select Execute node to run the node manually. n8n calls the NASA API and displays details of solar flares in the past seven days in the OUTPUT section.
  9. Close the NASA node to return to the workflow canvas.

Step five: Add logic with the If node#

n8n supports complex logic in workflows. In this tutorial, use the If node to create two branches that each generate a report from the NASA data. Solar flares have five possible classifications. You'll create logic that sends a report with the lower classifications to one output, and the higher classifications to another.

Add the If node:

  1. Select the Add node Add node icon connector on the NASA node.
  2. Search for If. n8n shows a list of nodes that match the search.
  3. Select If to add the node to the canvas. n8n opens the node.
  4. Select Add condition > String.
  5. You need to check the value of the classType property in the NASA data. To do this:

    1. Next to Value 1, select the Expression tab. n8n opens the expressions editor for this field.
    2. Select Current Node > Input Data > JSON > classType. n8n adds the expression to the Expression editor, and displays a sample output.

    Make sure you ran the NASA node in the previous section

    If you didn't follow the step in the previous section to run the NASA node, you won't see any data to work with in this step.

    1. Close the expressions editor to return to the node.
    2. In Operation, select Contains.
    3. In Value 2, enter X. This is the highest classification of solar flare. In the next step, you will create two reports: one for X class solar flares, and one for all the smaller solar flares.
    4. You can now check that the node is working and returning the expected date: select Execute node to run the node manually. n8n tests the data against the condition, and shows which results match true or false in the OUTPUT panel.

Weeks without large solar flares

In this tutorial, you are working with live date. If you find there are no X class solar flares when you run the workflow, try replacing X in Value 2 with either A, B, C, or M.

Step six: Output data from your workflow#

The last step of the workflow is to send the two reports about solar flares. For this example, you'll send data to Postbin. Postbin is a service that receives data and displays it on a temporary web page.

  1. On the If node, select the Add node Add node icon connector labeled true.
  2. Search for Postbin. n8n shows a list of nodes that match the search.
  3. Select Postbin to add the node to the canvas.
  4. Change Resource to Request.
  5. In Operation, select Send.
  6. Go to Postbin and select Create Bin.
  7. Copy the bin ID. It looks similar to 1651063625300-2016451240051.
  8. In n8n, paste your Postbin ID into Bin ID.
  9. Now, configure the data to send to Postbin. Next to Bin Content, select the Expression tab. n8n opens the expressions editor for this field.
  10. Select Current Node > Input Data > JSON > classType. n8n adds the expression to the Expression editor, and displays a sample output.
  11. The expression is: {{$json["classType"]}}. Add a message to it, so that the full expression is:
    1
    There was a solar flare of class {{$json["classType"]}}
    
  12. Close the expressions editor to return to the node.
  13. Close the Postbin node to return to the canvas.
  14. Add another Postbin node, to handle the false output path from the If node:
    1. Hover over the Postbin node, then select Duplicate node Duplicate node icon to duplicate the first Postbin node.
    2. Drag the false connector from the If node to the left side of the new Postbin node.

Step seven: Test the workflow#

  1. You can now test the entire workflow. Select Execute Workflow. n8n runs the workflow, showing each stage in progress.
  2. Go back to your Postbin bin. Refresh the page to see the output.
  3. If you want to use this workflow (in other words, if you want it to run once a week automatically), you need to activate it by selecting the Active toggle.

Time limit

Postbin's bins exist for 30 minutes after creation. You may need to create a new bin and update the ID in the Postbin nodes, if you exceed this time limit.

Next steps#

  • Take n8n's courses.
  • Explore more examples in workflow templates.