Mercurial > 510Connectbot
comparison src/ch/ethz/ssh2/SFTPv3FileAttributes.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 | 071eccdff8ea |
children |
comparison
equal
deleted
inserted
replaced
272:ce2f4e397703 | 342:175c7d68f3c4 |
---|---|
1 /* | |
2 * Copyright (c) 2006-2011 Christian Plattner. All rights reserved. | |
3 * Please refer to the LICENSE.txt for licensing details. | |
4 */ | |
5 package ch.ethz.ssh2; | |
6 | |
7 import java.io.IOException; | |
8 | |
9 import ch.ethz.ssh2.packets.TypesReader; | |
10 import ch.ethz.ssh2.packets.TypesWriter; | |
11 import ch.ethz.ssh2.sftp.AttribFlags; | |
12 | |
13 /** | |
14 * A <code>SFTPv3FileAttributes</code> object represents detail information | |
15 * about a file on the server. Not all fields may/must be present. | |
16 * | |
17 * @author Christian Plattner, plattner@inf.ethz.ch | |
18 * @version $Id: SFTPv3FileAttributes.java 133 2014-04-14 12:26:29Z dkocher@sudo.ch $ | |
19 */ | |
20 public class SFTPv3FileAttributes implements SFTPFileAttributes { | |
21 /** | |
22 * The SIZE attribute. <code>NULL</code> if not present. | |
23 */ | |
24 public Long size = null; | |
25 | |
26 /** | |
27 * The UID attribute. <code>NULL</code> if not present. | |
28 */ | |
29 public Integer uid = null; | |
30 | |
31 /** | |
32 * The GID attribute. <code>NULL</code> if not present. | |
33 */ | |
34 public Integer gid = null; | |
35 | |
36 /** | |
37 * The POSIX permissions. <code>NULL</code> if not present. | |
38 * <p/> | |
39 * Here is a list: | |
40 * <p/> | |
41 * <pre>Note: these numbers are all OCTAL. | |
42 * <p/> | |
43 * S_IFMT 0170000 bitmask for the file type bitfields | |
44 * S_IFSOCK 0140000 socket | |
45 * S_IFLNK 0120000 symbolic link | |
46 * S_IFREG 0100000 regular file | |
47 * S_IFBLK 0060000 block device | |
48 * S_IFDIR 0040000 directory | |
49 * S_IFCHR 0020000 character device | |
50 * S_IFIFO 0010000 fifo | |
51 * S_ISUID 0004000 set UID bit | |
52 * S_ISGID 0002000 set GID bit | |
53 * S_ISVTX 0001000 sticky bit | |
54 * <p/> | |
55 * S_IRWXU 00700 mask for file owner permissions | |
56 * S_IRUSR 00400 owner has read permission | |
57 * S_IWUSR 00200 owner has write permission | |
58 * S_IXUSR 00100 owner has execute permission | |
59 * S_IRWXG 00070 mask for group permissions | |
60 * S_IRGRP 00040 group has read permission | |
61 * S_IWGRP 00020 group has write permission | |
62 * S_IXGRP 00010 group has execute permission | |
63 * S_IRWXO 00007 mask for permissions for others (not in group) | |
64 * S_IROTH 00004 others have read permission | |
65 * S_IWOTH 00002 others have write permisson | |
66 * S_IXOTH 00001 others have execute permission | |
67 * </pre> | |
68 */ | |
69 public Integer permissions = null; | |
70 | |
71 /** | |
72 * Last access time of the file. | |
73 * <p/> | |
74 * The atime attribute. Represented as seconds from Jan 1, 1970 in UTC. | |
75 * <code>NULL</code> if not present. | |
76 */ | |
77 public Integer atime = null; | |
78 | |
79 /** | |
80 * The mtime attribute. Represented as seconds from Jan 1, 1970 in UTC. | |
81 * <code>NULL</code> if not present. | |
82 */ | |
83 public Integer mtime = null; | |
84 | |
85 /** | |
86 * Checks if this entry is a directory. | |
87 * | |
88 * @return Returns true if permissions are available and they indicate | |
89 * that this entry represents a directory. | |
90 */ | |
91 public boolean isDirectory() { | |
92 if (permissions == null) { | |
93 return false; | |
94 } | |
95 | |
96 return ((permissions & 0040000) == 0040000); | |
97 } | |
98 | |
99 /** | |
100 * Checks if this entry is a regular file. | |
101 * | |
102 * @return Returns true if permissions are available and they indicate | |
103 * that this entry represents a regular file. | |
104 */ | |
105 public boolean isRegularFile() { | |
106 if (permissions == null) { | |
107 return false; | |
108 } | |
109 | |
110 return ((permissions & 0100000) == 0100000); | |
111 } | |
112 | |
113 /** | |
114 * Checks if this entry is a a symlink. | |
115 * | |
116 * @return Returns true if permissions are available and they indicate | |
117 * that this entry represents a symlink. | |
118 */ | |
119 public boolean isSymlink() { | |
120 if (permissions == null) { | |
121 return false; | |
122 } | |
123 | |
124 return ((permissions & 0120000) == 0120000); | |
125 } | |
126 | |
127 /** | |
128 * Turn the POSIX permissions into a 7 digit octal representation. | |
129 * Note: the returned value is first masked with <code>0177777</code>. | |
130 * | |
131 * @return <code>NULL</code> if permissions are not available. | |
132 */ | |
133 public String getOctalPermissions() { | |
134 if (permissions == null) { | |
135 return null; | |
136 } | |
137 | |
138 String res = Integer.toString(permissions.intValue() & 0177777, 8); | |
139 StringBuilder sb = new StringBuilder(); | |
140 int leadingZeros = 7 - res.length(); | |
141 | |
142 while (leadingZeros > 0) { | |
143 sb.append('0'); | |
144 leadingZeros--; | |
145 } | |
146 | |
147 sb.append(res); | |
148 return sb.toString(); | |
149 } | |
150 | |
151 public SFTPv3FileAttributes() { | |
152 // | |
153 } | |
154 | |
155 /** | |
156 * uint32 valid-attribute-flags | |
157 * byte type always present | |
158 * uint64 size if flag SIZE | |
159 * uint64 allocation-size if flag ALLOCATION_SIZE | |
160 * string owner if flag OWNERGROUP | |
161 * string group if flag OWNERGROUP | |
162 * uint32 permissions if flag PERMISSIONS | |
163 * int64 atime if flag ACCESSTIME | |
164 * uint32 atime-nseconds if flag SUBSECOND_TIMES | |
165 * int64 createtime if flag CREATETIME | |
166 * uint32 createtime-nseconds if flag SUBSECOND_TIMES | |
167 * int64 mtime if flag MODIFYTIME | |
168 * uint32 mtime-nseconds if flag SUBSECOND_TIMES | |
169 * int64 ctime if flag CTIME | |
170 * uint32 ctime-nseconds if flag SUBSECOND_TIMES | |
171 * string acl if flag ACL | |
172 * uint32 attrib-bits if flag BITS | |
173 * uint32 attrib-bits-valid if flag BITS | |
174 * byte text-hint if flag TEXT_HINT | |
175 * string mime-type if flag MIME_TYPE | |
176 * uint32 link-count if flag LINK_COUNT | |
177 * string untranslated-name if flag UNTRANSLATED_NAME | |
178 * uint32 extended-count if flag EXTENDED | |
179 * extension-pair extensions | |
180 */ | |
181 public SFTPv3FileAttributes(final TypesReader tr) throws IOException { | |
182 int flags = tr.readUINT32(); | |
183 | |
184 if ((flags & AttribFlags.SSH_FILEXFER_ATTR_SIZE) != 0) { | |
185 this.size = tr.readUINT64(); | |
186 } | |
187 | |
188 if ((flags & AttribFlags.SSH_FILEXFER_ATTR_V3_UIDGID) != 0) { | |
189 this.uid = tr.readUINT32(); | |
190 this.gid = tr.readUINT32(); | |
191 } | |
192 | |
193 if ((flags & AttribFlags.SSH_FILEXFER_ATTR_PERMISSIONS) != 0) { | |
194 this.permissions = tr.readUINT32(); | |
195 } | |
196 | |
197 if ((flags & AttribFlags.SSH_FILEXFER_ATTR_V3_ACMODTIME) != 0) { | |
198 this.atime = tr.readUINT32(); | |
199 this.mtime = tr.readUINT32(); | |
200 } | |
201 | |
202 if ((flags & AttribFlags.SSH_FILEXFER_ATTR_EXTENDED) != 0) { | |
203 int count = tr.readUINT32(); | |
204 | |
205 // Read it anyway to detect corrupt packets | |
206 while (count > 0) { | |
207 tr.readByteString(); | |
208 tr.readByteString(); | |
209 count--; | |
210 } | |
211 } | |
212 } | |
213 | |
214 /** | |
215 * The same encoding is used both when returning file | |
216 * attributes from the server and when sending file attributes to the | |
217 * server. | |
218 * | |
219 * @return Encoded attributes | |
220 */ | |
221 public byte[] toBytes() { | |
222 TypesWriter tw = new TypesWriter(); | |
223 int attrFlags = 0; | |
224 | |
225 if (this.size != null) { | |
226 attrFlags = attrFlags | AttribFlags.SSH_FILEXFER_ATTR_SIZE; | |
227 } | |
228 | |
229 if ((this.uid != null) && (this.gid != null)) { | |
230 attrFlags = attrFlags | AttribFlags.SSH_FILEXFER_ATTR_V3_UIDGID; | |
231 } | |
232 | |
233 if (this.permissions != null) { | |
234 attrFlags = attrFlags | AttribFlags.SSH_FILEXFER_ATTR_PERMISSIONS; | |
235 } | |
236 | |
237 if ((this.atime != null) && (this.mtime != null)) { | |
238 attrFlags = attrFlags | AttribFlags.SSH_FILEXFER_ATTR_V3_ACMODTIME; | |
239 } | |
240 | |
241 tw.writeUINT32(attrFlags); | |
242 | |
243 if (this.size != null) { | |
244 tw.writeUINT64(this.size); | |
245 } | |
246 | |
247 if ((this.uid != null) && (this.gid != null)) { | |
248 tw.writeUINT32(this.uid); | |
249 tw.writeUINT32(this.gid); | |
250 } | |
251 | |
252 if (this.permissions != null) { | |
253 tw.writeUINT32(this.permissions); | |
254 } | |
255 | |
256 if ((this.atime != null) && (this.mtime != null)) { | |
257 tw.writeUINT32(this.atime); | |
258 tw.writeUINT32(this.mtime); | |
259 } | |
260 | |
261 return tw.getBytes(); | |
262 } | |
263 | |
264 @Override | |
265 public String toString() { | |
266 final StringBuilder sb = new StringBuilder("SFTPv3FileAttributes{"); | |
267 sb.append("size=").append(size); | |
268 sb.append(", uid=").append(uid); | |
269 sb.append(", gid=").append(gid); | |
270 sb.append(", permissions=").append(permissions); | |
271 sb.append(", atime=").append(atime); | |
272 sb.append(", mtime=").append(mtime); | |
273 sb.append('}'); | |
274 return sb.toString(); | |
275 } | |
276 } |