| /* |
| * Copyright (c) 2009, Oracle and/or its affiliates. All rights reserved. |
| * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
| * |
| * This code is free software; you can redistribute it and/or modify it |
| * under the terms of the GNU General Public License version 2 only, as |
| * published by the Free Software Foundation. Oracle designates this |
| * particular file as subject to the "Classpath" exception as provided |
| * by Oracle in the LICENSE file that accompanied this code. |
| * |
| * This code is distributed in the hope that it will be useful, but WITHOUT |
| * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
| * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License |
| * version 2 for more details (a copy is included in the LICENSE file that |
| * accompanied this code). |
| * |
| * You should have received a copy of the GNU General Public License version |
| * 2 along with this work; if not, write to the Free Software Foundation, |
| * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. |
| * |
| * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
| * or visit www.oracle.com if you need additional information or have any |
| * questions. |
| */ |
| package sun.net.ftp; |
| |
| import java.util.Date; |
| import java.util.HashMap; |
| |
| /** |
| * A {@code FtpDirEntry} is a class agregating all the information that the FTP client |
| * can gather from the server by doing a {@code LST} (or {@code NLST}) command and |
| * parsing the output. It will typically contain the name, type, size, last modification |
| * time, owner and group of the file, although some of these could be unavailable |
| * due to specific FTP server limitations. |
| * |
| * @see sun.net.ftp.FtpDirParser |
| * @since 1.7 |
| */ |
| public class FtpDirEntry { |
| |
| public enum Type { |
| |
| FILE, DIR, PDIR, CDIR, LINK |
| }; |
| |
| public enum Permission { |
| |
| USER(0), GROUP(1), OTHERS(2); |
| int value; |
| |
| Permission(int v) { |
| value = v; |
| } |
| }; |
| private final String name; |
| private String user = null; |
| private String group = null; |
| private long size = -1; |
| private java.util.Date created = null; |
| private java.util.Date lastModified = null; |
| private Type type = Type.FILE; |
| private boolean[][] permissions = null; |
| private HashMap<String, String> facts = new HashMap<String, String>(); |
| |
| private FtpDirEntry() { |
| name = null; |
| } |
| |
| /** |
| * Creates an FtpDirEntry instance with only the name being set. |
| * |
| * @param name The name of the file |
| */ |
| public FtpDirEntry(String name) { |
| this.name = name; |
| } |
| |
| /** |
| * Returns the name of the remote file. |
| * |
| * @return a {@code String} containing the name of the remote file. |
| */ |
| public String getName() { |
| return name; |
| } |
| |
| /** |
| * Returns the user name of the owner of the file as returned by the FTP |
| * server, if provided. This could be a name or a user id (number). |
| * |
| * @return a {@code String} containing the user name or |
| * {@code null} if that information is not available. |
| */ |
| public String getUser() { |
| return user; |
| } |
| |
| /** |
| * Sets the user name of the owner of the file. Intended mostly to be |
| * used from inside a {@link java.net.FtpDirParser} implementation. |
| * |
| * @param user The user name of the owner of the file, or {@code null} |
| * if that information is not available. |
| * @return this FtpDirEntry |
| */ |
| public FtpDirEntry setUser(String user) { |
| this.user = user; |
| return this; |
| } |
| |
| /** |
| * Returns the group name of the file as returned by the FTP |
| * server, if provided. This could be a name or a group id (number). |
| * |
| * @return a {@code String} containing the group name or |
| * {@code null} if that information is not available. |
| */ |
| public String getGroup() { |
| return group; |
| } |
| |
| /** |
| * Sets the name of the group to which the file belong. Intended mostly to be |
| * used from inside a {@link java.net.FtpDirParser} implementation. |
| * |
| * @param group The name of the group to which the file belong, or {@code null} |
| * if that information is not available. |
| * @return this FtpDirEntry |
| */ |
| public FtpDirEntry setGroup(String group) { |
| this.group = group; |
| return this; |
| } |
| |
| /** |
| * Returns the size of the remote file as it was returned by the FTP |
| * server, if provided. |
| * |
| * @return the size of the file or -1 if that information is not available. |
| */ |
| public long getSize() { |
| return size; |
| } |
| |
| /** |
| * Sets the size of that file. Intended mostly to be used from inside an |
| * {@link java.net.FtpDirParser} implementation. |
| * |
| * @param size The size, in bytes, of that file. or -1 if unknown. |
| * @return this FtpDirEntry |
| */ |
| public FtpDirEntry setSize(long size) { |
| this.size = size; |
| return this; |
| } |
| |
| /** |
| * Returns the type of the remote file as it was returned by the FTP |
| * server, if provided. |
| * It returns a FtpDirEntry.Type enum and the values can be: |
| * - FtpDirEntry.Type.FILE for a normal file |
| * - FtpDirEntry.Type.DIR for a directory |
| * - FtpDirEntry.Type.LINK for a symbolic link |
| * |
| * @return a {@code FtpDirEntry.Type} describing the type of the file |
| * or {@code null} if that information is not available. |
| */ |
| public Type getType() { |
| return type; |
| } |
| |
| /** |
| * Sets the type of the file. Intended mostly to be used from inside an |
| * {@link java.net.FtpDirParser} implementation. |
| * |
| * @param type the type of this file or {@code null} if that information |
| * is not available. |
| * @return this FtpDirEntry |
| */ |
| public FtpDirEntry setType(Type type) { |
| this.type = type; |
| return this; |
| } |
| |
| /** |
| * Returns the last modification time of the remote file as it was returned |
| * by the FTP server, if provided, {@code null} otherwise. |
| * |
| * @return a <code>Date</code> representing the last time the file was |
| * modified on the server, or {@code null} if that |
| * information is not available. |
| */ |
| public java.util.Date getLastModified() { |
| return this.lastModified; |
| } |
| |
| /** |
| * Sets the last modification time of the file. Intended mostly to be used |
| * from inside an {@link java.net.FtpDirParser} implementation. |
| * |
| * @param lastModified The Date representing the last modification time, or |
| * {@code null} if that information is not available. |
| * @return this FtpDirEntry |
| */ |
| public FtpDirEntry setLastModified(Date lastModified) { |
| this.lastModified = lastModified; |
| return this; |
| } |
| |
| /** |
| * Returns whether read access is granted for a specific permission. |
| * |
| * @param p the Permission (user, group, others) to check. |
| * @return {@code true} if read access is granted. |
| */ |
| public boolean canRead(Permission p) { |
| if (permissions != null) { |
| return permissions[p.value][0]; |
| } |
| return false; |
| } |
| |
| /** |
| * Returns whether write access is granted for a specific permission. |
| * |
| * @param p the Permission (user, group, others) to check. |
| * @return {@code true} if write access is granted. |
| */ |
| public boolean canWrite(Permission p) { |
| if (permissions != null) { |
| return permissions[p.value][1]; |
| } |
| return false; |
| } |
| |
| /** |
| * Returns whether execute access is granted for a specific permission. |
| * |
| * @param p the Permission (user, group, others) to check. |
| * @return {@code true} if execute access is granted. |
| */ |
| public boolean canExexcute(Permission p) { |
| if (permissions != null) { |
| return permissions[p.value][2]; |
| } |
| return false; |
| } |
| |
| /** |
| * Sets the permissions for that file. Intended mostly to be used |
| * from inside an {@link java.net.FtpDirParser} implementation. |
| * The permissions array is a 3x3 {@code boolean} array, the first index being |
| * the User, group or owner (0, 1 and 2 respectively) while the second |
| * index is read, write or execute (0, 1 and 2 respectively again). |
| * <p>E.G.: {@code permissions[1][2]} is the group/execute permission.</p> |
| * |
| * @param permissions a 3x3 {@code boolean} array |
| * @return this {@code FtpDirEntry} |
| */ |
| public FtpDirEntry setPermissions(boolean[][] permissions) { |
| this.permissions = permissions; |
| return this; |
| } |
| |
| /** |
| * Adds a 'fact', as defined in RFC 3659, to the list of facts of this file. |
| * Intended mostly to be used from inside a {@link java.net.FtpDirParser} |
| * implementation. |
| * |
| * @param fact the name of the fact (e.g. "Media-Type"). It is not case-sensitive. |
| * @param value the value associated with this fact. |
| * @return this {@code FtpDirEntry} |
| */ |
| public FtpDirEntry addFact(String fact, String value) { |
| facts.put(fact.toLowerCase(), value); |
| return this; |
| } |
| |
| /** |
| * Returns the requested 'fact', as defined in RFC 3659, if available. |
| * |
| * @param fact The name of the fact *e.g. "Media-Type"). It is not case sensitive. |
| * @return The value of the fact or, {@code null} if that fact wasn't |
| * provided by the server. |
| */ |
| public String getFact(String fact) { |
| return facts.get(fact.toLowerCase()); |
| } |
| |
| /** |
| * Returns the creation time of the file, when provided by the server. |
| * |
| * @return The Date representing the creation time, or {@code null} |
| * if the server didn't provide that information. |
| */ |
| public Date getCreated() { |
| return created; |
| } |
| |
| /** |
| * Sets the creation time for that file. Intended mostly to be used from |
| * inside a {@link java.net.FtpDirParser} implementation. |
| * |
| * @param created the Date representing the creation time for that file, or |
| * {@code null} if that information is not available. |
| * @return this FtpDirEntry |
| */ |
| public FtpDirEntry setCreated(Date created) { |
| this.created = created; |
| return this; |
| } |
| |
| /** |
| * Returns a string representation of the object. |
| * The {@code toString} method for class {@code FtpDirEntry} |
| * returns a string consisting of the name of the file, followed by its |
| * type between brackets, followed by the user and group between |
| * parenthesis, then size between '{', and, finally, the lastModified of last |
| * modification if it's available. |
| * |
| * @return a string representation of the object. |
| */ |
| @Override |
| public String toString() { |
| if (lastModified == null) { |
| return name + " [" + type + "] (" + user + " / " + group + ") " + size; |
| } |
| return name + " [" + type + "] (" + user + " / " + group + ") {" + size + "} " + java.text.DateFormat.getDateInstance().format(lastModified); |
| } |
| } |