From 52013d1fde52360694f7ef5d8eed43585c8f4337 Mon Sep 17 00:00:00 2001 From: Keuin Date: Mon, 28 Mar 2022 10:12:23 +0800 Subject: Support legacy GET request (for backward compatibility). --- src/web.rs | 22 +++++++++++++++++++++- 1 file changed, 21 insertions(+), 1 deletion(-) (limited to 'src/web.rs') diff --git a/src/web.rs b/src/web.rs index 9ec73fd..dc42bfc 100644 --- a/src/web.rs +++ b/src/web.rs @@ -1,3 +1,4 @@ +use std::collections::HashMap; use std::fmt; use std::fmt::Formatter; @@ -5,6 +6,7 @@ use serde_derive::{Deserialize, Serialize}; use teloxide::{prelude2::*}; use tracing::{debug, error, info, warn}; use warp::{Rejection, Reply}; +use warp::reply::Json; use crate::{Bot, database, DbPool}; @@ -32,8 +34,26 @@ impl fmt::Display for SendMessageResponse { } } +pub async fn get_handler(params: HashMap, db: DbPool, bot: Bot) + -> std::result::Result { + let token = params.get("token"); + let message = params.get("message"); + if token == None || message == None { + return Ok(warp::reply::json(&SendMessageResponse { + success: false, + message: String::from(concat!("Missing parameters. ", + "Usage: GET /?token=&message=")), + })); + } + let message = SendMessage { + token: token.unwrap().clone(), + message: message.unwrap().clone(), + }; + handler(message, db, bot).await +} + pub async fn handler(req: SendMessage, db: DbPool, bot: Bot) - -> std::result::Result { + -> std::result::Result { info!("Income API request: {}", req); let user = database::get_user_by_token(&db, req.token.as_str()).await; -- cgit v1.2.3