How to Create a Simple PHP chat-bot using Botman.io

in #utopian-io7 years ago (edited)

What Will I Learn?

  • You will get introduced to the most popular PHP chatbot framework in the world.
  • You will learn how to setup a simple chatbot with the botman package

Requirements

  • PHP >= 7
  • Composer
  • Local Server (Xammp, Wamp, Laragon or Mamp)

Difficulty

This can be done by anyone ... ranging from a beginner to an expert.

  • Basic
  • Intermediate
  • Advanced

Tutorial Contents

We all see various bots on platforms we come across with, examples are Slack bot, Telegram bot , Messenger bot.

Today, together I'll show how to integrate a simple chatbot of your own , using the botman library.

the stage 4 task .

Probably, I should take this tutorial in steps, So ....

STEP 1

Make a Folder in your local web server .... I'm using laragon, so mine goes like this image.png

Now open this folder using your preferred text-editor.

STEP 2

Make a simple page index.php and draft out a html template on it .... Mine looks like this
image.png

STEP 3

Okay ... we have our view now .... Next we install the the botman library.
In this project folder, lets run the command to setup the required dependencies

composer require botman/botman

and then

composer require botman/driver-web

This two commands above , helps us install the botman library we will use for this project using the PHP dependency manager Composer. Now we are setup for our chatbot.

STEP 4

Make two files in this project folder chat.html and chat.php.

A)

chat.html will be chat interface that will be rendered on our index.php.

Open the chat.html file and copy this to it.

  <!doctype html>
<html>

<head>
    <title>BotMan Widget</title>
    <meta charset="UTF-8">
    <link rel="stylesheet" type="text/css" href="https://cdn.jsdelivr.net/npm/botman-web-widget@0/build/assets/css/chat.min.css">
</head>

<body>
    <script id="botmanWidget" src='https://cdn.jsdelivr.net/npm/botman-web-widget@0/build/js/chat.js'></script>
</body>
   
</html>

The html code above contains the link to botman css and javascript which will help style the widget.

B)

chat.php hosts the php code we will use in getting messages for the bot to listen and reply to .

Open chat.php and copy this ....

     <?php
   require_once 'vendor/autoload.php';

   use BotMan\BotMan\BotMan;
   use BotMan\BotMan\BotManFactory;
   use BotMan\BotMan\Drivers\DriverManager;
   
   $config = [
    // Your driver-specific configuration
    // "telegram" => [
    //    "token" => "TOKEN"
    // ]
];

   DriverManager::loadDriver(\BotMan\Drivers\Web\WebDriver::class);

   $botman = BotManFactory::create($config);

  // Give the bot something to listen for.
$botman->hears('Hello', function (BotMan $bot) {
    $bot->reply('Hello too');
});

$botman->fallback(function($bot) {
    $bot->reply('Sorry, I did not understand these commands. Here is a list of commands I understand: ...');
});

// Start listening
$botman->listen();

As you can see from the above ... we have use used the botman library in chat.php to create our own bot instance ... which provides our bot with a hearing capability and replying back to what it heard.

  • I required the vendor autoload file installed via composer.
  • Then required the various Botman instance we will use for this tutorial.
  • DriverManager::loadDriver(\BotMan\Drivers\Web\WebDriver::class);
    This line of code invokes the botman web instance ... Other Instance may include ( Telegram, Facebook, Slack")
  • $botman = BotManFactory::create($config); here we create our own BotManFactory.
  • $botman->listen(); this functions listens to any incoming message
  • $botman->hears('Hello', function (BotMan $bot){ } is used to define what our bot listens to then interpreting it before replying.
  • $botman->reply(); Our bot is now able to reply any incoming message it hears .
  • $botman->fallback(function($bot) { } For any message our bot listens too any does not hear ... We can include a fallback reply for it.
C)

Now in our index.php we have to include 2 script tag ... which will call our chat.html and chat.php files.
In the body tag of the index.php include this

<script>
        var botmanWidget = {
            frameEndpoint: '/chat.html',
            introMessage: 'Hello, I am a Chatbot',
            chatServer : 'chat.php', 
            title: 'My Chatbot', 
            mainColor: '#456765',
            bubbleBackground: '#ff76f4',
            aboutText: '',
            bubbleAvatarUrl: '',
        }; 
    </script>
        <script src='https://cdn.jsdelivr.net/npm/botman-web-widget@0/build/js/widget.js'></script>

  • The first script tag is an object used to define custom properties for our botman widget.
    FrameEndPoint defines where our widget which calls the chat.html file .... ChatServer
    receives all incoming messages and send to the bot to listen to and waits for it reply.

Viewing my index.php on the browser using a local server ... my page looks like this

image.png

image.png

This is Cool Right!....

STEP 5

So far .... we can now see our chat interface ... For this step I'll implement a simple time query for our chatbot to listen.

Let's say we ask our chatbot .... What's the time in Lagos located in Africa and it replies with the time ... cool right.

Okay open your chat.php and add this new hearing capability for our chatbot


$botman->hears('what is the time in {city} located in {continent}' , function (BotMan $bot,$city,$continent) {
     date_default_timezone_set("$continent/$city");
      $reply = "The time in ".$city." ".$continent." is ".date("h:i:sa");
    $bot->reply($reply);
});

Let's try this in the browser:
image.png

Hope you Learnt something from this tutorial

To add more features to your chatbot I recommend you read the botman documentaion.

Checkout the repository of this tutorial here

And also a live demo of this tutorial here also



Posted on Utopian.io - Rewarding Open Source Contributors

Sort:  

Thank you for your contribution, yet it cannot be accepted for the following reasons:

  • I am not sure I understand the meaning of this sentence in your tutorial: "If you are in the HNGInternship 4.0, and you are reading this, it might be very useful to complete the stage 4 task ."
  • You have not explained well the content of the code you asked your reader to simply copy paste for botman to function. Further tutorials need to be well explained and better detailed.

Need help? Write a ticket on https://support.utopian.io.
Chat with us on Discord.

[utopian-moderator]