Quickstart
Get started with Teams SDK quickly using the Teams Developer CLI.
Set up a new project​
Prerequisites​
- Node.js v.20 or higher. Install or upgrade from nodejs.org.
Instructions​
Install the Teams Developer CLI​
Install teams globally:
npm install -g @microsoft/teams.cli
teams --version
The Teams Developer CLI is the command-line tool for scaffolding, registering, and managing Teams apps. It's currently in Preview.
Creating Your First Agent​
Let's begin by creating a simple echo agent that responds to messages. Run:
teams project new typescript quote-agent --template echo
This command:
- Creates a new directory called
quote-agent. - Bootstraps the echo agent template files into it under
quote-agent/src. - Creates your agent's manifest files, including a
manifest.jsonfile and placeholder icons in thequote-agent/appPackagedirectory. The Teams app manifest is required for sideloading the app into Teams.
The
echotemplate creates a basic agent that repeats back any message it receives - perfect for learning the fundamentals.
Running your agent​
- Navigate to your new agent's directory:
cd quote-agent
- Install the dependencies:
npm install
- Start the development server:
npm run dev
- In the console, you should see a similar output:
> quote-agent@0.0.0 dev
> npx nodemon -w "./src/**" -e ts --exec "node -r ts-node/register -r dotenv/config ./src/index.ts"
[nodemon] 3.1.9
[nodemon] to restart at any time, enter `rs`
[nodemon] watching path(s): src/**
[nodemon] watching extensions: ts
[nodemon] starting `node -r ts-node/register -r dotenv/config ./src/index.ts`
[INFO] @teams/app/http listening on port 3978 🚀
The HTTP server is now listening on port 3978. To test your agent locally without sideloading it into Teams, use the Microsoft 365 Agents Playground.
Install the playground globally:
npm install -g @microsoft/m365agentsplayground
Then, with your agent still running, open a second terminal and launch the playground pointed at your agent:
agentsplayground -e http://localhost:3978/api/messages -c emulator
The playground opens at http://localhost:56150. Send a message in the compose box and your agent's reply renders inline.

Add to an Existing Project​
If you already have a project and want to add Teams support, install the SDK directly:
npm i @microsoft/teams.apps
Then initialize the Teams app with your existing server:
import http from 'http';
import express from 'express';
import { App, ExpressAdapter } from '@microsoft/teams.apps';
// Your existing Express server
const expressApp = express();
const server = http.createServer(expressApp);
// Wrap your server in an adapter and create the Teams app
const adapter = new ExpressAdapter(server);
const app = new App({ httpServerAdapter: adapter });
app.on('message', async ({ send, activity }) => {
await send(`You said: ${activity.text}`);
});
// Register the Teams endpoint on your server (does not start it)
await app.initialize();
// Start your server as usual
server.listen(3978);
app.initialize() registers the Teams endpoint on your server without starting a new one — you keep full control of your server lifecycle.
See the HTTP Server guide for full details on adapters and custom server setups.
Next steps​
After creating and running your first agent, read about the code basics to better understand its components and structure.
Otherwise, if you want to run your agent in Teams, you can check out the Running in Teams guide.