org/sonews/daemon/command/ListCommand.java
changeset 19 91dc9acb03ed
parent 12 bb6990c0dd1a
child 20 6ae5e4f8329b
     1.1 --- a/org/sonews/daemon/command/ListCommand.java	Thu Aug 20 14:31:19 2009 +0200
     1.2 +++ b/org/sonews/daemon/command/ListCommand.java	Fri Aug 21 17:40:54 2009 +0200
     1.3 @@ -20,9 +20,13 @@
     1.4  
     1.5  import java.io.IOException;
     1.6  import java.util.List;
     1.7 +import java.util.regex.Matcher;
     1.8 +import java.util.regex.Pattern;
     1.9 +import java.util.regex.PatternSyntaxException;
    1.10  import org.sonews.daemon.NNTPConnection;
    1.11  import org.sonews.storage.Channel;
    1.12  import org.sonews.storage.StorageBackendException;
    1.13 +import org.sonews.util.Log;
    1.14  
    1.15  /**
    1.16   * Class handling the LIST command.
    1.17 @@ -90,8 +94,9 @@
    1.18        }
    1.19        else if(command[1].equalsIgnoreCase("ACTIVE"))
    1.20        {
    1.21 -        // TODO: Implement wildcards for LIST ACTIVE
    1.22 -        printGroupInfo(conn);
    1.23 +        String  pattern  = command.length == 2
    1.24 +          ? null : command[2].replace("*", "\\w*");
    1.25 +        printGroupInfo(conn, pattern);
    1.26        }
    1.27        else
    1.28        {
    1.29 @@ -100,31 +105,42 @@
    1.30      }
    1.31      else
    1.32      {
    1.33 -      printGroupInfo(conn);
    1.34 +      printGroupInfo(conn, null);
    1.35      }
    1.36    }
    1.37  
    1.38 -  private void printGroupInfo(NNTPConnection conn)
    1.39 +  private void printGroupInfo(NNTPConnection conn, String pattern)
    1.40      throws IOException, StorageBackendException
    1.41    {
    1.42      final List<Channel> groups = Channel.getAll();
    1.43 -    if (groups != null)
    1.44 +    if(groups != null)
    1.45      {
    1.46        conn.println("215 list of newsgroups follows");
    1.47 -      for (Channel g : groups)
    1.48 +      for(Channel g : groups)
    1.49        {
    1.50 -        if (!g.isDeleted())
    1.51 +        try
    1.52          {
    1.53 -          String writeable = g.isWriteable() ? " y" : " n";
    1.54 -          // Indeed first the higher article number then the lower
    1.55 -          conn.println(g.getName() + " " + g.getLastArticleNumber() + " " + g.getFirstArticleNumber() + writeable);
    1.56 +          Matcher matcher = pattern == null ?
    1.57 +            null : Pattern.compile(pattern).matcher(g.getName());
    1.58 +          if(!g.isDeleted() &&
    1.59 +            (matcher == null || matcher.find()))
    1.60 +          {
    1.61 +            String writeable = g.isWriteable() ? " y" : " n";
    1.62 +            // Indeed first the higher article number then the lower
    1.63 +            conn.println(g.getName() + " " + g.getLastArticleNumber() + " "
    1.64 +              + g.getFirstArticleNumber() + writeable);
    1.65 +          }
    1.66 +        }
    1.67 +        catch(PatternSyntaxException ex)
    1.68 +        {
    1.69 +          Log.get().info(ex.toString());
    1.70          }
    1.71        }
    1.72        conn.println(".");
    1.73      }
    1.74      else
    1.75      {
    1.76 -      conn.println("500 server database malfunction");
    1.77 +      conn.println("500 server backend malfunction");
    1.78      }
    1.79    }
    1.80