сообщения из чата.
Решил копить айдишники сообщений в стэке.
При этом он почему то вообще ничего не записывает туда.
Вводные:
У меня есть такое поле: private final Map<Long, Stack<Integer>> chatHistory;
Во время первого обращения к боту я в него инициализирую стэк, привязывая его к пользователю: chatHistory.put(chatId, new Stack<Integer>());
Дальше вот таким макаром я ПУШу в него сообщения самого бота:
Message sentOut = sender.execute(answer).get();
chatHistory.get(chatId).push(sentOut.getMessageId());
И таким макаром ПУШу сообщения от пользователя:
chatHistory.get(chatId).push(message.getMessageId());
Вот мой первый метод, который ВСЕГДА реагирует на кнопку /start, которую нажали в боте:
private void toStart(long chatId) {
System.out.println("Created new char history stack for user : " + chatId);
chatHistory.put(chatId, new Stack<Integer>());
System.out.println("New stack created and added to HashMap : " + chatHistory.get(chatId));
SendMessage answer = new SendMessage();
answer.setChatId(String.valueOf(chatId));
answer.setText(START_TEXT);
Message sentOut = sender.execute(answer).get();
chatHistory.get(chatId).push(sentOut.getMessageId());
chatStates.put(chatId, AWAITING_CODE);
}
Это показывает, что в ЛЮБОМ случае в стэке должно быть хотя бы одно сообщение, которое отправил сам бот.
На при этом, после того, как сам пользователь ответит ему (то есть уже как минимум 2 сообщения там должно быть), оказывается, что Стек то у меня - пустой.
Вот код, который обрабатывает действия пользователя и выводит содержимое:
System.out.println("chatHistory.get(chatId) = " + chatHistory.get(chatId));
System.out.println("message.getMessageId() = " + message.getMessageId());
System.out.println("message.getText() = " + message.getText());
А вот собссно вывод в консоль:
chatHistory.get(chatId) = []
message.getMessageId() = 550
message.getText() = 1241423
Это вывод, который срабатывает, когда бот получает сообщения от пользователя.
И почему-то, в любом моменте программы, стэк всегда пустой.
тебе поможет только дебагер. Если это не самописный как написали выше, а импортированный из java.util то он 100% работает как нужно
Это из java.util
P.S. Вот в подтверждение слов, что импорт не кривой.
Ну и где ты мапу chat Dictionary инициализируешь? И зачем ты маленькие куски кода скинул? Может ты во время каждого сообщения новый стек записываешь
Инициализирую в конструкторе. Извлекая из дб контекста. private final Map<Long, Stack<Integer>> chatHistory; public ResponseHandler(SilentSender silent, DBContext db, DiscountCardService service) { this.sender = silent; this.service = service; chatStates = db.getMap(CHAT_STATES); builderStates = db.getMap(BUILDER_STATES); dateStates = db.getMap(DATE_STATES); chatHistory = db.getMap(CHAT_HISTORY); }
ResponseHandler где создаётся?
@Autowired public DiscountActivationBot(Environment environment, DiscountCardService service) { super(environment.getProperty("ok_bolt_bot_token"), "ok_bolt_discount_bot"); responseHandler = new ResponseHandler(silent, db, service); } Создаётся в единичном экземпляре. Ибо логи о создании ResponseHandler появляются только один раз. Создаёт его сам Spring.
Стек где создаётся?
https://t.me/javastart/590995 Вот.
Покажи код этого Во время первого обращения к боту я в него инициализирую стэк, привязывая его к пользователю: chatHistory.put(chatId, new Stack<Integer>());
Вот мой первый метод, который ВСЕГДА реагирует на кнопку /start, которую нажали в боте: private void toStart(long chatId) { System.out.println("Created new char history stack for user : " + chatId); chatHistory.put(chatId, new Stack<Integer>()); System.out.println("New stack created and added to HashMap : " + chatHistory.get(chatId)); SendMessage answer = new SendMessage(); answer.setChatId(String.valueOf(chatId)); answer.setText(START_TEXT); Message sentOut = sender.execute(answer).get(); chatHistory.get(chatId).push(sentOut.getMessageId()); chatStates.put(chatId, AWAITING_CODE); } Вот. Это из того сообщения
А как вызывается этот метод?
public Ability startBot() { return Ability .builder() .name("start") .info(Constants.START_DESCRIPTION) .locality(USER) .privacy(PUBLIC) .action(ctx -> responseHandler.replyToStart(ctx.chatId(), ctx.update().getMessage())) .build(); } Вызывается он с помощью либы telegrambots-abilities. Во время билда Ability в разделе action. P.S. Да, я переименовал метод c toStart на replyToStart.
Обсуждают сегодня