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 java.sql.SQLException;
23 import java.util.List;
24 import org.sonews.daemon.NNTPConnection;
25 import org.sonews.daemon.storage.Group;
28 * Class handling the LIST command.
29 * @author Christian Lins
30 * @author Dennis Schwerdel
33 public class ListCommand extends AbstractCommand
36 public ListCommand(final NNTPConnection conn)
42 public boolean hasFinished()
48 public void processLine(final String line)
49 throws IOException, SQLException
51 final String[] command = line.split(" ");
53 if (command.length >= 2)
55 if (command[1].equalsIgnoreCase("OVERVIEW.FMT"))
57 printStatus(215, "information follows");
58 println("Subject:\nFrom:\nDate:\nMessage-ID:\nReferences:\nBytes:\nLines:\nXref");
61 else if (command[1].equalsIgnoreCase("NEWSGROUPS"))
63 printStatus(215, "information follows");
64 final List<Group> list = Group.getAll();
67 println(g.getName() + "\t" + "-");
71 else if (command[1].equalsIgnoreCase("SUBSCRIPTIONS"))
73 printStatus(215, "information follows");
76 else if (command[1].equalsIgnoreCase("EXTENSIONS"))
78 printStatus(202, "Supported NNTP extensions.");
85 printStatus(500, "unknown argument to LIST command");
90 final List<Group> groups = Group.getAll();
93 printStatus(215, "list of newsgroups follows");
94 for (Group g : groups)
96 // Indeed first the higher article number then the lower
97 println(g.getName() + " " + g.getLastArticleNumber() + " "
98 + g.getFirstArticleNumber() + " y");
104 printStatus(500, "server database malfunction");