Skip to content

An app for tracking tagged questions on Microsoft Stack Overflow in team channels or chat

License

Notifications You must be signed in to change notification settings

jotrick/stack-overflow-enterprise-bot

 
 

Repository files navigation

Overview

This project is meant to help a Teams developer in two ways. First, it is meant to show many examples of how an app can integrate into Teams. Second, it is meant to give a set of patterns, templates, and tools that can be used as a starting point for creating a larger, scalable, more enterprise level bot to work within Teams. Although this project focuses on creating a robust bot, it does include simples examples of tabs as well as examples of how a bot can give links into these tabs.

What it is

At a high level, this project is written in Typescript, built to run a Node server, uses Gulp to run its build steps, runs a Typescript linting tool to keep the code uniform, and uses the BotFramework to handle the bot's requests and responses. This project is designed to be run in VSCode using its debugger in order to leverage breakpoints in Typescript. Most directories will hold a README file which will describe what the files within that directory do.

The easiest way to get started is to follow the steps listed in the "Steps to get started running the Bot Emulator". Once this is complete and running, the easiest way to add your own content is to create a new dialog in src/dialogs by copying one from src/dialogs/examples, change it accordingly, and then instantiate it with the others in the RootDialog.ts.

General Architecture

Most Typescript files that need to be transpiled (and the bulk of the project) reside in the src directory. Most files outside of the src directory are static files used for either configuration or for providing static resources to tabs, e.g. images and html. At build time, Gulp will transpile everything in the src directory and place these transpiled files into a build directory. Gulp will also move a few static files into this new build directory. Because of this, it is recommended that nothing be changed by a developer in the build directory. All changes should be done on the "source" files so rebuilding the project will update the build directory.

The general flow for using this template is to copy/paste/create/build on the example dialogs in the src/dialogs/examples directory, but to put your newly created dialogs outside of the src/dialogs/examples directory (either parallel to the src/dialogs/examples directory or in new directories of your own). In this way, your dialogs do not coexist with the example dialogs so if the time comes to delete the examples, one can simply delete the src/dialogs/examples directory. More information on how to create new dialogs and add to this project can be found in the file src/dialogs/README.md in the "Creating a New Dialog" section.

Steps to get started running in the Bot Emulator

Get VSCode:

Install Node:

Install the bot Emulator - click on "Bot Framework Emulator (Mac and Windows)":

Install Git for windows:

Clone this repo:

Get the npm modules - in the microsoft-teams-bot-template directory run:

  • npm install

Open microsoft-teams-bot-template with VSCode

In VSCode go to the debug tab on the left side (looks like a bug) and click the play button

Once the code is running you can now connect and chat with the bot using the emulator

NOTE: Athough not necessary to get running in the Bot Emulator, installing ngrok (or another tunnelling tool) will help to get a locally running instance of this project into Teams:

Files and Directories

  • .vscode

    This directory holds the files used by VSCode to build the project. The launch.json file is where important environment variables will be stored.

  • luis

    This directory holds an example of a json file used to instruct a Luis recognizer for natural language processing.

  • manifest

    This directory holds the skeleton of a manifest.json file that can be altered in order sideload this application into a team.

  • public

    This directory holds static html, image, and javascript files used by the tabs and bot. This is not the only public directory that is used for the tabs, though. This directory holds the html and javascript used for the configuration page of the configurable tab. The main content of the static and configurable tabs is created dynamically by the code in src/tab/TabSetup.ts or comes from the static files placed in build/src/public/exampleDialogs, which are created at build time based upon the typescript dialogs in src/dialogs/examples.

  • src

    This directory holds all of the typescript files, which run the entire application. These files, at build, are transpiled and their transpiled javascript files are placed in the build directory.

  • test

    This is a directory to do two things. First, it acts as a placeholder to give an example of a place to store tests. Second, it is a directory that works to keep the directory hierarchy correct when files are moved into the build directory.

  • gulpfile.js

    This file defines the tasks that Gulp will run to build the project correctly. The task to completely build the project is named "build".

  • tsconfig.json

    This file configures the Typescript transpiling tool.

  • tslint.json

    This file configures the Typescript linting tool.

  • web.config

    This file is a skeleton of a web.config file that can be used to upload this project into an Azure application.

Contributing

This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.

About

An app for tracking tagged questions on Microsoft Stack Overflow in team channels or chat

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 96.6%
  • JavaScript 2.1%
  • Batchfile 1.2%
  • HTML 0.1%