comparison src/ch/ethz/ssh2/ServerAuthenticationCallback.java @ 308:42b15aaa7ac7 ganymed

merge
author Carl Byington <carl@five-ten-sg.com>
date Wed, 30 Jul 2014 14:21:50 -0700 (2014-07-30)
parents 071eccdff8ea
children
comparison
equal deleted inserted replaced
306:90e47d99ea54 308:42b15aaa7ac7
5 5
6 package ch.ethz.ssh2; 6 package ch.ethz.ssh2;
7 7
8 /** 8 /**
9 * A callback used during the authentication phase (see RFC 4252) when 9 * A callback used during the authentication phase (see RFC 4252) when
10 * implementing a SSH server. 10 * implementing a SSH server.
11 * 11 *
12 * @author Christian Plattner 12 * @author Christian Plattner
13 * @version 2.50, 03/15/10 13 * @version 2.50, 03/15/10
14 */ 14 */
15 public interface ServerAuthenticationCallback 15 public interface ServerAuthenticationCallback {
16 { 16 /**
17 /** 17 * The method name for host-based authentication.
18 * The method name for host-based authentication. 18 */
19 */ 19 public final String METHOD_HOSTBASED = "hostbased";
20 public final String METHOD_HOSTBASED = "hostbased";
21 20
22 /** 21 /**
23 * The method name for public-key authentication. 22 * The method name for public-key authentication.
24 */ 23 */
25 public final String METHOD_PUBLICKEY = "publickey"; 24 public final String METHOD_PUBLICKEY = "publickey";
26 25
27 /** 26 /**
28 * The method name for password authentication. 27 * The method name for password authentication.
29 */ 28 */
30 public final String METHOD_PASSWORD = "password"; 29 public final String METHOD_PASSWORD = "password";
31 30
32 /** 31 /**
33 * Called when the client enters authentication. 32 * Called when the client enters authentication.
34 * This gives you the chance to set a custom authentication banner 33 * This gives you the chance to set a custom authentication banner
35 * for this SSH-2 session. This is the first method called in this interface. 34 * for this SSH-2 session. This is the first method called in this interface.
36 * It will only called at most once per <code>ServerConnection</code>. 35 * It will only called at most once per <code>ServerConnection</code>.
37 * 36 *
38 * @param sc The corresponding <code>ServerConnection</code> 37 * @param sc The corresponding <code>ServerConnection</code>
39 * @return The authentication banner or <code>NULL</code> in case no banner should be send. 38 * @return The authentication banner or <code>NULL</code> in case no banner should be send.
40 */ 39 */
41 public String initAuthentication(ServerConnection sc); 40 public String initAuthentication(ServerConnection sc);
42 41
43 /** 42 /**
44 * Return the authentication methods that are currently available to the client. 43 * Return the authentication methods that are currently available to the client.
45 * Be prepared to return this information at any time during the authentication procedure. 44 * Be prepared to return this information at any time during the authentication procedure.
46 * <p/> 45 * <p/>
47 * The returned name-list of 'method names' (see RFC4252) indicate the authentication methods 46 * The returned name-list of 'method names' (see RFC4252) indicate the authentication methods
48 * that may productively continue the authentication dialog. 47 * that may productively continue the authentication dialog.
49 * </p> 48 * </p>
50 * It is RECOMMENDED that servers only include those 'method name' 49 * It is RECOMMENDED that servers only include those 'method name'
51 * values in the name-list that are actually useful. However, it is not 50 * values in the name-list that are actually useful. However, it is not
52 * illegal to include 'method name' values that cannot be used to 51 * illegal to include 'method name' values that cannot be used to
53 * authenticate the user. 52 * authenticate the user.
54 * <p/> 53 * <p/>
55 * Already successfully completed authentications SHOULD NOT be included 54 * Already successfully completed authentications SHOULD NOT be included
56 * in the name-list, unless they should be performed again for some reason. 55 * in the name-list, unless they should be performed again for some reason.
57 * 56 *
58 * @see #METHOD_HOSTBASED 57 * @see #METHOD_HOSTBASED
59 * @see #METHOD_PASSWORD 58 * @see #METHOD_PASSWORD
60 * @see #METHOD_PUBLICKEY 59 * @see #METHOD_PUBLICKEY
61 * 60 *
62 * @param sc 61 * @param sc
63 * @return A list of method names. 62 * @return A list of method names.
64 */ 63 */
65 public String[] getRemainingAuthMethods(ServerConnection sc); 64 public String[] getRemainingAuthMethods(ServerConnection sc);
66 65
67 /** 66 /**
68 * Typically, this will be called be the client to get the list of 67 * Typically, this will be called be the client to get the list of
69 * authentication methods that can continue. You should simply return 68 * authentication methods that can continue. You should simply return
70 * {@link AuthenticationResult#FAILURE}. 69 * {@link AuthenticationResult#FAILURE}.
71 * 70 *
72 * @param sc 71 * @param sc
73 * @param username Name of the user that wants to log in with the "none" method. 72 * @param username Name of the user that wants to log in with the "none" method.
74 * @return 73 * @return
75 */ 74 */
76 public AuthenticationResult authenticateWithNone(ServerConnection sc, String username); 75 public AuthenticationResult authenticateWithNone(ServerConnection sc, String username);
77 76
78 public AuthenticationResult authenticateWithPassword(ServerConnection sc, String username, String password); 77 public AuthenticationResult authenticateWithPassword(ServerConnection sc, String username, String password);
79 78
80 /** 79 /**
81 * NOTE: Not implemented yet. 80 * NOTE: Not implemented yet.
82 * 81 *
83 * @param sc 82 * @param sc
84 * @param username 83 * @param username
85 * @param algorithm 84 * @param algorithm
86 * @param publickey 85 * @param publickey
87 * @param signature 86 * @param signature
88 * @return 87 * @return
89 */ 88 */
90 public AuthenticationResult authenticateWithPublicKey(ServerConnection sc, String username, String algorithm, 89 public AuthenticationResult authenticateWithPublicKey(ServerConnection sc, String username, String algorithm,
91 byte[] publickey, byte[] signature); 90 byte[] publickey, byte[] signature);
92 } 91 }