chris@1
|
1 |
/*
|
chris@1
|
2 |
* SONEWS News Server
|
chris@1
|
3 |
* see AUTHORS for the list of contributors
|
chris@1
|
4 |
*
|
chris@1
|
5 |
* This program is free software: you can redistribute it and/or modify
|
chris@1
|
6 |
* it under the terms of the GNU General Public License as published by
|
chris@1
|
7 |
* the Free Software Foundation, either version 3 of the License, or
|
chris@1
|
8 |
* (at your option) any later version.
|
chris@1
|
9 |
*
|
chris@1
|
10 |
* This program is distributed in the hope that it will be useful,
|
chris@1
|
11 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
chris@1
|
12 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
chris@1
|
13 |
* GNU General Public License for more details.
|
chris@1
|
14 |
*
|
chris@1
|
15 |
* You should have received a copy of the GNU General Public License
|
chris@1
|
16 |
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
chris@1
|
17 |
*/
|
chris@1
|
18 |
|
chris@1
|
19 |
package org.sonews.daemon.command;
|
chris@1
|
20 |
|
chris@1
|
21 |
import java.io.IOException;
|
chris@1
|
22 |
import org.sonews.daemon.NNTPConnection;
|
chris@3
|
23 |
import org.sonews.storage.Article;
|
chris@3
|
24 |
import org.sonews.storage.Channel;
|
chris@3
|
25 |
import org.sonews.storage.StorageBackendException;
|
chris@1
|
26 |
|
chris@1
|
27 |
/**
|
chris@1
|
28 |
* Class handling the NEXT and LAST command.
|
chris@1
|
29 |
* @author Christian Lins
|
chris@1
|
30 |
* @author Dennis Schwerdel
|
chris@1
|
31 |
* @since n3tpd/0.1
|
chris@1
|
32 |
*/
|
chris@3
|
33 |
public class NextPrevCommand implements Command
|
chris@1
|
34 |
{
|
chris@1
|
35 |
|
cli@37
|
36 |
@Override
|
cli@37
|
37 |
public String[] getSupportedCommandStrings()
|
cli@37
|
38 |
{
|
cli@37
|
39 |
return new String[] {"NEXT", "PREV"};
|
cli@37
|
40 |
}
|
chris@1
|
41 |
|
cli@37
|
42 |
@Override
|
cli@37
|
43 |
public boolean hasFinished()
|
cli@37
|
44 |
{
|
cli@37
|
45 |
return true;
|
cli@37
|
46 |
}
|
chris@1
|
47 |
|
cli@37
|
48 |
@Override
|
cli@37
|
49 |
public String impliedCapability()
|
cli@37
|
50 |
{
|
cli@37
|
51 |
return null;
|
cli@37
|
52 |
}
|
cli@20
|
53 |
|
cli@37
|
54 |
@Override
|
cli@37
|
55 |
public boolean isStateful()
|
cli@37
|
56 |
{
|
cli@37
|
57 |
return false;
|
cli@37
|
58 |
}
|
chris@3
|
59 |
|
cli@37
|
60 |
@Override
|
cli@37
|
61 |
public void processLine(NNTPConnection conn, final String line, byte[] raw)
|
cli@37
|
62 |
throws IOException, StorageBackendException
|
cli@37
|
63 |
{
|
cli@37
|
64 |
final Article currA = conn.getCurrentArticle();
|
cli@37
|
65 |
final Channel currG = conn.getCurrentChannel();
|
chris@1
|
66 |
|
cli@37
|
67 |
if (currA == null) {
|
cli@37
|
68 |
conn.println("420 no current article has been selected");
|
cli@37
|
69 |
return;
|
cli@37
|
70 |
}
|
chris@1
|
71 |
|
cli@37
|
72 |
if (currG == null) {
|
cli@37
|
73 |
conn.println("412 no newsgroup selected");
|
cli@37
|
74 |
return;
|
cli@37
|
75 |
}
|
chris@1
|
76 |
|
cli@37
|
77 |
final String[] command = line.split(" ");
|
chris@1
|
78 |
|
cli@37
|
79 |
if (command[0].equalsIgnoreCase("NEXT")) {
|
cli@37
|
80 |
selectNewArticle(conn, currA, currG, 1);
|
cli@37
|
81 |
} else if (command[0].equalsIgnoreCase("PREV")) {
|
cli@37
|
82 |
selectNewArticle(conn, currA, currG, -1);
|
cli@37
|
83 |
} else {
|
cli@37
|
84 |
conn.println("500 internal server error");
|
cli@37
|
85 |
}
|
cli@37
|
86 |
}
|
cli@37
|
87 |
|
cli@37
|
88 |
private void selectNewArticle(NNTPConnection conn, Article article, Channel grp,
|
cli@37
|
89 |
final int delta)
|
cli@37
|
90 |
throws IOException, StorageBackendException
|
cli@37
|
91 |
{
|
cli@37
|
92 |
assert article != null;
|
cli@37
|
93 |
|
cli@37
|
94 |
article = grp.getArticle(grp.getIndexOf(article) + delta);
|
cli@37
|
95 |
|
cli@37
|
96 |
if (article == null) {
|
cli@37
|
97 |
conn.println("421 no next article in this group");
|
cli@37
|
98 |
} else {
|
cli@37
|
99 |
conn.setCurrentArticle(article);
|
cli@37
|
100 |
conn.println("223 " + conn.getCurrentChannel().getIndexOf(article)
|
cli@37
|
101 |
+ " " + article.getMessageID()
|
cli@37
|
102 |
+ " article retrieved - request text separately");
|
cli@37
|
103 |
}
|
cli@37
|
104 |
}
|
chris@1
|
105 |
}
|