mirror of
https://github.com/teloxide/teloxide.git
synced 2025-01-08 19:33:53 +01:00
Fix simple_fsm
This commit is contained in:
parent
7e34007a4d
commit
4002d8fbbc
1 changed files with 41 additions and 18 deletions
|
@ -53,12 +53,39 @@ impl Display for User {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// ============================================================================
|
||||||
|
// [FSM - Finite-State Machine]
|
||||||
|
// ============================================================================
|
||||||
|
|
||||||
|
enum Fsm {
|
||||||
|
Start,
|
||||||
|
FullName,
|
||||||
|
Age,
|
||||||
|
FavouriteMusic,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Default for Fsm {
|
||||||
|
fn default() -> Self {
|
||||||
|
Self::Start
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// ============================================================================
|
||||||
|
// [Our Session type]
|
||||||
|
// ============================================================================
|
||||||
|
|
||||||
|
#[derive(Default)]
|
||||||
|
struct Session {
|
||||||
|
user: User,
|
||||||
|
fsm: Fsm,
|
||||||
|
}
|
||||||
|
|
||||||
// ============================================================================
|
// ============================================================================
|
||||||
// [Control our FSM]
|
// [Control our FSM]
|
||||||
// ============================================================================
|
// ============================================================================
|
||||||
|
|
||||||
type Ctx = SessionHandlerCtx<Message, User>;
|
type Ctx = SessionHandlerCtx<Message, Session>;
|
||||||
type Res = Result<SessionState<User>, RequestError>;
|
type Res = Result<SessionState<Session>, RequestError>;
|
||||||
|
|
||||||
async fn send_favourite_music_types(ctx: &Ctx) -> Result<(), RequestError> {
|
async fn send_favourite_music_types(ctx: &Ctx) -> Result<(), RequestError> {
|
||||||
ctx.bot
|
ctx.bot
|
||||||
|
@ -72,12 +99,14 @@ async fn send_favourite_music_types(ctx: &Ctx) -> Result<(), RequestError> {
|
||||||
async fn start(ctx: Ctx) -> Res {
|
async fn start(ctx: Ctx) -> Res {
|
||||||
ctx.reply("Let's start! First, what's your full name?")
|
ctx.reply("Let's start! First, what's your full name?")
|
||||||
.await?;
|
.await?;
|
||||||
|
ctx.session.state = Fsm::FullName;
|
||||||
Ok(SessionState::Next(ctx.session))
|
Ok(SessionState::Next(ctx.session))
|
||||||
}
|
}
|
||||||
|
|
||||||
async fn full_name(mut ctx: Ctx) -> Res {
|
async fn full_name(mut ctx: Ctx) -> Res {
|
||||||
ctx.reply("What a wonderful name! Your age?").await?;
|
ctx.reply("What a wonderful name! Your age?").await?;
|
||||||
ctx.session.full_name = Some(ctx.update.text().unwrap().to_owned());
|
ctx.session.user.full_name = Some(ctx.update.text().unwrap().to_owned());
|
||||||
|
ctx.session.fsm = Fsm::Age;
|
||||||
Ok(SessionState::Next(ctx.session))
|
Ok(SessionState::Next(ctx.session))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -85,7 +114,8 @@ async fn age(mut ctx: Ctx) -> Res {
|
||||||
match ctx.update.text().unwrap().parse() {
|
match ctx.update.text().unwrap().parse() {
|
||||||
Ok(ok) => {
|
Ok(ok) => {
|
||||||
send_favourite_music_types(&ctx).await?;
|
send_favourite_music_types(&ctx).await?;
|
||||||
ctx.session.age = Some(ok);
|
ctx.session.user.age = Some(ok);
|
||||||
|
ctx.session.fsm = Fsm::FavouriteMusic;
|
||||||
}
|
}
|
||||||
Err(_) => ctx.reply("Oh, please, enter a number!").await?,
|
Err(_) => ctx.reply("Oh, please, enter a number!").await?,
|
||||||
}
|
}
|
||||||
|
@ -96,8 +126,8 @@ async fn age(mut ctx: Ctx) -> Res {
|
||||||
async fn favourite_music(mut ctx: Ctx) -> Res {
|
async fn favourite_music(mut ctx: Ctx) -> Res {
|
||||||
match ctx.update.text().unwrap().parse() {
|
match ctx.update.text().unwrap().parse() {
|
||||||
Ok(ok) => {
|
Ok(ok) => {
|
||||||
ctx.session.favourite_music = Some(ok);
|
ctx.session.user.favourite_music = Some(ok);
|
||||||
ctx.reply(format!("Fine. {}", ctx.session)).await?;
|
ctx.reply(format!("Fine. {}", ctx.session.user)).await?;
|
||||||
Ok(SessionState::Exit)
|
Ok(SessionState::Exit)
|
||||||
}
|
}
|
||||||
Err(_) => {
|
Err(_) => {
|
||||||
|
@ -108,19 +138,12 @@ async fn favourite_music(mut ctx: Ctx) -> Res {
|
||||||
}
|
}
|
||||||
|
|
||||||
async fn handle_message(ctx: Ctx) -> Res {
|
async fn handle_message(ctx: Ctx) -> Res {
|
||||||
if ctx.session.full_name.is_none() {
|
match ctx.session.fsm {
|
||||||
return full_name(ctx).await;
|
Fsm::Start => start(ctx).await,
|
||||||
|
Fsm::FullName => full_name(ctx).await,
|
||||||
|
Fsm::Age => age(ctx).await,
|
||||||
|
Fsm::FavouriteMusic => favourite_music(ctx).await,
|
||||||
}
|
}
|
||||||
|
|
||||||
if ctx.session.age.is_none() {
|
|
||||||
return age(ctx).await;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ctx.session.favourite_music.is_none() {
|
|
||||||
return favourite_music(ctx).await;
|
|
||||||
}
|
|
||||||
|
|
||||||
Ok(SessionState::Exit)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// ============================================================================
|
// ============================================================================
|
||||||
|
|
Loading…
Reference in a new issue