/* * Juick * Copyright (C) 2008-2011, Ugnich Anton * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see . */ package com.juick.http.www; import com.juick.Tag; import com.juick.server.MessagesQueries; import com.juick.server.SubscriptionsQueries; import com.juick.server.TagQueries; import com.juick.server.UserQueries; import com.juick.xmpp.JID; import com.juick.xmpp.Message; import com.juick.xmpp.Stream; import com.juick.xmpp.extensions.JuickMessage; import com.juick.xmpp.extensions.Nickname; import com.juick.xmpp.extensions.XOOB; import java.io.IOException; import java.io.PrintWriter; import java.io.UnsupportedEncodingException; import java.net.URLEncoder; import java.sql.Connection; import java.util.ArrayList; import javax.servlet.ServletException; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; /** * * @author Ugnich Anton */ public class NewMessage { protected void doGetNewMessage(Connection sql, HttpServletRequest request, HttpServletResponse response, com.juick.User visitor) throws ServletException, IOException { response.setContentType("text/html; charset=UTF-8"); PrintWriter out = response.getWriter(); try { PageTemplates.pageHead(out, "Написать", "" + "" + "" + ""); if (!Utils.isMobileRequest(request)) { PageTemplates.pageNavigation(out, visitor, null); } out.println("
"); out.println("
"); out.println("

Место: Отменить

"); out.println("

Фото: (JPG, PNG, до 10Мб)

"); String body = request.getParameter("body"); if (body == null) { body = ""; } else { if (body.length() > 4096) { body = body.substring(0, 4096); } body = Utils.encodeHTML(body); } out.println("


"); out.println("" + "" + "

"); out.println("
"); out.println("
"); out.println("

Теги:

"); printUserTags(sql, out, visitor); out.println("
"); if (!Utils.isMobileRequest(request)) { PageTemplates.pageFooter(request, out, visitor, false); } PageTemplates.pageEnd(out); } finally { out.close(); } } void printUserTags(Connection sql, PrintWriter out, com.juick.User visitor) { ArrayList tags = TagQueries.getUserTagsAll(sql, visitor.UID); if (tags.isEmpty()) { return; } int min = tags.get(0).UsageCnt; int max = tags.get(0).UsageCnt; for (int i = 1; i < tags.size(); i++) { int usagecnt = tags.get(i).UsageCnt; if (usagecnt < min) { min = usagecnt; } if (usagecnt > max) { max = usagecnt; } } max -= min; out.print("

"); for (int i = 0; i < tags.size(); i++) { if (i > 0) { out.print(" "); } String taglink = ""; try { taglink = "" + Utils.encodeHTML(tags.get(i).Name) + ""; } catch (UnsupportedEncodingException e) { } int usagecnt = tags.get(i).UsageCnt; if (usagecnt <= max / 5 + min) { out.print("" + taglink + ""); } else if (usagecnt <= max / 5 * 2 + min) { out.print(taglink); } else if (usagecnt <= max / 5 * 3 + min) { out.print("" + taglink + ""); } else if (usagecnt <= max / 5 * 4 + min) { out.print("" + taglink + ""); } else { out.print("" + taglink + ""); } } out.println("

"); } public void doPostMessage(Connection sql, HttpServletRequest request, HttpServletResponse response, Stream xmpp, com.juick.User visitor) throws ServletException, IOException { String body = request.getParameter("body"); if (body == null || body.length() < 1 || body.length() > 4096) { response.sendError(400); return; } String tagsStr = request.getParameter("tags"); if (tagsStr == null || tagsStr.isEmpty()) { response.sendError(400); return; } String tagsArr[] = tagsStr.split("[ \\,]"); for (int i = 0; i < tagsArr.length; i++) { if (tagsArr[i].startsWith("*")) { tagsArr[i] = tagsArr[i].substring(1); } if (tagsArr[i].length() > 64) { tagsArr[i] = tagsArr[i].substring(0, 64); } } ArrayList tags = TagQueries.getTags(sql, tagsArr, true); if (tags.isEmpty()) { response.sendError(400); return; } while (tags.size() > 5) { tags.remove(5); } String attachmentFName = null; try { attachmentFName = Utils.receiveMultiPartFile(request, "attach"); } catch (Exception e) { response.sendError(400); return; } String paramImg = request.getParameter("img"); if (attachmentFName == null && paramImg != null && paramImg.length() > 12 && paramImg.startsWith("http://") && !paramImg.equals("http://")) { try { attachmentFName = Utils.downloadImage(paramImg); } catch (Exception e) { System.out.println("DOWNLOAD ERROR: " + e.toString()); response.sendError(500); return; } } String attachmentType = attachmentFName != null ? attachmentFName.substring(attachmentFName.length() - 3) : null; int mid = MessagesQueries.createMessage(sql, visitor.UID, body, attachmentType, tags); SubscriptionsQueries.subscribeMessage(sql, mid, visitor.UID); Message xmsg = new Message(); xmsg.from = new JID("juick", "juick.com", null); xmsg.type = Message.Type.chat; xmsg.thread = "juick-" + mid; JuickMessage jmsg = new JuickMessage(MessagesQueries.getMessage(sql, mid)); xmsg.addChild(jmsg); Nickname nick = new Nickname(); nick.Nickname = "@" + jmsg.User.UName; xmsg.addChild(nick); if (attachmentFName != null) { String fname = mid + "." + attachmentType; String attachmentURL = "http://i.juick.com/photos-1024/" + fname; Runtime.getRuntime().exec("/var/www/juick.com/cgi/p-convert.sh /var/www/juick.com/i/tmp/" + attachmentFName + " " + fname); body = attachmentURL + "\n" + body; XOOB xoob = new XOOB(); xoob.URL = attachmentURL; xmsg.addChild(xoob); } String tagsStr2 = ""; for (int i = 0; i < tagsArr.length; i++) { tagsStr2 += " *" + tagsArr[i]; } xmsg.body = "@" + jmsg.User.UName + ":" + tagsStr2 + "\n" + body + "\n\n#" + mid + " http://juick.com/" + mid; xmsg.to = new JID("juick", "s2s.juick.com", null); xmpp.send(xmsg); xmsg.to.Host = "ws.juick.com"; xmpp.send(xmsg); xmsg.to.Host = "push.juick.com"; xmpp.send(xmsg); xmsg.to.Host = "crosspost.juick.com"; xmsg.to.Username = "twitter"; xmpp.send(xmsg); xmsg.to.Username = "fb"; xmpp.send(xmsg); xmsg.to.Host = "nologin.ru"; xmsg.to.Username = "jubo"; xmpp.send(xmsg); Utils.sendTemporaryRedirect(response, "/" + visitor.UName + "/" + mid); } public void doPostComment(Connection sql, HttpServletRequest request, HttpServletResponse response, Stream xmpp, com.juick.User visitor) throws ServletException, IOException { int mid = Utils.parseInt(request.getParameter("mid"), 0); if (mid == 0) { response.sendError(400); return; } com.juick.Message msg = MessagesQueries.getMessage(sql, mid); if (msg == null) { response.sendError(404); return; } int rid = Utils.parseInt(request.getParameter("rid"), 0); com.juick.Message reply = null; if (rid > 0) { reply = MessagesQueries.getReply(sql, mid, rid); if (reply == null) { response.sendError(404); return; } } String body = request.getParameter("body"); if (body == null || body.length() < 1 || body.length() > 4096) { response.sendError(400); return; } if ((msg.ReadOnly && msg.User.UID != visitor.UID) || UserQueries.isInBLAny(sql, msg.User.UID, visitor.UID) || (reply != null && UserQueries.isInBLAny(sql, reply.User.UID, visitor.UID))) { response.sendError(403); return; } String attachmentFName = null; try { attachmentFName = Utils.receiveMultiPartFile(request, "attach"); } catch (Exception e) { response.sendError(400); return; } String paramImg = request.getParameter("img"); if (attachmentFName == null && paramImg != null && paramImg.length() > 12 && paramImg.startsWith("http://") && !paramImg.equals("http://")) { try { attachmentFName = Utils.downloadImage(paramImg); } catch (Exception e) { System.out.println("DOWNLOAD ERROR: " + e.toString()); response.sendError(500); return; } } String attachmentType = attachmentFName != null ? attachmentFName.substring(attachmentFName.length() - 3) : null; int ridnew = MessagesQueries.createReply(sql, mid, rid, visitor.UID, body, attachmentType); SubscriptionsQueries.subscribeMessage(sql, mid, visitor.UID); Message xmsg = new Message(); xmsg.from = new JID("juick", "juick.com", null); xmsg.type = Message.Type.chat; xmsg.thread = "juick-" + mid; JuickMessage jmsg = new JuickMessage(MessagesQueries.getReply(sql, mid, ridnew)); xmsg.addChild(jmsg); String quote = reply != null ? reply.Text : msg.Text; if (quote.length() >= 50) { quote = quote.substring(0, 47) + "..."; } Nickname nick = new Nickname(); nick.Nickname = "@" + jmsg.User.UName; xmsg.addChild(nick); if (attachmentFName != null) { String fname = mid + "-" + ridnew + "." + attachmentType; String attachmentURL = "http://i.juick.com/photos-1024/" + fname; Runtime.getRuntime().exec("/var/www/juick.com/cgi/p-convert.sh /var/www/juick.com/i/tmp/" + attachmentFName + " " + fname); body = attachmentURL + "\n" + body; XOOB xoob = new XOOB(); xoob.URL = attachmentURL; xmsg.addChild(xoob); } xmsg.body = "Reply by @" + jmsg.User.UName + ":\n>" + quote + "\n" + body + "\n\n#" + mid + "/" + ridnew + " http://juick.com/" + mid + "#" + ridnew; xmsg.to = new JID("juick", "s2s.juick.com", null); xmpp.send(xmsg); xmsg.to.Host = "ws.juick.com"; xmpp.send(xmsg); Utils.sendTemporaryRedirect(response, "/" + msg.User.UName + "/" + mid + "#" + ridnew); } }