diff options
author | valentineus <valentineus@gmail.com> | 2016-09-14 00:30:05 +0300 |
---|---|---|
committer | valentineus <valentineus@gmail.com> | 2016-09-14 00:30:05 +0300 |
commit | 288980ceb35d5ace51284cfdf176e9acb5f7bb39 (patch) | |
tree | 97b9f6779fae3a630a42951e1a85b7eeced93375 | |
parent | 4d0e9148a3551e0af6fa7476021c9ef052149c71 (diff) | |
download | iii-module-288980ceb35d5ace51284cfdf176e9acb5f7bb39.tar.xz iii-module-288980ceb35d5ace51284cfdf176e9acb5f7bb39.zip |
Alpha version
-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; +} |