{
 "cells": [
  {
   "metadata": {},
   "cell_type": "markdown",
   "source": [
    "# Lab 0: An MCP Server for DHT11\n",
    "\n",
    "Course: [Fill in if needed]\n",
    "Name: [Fill in your name]\n",
    "Date: [Fill in date]\n",
    "\n",
    "---"
   ],
   "id": "4e94ea2abe17c955"
  },
  {
   "metadata": {},
   "cell_type": "markdown",
   "source": "This is an example given in Lecture note.",
   "id": "909590c740914e5e"
  },
  {
   "metadata": {},
   "cell_type": "markdown",
   "source": [
    "## Introduction\n",
    "\n",
    "In this lab, you will build an MCP Server to interface with an IoT sensor (DHT11) for temperature and humidity data collection. The lab demonstrates how to organize and invoke sensor functions using the MCP toolchain, providing hands-on experience in integrating LLMs with IoT systems."
   ],
   "id": "8461572159917fc5"
  },
  {
   "metadata": {},
   "cell_type": "markdown",
   "source": [
    "## Objectives\n",
    "\n",
    "- Understand the basic interaction flow between MCP Server and IoT communication protocol.\n",
    "- Implement MCP tools corresponding to sensor functions using Python.\n"
   ],
   "id": "63800bd8f65cce89"
  },
  {
   "metadata": {},
   "cell_type": "markdown",
   "source": [
    "## Step 0: Preliminaries\n",
    "- Import all required packages"
   ],
   "id": "604ff37a136c8c6"
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-29T23:57:19.639323Z",
     "start_time": "2025-07-29T23:57:19.636180Z"
    }
   },
   "cell_type": "code",
   "source": [
    "import requests\n",
    "from mcp.server.fastmcp import FastMCP"
   ],
   "id": "de97cc423f95fc61",
   "outputs": [],
   "execution_count": 2
  },
  {
   "metadata": {},
   "cell_type": "markdown",
   "source": "- Specify the Communication Protocol",
   "id": "6b38d9f3224ae87"
  },
  {
   "metadata": {},
   "cell_type": "code",
   "outputs": [],
   "execution_count": null,
   "source": [
    "\"\"\"\n",
    "This code assumes that the communication protocol server is running locally on port 8000.\n",
    "The following variables define the connection settings for sending commands to this server.\n",
    "\"\"\"\n",
    "# The hostname or IP address of the communication protocol server\n",
    "COMMUNICATION_PROTOCOL_HOST = 'localhost'\n",
    "# The port number where the protocol server is listening\n",
    "COMMUNICATION_PROTOCOL_PORT = 8000\n",
    "# The full URL endpoint for sending commands to the communication protocol server\n",
    "URL = f\"http://{COMMUNICATION_PROTOCOL_HOST}:{COMMUNICATION_PROTOCOL_PORT}/send_cmd\""
   ],
   "id": "a5e91cd84b579c2"
  },
  {
   "metadata": {},
   "cell_type": "markdown",
   "source": "## Step 1: Create an MCP Server Instance\n",
   "id": "8fadce2e8c1956d7"
  },
  {
   "metadata": {},
   "cell_type": "code",
   "outputs": [],
   "execution_count": null,
   "source": [
    "\"\"\"\n",
    "This MCP Server is specifically designed for the DHT11 sensor and is named 'DHT11 MCP Server'.\n",
    "The description below briefly outlines the server's functionality.\n",
    "\"\"\"\n",
    "server = FastMCP(\n",
    "    \"DHT11\",\n",
    "    description=\"DHT11 PC data monitoring via MCP. Supports general_accuracy temperature and humidity reading.\"\n",
    ")"
   ],
   "id": "b29c99dbe8b5cf65"
  },