Skip to main content

Build An Advanced Agent

The following diagram shows the key steps for building, maintaining, scheduling, and monitoring Sequentum Cloud agents . We provide links for other topics which will explain each of these steps in further detail.

Basic web data extraction agent creation process

image (1).png

In this section, we will cover the identification of data elements on your target website and create your first Sequentum Cloud agent. We'll work through each of the above steps with examples that match common web data extraction usage, so you can get comfortable building agents on your own and at your own pace.

Choosing a Start URL

The Start URL is the place where you begin data collection and corresponds to the starting point of your web data extraction agent.

In the following sections, we'll use the Cruise Direct website for our example.

http://www.cruisedirect.com

Note: In this example, we start from the Cruise Direct home page, however, if the data you require is not located on a website home page, you can start the agent from a website sub-page. This approach will make the agent more efficient, so it’s worth taking the time to be more specific.

 

  1. We start by pasting the start web page URL from the target website (

http://www.cruisedirect.com) into the Sequentum Cloud Address Bar.

image-20241001-030650.png

Sequentum Cloud with Cruise Direct home page loaded

In the next section, Select the Content to Capture, we will continue to use the Cruise Direct website data for our example.

Select the Content to Capture

In the previous section, we selected our Start URL and loaded the web page into the Sequentum Cloud web editor. Next, you can select the data you want to capture and start building your first web data extraction agent. In our Cruise Direct example, we plan to search for available cruise vacations and then extract details about each cruise.

 

  1. First, we need to perform a search to retrieve the data for the available cruises. For this we will enter in a destination and the month of departure. Click once on the “Select Destination” on the web page, then click the “Selection” tab at the bottom of the screen. Then click the “Select” button to pop up the drop down selections. Select “Bahamas“ and click on “Add Command”.
    NOTE: Hit Enter key to ensure you save the changes after adding command(s).

    image-20241019-210033.png

  2. Rename your command to something more intuitive, such as “Destinations,” by clicking the command name, entering the new name, and pressing the Enter key.

    image-20241019-210420.png
  3. Now click on the “Options” button in the top right corner to configure some additional settings for the “Destinations” command.

    image-20241019-210757.png

  4. Click on the tab called “Browser” and scroll down to the category called “Dynamic browser settings”.

    image-20241019-211049.png

    From here, we’ll change the wait settings to wait for async loaded content. You can find out about what each property performs in the text manual that appears in the right pane, but for now, just know that we need to make this change since there is new async content being loaded every time we make a change on the website.

    image-20241019-211247.png

  5. After pressing save, click back on the “Browser” button in the top right corner to go back to the interactive browser screen.

    image-20241019-211412.png
  6. Next hover over the “Destinations” command, and press the lighting bolt icon to execute the newly generated command.

    image-20241019-211606.png

  7. Next, apply the same steps to the “Select Month” form field. Choose the latest date, rename the command to "Months," and press Enter to save the new name. Update the “Options” settings just as you did for the Destinations command. Finally, click the lightning bolt to run the command.

    image-20241017-194501.png

    NOTE: If you are having trouble scrolling down the page to click on the “Select Month” field, you might need to switch to navigation mode first to be able to click the scroll bar. To do this click on the globe icon at the top of the screen next to the Help menu.

    image-20250113-062227.png

    Once you have Turned on Navigation Mode, scroll down the page until you can see the Month selection, then click the Globe icon again to return to Off Navigation Mode. Now you can continue with your selection.

  8. Next, initiate the search to retrieve cruise details by clicking the orange “Search” button. Then, in the “Extracted Content” tab below, select the “Action” button. Rename this command to “Search” and press Enter key to save it.

    image-20241019-215607.png
  9. While hovering over the “Search” command, you’ll notice a lighting bolt icon. Click on the lighting bolt icon to manually execute the new search command.

    image-20241019-215736.png
  10. We are now redirected to the result page with cruises that match the filters that we previously set. To select any information from this page, we simply need to point and click to select the information we want to extract. In the bottom, click away from the default “Extracted Content” tab to the “Selection” Tab. This “Selection” view allows us to select elements on the page even more easily than clicking on elements on the page.

    image-20241001-175625.png
  11. Using your mouse, try clicking the object on the page which has all of the cruise information. As you click, the object on the page is highlighted and surrounded by a bounding box. On a site like this, it can be tricky to click on the whole object you want since it is running off screen so another method which might be easier in this case is to select from the page elements behind the scenes. To view these, go to the “Selection” tab and select a div which contains all of the information that we want to extract (e.g. Cruise name, ratings, duration, description, prices, etc). In our case, this is the div with a class of “views-row“.

    image-20241019-220843.png
  12. Once we have selected the <div class=”views-row”>, scroll down on the page, hold down the “Shift” key, and click on the same div in the second element. If you performed this step correctly, you will notice in the selection box that there are “5 Selected” elements.

    image-20241019-221023.png
  13. Click on the “Extract” command and you will notice that a new “Selection List” command along with a “Section” command gets generated. Rename the command “Name” and click on the name of the cruise while the command is still in edit mode and press “Save Selection” in the bottom right corner to save the changes.

    image-20241001-182119.png
  14. Next, we'll add additional commands to capture more relevant details. Click on the departure location and select it. In the Selection tab, click “Extract” to create the command, then rename it to “Departure.” Remember to press Enter to save your changes.

    image-20241001-182934.png
  15. After the departure command has been generated, click back to the “Extracted Content” tab in the bottom left corner. From here, we can highlight the text that we want to extract (e.g Miami, Port Canaveral, etc, and parse out the string “Departing From”). After highlighting the text, click on the “Extract selected” button to parse out the data. A regular expression automatically got generated and parsed out the string “Departing from”. [Note: Firefox browser not currently supported for this action.]

    image-20241001-183458.png

  16. Repeat the Select, Extract, Extract Selected steps above for the fields “Duration”, ““Ship”, “Port of Call“, and “Best For“

    image-20241001-184711.png
  17. Now we want to extract pricing information for each cruise. Since there are multiple dates with different prices, we will need to generate a list like we previously did with the list of cruises. Find a list item on the page with multiple rows of data, then click on the first object that contains a cruise date, hold down the shift key, and select the second page object that contains a cruise date. Now click on the “Extract” button and a new sub list gets generated underneath the earlier commands. Rename the “Section” command as “Departure Date”, and click on the departure date column and press “Save Selection”.

    image-20241001-191306.png
  18. Click on the other columns and capture the interior, ocean view, balcony, and suite prices. Use our previously taught method of generating an automatic regular expression to parse out the “USD” part of the prices.

    image-20241001-193539.png
  19. We will now try to extract some information from the “Bonus” column. Since they are icons and not text, if we click on the bonus column, you’ll notice that there is no data being returned in the extracted content section.

    image-20241001-193709.png
  20. To bypass this, we simply need to change what we are extracting from the column. On the “Extracted Content” tab, click on the dropdown list labeled “Text” to see what other types of attributes you can perform. Change the selection to “Styled HTML“ to get a bit more information out of the icons such as the name of the icons or any other specific data that might be on the backend.

    image-20241019-224011.png
  21. We have now extracted all of the fields we want to extract and are almost done with creating our first agent.

  22. Next let’s add some pagination. To do this, we first need to determine where to add the pagination command.

    In this case, we want to repeat everything after the “Section List” command since on every page there is new relevant information that needs to be extracted. In order to do this, click on the parent command of the “Section List” command in the agent explorer, which is the “Search” command.

    image-20241001-200034.png

    Positioning the selection to the “Search” command before adding pagination

    From here, click on the “Action“ command on the left navigation menu to expand a list of action commands.

    image-20241019-224423.png

    Mouseover the commands that are in this section to display their names and click on the one labeled “Action Repeater” :

    image-20241019-224604.png

    This creates the “Action Repeater” command”. Rename this command to “Pagination” and scroll down the page and select where the pagination should be (in this case, the “Next” button at the bottom of the page) and press “Save Selection”

    image-20241001-200356.png

  23. Press the lighting bolt icon next to the pagination command to manually execute the command and if everything is done correctly, the pagination will work and you will see the second page.

    image-20241001-200605.png

     

  24. Now that we have confirmed that the pagination command works, we will need to move the command to the correct position. Drag the pagination up above the “Section List” command and just below the “Search” command and drop it there:

    image-20241019-225101.png
    image-20241019-225256.png

    image-20241019-225357.png

  25. Then drag the “Section List” command onto the pagination command so that the “Section List” command becomes nested beneath the pagination command.

    image-20241019-225444.png
  26. If done correctly, the your pagination command will should look like the following image.

    image-20241001-200836.png

     

  27. We will now use the Sequentum Cloud Visual debugger to debug our agent and see if there are any errors. First, let’s publish this agent before we debug it. Press the “Publish” button highlighted on top. Name the agent Cruisedirect and press Publish with any comments (optional).

    image-20241001-203337.png

     

  28. Now let’s debug our agent! Press the “Clear Storage” button next to the “Publish” button on the top to clear all storage before we start. Next, click on the “Play” button to start debugging.

    image-20241001-203656.png

    Clearing storage before debugging

    image-20241001-203931.png

    Editor screen while debugging

     

  29. Congratulations! You have built your first agent using Sequentum Cloud! Let’s stop debugging now and move onto the next step of refining your data, formatting the output and eventually running your agent and delivering the data to your specific endpoint.

Data Validation

Creating an agent to extract data is only the first step in your ETL process! Now we will apply data validation in our agents in the form of validation rules/success criteria to ensure that the data we are extracting every run is actually useable data. We will now click on the “Export” command in the agent explorer to pull open the settings in the command.

Sequentum Cloud by default exports in csv format. You can also export in JSON format by clicking on expanding the “Export” section on the left land side of the agent explorer and selecting JSON.

image-20241001-210900.png

Data schema screen

From this page, we’re able to view all of the fields in our schema along with any default data type requirements, null values, format styles, format type, and time zones. Please feel free to make any changes that you feel applicable.

Next, we’ll move onto our success criteria definitions. Click on the main agent command in the agent explorer, and then click on success criteria. Success criteria defines a successful run based on a predetermined number of criteria which can be defined as a minimum number of page loads, minimum number of data count, minimum export count, and/or a maximum number of errors. These can also be a percentage of the previous run if a number between 0-100 is inserted in the allowed page load variation column.

Configure any set of success criteria and we’ll move onto the next section.

image-20241015-202653.png

Success criteria screen

Data Delivery

Now that we’ve set up data validation to ensure that we’re extracting high quality data, we will configure our data delivery target so that we can receive data at our endpoints to use for processing later. The default export format is csv format. Click on the “Export” icon on the left hand side of the agent explorer to expand the full list of export commands.

image-20241015-215230.png

Full list of export commands

This list consist of csv, json, s3, google sheets, google drive, ftp/sftp, snowflake, and custom script as of version 1.16. In this example, we will export a csv file to an internal s3 bucket. S3 export needs to be configured from the main Sequentum Cloud and then used in agent.

Click back to the control center, in the bottom left corner, click on “Organization”, then the “Destinations” tab, and click on “New Destination”

image-20241018-185426.png

Destinations Screen

Enter in a destination name and description for the new destination. For destination type, keep as the default S3 bucket. Now enter in the bucket name and folder path in which you want to deliver the data. A policy will be generated for you which looks something like the screenshot below.

image-20241018-195150.png

Configuring our bucket name and folder

Scroll down on the page and let’s fill out the Role ARN

image-20241018-195241.png

Configuring our ARN

Copy these policies and trust relationship policies to your external IAM role and press test connection to upload a test file to your S3 bucket. After this is finished, we can head back over to our agent, click a S3 export, and change the destination name to our newly created destination.

image-20241018-211159.png

Adding the destination to our agent

Running, Scheduling, and Monitoring Your Agent

Once we are fully done configuring our export targets, we can start to run, schedule, and monitor our agent through the Sequentum Cloud Control Center. Head back over to the control center by clicking on the Control Center icon in the top right corner. Once there, click on our personal directory (if that’s where you saved your agent), and from that dashboard, you’ll be able to view the status of all of your agents.

image-20241016-195930.png

Personal Dashboard

The name, versions, updated date, activity date, and status of our runs can be viewed for all agents directly on this page. When we want to edit our agent, simply click on the agent name, and we’ll be redirected to the runs page where we can click on “Edit Agent” in the right corner.

image-20241016-200150.png

Note that while the agent is running, you can see the same visual playback you saw when you pressed “Play” to test your agent. Click the “View Live Information” button:

image-20241019-232047.png

And this will show you the agent run in progress:

image-20241019-232618.png

 

Toggle the Visual icon and Log icon back and forth to see the logs or visual playback in each instance. This can be viewed for as many sessions as you have running in parallel.

image-20241019-232511.png

From this runs page, we’re also able to click on the “Info” tab to add descriptions, documentation, icons, and view the schema of the run.

image-20241016-200406.png

We can also click on the “Run History” tab to view all of our previous runs (*Note that the “Runs” tab only shows the status of the latest run, and all previous runs before that are located in the “Run History” tab).

image-20241016-200448.png

The run history page also provides detailed info on the status of the run in terms of actions performed, data points extracted, errors (includes page load errors and also errors from data validation), pages loaded, dynamic pages loaded, rate of request, number of requests, and also traffic.

From here, we’ll now schedule our agent to run on a daily basis! Click on the “Setup Run” icon on the right.

image-20241016-201105.png

Setup run screen

From here, we can set up a set of proxies to use for the run. Click on the “Schedule” checkbox to load up more info on scheduling the agent.

image-20241016-201229.png

From here, we’re able to change the start date & time, along with any specific schedule type (run once, run every day, or a custom CRON expression). Press the “Save Task” button when you are done setting up your schedule. In addition, you can also press the “Run Now” button if you simply want to run the agent once instead of setting up a schedule. You have now set up your first schedule and will be redirected to the “Tasks” tab where you can monitor your schedules.

image-20241016-201454.png

Congratulations, you have fully completed your first agent! In this guide, we learned how to build our first agent, setup our data validation schemas to ensure we’re extracting high quality data, configured our export target configuration so that we’re receiving data in our s3 bucket, and finally scheduled our agent to run on a daily basis! If you have any additional questions, please reach out to us at support@sequentum.com

JavaScript errors detected

Please note, these errors can depend on your browser setup.

If this problem persists, please contact our support.