aboutsummaryrefslogtreecommitdiff
path: root/juick-api/src/main/java/com/juick/api/controllers/TelegramWebhook.java
blob: 22f588e0baaecdab6417bce83692d3bd820f9c16 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
package com.juick.api.controllers;

import com.juick.User;
import com.juick.api.TGBot;
import com.juick.service.TelegramService;
import com.juick.service.UserService;
import com.pengrad.telegrambot.BotUtils;
import com.pengrad.telegrambot.model.Message;
import com.pengrad.telegrambot.model.Update;
import org.apache.commons.io.IOUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.http.HttpStatus;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.ResponseStatus;
import org.springframework.web.bind.annotation.RestController;

import javax.inject.Inject;
import javax.servlet.http.HttpServletRequest;
import java.io.IOException;
import java.nio.charset.StandardCharsets;
import java.util.List;

/**
 * Created by vt on 24/11/2016.
 */
@RestController
public class TelegramWebhook {
    private static Logger logger = LoggerFactory.getLogger(TelegramWebhook.class);
    @Inject
    UserService usersService;
    @Inject
    TelegramService telegramService;
    @Inject
    TGBot tgBot;


    @RequestMapping(value = "/tlgmbtwbhk", method = RequestMethod.POST)
    @ResponseStatus(value = HttpStatus.OK)
    public void processUpdate(HttpServletRequest request) throws IOException {
        Update update = BotUtils.parseUpdate(IOUtils.toString(request.getInputStream(), StandardCharsets.UTF_8));
        Message message = update.message();
        if (update.message() == null) {
            message = update.editedMessage();
            if (message == null) {
                logger.error("error parsing telegram update: {}", update);
                return;
            }
        }
        logger.info("got telegram msg {}", message);
        User user_from = usersService.getUserByUID(telegramService.getUser(message.chat().id())).orElse(new User());
        logger.info("Found juick user {}", user_from.getUid());

        List<Long> chats = telegramService.getChats();
        String username = message.from().username();
        if (username == null) {
            username = message.from().firstName();
        }
        if (!chats.contains(message.chat().id())) {
            telegramService.addChat(message.chat().id());
            logger.info("added chat with {}", username);
            telegramService.createTelegramUser(message.from().id(), username);
            tgBot.telegramSignupNotify(message.from().id().longValue(), usersService.getSignUpHashByTelegramID(message.from().id().longValue(), username));
        } else {
            if (user_from.getUid() == 0) {
                tgBot.telegramSignupNotify(message.from().id().longValue(), usersService.getSignUpHashByTelegramID(message.from().id().longValue(), username));
            } else {
                String text = message.text();
                if (text != null) {
                    if (text.equalsIgnoreCase("/login")) {
                        String msg = String.format("Hi, %s!\nTap to log in", user_from.getName());
                        String msgUrl = "http://juick.com/login?" + usersService.getHashByUID(user_from.getUid());
                        tgBot.telegramNotify(message.from().id().longValue(), msg, msgUrl);
                    } /* else {
                            ProtocolReply reply = protocol.getReply(user_from, text);
                            telegramNotify(message.from().id().longValue(), reply.getResult(), null);
                        }*/
                }
            }
        }
    }
}