- AgentStack: A CLI-first framework for rapidly scaffolding AI agent workflows, generating agents, tasks, and tools with seamless CrewAI integration.
- CrewAI: A lightweight multi-agent orchestration engine, perfect for managing sequential or collaborative task execution between agents.
- Dappier: A platform that connects LLMs to real-time, rights-cleared data from trusted sources, specializing in domains like web search, finance, and travel. It delivers enriched, prompt-ready data, empowering AI with verified and up-to-date information for diverse applications.
- OpenAI: A leading provider of advanced AI models capable of natural language understanding, contextual reasoning, and content generation. It enables intelligent, human-like interactions and supports a wide range of applications across various domains.
- AgentOps: Track and analyze the running of CrewAI agents with full visibility into cost, token usage, execution traces, and replays.
📦 Project Initialization and Setup
To get started, we’ll use theagentstack CLI to scaffold a fully functional multi-agent project. This command generates the base project structure, config files, virtual environment, and a ready-to-customize crew.py file with support for tools like Dappier and frameworks like CrewAI.
Step 1: Initialize the Project
Run the following command in your terminal:dynamic_travel_planner with the complete project structure.
Step 2: Move Into the Project
Step 3: Activate the Virtual Environment
Activate the virtual environment created byagentstack:
✅ You now have a fully bootstrapped multi-agent AI project using AgentStack and CrewAI.
🔑 Setting Up API Keys
To enable real-time data access and AI reasoning, you’ll need API keys for the following services:- OpenAI – for LLM-powered reasoning and summarization
- Dappier – for real-time stock market data and web search
- AgentOps – for run monitoring and debugging
.env file created during project initialization.
Step 1: Open the .env file
Inside your project root, open .env and update it with your API keys:
- 🔑 Get your OpenAI API Key here
- 🔑 Get your Dappier API Key here — free credits available
- 🔑 Get your AgentOps API Key here - enables run tracking and replay
🧪 Make sure to keep these keys private. Do not commit .env to version control.
⚙️ Installing Dependencies
After initializing the project and configuring your API keys, install the required dependencies to ensure everything runs smoothly. The key packages used in this project are:crewai– Multi-agent execution and orchestrationagentstack– CLI toolchain for generating agents, tasks, and crewsdappier– Real-time data access layer for tools like stock search and newsopenai– LLM access to GPT-4o and other OpenAI models (automatically included)
Step 1: Sync All Dependencies from pyproject.toml
If you’re using the pre-generated project setup from agentstack init, run:
uv lockwill generate theuv.lockfile based on yourpyproject.tomluv syncwill install all dependencies into the virtual environment
Step 2: Add or Upgrade Individual Packages
You need to upgrade packages manually, use:✅ You now have all the required dependencies installed locally and locked for reproducible agent execution.
👤 Creating Agents
Now that your environment is ready, let’s generate the agents that will power the travel planning workflow. These agents are created using the AgentStack CLI and are defined declaratively inagents.yaml.
Step 1: Generate the Agents
You’ll use the following command to scaffold each agent:🗺️ travel_planner
📋 itinerary_reporter
✅ Creating Tasks
Each task defines a specific responsibility to be performed by one of the agents. In this project, tasks are tightly scoped and executed sequentially by CrewAI, allowing agents to collaborate and generate a complete travel itinerary using real-time data. Tasks are defined declaratively intasks.yaml and are created using the AgentStack CLI.
Step 1: Generate Tasks Using the CLI
Run the following command to create a new task:task_name(required)--description– a detailed instruction including{city},{travel_date},{num_days}, and{timestamp}--expected_output– structured data, tables, or markdown expected from the task--agent– the agent responsible for this task
📅 determine_travel_period
🌤 fetch_weather_forecast
🎉 fetch_live_events
🏨 fetch_hotel_deals
📆 generate_travel_itinerary
⚠️ The following two fields must be added manually to thegenerate_travel_itinerarytask insidetasks.yaml, as they are not currently supported via the CLI:
🪄 All of the above tasks will be executed in sequence using CrewAI when you run the crew.
🛠️ Adding Tools to Agents
Tools enable agents to interact with external services like Dappier. In this project, Dappier provides real-time access to weather data, live events, and hotel deals, powering all the data-gathering tasks.Add Dappier Tools to the Project
Instead of manually assigning tools one-by-one, you can add the full Dappier toolkit using:- Adds all Dappier tools to the AgentStack project
- Automatically installs the
dappierpackage by updating yourpyproject.tomlfile - Registers the tools under
agentstack.tools["dappier"]for in-code access
📝 Providing Inputs & Setting Timestamps
Before running the crew, you need to define the runtime inputs that agents and tasks will use. The AgentStack project already includes aninputs.yaml file, which is used to inject these inputs when the crew is executed.
In this project, we use three dynamic inputs:
city: The destination city (e.g., “paris”)travel_date: The planned start date of the trip (e.g., “tomorrow”)num_days: The number of days for the trip (e.g., 5)timestamp: The current UTC time, injected automatically via code
Step 1: Update inputs.yaml
Open the pre-generated inputs.yaml file and set the travel details:
Step 2: Inject a Real-Time Timestamp in main.py
To provide the current timestamp at execution time, update the run() function in main.py:
- Dynamically inject the current UTC timestamp into the input dictionary
- Allow all tasks referencing
{timestamp}intasks.yamlto use consistent timing context
⏱️ Timestamped input ensures your travel itinerary is grounded in real-time context.
🚀 Running the Crew
Once your agents, tasks, tools, and inputs are all set up, you’re ready to run the multi-agent crew. The crew will execute each task in sequence, collaborating to generate a fully structured itinerary using real-time data.Step 1: Run the AgentStack Project
To start the crew execution, run the following command from the project root:- Loads your agents from
agents.yaml - Loads your tasks from
tasks.yaml - Injects inputs from
inputs.yaml(including the runtimetimestamp) - Executes all tasks sequentially via CrewAI
- Stores the final output (e.g., markdown itinerary) in the path defined in
tasks.yaml
✅ You should see terminal output as each agent completes its assigned task.
Step 2: Debug with --debug Mode (Optional)
For detailed execution traces, run with the debug flag:
- Which agent is running
- Which tool is being used
- Real-time function call results
- Intermediate outputs for each task
🧪 Use debug mode to troubleshoot tool usage or model behavior during each step.
Step 3: View the Final Output
After the crew finishes execution, you’ll find the generated itinerary at:📄 The final itinerary includes weather, events, hotel deals, and daily plans — all compiled in real time.
📊 Viewing Agent Run Summary in AgentOps
This project integrates with AgentOps to provide full visibility into agent execution, tool calls, and token usage. By setting theAGENTOPS_API_KEY in your .env file, all runs are automatically tracked.
Below is a sample AgentOps run for this project:
- Duration: 04m 12s
- Cost: $0.0718500
- LLM Calls: 29
- Tool Calls: 4
- Tokens: 60,006
Note: The AgentOps link shown above is tied to the AgentOps account. To access your own replay, you must run the crew using your personal AGENTOPS_API_KEY.
🌟 Highlights
This cookbook has guided you through setting up and running a local travel planning workflow using AgentStack, CrewAI, and Dappier. You created a structured multi-agent execution that generates real-time itineraries based on weather, events, and hotel data. Key tools utilized in this cookbook include:- AgentStack: A CLI framework to scaffold agents, tasks, and tools with support for local execution and configuration.
- CrewAI: A lightweight multi-agent framework that executes agents in sequential or collaborative workflows.
- OpenAI: A leading provider of AI models capable of language understanding, summarization, and reasoning, used to power each agent’s intelligence.
- Dappier: A platform that connects agents to real-time, rights-cleared data from trusted sources, specializing in domains like web search, finance, and travel.
- AgentOps: A tool to track and analyze agent runs, including replay, cost breakdowns, and prompt histories.

