diff options
author | Vitaly Takmazov | 2016-10-24 15:01:34 +0300 |
---|---|---|
committer | Vitaly Takmazov | 2016-10-24 15:05:43 +0300 |
commit | 1a38addf7a4ab6186d97ea1ee71ed3889a5e6b08 (patch) | |
tree | a00c98797807c9857df21ecb8965056ab2f6c1b7 /juick-api | |
parent | 95ac207e5dd5566490571fda7229b754a2bbe7ac (diff) |
api: subscriptions
Diffstat (limited to 'juick-api')
-rw-r--r-- | juick-api/src/main/java/com/juick/api/Main.java | 4 | ||||
-rw-r--r-- | juick-api/src/main/java/com/juick/api/Subscriptions.java | 35 |
2 files changed, 39 insertions, 0 deletions
diff --git a/juick-api/src/main/java/com/juick/api/Main.java b/juick-api/src/main/java/com/juick/api/Main.java index cad991ef..3bd1e750 100644 --- a/juick-api/src/main/java/com/juick/api/Main.java +++ b/juick-api/src/main/java/com/juick/api/Main.java @@ -70,6 +70,7 @@ public class Main extends HttpServlet implements Stream.StreamListener { Users users; PM pm; Others others; + Subscriptions subscriptions; TelegramBotHook tgb; SkypeEndpoint sep; @@ -90,6 +91,7 @@ public class Main extends HttpServlet implements Stream.StreamListener { users = new Users(jdbc); pm = new PM(jdbc); others = new Others(jdbc); + subscriptions = new Subscriptions(jdbc); tgb = new TelegramBotHook(jdbc, conf.getProperty("telegram_token", "")); sep = new SkypeEndpoint(); setupXmppComponent(conf.getProperty("xmpp_host", "localhost"), Integer.parseInt(conf.getProperty("xmpp_port", "5347")), @@ -183,6 +185,8 @@ public class Main extends HttpServlet implements Stream.StreamListener { messages.doSetPopular(request, response, xmpp); } else if (uri.equals("/messages/set_privacy") && vuid > 0) { messages.doSetPrivacy(request, response, xmpp, vuid); + } else if (uri.equals("/subscriptions")) { + subscriptions.doGet(request, response, vuid); } else { response.sendError(404); } diff --git a/juick-api/src/main/java/com/juick/api/Subscriptions.java b/juick-api/src/main/java/com/juick/api/Subscriptions.java new file mode 100644 index 00000000..49990080 --- /dev/null +++ b/juick-api/src/main/java/com/juick/api/Subscriptions.java @@ -0,0 +1,35 @@ +package com.juick.api; + +import com.juick.User; +import com.juick.json.UserSerializer; +import com.juick.server.SubscriptionsQueries; +import com.juick.server.UserQueries; +import org.apache.commons.lang3.math.NumberUtils; +import org.springframework.jdbc.core.JdbcTemplate; + +import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletResponse; +import java.io.IOException; +import java.util.List; + +/** + * Created by vitalyster on 24.10.2016. + */ +public class Subscriptions { + JdbcTemplate jdbc; + + public Subscriptions(JdbcTemplate jdbc) { + this.jdbc = jdbc; + } + public void doGet(HttpServletRequest request, HttpServletResponse response, int vuid) throws IOException { + User visitor = UserQueries.getUserByUID(jdbc, vuid).orElse(new User()); + if (!(visitor.getUID() > 0) && !(visitor.getUName().equals("juick"))) { + response.sendError(403); + } + int uid = NumberUtils.toInt(request.getParameter("uid"), 0); + int mid = NumberUtils.toInt(request.getParameter("mid"), 0); + List<User> users = SubscriptionsQueries.getSubscribedUsers(jdbc, uid, mid); + UserSerializer userSerializer = new UserSerializer(); + Main.replyJSON(request, response, userSerializer.serializeList(users)); + } +} |