view src/ch/ethz/ssh2/sftp/ErrorCodes.java @ 408:0c519d0acdd4 stable-1.9.0-7

bump version number
author Carl Byington <carl@five-ten-sg.com>
date Fri, 24 Oct 2014 14:27:11 -0700
parents 071eccdff8ea
children
line wrap: on
line source

/*
 * Copyright (c) 2006-2011 Christian Plattner. All rights reserved.
 * Please refer to the LICENSE.txt for licensing details.
 */
package ch.ethz.ssh2.sftp;

/**
 * SFTP Error Codes
 *
 * @author Christian Plattner
 * @version 2.50, 03/15/10
 */
public final class ErrorCodes {
    private ErrorCodes() {
    }

    public static final int SSH_FX_OK = 0;
    public static final int SSH_FX_EOF = 1;
    public static final int SSH_FX_NO_SUCH_FILE = 2;
    public static final int SSH_FX_PERMISSION_DENIED = 3;
    public static final int SSH_FX_FAILURE = 4;
    public static final int SSH_FX_BAD_MESSAGE = 5;
    public static final int SSH_FX_NO_CONNECTION = 6;
    public static final int SSH_FX_CONNECTION_LOST = 7;
    /**
     * The server MUST respond with SSH_FXP_STATUS(SSH_FX_OP_UNSUPPORTED) if
     * it receives a packet it does not recognize.
     */
    public static final int SSH_FX_OP_UNSUPPORTED = 8;
    public static final int SSH_FX_INVALID_HANDLE = 9;
    public static final int SSH_FX_NO_SUCH_PATH = 10;
    public static final int SSH_FX_FILE_ALREADY_EXISTS = 11;
    public static final int SSH_FX_WRITE_PROTECT = 12;
    public static final int SSH_FX_NO_MEDIA = 13;
    public static final int SSH_FX_NO_SPACE_ON_FILESYSTEM = 14;
    public static final int SSH_FX_QUOTA_EXCEEDED = 15;
    public static final int SSH_FX_UNKNOWN_PRINCIPAL = 16;
    public static final int SSH_FX_LOCK_CONFLICT = 17;
    public static final int SSH_FX_DIR_NOT_EMPTY = 18;
    public static final int SSH_FX_NOT_A_DIRECTORY = 19;
    public static final int SSH_FX_INVALID_FILENAME = 20;
    public static final int SSH_FX_LINK_LOOP = 21;
    public static final int SSH_FX_CANNOT_DELETE = 22;
    public static final int SSH_FX_INVALID_PARAMETER = 23;
    public static final int SSH_FX_FILE_IS_A_DIRECTORY = 24;
    public static final int SSH_FX_BYTE_RANGE_LOCK_CONFLICT = 25;
    public static final int SSH_FX_BYTE_RANGE_LOCK_REFUSED = 26;
    public static final int SSH_FX_DELETE_PENDING = 27;
    public static final int SSH_FX_FILE_CORRUPT = 28;
    public static final int SSH_FX_OWNER_INVALID = 29;
    public static final int SSH_FX_GROUP_INVALID = 30;
    public static final int SSH_FX_NO_MATCHING_BYTE_RANGE_LOCK = 31;

    private static final String[][] messages = {

        {"SSH_FX_OK", "Indicates successful completion of the operation."},
        {
            "SSH_FX_EOF",
            "An attempt to read past the end-of-file was made; or, there are no more directory entries to return."
        },
        {"SSH_FX_NO_SUCH_FILE", "A reference was made to a file which does not exist."},
        {"SSH_FX_PERMISSION_DENIED", "The user does not have sufficient permissions to perform the operation."},
        {"SSH_FX_FAILURE", "An error occurred, but no specific error code exists to describe the failure."},
        {"SSH_FX_BAD_MESSAGE", "A badly formatted packet or other SFTP protocol incompatibility was detected."},
        {"SSH_FX_NO_CONNECTION", "There is no connection to the server."},
        {"SSH_FX_CONNECTION_LOST", "The connection to the server was lost."},
        {
            "SSH_FX_OP_UNSUPPORTED",
            "An attempted operation could not be completed by the server because the server does not support the operation."
        },
        {"SSH_FX_INVALID_HANDLE", "The handle value was invalid."},
        {"SSH_FX_NO_SUCH_PATH", "The file path does not exist or is invalid."},
        {"SSH_FX_FILE_ALREADY_EXISTS", "The file already exists."},
        {"SSH_FX_WRITE_PROTECT", "The file is on read-only media, or the media is write protected."},
        {
            "SSH_FX_NO_MEDIA",
            "The requested operation cannot be completed because there is no media available in the drive."
        },
        {
            "SSH_FX_NO_SPACE_ON_FILESYSTEM",
            "The requested operation cannot be completed because there is insufficient free space on the filesystem."
        },
        {
            "SSH_FX_QUOTA_EXCEEDED",
            "The operation cannot be completed because it would exceed the user's storage quota."
        },
        {
            "SSH_FX_UNKNOWN_PRINCIPAL",
            "A principal referenced by the request (either the 'owner', 'group', or 'who' field of an ACL), was unknown. The error specific data contains the problematic names."
        },
        {"SSH_FX_LOCK_CONFLICT", "The file could not be opened because it is locked by another process."},
        {"SSH_FX_DIR_NOT_EMPTY", "The directory is not empty."},
        {"SSH_FX_NOT_A_DIRECTORY", "The specified file is not a directory."},
        {"SSH_FX_INVALID_FILENAME", "The filename is not valid."},
        {
            "SSH_FX_LINK_LOOP",
            "Too many symbolic links encountered or, an SSH_FXF_NOFOLLOW open encountered a symbolic link as the final component."
        },
        {
            "SSH_FX_CANNOT_DELETE",
            "The file cannot be deleted. One possible reason is that the advisory READONLY attribute-bit is set."
        },
        {
            "SSH_FX_INVALID_PARAMETER",
            "One of the parameters was out of range, or the parameters specified cannot be used together."
        },
        {
            "SSH_FX_FILE_IS_A_DIRECTORY",
            "The specified file was a directory in a context where a directory cannot be used."
        },
        {
            "SSH_FX_BYTE_RANGE_LOCK_CONFLICT",
            " A read or write operation failed because another process's mandatory byte-range lock overlaps with the request."
        },
        {"SSH_FX_BYTE_RANGE_LOCK_REFUSED", "A request for a byte range lock was refused."},
        {"SSH_FX_DELETE_PENDING", "An operation was attempted on a file for which a delete operation is pending."},
        {"SSH_FX_FILE_CORRUPT", "The file is corrupt; an filesystem integrity check should be run."},
        {"SSH_FX_OWNER_INVALID", "The principal specified can not be assigned as an owner of a file."},
        {"SSH_FX_GROUP_INVALID", "The principal specified can not be assigned as the primary group of a file."},
        {
            "SSH_FX_NO_MATCHING_BYTE_RANGE_LOCK",
            "The requested operation could not be completed because the	specifed byte range lock has not been granted."
        },

    };

    public static final String[] getDescription(int errorCode) {
        if ((errorCode < 0) || (errorCode >= messages.length)) {
            return null;
        }

        return messages[errorCode];
    }
}