
  {
   "metadata": {},
   "cell_type": "markdown",
   "source": [
    "## Step 2: Register MCP Tools\n",
    "\n",
    "The DHT11 sensor supports two main functions: reading temperature and reading humidity.\n",
    "To provide complete access, we will register three MCP tools:\n",
    "\n",
    "- `read_temperature`: Retrieves the current temperature from the DHT11 sensor.\n",
    "- `read_humidity`: Retrieves the current humidity value from the DHT11 sensor.\n",
    "- `read_all`: Reads both temperature and humidity values together.\n",
    "\n",
    "> **Note:**\n",
    "> Always provide a clear and concise description for each MCP tool.\n",
    "> This helps the LLM (large language model) understand the purpose and usage of each tool.\n",
    "\n",
    "Registering these tools ensures that all available sensor functionalities are accessible through the MCP server.\n"
   ],
   "id": "1f29e8d60246e2a4"
  },
  {
   "metadata": {},
   "cell_type": "code",
   "outputs": [],
   "execution_count": null,
   "source": [
    "@server.tool()\n",
    "async def read_temperature():\n",
    "    \"\"\"\n",
    "    Read temperature values from the DHT11 sensor.\n",
    "\n",
    "    Returns:\n",
    "    A json-format data of temperature with time stamp.\n",
    "    \"\"\"\n",
    "    cmd = {\"sensor\": \"DHT11\",\"command\": \"read_temp\"}\n",
    "    temperature = requests.post(URL, json=cmd)\n",
    "    return temperature\n",
    "\n",
    "@server.tool()\n",
    "async def read_humidity():\n",
    "    \"\"\"\n",
    "    Read humidity values from the DHT11 sensor.\n",
    "\n",
    "    Returns:\n",
    "    A json-format data of humidity with time stamp.\n",
    "    \"\"\"\n",
    "    cmd = {\"sensor\": \"DHT11\",\"command\": \"read_hum\"}\n",
    "    humidity = requests.post(URL, json=cmd)\n",
    "    return humidity\n",
    "\n",
    "@server.tool()\n",
    "async def read_all():\n",
    "    \"\"\"\n",
    "    Read temperature & humidity values from the DHT11 sensor.\n",
    "\n",
    "    Returns:\n",
    "    A json-format data of temperature & humidity with time stamp.\n",
    "    \"\"\"\n",
    "    cmd = {\"sensor\": \"DHT11\",\"command\": \"read_all\"}\n",
    "    all_data = requests.post(URL, json=cmd)\n",
    "    return all_data"
   ],
   "id": "a74e0b0df34590ab"
  },
  {
   "metadata": {},
   "cell_type": "markdown",
   "source": [
    "### Step 3: Main Entry Point\n",
    "\n",
    "This section defines the main entry point for the script.\n",
    "It is common to all MCP servers and ensures that the server runs when the script is executed directly.\n"
   ],
   "id": "4bda10fee74259ae"
  },
  {
   "metadata": {},
   "cell_type": "code",
   "outputs": [],
   "execution_count": null,
   "source": [
    "if __name__ == '__main__':\n",
    "    server.run()"
   ],
   "id": "39e651fdf6e99ce9"
  },
  {
   "metadata": {},
   "cell_type": "markdown",
   "source": [
    "## Conclusion\n",
    "\n",
    "This lab demonstrated how to design and implement an MCP Server for IoT sensor data collection. By encapsulating sensor functions as MCP Tools, you gain experience in automating and extending LLM-IoT integration, laying the groundwork for future multi-sensor and intelligent systems.\n"
   ],
   "id": "8ffe53d268f9f571"
  },
  {
   "metadata": {},
   "cell_type": "markdown",
   "source": [
    "## Further Exploration (Optional)\n",
    "\n",
    "- Try creating MCP Tools for other types of sensors.\n",
    "- Consider how to design more robust and extensible sensor data services.\n",
    "\n",
    "---\n",
    "\n",
    "# END"
   ],
   "id": "7f581e4e4734f459"
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 2
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython2",
   "version": "2.7.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
