diff options
-rw-r--r-- | composer.json | 28 | ||||
-rw-r--r-- | src/bot.php | 82 | ||||
-rw-r--r-- | test/components/communication.php | 17 | ||||
-rw-r--r-- | test/components/engine.php | 66 | ||||
-rw-r--r-- | test/components/footer.php | 9 | ||||
-rw-r--r-- | test/components/navbar.php | 36 | ||||
-rw-r--r-- | test/components/results.php | 20 | ||||
-rw-r--r-- | test/components/settings.php | 24 | ||||
-rw-r--r-- | test/index.php | 39 | ||||
-rw-r--r-- | test/javascript.js | 3 | ||||
-rw-r--r-- | test/style.css | 38 |
11 files changed, 362 insertions, 0 deletions
diff --git a/composer.json b/composer.json new file mode 100644 index 0000000..1896994 --- /dev/null +++ b/composer.json @@ -0,0 +1,28 @@ +{
+ "name": "valentineus/Module-III-API",
+ "version": "1.0.0",
+ "type": "library",
+ "description": "Small module to work with artificial intelligence of iii.ru",
+ "license": "MIT",
+ "homepage": "https://github.com/valentineus/Module-III-API",
+ "authors": [
+ {
+ "name": "Paul Belinsky",
+ "email": "vskyd1@gmail.com",
+ "homepage": "https://blog.vskyd1.ru/",
+ "role": "Developer"
+ },
+ {
+ "name": "Valentin Popov",
+ "email": "valentineus@gmail.com",
+ "homepage": "https://github.com/valentineus",
+ "role": "Developer"
+ }
+ ],
+ "support": {
+ "email": "valentineus@gmail.com",
+ },
+ "require": {
+ "php": ">=5.6.21"
+ }
+}
diff --git a/src/bot.php b/src/bot.php new file mode 100644 index 0000000..c04bb1c --- /dev/null +++ b/src/bot.php @@ -0,0 +1,82 @@ +<?php
+ class Bot {
+ protected $key = null;
+ protected $session = null;
+ private $salt = 'some very-very long string without any non-latin characters due to different string representations inside of variable programming languages';
+
+ /**
+ * @param $key - Ключ из урла после создания инфа
+ */
+ public function __construct($key) {
+ $this->key = $key;
+ }
+
+ /**
+ * @param null $session - Идентификатор сессии существующей, если нет то создается новая
+ * @return string Идентификатор текущей сессии
+ */
+ public function session($session = null) {
+ if ($session === null) {
+ $response = file_get_contents('http://iii.ru/api/2.0/json/Chat.init/'.$this->key.'/');
+ $this->session = $this->decode($response)->result->cuid;
+ } else {
+ $this->session = $session;
+ }
+
+ return $this->session;
+ }
+
+ /**
+ * ОТправить сообщение боту
+ * @param string $message Сообщение
+ * @return string Ответ
+ */
+ public function say($message) {
+ $request = '["'.$this->session.'","'.$message.'"]';
+ $myCurl = curl_init();
+ curl_setopt_array($myCurl, array(
+ CURLOPT_URL => 'http://iii.ru/api/2.0/json/Chat.request',
+ CURLOPT_RETURNTRANSFER => true,
+ CURLOPT_POST => true,
+ CURLOPT_POSTFIELDS => $this->encode($request)
+ ));
+ $response = curl_exec($myCurl);
+ curl_close($myCurl);
+
+ return $this->decode($response)->result->text->tts;
+ }
+
+ /**
+ * Кодирование сообщения
+ * @param $message
+ * @return string
+ */
+ private function encode($message) {
+ $message = base64_encode($message);
+ $ml = strlen($message);
+ $kl = strlen($this->salt);
+ $encoded = "";
+ for ($i = 0; $i < $ml; $i++) {
+ $encoded = $encoded . ($message[$i] ^ $this->salt[$i % $kl]);
+ }
+
+ return base64_encode($encoded);
+ }
+
+ /**
+ * Декодирование сообщения
+ * @param $message
+ * @return mixed|null
+ */
+ private function decode($message) {
+ $msg = base64_decode($message);
+ $ml = strlen($msg);
+ $kl = strlen($this->salt);
+ $decoded = "";
+ for ($i = 0; $i < $ml; $i++) {
+ $decoded.= ($msg[$i] ^ $this->salt[$i % $kl]);
+ }
+
+ return json_decode(base64_decode($decoded));
+ }
+ }
diff --git a/test/components/communication.php b/test/components/communication.php new file mode 100644 index 0000000..3f00204 --- /dev/null +++ b/test/components/communication.php @@ -0,0 +1,17 @@ +<!-- Home side panel -->
+<form class="form-horizontal" method="post">
+ <div class="row">
+ <!-- Text field -->
+ <div class="col-md-8">
+ <textarea class="form-control" rows="3" name="textarea"></textarea>
+ </div>
+ <!-- Control buttons -->
+ <div class="col-md-4">
+ <button type="submit" class="btn btn-default">Submit</button>
+ <button type="button" class="btn btn-success" data-toggle="modal" data-target="#SettingsModal">Settings</button>
+ <button type="button" class="btn btn-danger">Reset</button>
+ </div>
+ </div><!-- row -->
+</form>
+<br/>
+<!-- End side panel -->
diff --git a/test/components/engine.php b/test/components/engine.php new file mode 100644 index 0000000..bc89d8e --- /dev/null +++ b/test/components/engine.php @@ -0,0 +1,66 @@ +<?php
+function ShowRecord($id) {
+ for ($i=0; $i < $id; $i++) {
+ $cookie = json_decode($_COOKIE['TALK'.$i], true);
+ echo("<tr>");
+ echo("<td>".$cookie['type']."</td>");
+ echo("<td>".$cookie['textarea']."</td>");
+ echo("<td>".date("H:i:s", $cookie['time'])."</td>");
+ echo("</tr>");
+ }
+ return 0;
+}
+
+ if (isset($_COOKIE['BOT_TOKEN'])) {
+ $BOT_TOKEN = $_COOKIE['BOT_TOKEN'];
+ }
+
+ if (isset($_POST['BOT_TOKEN'])) {
+ unset($_COOKIE); // Clear the session
+ SetCookie("BOT_TOKEN", htmlspecialchars($_POST['BOT_TOKEN']));
+ $BOT_TOKEN = htmlspecialchars($_POST['BOT_TOKEN']);
+ }
+
+ if (isset($BOT_TOKEN)) {
+ define('BOT_TOKEN', $BOT_TOKEN);
+ $bot = new Bot(BOT_TOKEN);
+ if (isset($_COOKIE['BOT_SESSION'])) {
+ $session = $bot->session($_COOKIE['BOT_SESSION']);
+ } else {
+ $session = $bot->session();
+ SetCookie("BOT_SESSION", $session);
+ }
+ if (!isset($session)) { ?>
+ <div class="container">
+ <div class="alert alert-danger" role="alert">Session is not initialized, check the settings!</div>
+ </div>
+ <?php }
+ }
+
+ if (isset($_POST['textarea'])) {
+ $textarea = htmlspecialchars($_POST['textarea']);
+ if (isset($_COOKIE['CURRENT_ID'])) {
+ $current_id = (int)$_COOKIE['CURRENT_ID'];
+ SetCookie('CURRENT_ID', $current_id+1);
+ } else {
+ $current_id = 0;
+ SetCookie('CURRENT_ID', $current_id);
+ }
+
+ $cookie = array(
+ 'type' => 'user',
+ 'textarea' => $textarea,
+ 'time' => time()
+ );
+ SetCookie("TALK".$current_id, json_encode($cookie));
+
+ $current_id = $current_id+1;
+ SetCookie('CURRENT_ID', $current_id+1);
+ $cookie = array(
+ 'type' => 'bot',
+ 'textarea' => $bot->say($textarea),
+ 'time' => time()
+ );
+ SetCookie("TALK".$current_id, json_encode($cookie));
+ }
+?>
diff --git a/test/components/footer.php b/test/components/footer.php new file mode 100644 index 0000000..fa5a161 --- /dev/null +++ b/test/components/footer.php @@ -0,0 +1,9 @@ +<!-- Beginning footer -->
+<footer class="footer">
+ <div class="container">
+ <p class="text-muted">
+ <a href="mailto:valentineus@gmail.com">valentineus@gmail.com</a>
+ </p>
+ </div>
+</footer>
+<!-- End footer -->
diff --git a/test/components/navbar.php b/test/components/navbar.php new file mode 100644 index 0000000..ed858b5 --- /dev/null +++ b/test/components/navbar.php @@ -0,0 +1,36 @@ +<!-- Start navigation bar -->
+<nav class="navbar navbar-default navbar-fixed-top">
+ <div class="container">
+ <div class="collapse navbar-collapse">
+ <ul class="nav navbar-nav">
+ <li>
+ <!-- Home project -->
+ <a href="https://github.com/valentineus/Module-III-API"><span class="github" aria-hidden="true"></span> GitHub.com</a>
+ </li>
+ </ul>
+ <!-- The right side of the navigation bar -->
+ <ul class="nav navbar-nav navbar-right">
+ <li>
+ <p class="navbar-text" data-toggle="popover" data-placement="auto" data-trigger="hover" data-content="Cookies must be enabled in your browser!"><?php
+ // Check the ability to use Cookie
+ if (SetCookie("TestCookie", "Success")) { ?>
+ <span class="glyphicon glyphicon-ok" aria-hidden="true"></span>
+ <?php } else { ?>
+ <span class="glyphicon glyphicon-remove" aria-hidden="true"></span>
+ <?php }
+ ?> Cookie</p>
+
+ <p class="navbar-text" data-toggle="popover" data-placement="auto" data-trigger="hover" data-content="Before the work necessary to configure!"><?php
+ // Checking the portal settings
+ if (isset($_COOKIE['BOT_TOKEN']) OR isset($_POST['BOT_TOKEN'])) { ?>
+ <span class="glyphicon glyphicon-ok" aria-hidden="true"></span>
+ <?php } else { ?>
+ <span class="glyphicon glyphicon-remove" aria-hidden="true"></span>
+ <?php }
+ ?> Settings</p>
+ </li>
+ </ul><!-- navbar-right -->
+ </div>
+ </div><!-- container -->
+</nav>
+<!-- End navigation bar -->
diff --git a/test/components/results.php b/test/components/results.php new file mode 100644 index 0000000..def09b1 --- /dev/null +++ b/test/components/results.php @@ -0,0 +1,20 @@ +<div class="row">
+ <div class="col-md-12">
+ <table class="table table-striped">
+ <tr>
+ <th>#</th>
+ <th>Text</th>
+ <th>Date</th>
+ </tr>
+ <?php
+ if (isset($current_id)) {
+ ShowRecord($current_id);
+ } elseif (isset($_COOKIE['CURRENT_ID'])) {
+ ShowRecord((int)$_COOKIE['CURRENT_ID']);
+ } else {
+ echo("Error!");
+ }
+ ?>
+ </table>
+ </div>
+</div>
diff --git a/test/components/settings.php b/test/components/settings.php new file mode 100644 index 0000000..fe8e5ff --- /dev/null +++ b/test/components/settings.php @@ -0,0 +1,24 @@ +<!-- Start pop-up window for the settings -->
+<div class="modal fade" id="SettingsModal" tabindex="-1" role="dialog" aria-labelledby="SettingsModal">
+ <div class="modal-dialog" role="document">
+ <div class="modal-content"> + <form class="form-horizontal" method="post">
+ <div class="modal-body">
+ <!-- Elements of a modal window -->
+ <div class="form-group">
+ <label for="inputPassword" class="col-sm-2 control-label">ID:</label>
+ <div class="col-sm-10">
+ <input type="text" class="form-control" id="inputPassword" name="BOT_TOKEN" placeholder="109cd867-0ef3-4473-af71-7543a9b2fccd">
+ </div>
+ </div>
+ </div>
+ <!-- The window control buttons -->
+ <div class="modal-footer">
+ <button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
+ <button type="submit" class="btn btn-success">Save changes</button>
+ </div> + </form>
+ </div><!-- modal-content -->
+ </div><!-- modal-dialog -->
+</div>
+<!-- End pop-up window for the settings -->
diff --git a/test/index.php b/test/index.php new file mode 100644 index 0000000..dd44afc --- /dev/null +++ b/test/index.php @@ -0,0 +1,39 @@ +<!DOCTYPE html>
+<html>
+ <head>
+ <!-- Connecting library jQuery -->
+ <script src="https://code.jquery.com/jquery-3.1.0.slim.min.js" integrity="sha256-cRpWjoSOw5KcyIOaZNo4i6fZ9tKPhYYb6i5T9RSVJG8=" crossorigin="anonymous"></script>
+ <!-- Connecting library Bootstrap -->
+ <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous">
+ <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap-theme.min.css" integrity="sha384-rHyoN1iRsVXV4nD0JutlnGaslCJuC7uwjduW9SVrLvRYooPp2bWYgmgJQIXwl/Sp" crossorigin="anonymous">
+ <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha384-Tc5IQib027qvyjSMfHjOMaLkfuWVxZxUPnCJA7l2mCWNIpG9mGCD8wGNIcPD7Txa" crossorigin="anonymous"></script>
+ <!-- Custom styles -->
+ <link href="style.css" rel="stylesheet">
+ <!-- Custom JavaScript -->
+ <script type="text/javascript" src="javascript.js"></script>
+ <!-- Meta -->
+ <meta charset="utf-8">
+ <meta name="robots" content="NONE">
+ <!-- Title -->
+ <title>Testing conversational bot</title>
+ </head>
+ <body>
+ <?php // Connect all of the dependencies
+ include("../src/bot.php");
+ include("components/navbar.php"); // Connect the navigation bar
+ include("components/engine.php"); // Connect the engine project
+ include("components/settings.php"); // Connecting a modal window with the settings
+ ?>
+ <!-- Begin page content -->
+ <div class="container">
+ <div class="page-header">
+ <h1>Communication with the bot</h1>
+ </div>
+ <?php
+ include("components/communication.php");
+ include("components/results.php");
+ ?>
+ </div>
+ <?php include("components/footer.php"); // Connect the bottom panel ?>
+ </body>
+</html>
diff --git a/test/javascript.js b/test/javascript.js new file mode 100644 index 0000000..22e0185 --- /dev/null +++ b/test/javascript.js @@ -0,0 +1,3 @@ +jQuery(function () {
+ $('[data-toggle="popover"]').popover()
+})
diff --git a/test/style.css b/test/style.css new file mode 100644 index 0000000..a2058d8 --- /dev/null +++ b/test/style.css @@ -0,0 +1,38 @@ +html {
+ position: relative;
+ min-height: 100%;
+}
+
+body {
+ margin-bottom: 60px;
+}
+
+body > .container {
+ padding: 60px 15px 0;
+}
+
+textarea.form-control {
+ resize: none;
+}
+
+.footer {
+ background-color: #f5f5f5;
+ position: absolute;
+ height: 60px;
+ width: 100%;
+ bottom: 0;
+}
+
+.container .text-muted {
+ margin: 20px 0;
+}
+
+/* Loaded one icon from GitHub */
+.github {
+ background: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAyRpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMy1jMDExIDY2LjE0NTY2MSwgMjAxMi8wMi8wNi0xNDo1NjoyNyAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RSZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNiAoTWFjaW50b3NoKSIgeG1wTU06SW5zdGFuY2VJRD0ieG1wLmlpZDpFNTE3OEEyQTk5QTAxMUUyOUExNUJDMTA0NkE4OTA0RCIgeG1wTU06RG9jdW1lbnRJRD0ieG1wLmRpZDpFNTE3OEEyQjk5QTAxMUUyOUExNUJDMTA0NkE4OTA0RCI+IDx4bXBNTTpEZXJpdmVkRnJvbSBzdFJlZjppbnN0YW5jZUlEPSJ4bXAuaWlkOkU1MTc4QTI4OTlBMDExRTI5QTE1QkMxMDQ2QTg5MDREIiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOkU1MTc4QTI5OTlBMDExRTI5QTE1QkMxMDQ2QTg5MDREIi8+IDwvcmRmOkRlc2NyaXB0aW9uPiA8L3JkZjpSREY+IDwveDp4bXBtZXRhPiA8P3hwYWNrZXQgZW5kPSJyIj8+m4QGuQAAAyRJREFUeNrEl21ojWEYx895TDPbMNlBK46IUiNmPvHBSUjaqc0H8pF5+aDUKPEBqU2NhRQpX5Rv5jWlDIWlMCv7MMSWsWwmb3tpXub4XXWdPHvc9/Gc41nu+nedc7/8r/99PffLdYdDPsvkwsgkTBwsA/PADJCnzX2gHTwBt8Hl7p537/3whn04XoDZDcpBlk+9P8AFcAghzRkJwPF4zGGw0Y9QS0mAM2AnQj77FqCzrtcwB1Hk81SYojHK4DyGuQ6mhIIrBWB9Xm7ug/6B/nZrBHBegrkFxoVGpnwBMSLR9EcEcC4qb8pP14BWcBcUgewMnF3T34VqhWMFkThLJAalwnENOAKiHpJq1FZgI2AT6HZtuxZwR9GidSHtI30jOrbawxlVX78/AbNfhHlomEUJJI89O2MqeE79T8/nk8nMBm/dK576hZgmA3cp/R4l9/UeSxiHLVIlNm4nFfT0bxyuIj7LHRTKai+zdJobwMKzcZSJb0ePV5PKN+BqAAKE47UlMnERELMM3EdYP/yrd+XYb2mOiYBiQ8OQnoRBlXrl9JZix7D1pHTazu4MoyBcnYamqAjIMTR8G4FT8LuhLsexXYYjICBiqhQBvYb6fLZIJCjPypVvaOoVAW2WcasCnL2Nq82xHJNSqlCeFcDshaPK0twkAhosjZL31QYw+1rlMpWGMArl23SBsZZO58F2tlJXmjOXS+s4WGvpMiBJT/I2PInZ6lIs9/hBsNS1hS6BG0DSqmYEDRlCXQrmy50P1oDRKTSegmNbUsA0zDMwRhPJXeCE3vWLPQMvan6X8AgIa1vcR4AkGZkDR4ejJ1UHpsaVI0g2LInpOsNFUud1rhxSV+fzC9Woz2EZkWQuja7/B+jUrgtIMpy9YCW4n4K41YfzRneW5E1KJTe4B2Zq1Q5EHEtj4U3AfEzR5SVY4l7QYQPJdN2as7RKBF0BPZqqH4VgMAMBL8Byxr7y8zCZiDlnOcEKIPmUpgB5Z2ww5RdOiiRiNajUmWda5IG6WbhsyY2fx6m8gLcoJDJFkH219M3We1+cnda93pfycZpIJEL/s/wSYADmOAwAQgdpBAAAAABJRU5ErkJggg==');
+ background-size: cover;
+ margin: 2px 5px;
+ height: 15px;
+ width: 15px;
+ float:left;
+}
|