def handle_memo(user_id, message_text): if len(message_text.split(" ")) > 10: Mongo.add_memo(memos, g.user, message_text) url = url_for("memo", user_id=user_id, _external=True) FB.send_url(app.config['PAT'], user_id, "I've saved it for you :D", "View Memos", url) Mongo.pop_context(users, g.user) return 'pseudo'
def messaging_events(payload): data = json.loads(payload) messaging_events = data["entry"][0]["messaging"] for event in messaging_events: sender_id = event["sender"]["id"] # Not a message if "message" not in event: yield sender_id, None if "message" in event and "text" in event["message"] and "quick_reply" not in event["message"]: data = event["message"]["text"].encode('unicode_escape') Mongo.log_message(log, sender_id, 'text', data) yield sender_id, {'type':'text', 'data': data, 'message_id': event['message']['mid']} elif "attachments" in event["message"]: if "location" == event['message']['attachments'][0]["type"]: coordinates = event['message']['attachments'][ 0]['payload']['coordinates'] latitude = coordinates['lat'] longitude = coordinates['long'] Mongo.log_message(log, sender_id, 'coordinates', str([latitude, longitude])) yield sender_id, {'type':'location','data':[latitude, longitude],'message_id': event['message']['mid']} elif "audio" == event['message']['attachments'][0]["type"]: audio_url = event['message'][ 'attachments'][0]['payload']['url'] Mongo.log_message(log, sender_id, 'audio', audio_url) yield sender_id, {'type':'audio','data': audio_url, 'message_id': event['message']['mid']} else: Mongo.log_message(log, sender_id, 'other1', event["message"]) yield sender_id, {'type':'text','data':"I don't understand this", 'message_id': event['message']['mid']} elif "quick_reply" in event["message"]: data = event["message"]["quick_reply"]["payload"] yield sender_id, {'type':'quick_reply','data': data, 'message_id': event['message']['mid']} else: Mongo.log_message(log, sender_id, 'other2', event["message"]) yield sender_id, {'type':'text','data':"I don't understand this", 'message_id': event['message']['mid']}
async def on_website_rec(self, data): r""" Usage: -------------- Data recieved from the websocket is encrypted to prevent packet snatching Once a responce has been sent to the website to the bot, if it makes it this event is called. Used to read any info which needs to used to modify the bot Parameters: ----------------- data: :class:`bytes` Encoded instructions / data recieved from the websocket which is connected to the bot """ viable_inst = data.decode('utf-8', errors='ignore') if not viable_inst: self.bot.logging.Debug('[{}] | [{}] -> Recieved info from False Peer-Network.', "time", "date") _format = Mongo._handle(viable_inst) Mongo.execute(_format['data'], mode=_format['mode'])
def memo(user_id): if 'logged_in' in session and session['logged_in']: data = facebook.get('/me').data if 'id' in data and 'name' in data: # user_id = data['id'] user_name = data['name'] else: user_name = None # if not g.web_user: # return redirect(url_for('hi')) # user_name = g.web_user['first_name'] memo_data = Mongo.get_memos_from_user(memos, user_id) return render_template('memo.html', user_name=user_name, memo_data=memo_data)
def processIncoming(user_id, message, just_text=False): # First time user if not Mongo.user_exists(users, user_id): g.user = Mongo.get_user_mongo(users, user_id) return handle_first_time_user(users, g.user) else: g.user = Mongo.get_user_mongo(users, user_id) last_seen = datetime.strptime(g.user['last_seen'],"%Y-%m-%d %H:%M:%S") recent5min = datetime.now() - timedelta(minutes=5) if last_seen < recent5min: Mongo.update_last_seen(users, g.user) contextData = g.user['contexts'] # Text message type ========================================================= if just_text or message['type'] == 'text': # just_text is transcribe audio message_text = message if just_text else message['data'] if dev_area(message_text): # go through development codes return 'pseudo' if message_text.lower() == "help": handle_help(user_id) return 'pseudo' if message_text[-1] != ".": # help separate sentence for parsetree dotted_message = message_text + "." s = parsetree(dotted_message, relations=True, lemmata=True) sentence = s[0] nounPhrase = NLP.findNounPhrase(sentence) if NLP.isAskingBotInformation(sentence): return NLP.handleBotInfo(sentence) if contextData is not None and len(contextData) > 0: context = contextData[-1] if NLP.isDismissPreviousRequest(message_text): Mongo.pop_context(users, g.user) return "Sure, no problem" # Find food functionality if context['context'] == 'find-food': return handle_find_food(user_id, context, sentence, nounPhrase, message, message_text, 'receive_location_text') elif context['context'] == 'yelp-rename': handle_yelp_rename(user_id, g.user, context, message_text) Mongo.pop_context(users, g.user) # pop yelp-rename return "Ta da! %s is now in my cloudy memory :D"%(message_text) elif context['context'] == 'create-memo': return handle_memo(user_id, message_text) else: if NLP.isGreetings(message_text): greeting = "%s %s :D"%(NLP.sayHiTimeZone(g.user), g.user['first_name']) FB.send_message(app.config['PAT'], user_id, greeting) return "How can I help you?" elif NLP.isGoodbye(message_text): return NLP.sayByeTimeZone(g.user) elif NLP.isYelp(sentence): print nounPhrase return handle_find_food(user_id, None, sentence, nounPhrase, message, message_text, 'receive_request') elif NLP.isMemoCommandOnly(message_text): data = { 'context': 'create-memo' } Mongo.add_context(users, g.user, data) return "I'm listening, go ahead :D" elif NLP.isMemo(message_text): content = NLP.get_memo_content(message_text) return handle_memo(user_id, content) elif NLP.isGetNews(sentence): keyword = NLP.getNewsQuery(sentence) FB.send_message(app.config['PAT'], user_id, "Scanning %s documents on the Internet B-)"%(random.randint(9999,999999)*random.randint(9999,999999)+random.randint(1,9)) ) FB.show_typing(app.config['PAT'], user_id) posts = News.get_trending_news(keyword) FB.show_typing(app.config['PAT'], user_id, 'typing_off') # Log if there's no result to analyze if len(posts) == 0: FB.send_message(app.config['PAT'], user_id, "Sorry, I can't find any news for that :(") Mongo.log_message(log, user_id, 'no_news', keyword) else: FB.send_trending_news(app.config['PAT'], user_id, posts) return 'pseudo' else: # Log this message for categorization later Mongo.log_message(uncategorized_messages, user_id, "text", message_text) try: response = simSimi.getConversation(message_text)['response'] bad_times = 0 while NLP.badWords(response): bad_times += 1 print response response = simSimi.getConversation(message_text)['response'] if bad_times == 5: return "Hmm... I can't think of anything witty enough to respond to that :P" if 'simsimi' in response.lower(): response = response.lower().replace("simsimi", "Optimist Prime") return response except simsimi.SimSimiException as e: print e return # return None will trigger a bot confusion response # ==/ END Text message type ===================================================== # Location message type ========================================================= elif message['type'] == 'location': FB.send_message(app.config['PAT'], user_id, "I've received location (%s,%s) (y)"%(message['data'][0],message['data'][1])) if contextData is not None and len(contextData) > 0: context = contextData[-1] if 'context' in context and context['context'] == 'find-food': return handle_find_food(user_id, context, None, None, message, None, 'receive_location_gps') else: return 'pseudo' # ==/ END Location message type ================================================== # Audio message type ========================================================= elif message['type'] == 'audio': audio_url = message['data'] # Get text from audio try: message_text = STT.transcribe(audio_url) if message_text == "" or message_text == None: return # if 'DISPLAY_STT_RESULT' in os.environ and os.environ['DISPLAY_STT_RESULT'] != 0: print message_text except Exception, e: message_text = "Sorry I can't process that now :(" FB.send_message(app.config['PAT'], user_id, message_text) print e return # Begin processing audio command message_text = message_text.decode('utf-8') return processIncoming(user_id, message_text, True)
def handle_messages(): # print "Handling Messages" payload = request.get_data() if app.config['PRINT_INCOMING_PAYLOAD']: print payload token = app.config['PAT'] webhook_type = get_type_from_payload(payload) # Handle Postback # Developer-defined postbacks # Currently in use: Help button (in Persistent Menu), and Getting Started button (first-time users will see this) if webhook_type == 'postback': for sender_id, postback_payload in postback_events(payload): if postback_payload == 'OPTIMIST_HELP': handle_help(sender_id) elif postback_payload == 'OPTIMIST_GET_STARTED': if not Mongo.user_exists(users, sender_id): g.user = Mongo.get_user_mongo(users, sender_id) return handle_first_time_user(users, g.user) # Handle messages elif webhook_type == 'message': for sender_id, message in messaging_events(payload): # Only process message in here if not message: return "ok" # Handle Facebook's bug when receiving long audio # The bug: The app keeps receiving the same POST request # This acts as a rescue exit signal global temp_message_id mid = message['message_id'] if mid == temp_message_id: return 'ok' temp_message_id = mid # Start processing valid requests if app.config['PRINT_INCOMING_MESSAGE']: print "User ID: %s\nMessage:%s" % (sender_id, message) try: FB.show_typing(token, sender_id) response = processIncoming(sender_id, message) FB.show_typing(token, sender_id, 'typing_off') if response is not None and response != 'pseudo': # 'pseudo' is an "ok" signal for functions that sends response on their own # without returning anything back this function print response FB.send_message(token, sender_id, response) elif response != 'pseudo': if NLP.randOneIn(7): FB.send_message(token, sender_id, NLP.oneOf(NLP.no_response)) FB.send_picture(token, sender_id, 'https://monosnap.com/file/I6WEAs2xvpZ5qTNmVauNguEzcaRrnI.png') except Exception, e: print e traceback.print_exc() FB.send_message(app.config['PAT'], sender_id, NLP.oneOf(NLP.error)) Mongo.pop_context(users, g.user) if NLP.randOneIn(7): FB.send_picture(app.config['PAT'], sender_id, 'https://monosnap.com/file/3DnnKT60TkUhF93dwjGbNQCaCUK9WH.png')
# ==/ End Audio message type ==================================================== # Quick Reply message type ====================================================== elif message['type'] == 'quick_reply': context = contextData[-1] cmd = message['data'] return handle_quick_reply(user_id, context, cmd) # ==/ END Quick Reply message type ================================================== # Unrecognizable incoming, remove context and reset all data to start afresh else: Mongo.pop_context(users, g.user) Mongo.reset_yelp_offset(users, g.user) # Get type of webhook # Current support: message, postback # Reference: https://developers.facebook.com/docs/messenger-platform/webhook-reference/message-received def get_type_from_payload(payload): data = json.loads(payload) if "postback" in data["entry"][0]["messaging"][0]: return "postback" elif "message" in data["entry"][0]["messaging"][0]: return "message" def postback_events(payload):
def handle_yelp_rename(user_id, user, context, name): Mongo.add_yelp_location_history(users, user, context['coordinates'], name)
def handle_find_food(user_id, context, sentence, nounPhrase, message, incomingMessage, stage, location_from_memory=0): if stage == 'receive_request': # "Stage 1" contextNow = { 'context': 'find-food', 'location': None, 'coordinates': None, 'terms': nounPhrase, 'location_from_memory': location_from_memory } Mongo.add_context(users, g.user, contextNow) FB.send_message(app.config['PAT'], user_id, "Can you send me your location? :D") if len(g.user['yelp_location_history']) > 0: FB.send_quick_replies_yelp_suggest_location( app.config['PAT'], user_id, get_recent_locations_yelp()) return 'pseudo' elif stage == 'receive_location_gps': # "Stage 2-GPS" if location_from_memory == 1: Mongo.update_context(users, g.user, 'find-food', 'location_from_memory', 1) location = message['data'] Mongo.update_context(users, g.user, 'find-food', 'coordinates', location) FB.send_message(app.config['PAT'], user_id, NLP.oneOf(NLP.looking_replies)) FB.show_typing(app.config['PAT'], user_id) result = yelp_search(context['terms'], None, location) FB.show_typing(app.config['PAT'], user_id, 'typing_off') if result['status'] == 1: FB.send_message( app.config['PAT'], user_id, "Okay, I've found %s places:" % (len(result['businesses']))) FB.send_yelp_results(app.config['PAT'], user_id, result['businesses']) FB.send_quick_replies_yelp_search(app.config['PAT'], user_id) return 'pseudo' else: return "Sorry I couldn't find anything :(" elif stage == 'receive_location_text': # "Stage 2 - Text" if context['location'] == None and context['coordinates'] == None: context['location'] = nounPhrase try: geolocator = Nominatim() location_lookup = geolocator.geocode(nounPhrase) coords = [location_lookup.latitude, location_lookup.longitude] Mongo.update_context(users, g.user, 'find-food', 'coordinates', coords) Mongo.update_context(users, g.user, 'find-food', 'location', nounPhrase) FB.show_typing(app.config['PAT'], user_id) FB.send_message(app.config['PAT'], user_id, NLP.oneOf(NLP.looking_replies)) result = yelp_search(context['terms'], None, coords) except Exception, e: print e Mongo.update_context(users, g.user, 'find-food', 'location', nounPhrase) FB.send_message(app.config['PAT'], user_id, NLP.oneOf(NLP.looking_replies)) result = yelp_search(context['terms'], nounPhrase) FB.show_typing(app.config['PAT'], user_id, 'typing_off') if result['status'] == 1: # Successful search FB.send_message( app.config['PAT'], user_id, "Okay, I've found %s places:" % (len(result['businesses']))) FB.send_yelp_results(app.config['PAT'], user_id, result['businesses']) FB.send_quick_replies_yelp_search(app.config['PAT'], user_id) return 'pseudo' else: Mongo.pop_context(users, g.user) return "Sorry I can't find any results for that :(" # Follow up? else: Mongo.pop_context(users, g.user) return
def processIncoming(user_id, message, just_text=False): # First time user if not Mongo.user_exists(users, user_id): g.user = Mongo.get_user_mongo(users, user_id) return handle_first_time_user(users, g.user) else: g.user = Mongo.get_user_mongo(users, user_id) last_seen = datetime.strptime(g.user['last_seen'], "%Y-%m-%d %H:%M:%S") recent5min = datetime.now() - timedelta(minutes=5) if last_seen < recent5min: Mongo.update_last_seen(users, g.user) contextData = g.user['contexts'] # Text message type ========================================================= if just_text or message['type'] == 'text': # just_text is transcribe audio message_text = message if just_text else message['data'] if dev_area(message_text): # go through development codes return 'pseudo' if message_text.lower() == "help": handle_help(user_id) return 'pseudo' if message_text[-1] != ".": # help separate sentence for parsetree dotted_message = message_text + "." s = parsetree(dotted_message, relations=True, lemmata=True) sentence = s[0] nounPhrase = NLP.findNounPhrase(sentence) if NLP.isAskingBotInformation(sentence): return NLP.handleBotInfo(sentence) if contextData is not None and len(contextData) > 0: context = contextData[-1] if NLP.isDismissPreviousRequest(message_text): Mongo.pop_context(users, g.user) return "Sure, no problem" # Find food functionality if context['context'] == 'find-food': return handle_find_food(user_id, context, sentence, nounPhrase, message, message_text, 'receive_location_text') elif context['context'] == 'yelp-rename': handle_yelp_rename(user_id, g.user, context, message_text) Mongo.pop_context(users, g.user) # pop yelp-rename return "Ta da! %s is now in my cloudy memory :D" % ( message_text) elif context['context'] == 'create-memo': return handle_memo(user_id, message_text) else: if NLP.isGreetings(message_text): greeting = "%s %s :D" % (NLP.sayHiTimeZone( g.user), g.user['first_name']) FB.send_message(app.config['PAT'], user_id, greeting) return "How can I help you?" elif NLP.isGoodbye(message_text): return NLP.sayByeTimeZone(g.user) elif NLP.isYelp(sentence): print nounPhrase return handle_find_food(user_id, None, sentence, nounPhrase, message, message_text, 'receive_request') elif NLP.isMemoCommandOnly(message_text): data = {'context': 'create-memo'} Mongo.add_context(users, g.user, data) return "I'm listening, go ahead :D" elif NLP.isMemo(message_text): content = NLP.get_memo_content(message_text) return handle_memo(user_id, content) elif NLP.isGetNews(sentence): keyword = NLP.getNewsQuery(sentence) FB.send_message( app.config['PAT'], user_id, "Scanning %s documents on the Internet B-)" % (random.randint(9999, 999999) * random.randint(9999, 999999) + random.randint(1, 9))) FB.show_typing(app.config['PAT'], user_id) posts = News.get_trending_news(keyword) FB.show_typing(app.config['PAT'], user_id, 'typing_off') # Log if there's no result to analyze if len(posts) == 0: FB.send_message( app.config['PAT'], user_id, "Sorry, I can't find any news for that :(") Mongo.log_message(log, user_id, 'no_news', keyword) else: FB.send_trending_news(app.config['PAT'], user_id, posts) return 'pseudo' else: # Log this message for categorization later Mongo.log_message(uncategorized_messages, user_id, "text", message_text) try: response = simSimi.getConversation( message_text)['response'] bad_times = 0 while NLP.badWords(response): bad_times += 1 print response response = simSimi.getConversation( message_text)['response'] if bad_times == 5: return "Hmm... I can't think of anything witty enough to respond to that :P" if 'simsimi' in response.lower(): response = response.lower().replace( "simsimi", "Optimist Prime") return response except simsimi.SimSimiException as e: print e return # return None will trigger a bot confusion response # ==/ END Text message type ===================================================== # Location message type ========================================================= elif message['type'] == 'location': FB.send_message( app.config['PAT'], user_id, "I've received location (%s,%s) (y)" % (message['data'][0], message['data'][1])) if contextData is not None and len(contextData) > 0: context = contextData[-1] if 'context' in context and context['context'] == 'find-food': return handle_find_food(user_id, context, None, None, message, None, 'receive_location_gps') else: return 'pseudo' # ==/ END Location message type ================================================== # Audio message type ========================================================= elif message['type'] == 'audio': audio_url = message['data'] # Get text from audio try: message_text = STT.transcribe(audio_url) if message_text == "" or message_text == None: return # if 'DISPLAY_STT_RESULT' in os.environ and os.environ['DISPLAY_STT_RESULT'] != 0: print message_text except Exception, e: message_text = "Sorry I can't process that now :(" FB.send_message(app.config['PAT'], user_id, message_text) print e return # Begin processing audio command message_text = message_text.decode('utf-8') return processIncoming(user_id, message_text, True)
def handle_messages(): # print "Handling Messages" payload = request.get_data() if app.config['PRINT_INCOMING_PAYLOAD']: print payload token = app.config['PAT'] webhook_type = get_type_from_payload(payload) # Handle Postback # Developer-defined postbacks # Currently in use: Help button (in Persistent Menu), and Getting Started button (first-time users will see this) if webhook_type == 'postback': for sender_id, postback_payload in postback_events(payload): if postback_payload == 'OPTIMIST_HELP': handle_help(sender_id) elif postback_payload == 'OPTIMIST_GET_STARTED': if not Mongo.user_exists(users, sender_id): g.user = Mongo.get_user_mongo(users, sender_id) return handle_first_time_user(users, g.user) # Handle messages elif webhook_type == 'message': for sender_id, message in messaging_events(payload): # Only process message in here if not message: return "ok" # Handle Facebook's bug when receiving long audio # The bug: The app keeps receiving the same POST request # This acts as a rescue exit signal global temp_message_id mid = message['message_id'] if mid == temp_message_id: return 'ok' temp_message_id = mid # Start processing valid requests if app.config['PRINT_INCOMING_MESSAGE']: print "User ID: %s\nMessage:%s" % (sender_id, message) try: FB.show_typing(token, sender_id) response = processIncoming(sender_id, message) FB.show_typing(token, sender_id, 'typing_off') if response is not None and response != 'pseudo': # 'pseudo' is an "ok" signal for functions that sends response on their own # without returning anything back this function print response FB.send_message(token, sender_id, response) elif response != 'pseudo': if NLP.randOneIn(7): FB.send_message(token, sender_id, NLP.oneOf(NLP.no_response)) FB.send_picture( token, sender_id, 'https://monosnap.com/file/I6WEAs2xvpZ5qTNmVauNguEzcaRrnI.png' ) except Exception, e: print e traceback.print_exc() FB.send_message(app.config['PAT'], sender_id, NLP.oneOf(NLP.error)) Mongo.pop_context(users, g.user) if NLP.randOneIn(7): FB.send_picture( app.config['PAT'], sender_id, 'https://monosnap.com/file/3DnnKT60TkUhF93dwjGbNQCaCUK9WH.png' )
message_text = message_text.decode('utf-8') return processIncoming(user_id, message_text, True) # ==/ End Audio message type ==================================================== # Quick Reply message type ====================================================== elif message['type'] == 'quick_reply': context = contextData[-1] cmd = message['data'] return handle_quick_reply(user_id, context, cmd) # ==/ END Quick Reply message type ================================================== # Unrecognizable incoming, remove context and reset all data to start afresh else: Mongo.pop_context(users, g.user) Mongo.reset_yelp_offset(users, g.user) # Get type of webhook # Current support: message, postback # Reference: https://developers.facebook.com/docs/messenger-platform/webhook-reference/message-received def get_type_from_payload(payload): data = json.loads(payload) if "postback" in data["entry"][0]["messaging"][0]: return "postback" elif "message" in data["entry"][0]["messaging"][0]: return "message"
def handle_find_food(user_id, context, sentence, nounPhrase, message, incomingMessage, stage, location_from_memory=0): if stage == 'receive_request': # "Stage 1" contextNow = {'context':'find-food', 'location': None, 'coordinates': None, 'terms': nounPhrase, 'location_from_memory': location_from_memory } Mongo.add_context(users, g.user, contextNow) FB.send_message(app.config['PAT'], user_id, "Can you send me your location? :D") if len(g.user['yelp_location_history']) > 0: FB.send_quick_replies_yelp_suggest_location(app.config['PAT'], user_id, get_recent_locations_yelp()) return 'pseudo' elif stage == 'receive_location_gps': # "Stage 2-GPS" if location_from_memory == 1: Mongo.update_context(users, g.user, 'find-food', 'location_from_memory', 1) location = message['data'] Mongo.update_context(users, g.user, 'find-food', 'coordinates', location) FB.send_message(app.config['PAT'], user_id, NLP.oneOf(NLP.looking_replies)) FB.show_typing(app.config['PAT'], user_id) result = yelp_search(context['terms'], None, location) FB.show_typing(app.config['PAT'], user_id, 'typing_off') if result['status'] == 1: FB.send_message(app.config['PAT'], user_id, "Okay, I've found %s places:"%(len(result['businesses']))) FB.send_yelp_results(app.config['PAT'], user_id, result['businesses']) FB.send_quick_replies_yelp_search(app.config['PAT'], user_id) return 'pseudo' else: return "Sorry I couldn't find anything :(" elif stage == 'receive_location_text': # "Stage 2 - Text" if context['location'] == None and context['coordinates'] == None: context['location'] = nounPhrase try: geolocator = Nominatim() location_lookup = geolocator.geocode(nounPhrase) coords = [location_lookup.latitude, location_lookup.longitude] Mongo.update_context(users, g.user, 'find-food', 'coordinates', coords) Mongo.update_context(users, g.user, 'find-food', 'location', nounPhrase) FB.show_typing(app.config['PAT'], user_id) FB.send_message(app.config['PAT'], user_id, NLP.oneOf(NLP.looking_replies)) result = yelp_search(context['terms'], None, coords) except Exception, e: print e Mongo.update_context(users, g.user, 'find-food', 'location', nounPhrase) FB.send_message(app.config['PAT'], user_id, NLP.oneOf(NLP.looking_replies)) result = yelp_search(context['terms'], nounPhrase) FB.show_typing(app.config['PAT'], user_id, 'typing_off') if result['status'] == 1: # Successful search FB.send_message(app.config['PAT'], user_id, "Okay, I've found %s places:"%(len(result['businesses']))) FB.send_yelp_results(app.config['PAT'], user_id, result['businesses']) FB.send_quick_replies_yelp_search(app.config['PAT'], user_id) return 'pseudo' else: Mongo.pop_context(users, g.user) return "Sorry I can't find any results for that :(" # Follow up? else: Mongo.pop_context(users, g.user) return
def handle_quick_reply(user_id, context, cmd): # Yelp YES response to "Do you want more result?" if cmd == 'yelp-more-yes': offset = g.user['yelp_offset'] + 5 Mongo.increment_yelp_offset(users, g.user, 5) # actually update result = yelp_search(context['terms'], context['location'], context['coordinates'], 5, offset) if result['status'] == 1: # Successful search FB.send_message( app.config['PAT'], user_id, "Okay, I've found %s places:" % (len(result['businesses']))) FB.send_yelp_results(app.config['PAT'], user_id, result['businesses']) FB.send_quick_replies_yelp_search(app.config['PAT'], user_id) return 'pseudo' else: Mongo.pop_context(users, g.user) Mongo.reset_yelp_offset(users, g.user) return "That's all I found for now :)" # Yelp NO response to "Do you want more result?" elif cmd == 'yelp-more-no': context = g.user['contexts'][-1] Mongo.reset_yelp_offset(users, g.user) if context['location_from_memory'] == 1: Mongo.pop_context(users, g.user) return "Glad I can help :)" if context['context'] == 'find-food' and context[ 'location'] is not None and context['coordinates'] is not None: latest_location = context['location'] FB.send_quick_replies_yelp_save_location(app.config['PAT'], user_id, latest_location) return 'pseudo' elif context['context'] == 'find-food' and context[ 'coordinates'] is not None and context['location'] is None: # Suggest saving this location FB.send_quick_replies_yelp_save_location(app.config['PAT'], user_id) return 'pseudo' else: Mongo.pop_context(users, g.user) return "Glad I can help :)" # Yelp YES response to "Do you want to save this location" elif cmd == 'yelp-save-location-yes': context = g.user['contexts'][-1] latest_coords = context['coordinates'] latest_location = context['location'] if context['location'] == None: # A search with only coordinates contextNow = { 'context': 'yelp-rename', 'name': 'untitled', 'coordinates': latest_coords, } Mongo.pop_context(users, g.user) # pop find-food context Mongo.add_context(users, g.user, contextNow) return "What do you want to call it? :D" else: Mongo.add_yelp_location_history(users, g.user, latest_coords, latest_location) Mongo.pop_context(users, g.user) Mongo.reset_yelp_offset(users, g.user) return "Ta da! I wrote it to my cloudy memory :D" # Yelp NO response to "Do you want to save this location" elif cmd == 'yelp-save-location-no': Mongo.pop_context(users, g.user) Mongo.reset_yelp_offset(users, g.user) return "OK (y) Hope you like those places I found :D" # Yelp RENAME response to "Do you want to save this location" elif cmd == 'yelp-save-location-rename': context = g.user['contexts'][-1] latest_location = context['location'] latest_coords = context['coordinates'] contextNow = { 'context': 'yelp-rename', 'name': latest_location, 'coordinates': latest_coords, } Mongo.pop_context(users, g.user) # pop find-food context Mongo.add_context(users, g.user, contextNow) return "What do you want to call it? :D" # Yelp choose one of the saved location elif 'yelp-cached-location-' in cmd: idx = int(cmd[-1]) # last character of payload string code location = get_recent_locations_yelp(idx) FB.send_message(app.config['PAT'], user_id, "Looking around %s :D" % (location['name'])) message = {} message['data'] = location['coordinates'] return handle_find_food(user_id, context, None, None, message, None, 'receive_location_gps', 1)
def handle_quick_reply(user_id, context, cmd): # Yelp YES response to "Do you want more result?" if cmd == 'yelp-more-yes': offset = g.user['yelp_offset'] + 5 Mongo.increment_yelp_offset(users, g.user, 5) # actually update result = yelp_search(context['terms'], context['location'], context['coordinates'], 5, offset) if result['status'] == 1: # Successful search FB.send_message(app.config['PAT'], user_id, "Okay, I've found %s places:"%(len(result['businesses']))) FB.send_yelp_results(app.config['PAT'], user_id, result['businesses']) FB.send_quick_replies_yelp_search(app.config['PAT'], user_id) return 'pseudo' else: Mongo.pop_context(users, g.user) Mongo.reset_yelp_offset(users, g.user) return "That's all I found for now :)" # Yelp NO response to "Do you want more result?" elif cmd == 'yelp-more-no': context = g.user['contexts'][-1] Mongo.reset_yelp_offset(users, g.user) if context['location_from_memory'] == 1: Mongo.pop_context(users, g.user) return "Glad I can help :)" if context['context'] == 'find-food' and context['location'] is not None and context['coordinates'] is not None: latest_location = context['location'] FB.send_quick_replies_yelp_save_location(app.config['PAT'], user_id, latest_location) return 'pseudo' elif context['context'] == 'find-food' and context['coordinates'] is not None and context['location'] is None: # Suggest saving this location FB.send_quick_replies_yelp_save_location(app.config['PAT'], user_id) return 'pseudo' else: Mongo.pop_context(users, g.user) return "Glad I can help :)" # Yelp YES response to "Do you want to save this location" elif cmd == 'yelp-save-location-yes': context = g.user['contexts'][-1] latest_coords = context['coordinates'] latest_location = context['location'] if context['location'] == None: # A search with only coordinates contextNow = {'context':'yelp-rename', 'name': 'untitled', 'coordinates': latest_coords, } Mongo.pop_context(users, g.user) # pop find-food context Mongo.add_context(users, g.user, contextNow) return "What do you want to call it? :D" else: Mongo.add_yelp_location_history(users, g.user, latest_coords, latest_location) Mongo.pop_context(users, g.user) Mongo.reset_yelp_offset(users, g.user) return "Ta da! I wrote it to my cloudy memory :D" # Yelp NO response to "Do you want to save this location" elif cmd == 'yelp-save-location-no': Mongo.pop_context(users, g.user) Mongo.reset_yelp_offset(users, g.user) return "OK (y) Hope you like those places I found :D" # Yelp RENAME response to "Do you want to save this location" elif cmd == 'yelp-save-location-rename': context = g.user['contexts'][-1] latest_location = context['location'] latest_coords = context['coordinates'] contextNow = {'context':'yelp-rename', 'name': latest_location, 'coordinates': latest_coords, } Mongo.pop_context(users, g.user) # pop find-food context Mongo.add_context(users, g.user, contextNow) return "What do you want to call it? :D" # Yelp choose one of the saved location elif 'yelp-cached-location-' in cmd: idx = int(cmd[-1]) # last character of payload string code location = get_recent_locations_yelp(idx) FB.send_message(app.config['PAT'], user_id, "Looking around %s :D"%(location['name'])) message = {} message['data'] = location['coordinates'] return handle_find_food(user_id, context, None, None, message, None, 'receive_location_gps', 1)
def define_endpoints(configuration): mongo_config = configuration['mongo'] dal = Mongo.mongo_controller(mongo_config) items_endpoints = Blueprint("crud_api", __name__) @items_endpoints.route("/get_all", methods=["GET", "POST"]) def get_all_items(): results = dal.get_all() response = jsonify({"items": results}) return response @items_endpoints.route("/get", methods=["GET", "POST"]) def get(): item_id = 0 if request.method == "POST": item_id = request.form["item_id"] elif request.method == "GET": item_id = request.args.get('page', default=0, type=int) response = jsonify({"items": "aquí van los items"}) return response @items_endpoints.route("/add", methods=["POST"]) def add(): name = request.form['name'] price = request.form['price'] stock = request.form['stock'] new_item = { 'name': name, 'price': price, 'stock': stock } dal.insert(new_item) response = jsonify({"status": "OK"}) return response @items_endpoints.route("/update", methods=["POST"]) def update(): item_id = ObjectId(request.form['_id']) name = request.form['name'] price = request.form['price'] stock = request.form['stock'] attrs_to_update = { 'name': name, 'price': price, 'stock': stock } dal.update(item_id, attrs_to_update) response = jsonify({"status": "OK"}) return response @items_endpoints.route("/delete", methods=["GET", "POST"]) def delete(): item_id = 0 if request.method == "POST": item_id = ObjectId(request.form['_id']) elif request.method == "GET": item_id = ObjectId(request.args.get('page', default=0, type=str)) dal.delete(item_id) response = jsonify({"status": "OK"}) return response return items_endpoints