Compare commits

..

No commits in common. "dev" and "master" have entirely different histories.
dev ... master

4 changed files with 147 additions and 214 deletions

2
.gitignore vendored
View File

@ -14,6 +14,4 @@ target
.idea .idea
*.conf *.conf
*.PNG *.PNG
.vscode/
*.class *.class

View File

@ -14,8 +14,8 @@
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<maven.test.failure.ignore>true</maven.test.failure.ignore> <maven.test.failure.ignore>true</maven.test.failure.ignore>
<maven.test.skip>true</maven.test.skip> <maven.test.skip>true</maven.test.skip>
<jdk.version>1.8</jdk.version> <jdk.version>1.6</jdk.version>
<slf4j.version>1.7.36</slf4j.version> <slf4j.version>1.7.26</slf4j.version>
</properties> </properties>
<dependencies> <dependencies>

View File

@ -16,7 +16,6 @@ package org.csource.common;
*/ */
public class MyException extends Exception { public class MyException extends Exception {
public MyException(String s, Exception e) { public MyException(String s, Exception e) {
super(s, e);
} }
public MyException(String message) { public MyException(String message) {

View File

@ -73,18 +73,15 @@ public class StorageClient {
* upload file to storage server (by file name) * upload file to storage server (by file name)
* *
* @param local_filename local filename to upload * @param local_filename local filename to upload
* @param file_ext_name file ext name, do not include dot(.), null to extract * @param file_ext_name file ext name, do not include dot(.), null to extract ext name from the local filename
* ext name from the local filename
* @param meta_list meta info array * @param meta_list meta info array
* @return 2 elements string array if success:<br> * @return 2 elements string array if success:<br>
* <ul> * <ul><li>results[0]: the group name to store the file </li></ul>
* <li>results[0]: the group name to store the file</li> * <ul><li>results[1]: the new created filename</li></ul>
* <li>results[1]: the new created filename</li> * return null if fail
* </ul>
* return null if fail
*/ */
public String[] upload_file(String local_filename, String file_ext_name, public String[] upload_file(String local_filename, String file_ext_name,
NameValuePair[] meta_list) throws IOException, MyException { NameValuePair[] meta_list) throws IOException, MyException {
final String group_name = null; final String group_name = null;
return this.upload_file(group_name, local_filename, file_ext_name, meta_list); return this.upload_file(group_name, local_filename, file_ext_name, meta_list);
} }
@ -94,18 +91,15 @@ public class StorageClient {
* *
* @param group_name the group name to upload file to, can be empty * @param group_name the group name to upload file to, can be empty
* @param local_filename local filename to upload * @param local_filename local filename to upload
* @param file_ext_name file ext name, do not include dot(.), null to extract * @param file_ext_name file ext name, do not include dot(.), null to extract ext name from the local filename
* ext name from the local filename
* @param meta_list meta info array * @param meta_list meta info array
* @return 2 elements string array if success:<br> * @return 2 elements string array if success:<br>
* <ul> * <ul><li>results[0]: the group name to store the file </li></ul>
* <li>results[0]: the group name to store the file</li> * <ul><li>results[1]: the new created filename</li></ul>
* <li>results[1]: the new created filename</li> * return null if fail
* </ul>
* return null if fail
*/ */
protected String[] upload_file(String group_name, String local_filename, String file_ext_name, protected String[] upload_file(String group_name, String local_filename, String file_ext_name,
NameValuePair[] meta_list) throws IOException, MyException { NameValuePair[] meta_list) throws IOException, MyException {
final byte cmd = ProtoCommon.STORAGE_PROTO_CMD_UPLOAD_FILE; final byte cmd = ProtoCommon.STORAGE_PROTO_CMD_UPLOAD_FILE;
return this.upload_file(cmd, group_name, local_filename, file_ext_name, meta_list); return this.upload_file(cmd, group_name, local_filename, file_ext_name, meta_list);
} }
@ -116,18 +110,15 @@ public class StorageClient {
* @param cmd the command * @param cmd the command
* @param group_name the group name to upload file to, can be empty * @param group_name the group name to upload file to, can be empty
* @param local_filename local filename to upload * @param local_filename local filename to upload
* @param file_ext_name file ext name, do not include dot(.), null to extract * @param file_ext_name file ext name, do not include dot(.), null to extract ext name from the local filename
* ext name from the local filename
* @param meta_list meta info array * @param meta_list meta info array
* @return 2 elements string array if success:<br> * @return 2 elements string array if success:<br>
* <ul> * <ul><li>results[0]: the group name to store the file </li></ul>
* <li>results[0]: the group name to store the file</li> * <ul><li>results[1]: the new created filename</li></ul>
* <li>results[1]: the new created filename</li> * return null if fail
* </ul>
* return null if fail
*/ */
protected String[] upload_file(byte cmd, String group_name, String local_filename, String file_ext_name, protected String[] upload_file(byte cmd, String group_name, String local_filename, String file_ext_name,
NameValuePair[] meta_list) throws IOException, MyException { NameValuePair[] meta_list) throws IOException, MyException {
File f = new File(local_filename); File f = new File(local_filename);
FileInputStream fis = new FileInputStream(f); FileInputStream fis = new FileInputStream(f);
@ -155,14 +146,12 @@ public class StorageClient {
* @param file_ext_name file ext name, do not include dot(.) * @param file_ext_name file ext name, do not include dot(.)
* @param meta_list meta info array * @param meta_list meta info array
* @return 2 elements string array if success:<br> * @return 2 elements string array if success:<br>
* <ul> * <ul><li>results[0]: the group name to store the file</li></ul>
* <li>results[0]: the group name to store the file</li> * <ul><li>results[1]: the new created filename</li></ul>
* <li>results[1]: the new created filename</li> * return null if fail
* </ul>
* return null if fail
*/ */
public String[] upload_file(byte[] file_buff, int offset, int length, String file_ext_name, public String[] upload_file(byte[] file_buff, int offset, int length, String file_ext_name,
NameValuePair[] meta_list) throws IOException, MyException { NameValuePair[] meta_list) throws IOException, MyException {
final String group_name = null; final String group_name = null;
return this.upload_file(group_name, file_buff, offset, length, file_ext_name, meta_list); return this.upload_file(group_name, file_buff, offset, length, file_ext_name, meta_list);
} }
@ -177,14 +166,12 @@ public class StorageClient {
* @param file_ext_name file ext name, do not include dot(.) * @param file_ext_name file ext name, do not include dot(.)
* @param meta_list meta info array * @param meta_list meta info array
* @return 2 elements string array if success:<br> * @return 2 elements string array if success:<br>
* <ul> * <ul><li>results[0]: the group name to store the file</li></ul>
* <li>results[0]: the group name to store the file</li> * <ul><li>results[1]: the new created filename</li></ul>
* <li>results[1]: the new created filename</li> * return null if fail
* </ul>
* return null if fail
*/ */
public String[] upload_file(String group_name, byte[] file_buff, int offset, int length, public String[] upload_file(String group_name, byte[] file_buff, int offset, int length,
String file_ext_name, NameValuePair[] meta_list) throws IOException, MyException { String file_ext_name, NameValuePair[] meta_list) throws IOException, MyException {
return this.do_upload_file(ProtoCommon.STORAGE_PROTO_CMD_UPLOAD_FILE, group_name, null, null, file_ext_name, return this.do_upload_file(ProtoCommon.STORAGE_PROTO_CMD_UPLOAD_FILE, group_name, null, null, file_ext_name,
length, new UploadBuff(file_buff, offset, length), meta_list); length, new UploadBuff(file_buff, offset, length), meta_list);
} }
@ -196,14 +183,12 @@ public class StorageClient {
* @param file_ext_name file ext name, do not include dot(.) * @param file_ext_name file ext name, do not include dot(.)
* @param meta_list meta info array * @param meta_list meta info array
* @return 2 elements string array if success:<br> * @return 2 elements string array if success:<br>
* <ul> * <ul><li>results[0]: the group name to store the file</li></ul>
* <li>results[0]: the group name to store the file</li> * <ul><li>results[1]: the new created filename</li></ul>
* <li>results[1]: the new created filename</li> * return null if fail
* </ul>
* return null if fail
*/ */
public String[] upload_file(byte[] file_buff, String file_ext_name, public String[] upload_file(byte[] file_buff, String file_ext_name,
NameValuePair[] meta_list) throws IOException, MyException { NameValuePair[] meta_list) throws IOException, MyException {
final String group_name = null; final String group_name = null;
return this.upload_file(group_name, file_buff, 0, file_buff.length, file_ext_name, meta_list); return this.upload_file(group_name, file_buff, 0, file_buff.length, file_ext_name, meta_list);
} }
@ -216,14 +201,12 @@ public class StorageClient {
* @param file_ext_name file ext name, do not include dot(.) * @param file_ext_name file ext name, do not include dot(.)
* @param meta_list meta info array * @param meta_list meta info array
* @return 2 elements string array if success:<br> * @return 2 elements string array if success:<br>
* <ul> * <ul><li>results[0]: the group name to store the file</li></ul>
* <li>results[0]: the group name to store the file</li> * <ul><li>results[1]: the new created filename</li></ul>
* <li>results[1]: the new created filename</li> * return null if fail
* </ul>
* return null if fail
*/ */
public String[] upload_file(String group_name, byte[] file_buff, public String[] upload_file(String group_name, byte[] file_buff,
String file_ext_name, NameValuePair[] meta_list) throws IOException, MyException { String file_ext_name, NameValuePair[] meta_list) throws IOException, MyException {
return this.do_upload_file(ProtoCommon.STORAGE_PROTO_CMD_UPLOAD_FILE, group_name, null, null, file_ext_name, return this.do_upload_file(ProtoCommon.STORAGE_PROTO_CMD_UPLOAD_FILE, group_name, null, null, file_ext_name,
file_buff.length, new UploadBuff(file_buff, 0, file_buff.length), meta_list); file_buff.length, new UploadBuff(file_buff, 0, file_buff.length), meta_list);
} }
@ -237,14 +220,12 @@ public class StorageClient {
* @param file_ext_name file ext name, do not include dot(.) * @param file_ext_name file ext name, do not include dot(.)
* @param meta_list meta info array * @param meta_list meta info array
* @return 2 elements string array if success:<br> * @return 2 elements string array if success:<br>
* <ul> * <ul><li>results[0]: the group name to store the file</li></ul>
* <li>results[0]: the group name to store the file</li> * <ul><li>results[1]: the new created filename</li></ul>
* <li>results[1]: the new created filename</li> * return null if fail
* </ul>
* return null if fail
*/ */
public String[] upload_file(String group_name, long file_size, UploadCallback callback, public String[] upload_file(String group_name, long file_size, UploadCallback callback,
String file_ext_name, NameValuePair[] meta_list) throws IOException, MyException { String file_ext_name, NameValuePair[] meta_list) throws IOException, MyException {
final String master_filename = null; final String master_filename = null;
final String prefix_name = null; final String prefix_name = null;
@ -259,18 +240,15 @@ public class StorageClient {
* @param master_filename the master file name to generate the slave file * @param master_filename the master file name to generate the slave file
* @param prefix_name the prefix name to generate the slave file * @param prefix_name the prefix name to generate the slave file
* @param local_filename local filename to upload * @param local_filename local filename to upload
* @param file_ext_name file ext name, do not include dot(.), null to extract * @param file_ext_name file ext name, do not include dot(.), null to extract ext name from the local filename
* ext name from the local filename
* @param meta_list meta info array * @param meta_list meta info array
* @return 2 elements string array if success:<br> * @return 2 elements string array if success:<br>
* <ul> * <ul><li>results[0]: the group name to store the file </li></ul>
* <li>results[0]: the group name to store the file</li> * <ul><li>results[1]: the new created filename</li></ul>
* <li>results[1]: the new created filename</li> * return null if fail
* </ul>
* return null if fail
*/ */
public String[] upload_file(String group_name, String master_filename, String prefix_name, public String[] upload_file(String group_name, String master_filename, String prefix_name,
String local_filename, String file_ext_name, NameValuePair[] meta_list) throws IOException, MyException { String local_filename, String file_ext_name, NameValuePair[] meta_list) throws IOException, MyException {
if ((group_name == null || group_name.length() == 0) || if ((group_name == null || group_name.length() == 0) ||
(master_filename == null || master_filename.length() == 0) || (master_filename == null || master_filename.length() == 0) ||
(prefix_name == null)) { (prefix_name == null)) {
@ -288,8 +266,8 @@ public class StorageClient {
} }
try { try {
return this.do_upload_file(ProtoCommon.STORAGE_PROTO_CMD_UPLOAD_SLAVE_FILE, group_name, master_filename, return this.do_upload_file(ProtoCommon.STORAGE_PROTO_CMD_UPLOAD_SLAVE_FILE, group_name, master_filename, prefix_name,
prefix_name, file_ext_name, f.length(), new UploadStream(fis, f.length()), meta_list); file_ext_name, f.length(), new UploadStream(fis, f.length()), meta_list);
} finally { } finally {
fis.close(); fis.close();
} }
@ -305,23 +283,20 @@ public class StorageClient {
* @param file_ext_name file ext name, do not include dot(.) * @param file_ext_name file ext name, do not include dot(.)
* @param meta_list meta info array * @param meta_list meta info array
* @return 2 elements string array if success:<br> * @return 2 elements string array if success:<br>
* <ul> * <ul><li>results[0]: the group name to store the file</li></ul>
* <li>results[0]: the group name to store the file</li> * <ul><li>results[1]: the new created filename</li></ul>
* <li>results[1]: the new created filename</li> * return null if fail
* </ul>
* return null if fail
*/ */
public String[] upload_file(String group_name, String master_filename, String prefix_name, public String[] upload_file(String group_name, String master_filename, String prefix_name,
byte[] file_buff, String file_ext_name, NameValuePair[] meta_list) throws IOException, MyException { byte[] file_buff, String file_ext_name, NameValuePair[] meta_list) throws IOException, MyException {
if ((group_name == null || group_name.length() == 0) || if ((group_name == null || group_name.length() == 0) ||
(master_filename == null || master_filename.length() == 0) || (master_filename == null || master_filename.length() == 0) ||
(prefix_name == null)) { (prefix_name == null)) {
throw new MyException("invalid arguement"); throw new MyException("invalid arguement");
} }
return this.do_upload_file(ProtoCommon.STORAGE_PROTO_CMD_UPLOAD_SLAVE_FILE, group_name, master_filename, return this.do_upload_file(ProtoCommon.STORAGE_PROTO_CMD_UPLOAD_SLAVE_FILE, group_name, master_filename, prefix_name,
prefix_name, file_ext_name, file_buff.length, new UploadBuff(file_buff, 0, file_buff.length), file_ext_name, file_buff.length, new UploadBuff(file_buff, 0, file_buff.length), meta_list);
meta_list);
} }
/** /**
@ -336,23 +311,21 @@ public class StorageClient {
* @param file_ext_name file ext name, do not include dot(.) * @param file_ext_name file ext name, do not include dot(.)
* @param meta_list meta info array * @param meta_list meta info array
* @return 2 elements string array if success:<br> * @return 2 elements string array if success:<br>
* <ul> * <ul><li>results[0]: the group name to store the file</li></ul>
* <li>results[0]: the group name to store the file</li> * <ul><li>results[1]: the new created filename</li></ul>
* <li>results[1]: the new created filename</li> * return null if fail
* </ul>
* return null if fail
*/ */
public String[] upload_file(String group_name, String master_filename, String prefix_name, public String[] upload_file(String group_name, String master_filename, String prefix_name,
byte[] file_buff, int offset, int length, String file_ext_name, byte[] file_buff, int offset, int length, String file_ext_name,
NameValuePair[] meta_list) throws IOException, MyException { NameValuePair[] meta_list) throws IOException, MyException {
if ((group_name == null || group_name.length() == 0) || if ((group_name == null || group_name.length() == 0) ||
(master_filename == null || master_filename.length() == 0) || (master_filename == null || master_filename.length() == 0) ||
(prefix_name == null)) { (prefix_name == null)) {
throw new MyException("invalid arguement"); throw new MyException("invalid arguement");
} }
return this.do_upload_file(ProtoCommon.STORAGE_PROTO_CMD_UPLOAD_SLAVE_FILE, group_name, master_filename, return this.do_upload_file(ProtoCommon.STORAGE_PROTO_CMD_UPLOAD_SLAVE_FILE, group_name, master_filename, prefix_name,
prefix_name, file_ext_name, length, new UploadBuff(file_buff, offset, length), meta_list); file_ext_name, length, new UploadBuff(file_buff, offset, length), meta_list);
} }
/** /**
@ -366,35 +339,30 @@ public class StorageClient {
* @param file_ext_name file ext name, do not include dot(.) * @param file_ext_name file ext name, do not include dot(.)
* @param meta_list meta info array * @param meta_list meta info array
* @return 2 elements string array if success:<br> * @return 2 elements string array if success:<br>
* <ul> * <ul><li>results[0]: the group name to store the file</li></ul>
* <li>results[0]: the group name to store the file</li> * <ul><li>results[1]: the new created filename</li></ul>
* <li>results[1]: the new created filename</li> * return null if fail
* </ul>
* return null if fail
*/ */
public String[] upload_file(String group_name, String master_filename, public String[] upload_file(String group_name, String master_filename,
String prefix_name, long file_size, UploadCallback callback, String prefix_name, long file_size, UploadCallback callback,
String file_ext_name, NameValuePair[] meta_list) throws IOException, MyException { String file_ext_name, NameValuePair[] meta_list) throws IOException, MyException {
return this.do_upload_file(ProtoCommon.STORAGE_PROTO_CMD_UPLOAD_SLAVE_FILE, group_name, master_filename, return this.do_upload_file(ProtoCommon.STORAGE_PROTO_CMD_UPLOAD_SLAVE_FILE, group_name, master_filename, prefix_name,
prefix_name, file_ext_name, file_size, callback, meta_list); file_ext_name, file_size, callback, meta_list);
} }
/** /**
* upload appender file to storage server (by file name) * upload appender file to storage server (by file name)
* *
* @param local_filename local filename to upload * @param local_filename local filename to upload
* @param file_ext_name file ext name, do not include dot(.), null to extract * @param file_ext_name file ext name, do not include dot(.), null to extract ext name from the local filename
* ext name from the local filename
* @param meta_list meta info array * @param meta_list meta info array
* @return 2 elements string array if success:<br> * @return 2 elements string array if success:<br>
* <ul> * <ul><li>results[0]: the group name to store the file </li></ul>
* <li>results[0]: the group name to store the file</li> * <ul><li>results[1]: the new created filename</li></ul>
* <li>results[1]: the new created filename</li> * return null if fail
* </ul>
* return null if fail
*/ */
public String[] upload_appender_file(String local_filename, String file_ext_name, public String[] upload_appender_file(String local_filename, String file_ext_name,
NameValuePair[] meta_list) throws IOException, MyException { NameValuePair[] meta_list) throws IOException, MyException {
final String group_name = null; final String group_name = null;
return this.upload_appender_file(group_name, local_filename, file_ext_name, meta_list); return this.upload_appender_file(group_name, local_filename, file_ext_name, meta_list);
} }
@ -404,18 +372,15 @@ public class StorageClient {
* *
* @param group_name the group name to upload file to, can be empty * @param group_name the group name to upload file to, can be empty
* @param local_filename local filename to upload * @param local_filename local filename to upload
* @param file_ext_name file ext name, do not include dot(.), null to extract * @param file_ext_name file ext name, do not include dot(.), null to extract ext name from the local filename
* ext name from the local filename
* @param meta_list meta info array * @param meta_list meta info array
* @return 2 elements string array if success:<br> * @return 2 elements string array if success:<br>
* <ul> * <ul><li>results[0]: the group name to store the file </li></ul>
* <li>results[0]: the group name to store the file</li> * <ul><li>results[1]: the new created filename</li></ul>
* <li>results[1]: the new created filename</li> * return null if fail
* </ul>
* return null if fail
*/ */
protected String[] upload_appender_file(String group_name, String local_filename, String file_ext_name, protected String[] upload_appender_file(String group_name, String local_filename, String file_ext_name,
NameValuePair[] meta_list) throws IOException, MyException { NameValuePair[] meta_list) throws IOException, MyException {
final byte cmd = ProtoCommon.STORAGE_PROTO_CMD_UPLOAD_APPENDER_FILE; final byte cmd = ProtoCommon.STORAGE_PROTO_CMD_UPLOAD_APPENDER_FILE;
return this.upload_file(cmd, group_name, local_filename, file_ext_name, meta_list); return this.upload_file(cmd, group_name, local_filename, file_ext_name, meta_list);
} }
@ -429,14 +394,12 @@ public class StorageClient {
* @param file_ext_name file ext name, do not include dot(.) * @param file_ext_name file ext name, do not include dot(.)
* @param meta_list meta info array * @param meta_list meta info array
* @return 2 elements string array if success:<br> * @return 2 elements string array if success:<br>
* <ul> * <ul><li>results[0]: the group name to store the file</li></ul>
* <li>results[0]: the group name to store the file</li> * <ul><li>results[1]: the new created filename</li></ul>
* <li>results[1]: the new created filename</li> * return null if fail
* </ul>
* return null if fail
*/ */
public String[] upload_appender_file(byte[] file_buff, int offset, int length, String file_ext_name, public String[] upload_appender_file(byte[] file_buff, int offset, int length, String file_ext_name,
NameValuePair[] meta_list) throws IOException, MyException { NameValuePair[] meta_list) throws IOException, MyException {
final String group_name = null; final String group_name = null;
return this.upload_appender_file(group_name, file_buff, offset, length, file_ext_name, meta_list); return this.upload_appender_file(group_name, file_buff, offset, length, file_ext_name, meta_list);
} }
@ -451,16 +414,14 @@ public class StorageClient {
* @param file_ext_name file ext name, do not include dot(.) * @param file_ext_name file ext name, do not include dot(.)
* @param meta_list meta info array * @param meta_list meta info array
* @return 2 elements string array if success:<br> * @return 2 elements string array if success:<br>
* <ul> * <ul><li>results[0]: the group name to store the file</li></ul>
* <li>results[0]: the group name to store the file</li> * <ul><li>results[1]: the new created filename</li></ul>
* <li>results[1]: the new created filename</li> * return null if fail
* </ul>
* return null if fail
*/ */
public String[] upload_appender_file(String group_name, byte[] file_buff, int offset, int length, public String[] upload_appender_file(String group_name, byte[] file_buff, int offset, int length,
String file_ext_name, NameValuePair[] meta_list) throws IOException, MyException { String file_ext_name, NameValuePair[] meta_list) throws IOException, MyException {
return this.do_upload_file(ProtoCommon.STORAGE_PROTO_CMD_UPLOAD_APPENDER_FILE, group_name, null, null, return this.do_upload_file(ProtoCommon.STORAGE_PROTO_CMD_UPLOAD_APPENDER_FILE, group_name, null, null, file_ext_name,
file_ext_name, length, new UploadBuff(file_buff, offset, length), meta_list); length, new UploadBuff(file_buff, offset, length), meta_list);
} }
/** /**
@ -470,14 +431,12 @@ public class StorageClient {
* @param file_ext_name file ext name, do not include dot(.) * @param file_ext_name file ext name, do not include dot(.)
* @param meta_list meta info array * @param meta_list meta info array
* @return 2 elements string array if success:<br> * @return 2 elements string array if success:<br>
* <ul> * <ul><li>results[0]: the group name to store the file</li></ul>
* <li>results[0]: the group name to store the file</li> * <ul><li>results[1]: the new created filename</li></ul>
* <li>results[1]: the new created filename</li> * return null if fail
* </ul>
* return null if fail
*/ */
public String[] upload_appender_file(byte[] file_buff, String file_ext_name, public String[] upload_appender_file(byte[] file_buff, String file_ext_name,
NameValuePair[] meta_list) throws IOException, MyException { NameValuePair[] meta_list) throws IOException, MyException {
final String group_name = null; final String group_name = null;
return this.upload_appender_file(group_name, file_buff, 0, file_buff.length, file_ext_name, meta_list); return this.upload_appender_file(group_name, file_buff, 0, file_buff.length, file_ext_name, meta_list);
} }
@ -490,16 +449,14 @@ public class StorageClient {
* @param file_ext_name file ext name, do not include dot(.) * @param file_ext_name file ext name, do not include dot(.)
* @param meta_list meta info array * @param meta_list meta info array
* @return 2 elements string array if success:<br> * @return 2 elements string array if success:<br>
* <ul> * <ul><li>results[0]: the group name to store the file</li></ul>
* <li>results[0]: the group name to store the file</li> * <ul><li>results[1]: the new created filename</li></ul>
* <li>results[1]: the new created filename</li> * return null if fail
* </ul>
* return null if fail
*/ */
public String[] upload_appender_file(String group_name, byte[] file_buff, public String[] upload_appender_file(String group_name, byte[] file_buff,
String file_ext_name, NameValuePair[] meta_list) throws IOException, MyException { String file_ext_name, NameValuePair[] meta_list) throws IOException, MyException {
return this.do_upload_file(ProtoCommon.STORAGE_PROTO_CMD_UPLOAD_APPENDER_FILE, group_name, null, null, return this.do_upload_file(ProtoCommon.STORAGE_PROTO_CMD_UPLOAD_APPENDER_FILE, group_name, null, null, file_ext_name,
file_ext_name, file_buff.length, new UploadBuff(file_buff, 0, file_buff.length), meta_list); file_buff.length, new UploadBuff(file_buff, 0, file_buff.length), meta_list);
} }
/** /**
@ -511,19 +468,16 @@ public class StorageClient {
* @param file_ext_name file ext name, do not include dot(.) * @param file_ext_name file ext name, do not include dot(.)
* @param meta_list meta info array * @param meta_list meta info array
* @return 2 elements string array if success:<br> * @return 2 elements string array if success:<br>
* <ul> * <ul><li>results[0]: the group name to store the file</li></ul>
* <li>results[0]: the group name to store the file</li> * <ul><li>results[1]: the new created filename</li></ul>
* <li>results[1]: the new created filename</li> * return null if fail
* </ul>
* return null if fail
*/ */
public String[] upload_appender_file(String group_name, long file_size, UploadCallback callback, public String[] upload_appender_file(String group_name, long file_size, UploadCallback callback,
String file_ext_name, NameValuePair[] meta_list) throws IOException, MyException { String file_ext_name, NameValuePair[] meta_list) throws IOException, MyException {
final String master_filename = null; final String master_filename = null;
final String prefix_name = null; final String prefix_name = null;
return this.do_upload_file(ProtoCommon.STORAGE_PROTO_CMD_UPLOAD_APPENDER_FILE, group_name, master_filename, return this.do_upload_file(ProtoCommon.STORAGE_PROTO_CMD_UPLOAD_APPENDER_FILE, group_name, master_filename, prefix_name,
prefix_name,
file_ext_name, file_size, callback, meta_list); file_ext_name, file_size, callback, meta_list);
} }
@ -535,8 +489,7 @@ public class StorageClient {
* @param local_filename local filename to append * @param local_filename local filename to append
* @return 0 for success, != 0 for error (error no) * @return 0 for success, != 0 for error (error no)
*/ */
public int append_file(String group_name, String appender_filename, String local_filename) public int append_file(String group_name, String appender_filename, String local_filename) throws IOException, MyException {
throws IOException, MyException {
File f = new File(local_filename); File f = new File(local_filename);
FileInputStream fis = new FileInputStream(f); FileInputStream fis = new FileInputStream(f);
@ -555,10 +508,8 @@ public class StorageClient {
* @param file_buff file content/buff * @param file_buff file content/buff
* @return 0 for success, != 0 for error (error no) * @return 0 for success, != 0 for error (error no)
*/ */
public int append_file(String group_name, String appender_filename, byte[] file_buff) public int append_file(String group_name, String appender_filename, byte[] file_buff) throws IOException, MyException {
throws IOException, MyException { return this.do_append_file(group_name, appender_filename, file_buff.length, new UploadBuff(file_buff, 0, file_buff.length));
return this.do_append_file(group_name, appender_filename, file_buff.length,
new UploadBuff(file_buff, 0, file_buff.length));
} }
/** /**
@ -572,7 +523,7 @@ public class StorageClient {
* @return 0 for success, != 0 for error (error no) * @return 0 for success, != 0 for error (error no)
*/ */
public int append_file(String group_name, String appender_filename, public int append_file(String group_name, String appender_filename,
byte[] file_buff, int offset, int length) throws IOException, MyException { byte[] file_buff, int offset, int length) throws IOException, MyException {
return this.do_append_file(group_name, appender_filename, length, new UploadBuff(file_buff, offset, length)); return this.do_append_file(group_name, appender_filename, length, new UploadBuff(file_buff, offset, length));
} }
@ -586,7 +537,7 @@ public class StorageClient {
* @return 0 for success, != 0 for error (error no) * @return 0 for success, != 0 for error (error no)
*/ */
public int append_file(String group_name, String appender_filename, public int append_file(String group_name, String appender_filename,
long file_size, UploadCallback callback) throws IOException, MyException { long file_size, UploadCallback callback) throws IOException, MyException {
return this.do_append_file(group_name, appender_filename, file_size, callback); return this.do_append_file(group_name, appender_filename, file_size, callback);
} }
@ -600,7 +551,7 @@ public class StorageClient {
* @return 0 for success, != 0 for error (error no) * @return 0 for success, != 0 for error (error no)
*/ */
public int modify_file(String group_name, String appender_filename, public int modify_file(String group_name, String appender_filename,
long file_offset, String local_filename) throws IOException, MyException { long file_offset, String local_filename) throws IOException, MyException {
File f = new File(local_filename); File f = new File(local_filename);
FileInputStream fis = new FileInputStream(f); FileInputStream fis = new FileInputStream(f);
@ -622,7 +573,7 @@ public class StorageClient {
* @return 0 for success, != 0 for error (error no) * @return 0 for success, != 0 for error (error no)
*/ */
public int modify_file(String group_name, String appender_filename, public int modify_file(String group_name, String appender_filename,
long file_offset, byte[] file_buff) throws IOException, MyException { long file_offset, byte[] file_buff) throws IOException, MyException {
return this.do_modify_file(group_name, appender_filename, file_offset, return this.do_modify_file(group_name, appender_filename, file_offset,
file_buff.length, new UploadBuff(file_buff, 0, file_buff.length)); file_buff.length, new UploadBuff(file_buff, 0, file_buff.length));
} }
@ -639,7 +590,7 @@ public class StorageClient {
* @return 0 for success, != 0 for error (error no) * @return 0 for success, != 0 for error (error no)
*/ */
public int modify_file(String group_name, String appender_filename, public int modify_file(String group_name, String appender_filename,
long file_offset, byte[] file_buff, int buffer_offset, int buffer_length) throws IOException, MyException { long file_offset, byte[] file_buff, int buffer_offset, int buffer_length) throws IOException, MyException {
return this.do_modify_file(group_name, appender_filename, file_offset, return this.do_modify_file(group_name, appender_filename, file_offset,
buffer_length, new UploadBuff(file_buff, buffer_offset, buffer_length)); buffer_length, new UploadBuff(file_buff, buffer_offset, buffer_length));
} }
@ -655,7 +606,7 @@ public class StorageClient {
* @return 0 for success, != 0 for error (error no) * @return 0 for success, != 0 for error (error no)
*/ */
public int modify_file(String group_name, String appender_filename, public int modify_file(String group_name, String appender_filename,
long file_offset, long modify_size, UploadCallback callback) throws IOException, MyException { long file_offset, long modify_size, UploadCallback callback) throws IOException, MyException {
return this.do_modify_file(group_name, appender_filename, file_offset, return this.do_modify_file(group_name, appender_filename, file_offset,
modify_size, callback); modify_size, callback);
} }
@ -666,14 +617,11 @@ public class StorageClient {
* @param group_name the group name of appender file * @param group_name the group name of appender file
* @param appender_filename the appender filename * @param appender_filename the appender filename
* @return 2 elements string array if success:<br> * @return 2 elements string array if success:<br>
* <ul> * <ul><li> results[0]: the group name to store the file</li></ul>
* <li>results[0]: the group name to store the file</li> * <ul><li> results[1]: the new created filename</li></ul>
* <li>results[1]: the new created filename</li> * return null if fail
* </ul>
* return null if fail
*/ */
public String[] regenerate_appender_filename(String group_name, String appender_filename) public String[] regenerate_appender_filename(String group_name, String appender_filename) throws IOException, MyException {
throws IOException, MyException {
byte[] header; byte[] header;
boolean bNewStorageServer; boolean bNewStorageServer;
Connection connection = null; Connection connection = null;
@ -752,15 +700,13 @@ public class StorageClient {
* @param callback the write data callback object * @param callback the write data callback object
* @param meta_list meta info array * @param meta_list meta info array
* @return 2 elements string array if success:<br> * @return 2 elements string array if success:<br>
* <ul> * <ul><li> results[0]: the group name to store the file</li></ul>
* <li>results[0]: the group name to store the file</li> * <ul><li> results[1]: the new created filename</li></ul>
* <li>results[1]: the new created filename</li> * return null if fail
* </ul>
* return null if fail
*/ */
protected String[] do_upload_file(byte cmd, String group_name, String master_filename, protected String[] do_upload_file(byte cmd, String group_name, String master_filename,
String prefix_name, String file_ext_name, long file_size, UploadCallback callback, String prefix_name, String file_ext_name, long file_size, UploadCallback callback,
NameValuePair[] meta_list) throws IOException, MyException { NameValuePair[] meta_list) throws IOException, MyException {
byte[] header; byte[] header;
byte[] ext_name_bs; byte[] ext_name_bs;
String new_group_name; String new_group_name;
@ -800,8 +746,8 @@ public class StorageClient {
masterFilenameBytes = master_filename.getBytes(ClientGlobal.g_charset); masterFilenameBytes = master_filename.getBytes(ClientGlobal.g_charset);
sizeBytes = new byte[2 * ProtoCommon.FDFS_PROTO_PKG_LEN_SIZE]; sizeBytes = new byte[2 * ProtoCommon.FDFS_PROTO_PKG_LEN_SIZE];
body_len = sizeBytes.length + ProtoCommon.FDFS_FILE_PREFIX_MAX_LEN body_len = sizeBytes.length + ProtoCommon.FDFS_FILE_PREFIX_MAX_LEN + ProtoCommon.FDFS_FILE_EXT_NAME_MAX_LEN
+ ProtoCommon.FDFS_FILE_EXT_NAME_MAX_LEN + masterFilenameBytes.length + file_size; + masterFilenameBytes.length + file_size;
hexLenBytes = ProtoCommon.long2buff(master_filename.length()); hexLenBytes = ProtoCommon.long2buff(master_filename.length());
System.arraycopy(hexLenBytes, 0, sizeBytes, 0, hexLenBytes.length); System.arraycopy(hexLenBytes, 0, sizeBytes, 0, hexLenBytes.length);
@ -915,7 +861,7 @@ public class StorageClient {
* @return return true for success, false for fail * @return return true for success, false for fail
*/ */
protected int do_append_file(String group_name, String appender_filename, protected int do_append_file(String group_name, String appender_filename,
long file_size, UploadCallback callback) throws IOException, MyException { long file_size, UploadCallback callback) throws IOException, MyException {
byte[] header; byte[] header;
boolean bNewStorageServer; boolean bNewStorageServer;
Connection connection = null; Connection connection = null;
@ -1008,7 +954,7 @@ public class StorageClient {
* @return return true for success, false for fail * @return return true for success, false for fail
*/ */
protected int do_modify_file(String group_name, String appender_filename, protected int do_modify_file(String group_name, String appender_filename,
long file_offset, long modify_size, UploadCallback callback) throws IOException, MyException { long file_offset, long modify_size, UploadCallback callback) throws IOException, MyException {
byte[] header; byte[] header;
boolean bNewStorageServer; boolean bNewStorageServer;
Connection connection = null; Connection connection = null;
@ -1134,7 +1080,7 @@ public class StorageClient {
* @return 0 for success, none zero for fail (error code) * @return 0 for success, none zero for fail (error code)
*/ */
public int truncate_file(String group_name, String appender_filename, public int truncate_file(String group_name, String appender_filename,
long truncated_file_size) throws IOException, MyException { long truncated_file_size) throws IOException, MyException {
byte[] header; byte[] header;
boolean bNewStorageServer; boolean bNewStorageServer;
Connection connection = null; Connection connection = null;
@ -1217,8 +1163,7 @@ public class StorageClient {
* @param download_bytes download bytes, 0 for remain bytes from offset * @param download_bytes download bytes, 0 for remain bytes from offset
* @return file content/buff, return null if fail * @return file content/buff, return null if fail
*/ */
public byte[] download_file(String group_name, String remote_filename, long file_offset, long download_bytes) public byte[] download_file(String group_name, String remote_filename, long file_offset, long download_bytes) throws IOException, MyException {
throws IOException, MyException {
boolean bNewStorageServer = this.newReadableStorageConnection(group_name, remote_filename); boolean bNewStorageServer = this.newReadableStorageConnection(group_name, remote_filename);
Connection connection = this.storageServer.getConnection(); Connection connection = this.storageServer.getConnection();
@ -1258,7 +1203,7 @@ public class StorageClient {
* @return 0 success, return none zero errno if fail * @return 0 success, return none zero errno if fail
*/ */
public int download_file(String group_name, String remote_filename, public int download_file(String group_name, String remote_filename,
String local_filename) throws IOException, MyException { String local_filename) throws IOException, MyException {
final long file_offset = 0; final long file_offset = 0;
final long download_bytes = 0; final long download_bytes = 0;
return this.download_file(group_name, remote_filename, return this.download_file(group_name, remote_filename,
@ -1276,8 +1221,8 @@ public class StorageClient {
* @return 0 success, return none zero errno if fail * @return 0 success, return none zero errno if fail
*/ */
public int download_file(String group_name, String remote_filename, public int download_file(String group_name, String remote_filename,
long file_offset, long download_bytes, long file_offset, long download_bytes,
String local_filename) throws IOException, MyException { String local_filename) throws IOException, MyException {
boolean bNewStorageServer = this.newReadableStorageConnection(group_name, remote_filename); boolean bNewStorageServer = this.newReadableStorageConnection(group_name, remote_filename);
Connection connection = this.storageServer.getConnection(); Connection connection = this.storageServer.getConnection();
try { try {
@ -1298,18 +1243,17 @@ public class StorageClient {
long remainBytes = header.body_len; long remainBytes = header.body_len;
int bytes; int bytes;
// System.out.println("expect_body_len=" + header.body_len); //System.out.println("expect_body_len=" + header.body_len);
while (remainBytes > 0) { while (remainBytes > 0) {
if ((bytes = in.read(buff, 0, remainBytes > buff.length ? buff.length : (int) remainBytes)) < 0) { if ((bytes = in.read(buff, 0, remainBytes > buff.length ? buff.length : (int) remainBytes)) < 0) {
throw new IOException( throw new IOException("recv package size " + (header.body_len - remainBytes) + " != " + header.body_len);
"recv package size " + (header.body_len - remainBytes) + " != " + header.body_len);
} }
out.write(buff, 0, bytes); out.write(buff, 0, bytes);
remainBytes -= bytes; remainBytes -= bytes;
// System.out.println("totalBytes=" + (header.body_len - remainBytes)); //System.out.println("totalBytes=" + (header.body_len - remainBytes));
} }
return 0; return 0;
@ -1348,7 +1292,7 @@ public class StorageClient {
* @return 0 success, return none zero errno if fail * @return 0 success, return none zero errno if fail
*/ */
public int download_file(String group_name, String remote_filename, public int download_file(String group_name, String remote_filename,
DownloadCallback callback) throws IOException, MyException { DownloadCallback callback) throws IOException, MyException {
final long file_offset = 0; final long file_offset = 0;
final long download_bytes = 0; final long download_bytes = 0;
return this.download_file(group_name, remote_filename, return this.download_file(group_name, remote_filename,
@ -1366,8 +1310,8 @@ public class StorageClient {
* @return 0 success, return none zero errno if fail * @return 0 success, return none zero errno if fail
*/ */
public int download_file(String group_name, String remote_filename, public int download_file(String group_name, String remote_filename,
long file_offset, long download_bytes, long file_offset, long download_bytes,
DownloadCallback callback) throws IOException, MyException { DownloadCallback callback) throws IOException, MyException {
int result; int result;
boolean bNewStorageServer = this.newReadableStorageConnection(group_name, remote_filename); boolean bNewStorageServer = this.newReadableStorageConnection(group_name, remote_filename);
Connection connection = this.storageServer.getConnection(); Connection connection = this.storageServer.getConnection();
@ -1387,7 +1331,7 @@ public class StorageClient {
long remainBytes = header.body_len; long remainBytes = header.body_len;
int bytes; int bytes;
// System.out.println("expect_body_len=" + header.body_len); //System.out.println("expect_body_len=" + header.body_len);
while (remainBytes > 0) { while (remainBytes > 0) {
if ((bytes = in.read(buff, 0, remainBytes > buff.length ? buff.length : (int) remainBytes)) < 0) { if ((bytes = in.read(buff, 0, remainBytes > buff.length ? buff.length : (int) remainBytes)) < 0) {
@ -1400,7 +1344,7 @@ public class StorageClient {
} }
remainBytes -= bytes; remainBytes -= bytes;
// System.out.println("totalBytes=" + (header.body_len - remainBytes)); //System.out.println("totalBytes=" + (header.body_len - remainBytes));
} }
return 0; return 0;
@ -1462,18 +1406,14 @@ public class StorageClient {
* @param remote_filename filename on storage server * @param remote_filename filename on storage server
* @param meta_list meta item array * @param meta_list meta item array
* @param op_flag flag, can be one of following values: <br> * @param op_flag flag, can be one of following values: <br>
* <ul> * <ul><li> ProtoCommon.STORAGE_SET_METADATA_FLAG_OVERWRITE: overwrite all old
* <li>ProtoCommon.STORAGE_SET_METADATA_FLAG_OVERWRITE: * metadata items</li></ul>
* overwrite all old * <ul><li> ProtoCommon.STORAGE_SET_METADATA_FLAG_MERGE: merge, insert when
* metadata items</li> * the metadata item not exist, otherwise update it</li></ul>
* <li>ProtoCommon.STORAGE_SET_METADATA_FLAG_MERGE:
* merge, insert when
* the metadata item not exist, otherwise update it</li>
* </ul>
* @return 0 for success, !=0 fail (error code) * @return 0 for success, !=0 fail (error code)
*/ */
public int set_metadata(String group_name, String remote_filename, public int set_metadata(String group_name, String remote_filename,
NameValuePair[] meta_list, byte op_flag) throws IOException, MyException { NameValuePair[] meta_list, byte op_flag) throws IOException, MyException {
boolean bNewStorageServer = this.newUpdatableStorageConnection(group_name, remote_filename); boolean bNewStorageServer = this.newUpdatableStorageConnection(group_name, remote_filename);
Connection connection = this.storageServer.getConnection(); Connection connection = this.storageServer.getConnection();
try { try {
@ -1514,7 +1454,7 @@ public class StorageClient {
header = ProtoCommon.packHeader(ProtoCommon.STORAGE_PROTO_CMD_SET_METADATA, header = ProtoCommon.packHeader(ProtoCommon.STORAGE_PROTO_CMD_SET_METADATA,
2 * ProtoCommon.FDFS_PROTO_PKG_LEN_SIZE + 1 + groupBytes.length 2 * ProtoCommon.FDFS_PROTO_PKG_LEN_SIZE + 1 + groupBytes.length
+ filenameBytes.length + meta_buff.length, (byte) 0); + filenameBytes.length + meta_buff.length, (byte) 0);
OutputStream out = connection.getOutputStream(); OutputStream out = connection.getOutputStream();
byte[] wholePkg = new byte[header.length + sizeBytes.length + 1 + groupBytes.length + filenameBytes.length]; byte[] wholePkg = new byte[header.length + sizeBytes.length + 1 + groupBytes.length + filenameBytes.length];
System.arraycopy(header, 0, wholePkg, 0, header.length); System.arraycopy(header, 0, wholePkg, 0, header.length);
@ -1576,7 +1516,7 @@ public class StorageClient {
} }
if (file_type == FileInfo.FILE_TYPE_SLAVE || if (file_type == FileInfo.FILE_TYPE_SLAVE ||
file_type == FileInfo.FILE_TYPE_APPENDER) { // slave file or appender file file_type == FileInfo.FILE_TYPE_APPENDER) { //slave file or appender file
FileInfo fi = this.query_file_info(group_name, remote_filename); FileInfo fi = this.query_file_info(group_name, remote_filename);
if (fi == null) { if (fi == null) {
return null; return null;
@ -1588,7 +1528,7 @@ public class StorageClient {
int create_timestamp = ProtoCommon.buff2int(buff, 4); int create_timestamp = ProtoCommon.buff2int(buff, 4);
if ((file_size >> 63) != 0) { if ((file_size >> 63) != 0) {
file_size &= 0xFFFFFFFFL; // low 32 bits is file size file_size &= 0xFFFFFFFFL; //low 32 bits is file size
} }
int crc32 = ProtoCommon.buff2int(buff, 4 * 4); int crc32 = ProtoCommon.buff2int(buff, 4 * 4);
@ -1678,7 +1618,7 @@ public class StorageClient {
TrackerClient tracker = new TrackerClient(); TrackerClient tracker = new TrackerClient();
this.storageServer = tracker.getStoreStorage(this.trackerServer, group_name); this.storageServer = tracker.getStoreStorage(this.trackerServer, group_name);
if (this.storageServer == null) { if (this.storageServer == null) {
throw new MyException("getStoreStorage fail, error code: " + tracker.getErrorCode()); throw new MyException("getStoreStorage fail, errno code: " + tracker.getErrorCode());
} }
return true; return true;
} }
@ -1691,8 +1631,7 @@ public class StorageClient {
* @param remote_filename filename on storage server * @param remote_filename filename on storage server
* @return true if create a new connection * @return true if create a new connection
*/ */
protected boolean newReadableStorageConnection(String group_name, String remote_filename) protected boolean newReadableStorageConnection(String group_name, String remote_filename) throws IOException, MyException {
throws IOException, MyException {
if (this.storageServer != null) { if (this.storageServer != null) {
return false; return false;
} else { } else {
@ -1712,8 +1651,7 @@ public class StorageClient {
* @param remote_filename filename on storage server * @param remote_filename filename on storage server
* @return true if create a new connection * @return true if create a new connection
*/ */
protected boolean newUpdatableStorageConnection(String group_name, String remote_filename) protected boolean newUpdatableStorageConnection(String group_name, String remote_filename) throws IOException, MyException {
throws IOException, MyException {
if (this.storageServer != null) { if (this.storageServer != null) {
return false; return false;
} else { } else {
@ -1733,8 +1671,7 @@ public class StorageClient {
* @param group_name the group name of storage server * @param group_name the group name of storage server
* @param remote_filename filename on storage server * @param remote_filename filename on storage server
*/ */
protected void send_package(byte cmd, String group_name, String remote_filename, Connection connection) protected void send_package(byte cmd, String group_name, String remote_filename, Connection connection) throws IOException {
throws IOException {
byte[] header; byte[] header;
byte[] groupBytes; byte[] groupBytes;
byte[] filenameBytes; byte[] filenameBytes;
@ -1855,8 +1792,7 @@ public class StorageClient {
} }
/** /**
* send file content callback function, be called only once when the file * send file content callback function, be called only once when the file uploaded
* uploaded
* *
* @param out output stream for writing file content * @param out output stream for writing file content
* @return 0 success, return none zero(errno) if fail * @return 0 success, return none zero(errno) if fail