Rename SoneImpl to DefaultSone, implement SoneProvider in MemoryDatabase.
[Sone.git] / src / main / java / net / pterodactylus / sone / web / CreatePostPage.java
1 /*
2  * Sone - CreatePostPage.java - Copyright © 2010–2013 David Roden
3  *
4  * This program is free software: you can redistribute it and/or modify
5  * it under the terms of the GNU General Public License as published by
6  * the Free Software Foundation, either version 3 of the License, or
7  * (at your option) any later version.
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
16  */
17
18 package net.pterodactylus.sone.web;
19
20 import static com.google.common.base.Optional.of;
21
22 import net.pterodactylus.sone.data.Post;
23 import net.pterodactylus.sone.data.Sone;
24 import net.pterodactylus.sone.text.TextFilter;
25 import net.pterodactylus.sone.web.page.FreenetRequest;
26 import net.pterodactylus.util.template.Template;
27 import net.pterodactylus.util.template.TemplateContext;
28 import net.pterodactylus.util.web.Method;
29
30 import com.google.common.base.Optional;
31
32 /**
33  * This page lets the user create a new {@link Post}.
34  *
35  * @author <a href="mailto:bombe@pterodactylus.net">David ‘Bombe’ Roden</a>
36  */
37 public class CreatePostPage extends SoneTemplatePage {
38
39         /**
40          * Creates a new “create post” page.
41          *
42          * @param template
43          *            The template to render
44          * @param webInterface
45          *            The Sone web interface
46          */
47         public CreatePostPage(Template template, WebInterface webInterface) {
48                 super("createPost.html", template, "Page.CreatePost.Title", webInterface, true);
49         }
50
51         //
52         // TEMPLATEPATH METHODS
53         //
54
55         /**
56          * {@inheritDoc}
57          */
58         @Override
59         protected void processTemplate(FreenetRequest request, TemplateContext templateContext) throws RedirectException {
60                 super.processTemplate(request, templateContext);
61                 String returnPage = request.getHttpRequest().getPartAsStringFailsafe("returnPage", 256);
62                 if (request.getMethod() == Method.POST) {
63                         String text = request.getHttpRequest().getPartAsStringFailsafe("text", 65536).trim();
64                         if (text.length() != 0) {
65                                 String senderId = request.getHttpRequest().getPartAsStringFailsafe("sender", 43);
66                                 String recipientId = request.getHttpRequest().getPartAsStringFailsafe("recipient", 43);
67                                 Sone currentSone = getCurrentSone(request.getToadletContext());
68                                 Optional<Sone> sender = webInterface.getCore().getLocalSone(senderId);
69                                 if (sender == null) {
70                                         sender = of(currentSone);
71                                 }
72                                 Optional<Sone> recipient = webInterface.getCore().getSone(recipientId);
73                                 text = TextFilter.filter(request.getHttpRequest().getHeader("host"), text);
74                                 webInterface.getCore().createPost(sender.get(), recipient, System.currentTimeMillis(), text);
75                                 throw new RedirectException(returnPage);
76                         }
77                         templateContext.set("errorTextEmpty", true);
78                 }
79                 templateContext.set("returnPage", returnPage);
80         }
81
82 }