Mercurial > 510Connectbot
comparison src/ch/ethz/ssh2/SFTPClient.java @ 342:175c7d68f3c4
merge ganymed into mainline
author | Carl Byington <carl@five-ten-sg.com> |
---|---|
date | Thu, 31 Jul 2014 16:33:38 -0700 |
parents | 91a31873c42a |
children |
comparison
equal
deleted
inserted
replaced
272:ce2f4e397703 | 342:175c7d68f3c4 |
---|---|
1 package ch.ethz.ssh2; | |
2 | |
3 import java.io.IOException; | |
4 import java.util.List; | |
5 | |
6 /** | |
7 * @version $Id: SFTPClient.java 151 2014-04-28 10:03:39Z dkocher@sudo.ch $ | |
8 */ | |
9 public interface SFTPClient { | |
10 | |
11 /** | |
12 * Retrieve the file attributes of an open file. | |
13 * | |
14 * @param handle a SFTPv3FileHandle handle. | |
15 * @return a SFTPv3FileAttributes object. | |
16 * @throws IOException | |
17 */ | |
18 SFTPFileAttributes fstat(SFTPFileHandle handle) throws IOException; | |
19 | |
20 /** | |
21 * Retrieve the file attributes of a file. This method | |
22 * follows symbolic links on the server. | |
23 * | |
24 * @param path See the {@link SFTPClient comment} for the class for more details. | |
25 * @return a SFTPv3FileAttributes object. | |
26 * @throws IOException | |
27 * @see #lstat(String) | |
28 */ | |
29 SFTPFileAttributes stat(String path) throws IOException; | |
30 | |
31 /** | |
32 * Retrieve the file attributes of a file. This method | |
33 * does NOT follow symbolic links on the server. | |
34 * | |
35 * @param path See the {@link SFTPClient comment} for the class for more details. | |
36 * @return a SFTPv3FileAttributes object. | |
37 * @throws IOException | |
38 * @see #stat(String) | |
39 */ | |
40 SFTPFileAttributes lstat(String path) throws IOException; | |
41 | |
42 /** | |
43 * Read the target of a symbolic link. Note: OpenSSH (as of version 4.4) gets very upset | |
44 * (SSH_FX_BAD_MESSAGE error) if you want to read the target of a file that is not a | |
45 * symbolic link. Better check first with {@link #lstat(String)}. | |
46 * | |
47 * @param path See the {@link SFTPClient comment} for the class for more details. | |
48 * @return The target of the link. | |
49 * @throws IOException | |
50 */ | |
51 String readLink(String path) throws IOException; | |
52 | |
53 /** | |
54 * Modify the attributes of a file. Used for operations such as changing | |
55 * the ownership, permissions or access times, as well as for truncating a file. | |
56 * | |
57 * @param path See the {@link SFTPClient comment} for the class for more details. | |
58 * @param attr A SFTPv3FileAttributes object. Specifies the modifications to be | |
59 * made to the attributes of the file. Empty fields will be ignored. | |
60 * @throws IOException | |
61 */ | |
62 void setstat(String path, SFTPFileAttributes attr) throws IOException; | |
63 | |
64 /** | |
65 * Modify the attributes of a file. Used for operations such as changing | |
66 * the ownership, permissions or access times, as well as for truncating a file. | |
67 * | |
68 * @param handle a SFTPv3FileHandle handle | |
69 * @param attr A SFTPv3FileAttributes object. Specifies the modifications to be | |
70 * made to the attributes of the file. Empty fields will be ignored. | |
71 * @throws IOException | |
72 */ | |
73 void fsetstat(SFTPFileHandle handle, SFTPFileAttributes attr) throws IOException; | |
74 | |
75 /** | |
76 * Create a symbolic link on the server. Creates a link "src" that points | |
77 * to "target". | |
78 * | |
79 * @param src See the {@link SFTPClient comment} for the class for more details. | |
80 * @param target See the {@link SFTPClient comment} for the class for more details. | |
81 * @throws IOException | |
82 */ | |
83 void createSymlink(String src, String target) throws IOException; | |
84 | |
85 /** | |
86 * Create a symbolic link on the server. Creates a link "src" that points | |
87 * to "target". | |
88 * | |
89 * @param src See the {@link SFTPClient comment} for the class for more details. | |
90 * @param target See the {@link SFTPClient comment} for the class for more details. | |
91 * @throws IOException | |
92 */ | |
93 void createHardlink(String src, String target) throws IOException; | |
94 | |
95 /** | |
96 * Have the server canonicalize any given path name to an absolute path. | |
97 * This is useful for converting path names containing ".." components or | |
98 * relative pathnames without a leading slash into absolute paths. | |
99 * | |
100 * @param path See the {@link SFTPClient comment} for the class for more details. | |
101 * @return An absolute path. | |
102 * @throws IOException | |
103 */ | |
104 String canonicalPath(String path) throws IOException; | |
105 | |
106 void setCharset(String charset) throws IOException; | |
107 | |
108 String getCharset(); | |
109 | |
110 SFTPFileHandle openDirectory(String path) throws IOException; | |
111 | |
112 boolean isConnected(); | |
113 | |
114 void close(); | |
115 | |
116 List<? extends SFTPDirectoryEntry> ls(String dirName) throws IOException; | |
117 | |
118 /** | |
119 * Create a new directory. | |
120 * | |
121 * @param name See the {@link SFTPClient comment} for the class for more details. | |
122 * @param posixPermissions the permissions for this directory, e.g., "0700" (remember that | |
123 * this is octal noation). The server will likely apply a umask. | |
124 * @throws IOException | |
125 */ | |
126 void mkdir(String name, int posixPermissions) throws IOException; | |
127 | |
128 /** | |
129 * Remove a file. | |
130 * | |
131 * @param filename See the {@link SFTPClient comment} for the class for more details. | |
132 * @throws IOException | |
133 */ | |
134 void rm(String filename) throws IOException; | |
135 | |
136 /** | |
137 * Remove an empty directory. | |
138 * | |
139 * @param dirName See the {@link SFTPClient comment} for the class for more details. | |
140 * @throws IOException | |
141 */ | |
142 void rmdir(String dirName) throws IOException; | |
143 | |
144 /** | |
145 * Move a file or directory. | |
146 * | |
147 * @param oldPath See the {@link SFTPClient comment} for the class for more details. | |
148 * @param newPath See the {@link SFTPClient comment} for the class for more details. | |
149 * @throws IOException | |
150 */ | |
151 void mv(String oldPath, String newPath) throws IOException; | |
152 | |
153 /** | |
154 * Create a file and open it for reading and writing. | |
155 * Same as {@link #createFile(String, SFTPFileAttributes) createFile(filename, null)}. | |
156 * | |
157 * @param filename See the {@link SFTPClient comment} for the class for more details. | |
158 * @return a SFTPv3FileHandle handle | |
159 * @throws IOException | |
160 */ | |
161 SFTPFileHandle createFile(String filename) throws IOException; | |
162 | |
163 /** | |
164 * Create a file and open it for reading and writing. | |
165 * You can specify the default attributes of the file (the server may or may | |
166 * not respect your wishes). | |
167 * | |
168 * @param filename See the {@link SFTPv3Client comment} for the class for more details. | |
169 * @param attr may be <code>null</code> to use server defaults. Probably only | |
170 * the <code>uid</code>, <code>gid</code> and <code>permissions</code> | |
171 * (remember the server may apply a umask) entries of the {@link SFTPv3FileHandle} | |
172 * structure make sense. You need only to set those fields where you want | |
173 * to override the server's defaults. | |
174 * @return a SFTPv3FileHandle handle | |
175 * @throws IOException | |
176 */ | |
177 SFTPFileHandle createFile(String filename, SFTPFileAttributes attr) throws IOException; | |
178 | |
179 SFTPFileHandle openFile(String filename, int flags) throws IOException; | |
180 | |
181 /** | |
182 * Read bytes from a file in a parallel fashion. As many bytes as you want will be read. | |
183 * <p/> | |
184 * <ul> | |
185 * <li>The server will read as many bytes as it can from the file (up to <code>len</code>), | |
186 * and return them.</li> | |
187 * <li>If EOF is encountered before reading any data, <code>-1</code> is returned. | |
188 * <li>If an error occurs, an exception is thrown</li>. | |
189 * <li>For normal disk files, it is guaranteed that the server will return the specified | |
190 * number of bytes, or up to end of file. For, e.g., device files this may return | |
191 * fewer bytes than requested.</li> | |
192 * </ul> | |
193 * | |
194 * @param handle a SFTPv3FileHandle handle | |
195 * @param fileOffset offset (in bytes) in the file | |
196 * @param dst the destination byte array | |
197 * @param dstoff offset in the destination byte array | |
198 * @param len how many bytes to read, 0 < len | |
199 * @return the number of bytes that could be read, may be less than requested if | |
200 * the end of the file is reached, -1 is returned in case of <code>EOF</code> | |
201 * @throws IOException | |
202 */ | |
203 int read(SFTPFileHandle handle, long fileOffset, byte[] dst, int dstoff, int len) throws IOException; | |
204 | |
205 /** | |
206 * Write bytes to a file. If <code>len</code> > 32768, then the write operation will | |
207 * be split into multiple writes. | |
208 * | |
209 * @param handle a SFTPv3FileHandle handle. | |
210 * @param fileOffset offset (in bytes) in the file. | |
211 * @param src the source byte array. | |
212 * @param srcoff offset in the source byte array. | |
213 * @param len how many bytes to write. | |
214 * @throws IOException | |
215 */ | |
216 void write(SFTPFileHandle handle, long fileOffset, byte[] src, int srcoff, int len) throws IOException; | |
217 | |
218 /** | |
219 * Close a file. | |
220 * | |
221 * @param handle a file handle | |
222 * @throws IOException | |
223 */ | |
224 void closeFile(SFTPFileHandle handle) throws IOException; | |
225 } |