บอทใช้การแปลงคำในรูปแบบแรกเพื่อจดจำคำค้นหาของผู้ใช้ได้แม่นยำยิ่งขึ้น เพื่อให้ทำงานได้อย่างถูกต้อง คุณต้องมีพจนานุกรมคำศัพท์ในภาษาที่ต้องการ ชุดนี้เหมาะสำหรับภาษารัสเซีย จำเป็นต้องระบุเส้นทางไปยังพจนานุกรม
$ bot = new alisa ( ' NAME ' );
//Такой используется по умолчанию
$ bot -> setDictionaryPath ( $ _SERVER [ ' DOCUMENT_ROOT ' ] . ' /dicts/ ' );
เซสชัน – ไฟล์ *.json ซึ่งข้อมูลบริการทั้งหมดถูกจัดเก็บไว้ในสาระสำคัญของบทสนทนาเดียว คุณต้องระบุเส้นทางไปยังไดเร็กทอรีที่จะจัดเก็บข้อมูล
$ bot = new alisa ( ' NAME ' );
//Такой используется по умолчанию
$ bot -> setDictionaryPath ( $ _SERVER [ ' DOCUMENT_ROOT ' ] . ' /sessions/ ' );
//Создаем бота. Аргумент – название навыка
$ bot = new alisa ( ' myawesomebot ' );
//Создаем триггер, в качестве аргумента строка с уникальным именем
$ helloTrigger = new Trigger ( ' HELLO ' );
//Привязываем к триггеру токены – в данном случае в одну группу.
//Токены – ключевые слова, объединенные в группы
$ helloTrigger -> linkTokens ([ ' привет ' , ' здравствуйте ' , ' приветсвую ' ]);
$ bayTrigger = new Trigger ( ' bay ' );
$ bayTrigger -> linkTokens ([ ' пока ' , ' до свидания ' , ' прощай ' ]);
//Привязываем триггеры боту
$ bot -> addTrigger ( $ helloTrigger , $ bayTrigger );
//Отправляем ответ, если распознан $helloTrigger
$ bot ->sendResponse( $ helloTrigger , static function (){
//$answer - экземпляр отправляемого ответа
$ answer = new Response ();
$ answer -> addText ( ' Привет! ' );
$ answer -> addText ( ' Доброго времени суток! ' );
//обязательно возвращаем объект Response
return $ answer ;
);
//Отправляем ответ, если распознан $bayTrigger
$ bot ->sendResponse( $ bayTrigger , static function (){
$ answer = new Response ();
$ answer -> addText ( ' Прошай! ' );
$ answer -> addText ( ' Всего доброго ' );
//обязательно возвращаем объект Response
return $ answer ;
);
ตามโปรโตคอล บอทจะต้องมีทริกเกอร์สำหรับการทักทายและการจัดการข้อผิดพลาดเป็นอย่างน้อย (ขอความช่วยเหลือ)
//Будет вызван автоматически, при первом обращении пользователя к навыку
$ helloTrigger = new Trigger ( ' HELLO ' );
$ helloTrigger -> setAsInit ( true );
//Будет вызыван автоматически, если ну удалось распознать запрос
$ mistakeTrigger = new Trigger ( ' MISTAKE ' );
$ mistakeTrigger -> setAsMistake ( true );
//Отправляем ответ, если распознан $mistakeTrigger
$ bot -> sendResponse ( $ mistakeTrigger , static function (){
$ answer = new Answer ();
$ answer -> addText ( ' Не удалось понять вашу команду :( ' );
return $ answer ;
);
หากไม่ได้กำหนดทริกเกอร์เหล่านี้ บอทจะส่งการตอบกลับเริ่มต้นพร้อมลิงก์ไปยังรายการนี้ และถ้านี่คือเหตุผลว่าทำไมคุณถึงอ่านข้อความนี้ การแกล้งก็ประสบความสำเร็จ
Trigger คือคำสั่งที่บอทต้องตอบสนอง
โทเค็น – คำสำคัญหรือตัวเลือกการสืบค้น (ขึ้นอยู่กับประเภทการจดจำที่เลือก)
โหมดนี้ใช้การเปรียบเทียบกลุ่มโทเค็นตามลำดับ โดยเลือกเฉพาะตัวเลือกที่เหมาะสมเท่านั้น การแยกวิเคราะห์จะดำเนินการจากซ้ายไปขวา - หากกลุ่มแรกไม่ผ่านการค้นหา กลุ่มที่เหลือจะไม่ถูกจัดเรียง และบอทจะเริ่มดูทริกเกอร์ถัดไป เมื่อป้อนทุกกลุ่มเป็นครั้งแรก ทริกเกอร์จะถูกทำเครื่องหมายว่ารู้จัก มิฉะนั้นจะไม่มีส่วนร่วมในการวิเคราะห์
$ greenTea -> linkTokens ([ ' дай ' , ' хочу ' , ' налей ' ],[ ' чай ' ],[ ' зеленый ' ]);
$ blackTea -> linkTokens ([ ' дай ' , ' хочу ' , ' налей ' ],[ ' чай ' ],[ ' черный ' , ' индийский ' ]);
$ coffeTrigger -> linkTokens ([ ' дай ' , ' хочу ' , ' налей ' ],[ ' кофе ' ]);
เมื่อร้องขอ "โปรดเติมชาดำ" $blackTea จะทำงาน; เมื่อถามว่า “ฉันไม่มีแรงที่จะอยากกินกาแฟที่เติมพลังนี้” – $coffeTrigger;
ข้อดี:
จุดด้อย:
ต่างจาก MORPHY_STRICT ตรงที่คำหลักจะถูกกำหนดโดยอัตโนมัติ แต่ต้องระบุตัวเลือกการสืบค้นหลายตัวเลือก ทริกเกอร์ทั้งหมดจะรวมอยู่ในการวิเคราะห์ โดยจะเลือกทริกเกอร์ที่ตรงกับคำขอมากที่สุดสำหรับทริกเกอร์ที่รู้จัก
$ greenTea -> linkTokens ([ ' Налей зеленого чая ' ],[ ' Хочу зеленого чая ' ],[ ' Дай зеленый чай ' ]);
$ blackTeas -> linkTokens ([ ' Налей чергого чая ' ],[ ' Хочу черного чая ' ],[ ' Дай черный чай ' ]);
$ coffeTrigger -> linkTokens ([ ' Налей кофе ' ],[ ' Хочу кофе ' ],[ ' Дай кофе ' ]);
ข้อดี:
จุดด้อย:
ในกรณีที่ใช้บอทเพื่อดำเนินการคำสั่งตามลำดับ คุณสามารถผูกทริกเกอร์ถัดไปเข้ากับทริกเกอร์ได้ ตัวอย่างเช่น หากคุณต้องการรวบรวมข้อมูลใด ๆ จากผู้ใช้ เช่น ชื่อ นามสกุล ฯลฯ
// Декларируем триггеры
$ nameTrigger = new Trigger ( ' NAME ' );
$ sNameTrigger = new Trigger ( ' SECOND_NAME ' );
$ yoTrigger = new Trigger ( ' YEARS ' );
$ personTrigger = new Trigger ( ' PERSON ' );
// Назначаем токены для триггера
$ nameTrigger -> setTokens ([ ' давай ' , ' хочу ' , ' может ' ],[ ' знакомиться ' , ' познакомиться ' , ' представлюсь ' ]);
// Привязываем следующие триггеры
$ nameTrigger -> nextDelegate ( $ sNameTrigger );
$ sNameTrigger -> nextDelegate ( $ yoTrigger );
$ yoTrigger -> nextDelegate ( $ personTrigger );
// Обрабочтик запроса. Сработает если пользователь произнес "Давай познакомимся"
$ bot -> sendResponse ( $ nameTrigger , static function () use ( $ bot ){
$ answer = new Response ();
$ answer -> addText ( ' Какое твое имя? ' );
return $ answer ;
});
// После шага $nameTrigger сработает обработчик $sNameTrigger
$ bot -> sendResponse ( $ sNameTrigger , static function () use ( $ bot ){
$ answer = new Response ();
$ answer -> addText ( ' А фамилия? ' );
return $ answer ;
});
// После шага $sNameTrigger сработает обработчик $yoTrigger
$ bot -> sendResponse ( $ yoTrigger , static function () use ( $ bot ){
$ answer = new Response ();
$ answer -> addText ( ' Сколько тебе лет? ' );
return $ answer ;
});
สำหรับแต่ละทริกเกอร์ คุณต้องสร้างตัวจัดการที่มีคำถาม เมื่อผู้ใช้ร้องขอ “เอาล่ะ มาทำความคุ้นเคยกันเถอะ” ทริกเกอร์ $nameTrigger จะเริ่มทำงาน สำหรับทริกเกอร์ $sNameTrigger และ $yoTrigger ไม่จำเป็นต้องใช้โทเค็น (โดยทั่วไปในกรณีนี้จะไม่สามารถทำงานได้เนื่องจากผู้ใช้จะส่งข้อมูลและไม่รู้จักคำสั่งในนั้น) พวกเขาจะถูกเรียกโดยอัตโนมัติ หลังจากนั้นอีก
ทริกเกอร์ไม่เพียงแต่ใช้เป็นวิธีกำหนดคำสั่งของผู้ใช้เท่านั้น แต่ยังใช้ในการรวบรวมข้อมูลอีกด้วย
//$personTrigger – назначен как следующий триггер после $yoTrigger
$ bot -> sendResponse ( $ personTrigger , static function () use ( $ bot ){
//В качестве аргумента строка, уникальное название триггера
$ name = $ bot -> getTriggerData ( ' NAME ' );
$ sName = $ bot -> getTriggerData ( ' SECOND_NAME ' );
$ yo = $ bot -> getTriggerData ( ' YEARS ' );
$ answer = new Answer ();
$ answer -> addText ( " Хорошо { $ name } { $ sName } , я тебя запомнила, и что тебе { $ yo } лет – тоже " );
return $ answer ;
);
บอทจัดเก็บข้อมูลเพียงอินสแตนซ์เดียวสำหรับทริกเกอร์ ดังนั้นจึงสามารถดึงข้อมูลที่ได้รับล่าสุดเท่านั้น
การตอบกลับคือข้อมูลที่บอทส่งไปยังผู้ใช้ทันทีที่ทริกเกอร์ถูกทริกเกอร์
//$personTrigger – назначен как следующий триггер после $yoTrigger
$ bot -> sendResponse ( $ personTrigger , static function () use ( $ bot ){
$ answer = new Answer ();
$ answer -> addText ( ' Один вариант ответа ' , ' Од!ин вари!ант отв!ета ' );
return $ answer ;
);
วิธีการ addText มีสองอาร์กิวเมนต์สตริง อันแรกใช้เพื่อส่งออกข้อความที่จะแสดงต่อผู้ใช้ ส่วนอันที่สองเป็นข้อความเดียวกันในรูปแบบ TTS
เพื่อการโต้ตอบที่ดียิ่งขึ้น ควรใช้ตัวเลือกคำตอบที่เป็นไปได้หลายตัวเลือก ตัวเลือกการจัดส่งจะถูกเลือกแบบสุ่ม
$ bot -> sendResponse ( $ bullshitTrigger , static function () {
$ answer = new Answer ();
$ answer -> addText ( ' Да не может быть! ' );
$ answer -> addText ( ' Чушь собачья! ' );
$ answer -> addText ( ' Не верю! ' );
return $ answer ;
);
คุณสามารถแนบปุ่มเพื่อตอบกลับได้ นี่อาจเป็นลิงก์ไปยังหน้าเว็บหรือปุ่มที่เมื่อคลิกแล้วจะทริกเกอร์ สามารถมีได้หลายปุ่มและประเภทต่างๆ
$ bot -> sendResponse ( $ helloPerson , static function () {
$ answer = new Answer ();
$ answer -> addText ( ' Может познакомимся? ' );
$ buttonY = new Button ( ' Давай ' );
$ answer -> addButton ( $ button );
$ buttonN = new Button ();
$ buttonN -> setTitle ( ' Неа ' );
return $ answer ;
);
ในตัวอย่างนี้ เมื่อคลิกปุ่ม ระบบจะเรียก $nameTrigger จากตัวอย่างในส่วน "การมอบหมาย" ดังนั้น $nameTrigger สามารถเรียกด้วยเสียงของผู้ใช้หรือโดยการกดปุ่มหากผู้ใช้ไม่ได้พูด
บอทของ Alice สามารถแสดงปุ่มให้กับผู้ใช้ในรูปแบบที่แตกต่างกันสองรูปแบบ - เป็นปุ่มที่วางไว้ใต้กล่องโต้ตอบ และเป็นลิงก์ภายในการตอบกลับที่ส่งไป
$ bButton = new Button ( ' Это кнопка ' );
//Будет отображена как кнопка, под диалогом. Со следующем ответом отображена не будет, если ее не привязатели к ответу Response
$ bButton -> setHide ( true );
$ bLink = new Button ( ' Это кнопка, но как ссылка ' )
//Будет отображена в ответе. Даже если пользователь выбирал что-то другие, эта ссылка так и останется в сообщении.
$ bButton-> setHide ( false );
$ bButton = new Button ( ' Это кнопка ' );
* * *
// Можно установить заголовок не в конструкторе, а в методе. Можно использовать как способ изменеия заголовка имеющейся кнопки, тем самым создавая вариативность
$ bButton -> setTitle ( ' Это все еще кнопка ' )
// К кнопке можно добавить ссылку. При клике на нее произойдет переход по адресу в браузере.
$ bButton -> addLink ( ' www.SITENAME.DOMAIN ' );
// Кнопке можно добавить обработчик какого-нибудь тригера. При клике на кнопку бот в первую очередь проверяет есть ли связанный Триггер для кнопки, и если есть – вызывает именно его.
$ bButton -> linkTrigger (Trigger $ trigger );
//Кнопке можно передать какие-нибудь данные, которые можно будет забрать и использовать, если пользователь нажимал на эту кнопку.
$ bButton -> addPayload ([ ' DATA ' => ' SOME_DATA ' ]);
นอกจากข้อมูลที่ผู้ใช้ส่งซึ่งถูกผูกและบันทึกโดยทริกเกอร์แล้ว คุณยังสามารถบันทึกข้อมูลของคุณเองได้อีกด้วย
$ bot ->sendResponse( $ firstRequest , static function () use ( $ bot ) {
* * *
$ bot -> storeCommonData ( ' Черный чай ' , ' TEA ' );
$ bot -> getCommonData ( ' TEA ' ); // Вернет "Черный чай", в т.ч. если пользователь уже перешел к другому запросу
* * *
);
$ bot ->sendResponse( $ secondRequest , static function () use ( $ bot ) {
* * *
$ bot -> getCommonData ( ' TEA ' ); // Вернет "Черный чай", в т.ч. если пользователь уже перешел к другому запросу
* * *
);
ในกรณีที่ทริกเกอร์ไม่เพียงเกี่ยวข้องกับการยอมรับข้อมูลเท่านั้น แต่ยังรวมถึงการตรวจสอบด้วย ควรใช้การวนซ้ำ
//Допустим что код триггера $chooseMeds – "MEDS"
$ bot -> sendResponse ( $ chooseMeds , static function () use ( $ bot ) {
$ answer = new Response ();
//Проверяем, это первичный запрос или цикл?
if ( ! $ bot -> isRepeatedRequest ()) {
//Нет, значит это первичный запрос со стороны пользователя, предлагаем выбор
$ answer -> addText ( ' Какую таблетку ты выберешь, Нео? ' );
//Задаем циклирование, результат будем проверять в этом же триггере
$ bot -> setRepeat ( true );
} else {
//Неправильный выбор?
if ( $ bot -> getTriggerData ( ' MEDS ' ) !== ' Синяя ' ) {
$ answer -> addText ( ' Неверный выбор, Нео ' );
//Задать цикл
$ bot -> setRepeat ( true );
} else {
//Все ок, выход из триггера
$ answer -> addText ( ' Ты сделал правильный выбор о-о ' );
}
}
return $ answer ;
});