Refactor logging to fix NullPointerException.
3 * see AUTHORS for the list of contributors
5 * This program is free software: you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation, either version 3 of the License, or
8 * (at your option) any later version.
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License
16 * along with this program. If not, see <http://www.gnu.org/licenses/>.
19 package org.sonews.daemon.command;
21 import java.io.IOException;
22 import org.sonews.storage.Article;
23 import org.sonews.daemon.NNTPConnection;
24 import org.sonews.storage.Channel;
25 import org.sonews.storage.StorageBackendException;
28 * Class handling the ARTICLE, BODY and HEAD commands.
29 * @author Christian Lins
30 * @author Dennis Schwerdel
33 public class ArticleCommand implements Command
37 public String[] getSupportedCommandStrings()
39 return new String[] {"ARTICLE", "BODY", "HEAD"};
43 public boolean hasFinished()
49 public String impliedCapability()
55 public boolean isStateful()
60 // TODO: Refactor this method to reduce its complexity!
62 public void processLine(NNTPConnection conn, final String line, byte[] raw)
65 final String[] command = line.split(" ");
67 Article article = null;
69 if (command.length == 1)
71 article = conn.getCurrentArticle();
74 conn.println("420 no current article has been selected");
78 else if (command[1].matches(NNTPConnection.MESSAGE_ID_PATTERN))
81 article = Article.getByMessageID(command[1]);
84 conn.println("430 no such article found");
93 Channel currentGroup = conn.getCurrentChannel();
94 if(currentGroup == null)
96 conn.println("400 no group selected");
100 artIndex = Long.parseLong(command[1]);
101 article = currentGroup.getArticle(artIndex);
103 catch(NumberFormatException ex)
105 ex.printStackTrace();
107 catch(StorageBackendException ex)
109 ex.printStackTrace();
114 conn.println("423 no such article number in this group");
117 conn.setCurrentArticle(article);
120 if(command[0].equalsIgnoreCase("ARTICLE"))
122 conn.println("220 " + artIndex + " " + article.getMessageID()
123 + " article retrieved - head and body follow");
124 conn.println(article.getHeaderSource());
126 conn.println(article.getBody());
129 else if(command[0].equalsIgnoreCase("BODY"))
131 conn.println("222 " + artIndex + " " + article.getMessageID() + " body");
132 conn.println(article.getBody());
137 * HEAD: This command is mandatory.
146 * First form (message-id specified)
147 * 221 0|n message-id Headers follow (multi-line)
148 * 430 No article with that message-id
150 * Second form (article number specified)
151 * 221 n message-id Headers follow (multi-line)
152 * 412 No newsgroup selected
153 * 423 No article with that number
155 * Third form (current article number used)
156 * 221 n message-id Headers follow (multi-line)
157 * 412 No newsgroup selected
158 * 420 Current article number is invalid
161 * number Requested article number
162 * n Returned article number
163 * message-id Article message-id
165 else if(command[0].equalsIgnoreCase("HEAD"))
167 conn.println("221 " + artIndex + " " + article.getMessageID()
168 + " Headers follow (multi-line)");
169 conn.println(article.getHeaderSource());