|
|
@ -1,3 +1,4 @@
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
/*
|
|
|
|
/*
|
|
|
|
* Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
|
|
|
|
* Copyright (c) 2010-2011, The MiCode Open Source Community (www.micode.net)
|
|
|
|
*
|
|
|
|
*
|
|
|
@ -15,6 +16,8 @@
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
// 定义包名
|
|
|
|
// 定义包名
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
package net.micode.notes.gtask.remote;
|
|
|
|
package net.micode.notes.gtask.remote;
|
|
|
|
|
|
|
|
|
|
|
|
// 导入相关类和接口
|
|
|
|
// 导入相关类和接口
|
|
|
@ -55,6 +58,7 @@ import org.json.JSONArray; // 引入JSON数组类
|
|
|
|
import org.json.JSONException; // 引入JSON异常类
|
|
|
|
import org.json.JSONException; // 引入JSON异常类
|
|
|
|
import org.json.JSONObject; // 引入JSON对象类
|
|
|
|
import org.json.JSONObject; // 引入JSON对象类
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
// 引入JDK类
|
|
|
|
// 引入JDK类
|
|
|
|
import java.io.BufferedReader; // 引入缓冲读取器类
|
|
|
|
import java.io.BufferedReader; // 引入缓冲读取器类
|
|
|
|
import java.io.IOException; // 引入IO异常类
|
|
|
|
import java.io.IOException; // 引入IO异常类
|
|
|
@ -67,18 +71,30 @@ import java.util.zip.Inflater; // 引入解压缩类
|
|
|
|
import java.util.zip.InflaterInputStream; // 引入解压缩输入流类
|
|
|
|
import java.util.zip.InflaterInputStream; // 引入解压缩输入流类
|
|
|
|
|
|
|
|
|
|
|
|
// GTaskClient类负责处理与Google任务(GTask)的通信
|
|
|
|
// GTaskClient类负责处理与Google任务(GTask)的通信
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// GTaskClient类用于与Google Tasks进行交互,实现诸如登录、任务和任务列表的创建、更新、移动、删除以及获取相关数据等功能
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
public class GTaskClient {
|
|
|
|
public class GTaskClient {
|
|
|
|
// 日志标签
|
|
|
|
// 日志标签
|
|
|
|
private static final String TAG = GTaskClient.class.getSimpleName();
|
|
|
|
private static final String TAG = GTaskClient.class.getSimpleName();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
// Google任务相关的URL
|
|
|
|
// Google任务相关的URL
|
|
|
|
private static final String GTASK_URL = "https://mail.google.com/tasks/";
|
|
|
|
private static final String GTASK_URL = "https://mail.google.com/tasks/";
|
|
|
|
private static final String GTASK_GET_URL = "https://mail.google.com/tasks/ig";
|
|
|
|
private static final String GTASK_GET_URL = "https://mail.google.com/tasks/ig";
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// Google Tasks的基础URL
|
|
|
|
|
|
|
|
private static final String GTASK_URL = "https://mail.google.com/tasks/";
|
|
|
|
|
|
|
|
// 用于获取Google Tasks数据的URL
|
|
|
|
|
|
|
|
private static final String GTASK_GET_URL = "https://mail.google.com/tasks/ig";
|
|
|
|
|
|
|
|
// 用于向Google Tasks发送POST请求的URL
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
private static final String GTASK_POST_URL = "https://mail.google.com/tasks/r/ig";
|
|
|
|
private static final String GTASK_POST_URL = "https://mail.google.com/tasks/r/ig";
|
|
|
|
|
|
|
|
|
|
|
|
// 单例实例
|
|
|
|
// 单例实例
|
|
|
|
private static GTaskClient mInstance = null;
|
|
|
|
private static GTaskClient mInstance = null;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
// HTTP客户端
|
|
|
|
// HTTP客户端
|
|
|
|
private DefaultHttpClient mHttpClient;
|
|
|
|
private DefaultHttpClient mHttpClient;
|
|
|
|
|
|
|
|
|
|
|
@ -97,6 +113,28 @@ public class GTaskClient {
|
|
|
|
private JSONArray mUpdateArray;
|
|
|
|
private JSONArray mUpdateArray;
|
|
|
|
|
|
|
|
|
|
|
|
// 私有构造函数,初始化类的成员变量
|
|
|
|
// 私有构造函数,初始化类的成员变量
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// 用于发送HTTP请求的HttpClient对象
|
|
|
|
|
|
|
|
private DefaultHttpClient mHttpClient;
|
|
|
|
|
|
|
|
// 获取数据的具体URL
|
|
|
|
|
|
|
|
private String mGetUrl;
|
|
|
|
|
|
|
|
// 发送POST请求的具体URL
|
|
|
|
|
|
|
|
private String mPostUrl;
|
|
|
|
|
|
|
|
// 客户端版本号
|
|
|
|
|
|
|
|
private long mClientVersion;
|
|
|
|
|
|
|
|
// 标记是否已登录
|
|
|
|
|
|
|
|
private boolean mLoggedin;
|
|
|
|
|
|
|
|
// 上次登录的时间戳
|
|
|
|
|
|
|
|
private long mLastLoginTime;
|
|
|
|
|
|
|
|
// 用于标识操作的ID,每次操作自增
|
|
|
|
|
|
|
|
private int mActionId;
|
|
|
|
|
|
|
|
// 当前使用的账户
|
|
|
|
|
|
|
|
private Account mAccount;
|
|
|
|
|
|
|
|
// 用于暂存更新操作相关数据的JSON数组
|
|
|
|
|
|
|
|
private JSONArray mUpdateArray;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 私有构造函数,初始化相关成员变量
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
private GTaskClient() {
|
|
|
|
private GTaskClient() {
|
|
|
|
mHttpClient = null;
|
|
|
|
mHttpClient = null;
|
|
|
|
mGetUrl = GTASK_GET_URL;
|
|
|
|
mGetUrl = GTASK_GET_URL;
|
|
|
@ -109,7 +147,11 @@ public class GTaskClient {
|
|
|
|
mUpdateArray = null;
|
|
|
|
mUpdateArray = null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
// 获取单例实例
|
|
|
|
// 获取单例实例
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// 获取GTaskClient的单例实例
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
public static synchronized GTaskClient getInstance() {
|
|
|
|
public static synchronized GTaskClient getInstance() {
|
|
|
|
if (mInstance == null) {
|
|
|
|
if (mInstance == null) {
|
|
|
|
mInstance = new GTaskClient();
|
|
|
|
mInstance = new GTaskClient();
|
|
|
@ -117,17 +159,31 @@ public class GTaskClient {
|
|
|
|
return mInstance;
|
|
|
|
return mInstance;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
// 登录方法
|
|
|
|
// 登录方法
|
|
|
|
public boolean login(Activity activity) {
|
|
|
|
public boolean login(Activity activity) {
|
|
|
|
// 假设cookie在5分钟后过期
|
|
|
|
// 假设cookie在5分钟后过期
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// 执行登录操作
|
|
|
|
|
|
|
|
public boolean login(Activity activity) {
|
|
|
|
|
|
|
|
// 假设Cookie在5分钟后过期,若距离上次登录时间超过5分钟,则需要重新登录
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
final long interval = 1000 * 60 * 5;
|
|
|
|
final long interval = 1000 * 60 * 5;
|
|
|
|
if (mLastLoginTime + interval < System.currentTimeMillis()) {
|
|
|
|
if (mLastLoginTime + interval < System.currentTimeMillis()) {
|
|
|
|
mLoggedin = false; // 如果超时,设置未登录
|
|
|
|
mLoggedin = false; // 如果超时,设置未登录
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
// 如果账户切换,需要重新登录
|
|
|
|
// 如果账户切换,需要重新登录
|
|
|
|
if (mLoggedin && !TextUtils.equals(getSyncAccount().name, NotesPreferenceActivity.getSyncAccountName(activity))) {
|
|
|
|
if (mLoggedin && !TextUtils.equals(getSyncAccount().name, NotesPreferenceActivity.getSyncAccountName(activity))) {
|
|
|
|
mLoggedin = false; // 账户切换,重新登录
|
|
|
|
mLoggedin = false; // 账户切换,重新登录
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// 如果已登录,但当前账户与设置中的同步账户不一致,也需要重新登录
|
|
|
|
|
|
|
|
if (mLoggedin
|
|
|
|
|
|
|
|
&& !TextUtils.equals(getSyncAccount().name, NotesPreferenceActivity
|
|
|
|
|
|
|
|
.getSyncAccountName(activity))) {
|
|
|
|
|
|
|
|
mLoggedin = false;
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// 若已经登录,无需再次登录
|
|
|
|
// 若已经登录,无需再次登录
|
|
|
@ -136,15 +192,27 @@ public class GTaskClient {
|
|
|
|
return true;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
mLastLoginTime = System.currentTimeMillis(); // 更新最后登录时间
|
|
|
|
mLastLoginTime = System.currentTimeMillis(); // 更新最后登录时间
|
|
|
|
String authToken = loginGoogleAccount(activity, false); // 获取Google账户的认证令牌
|
|
|
|
String authToken = loginGoogleAccount(activity, false); // 获取Google账户的认证令牌
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
mLastLoginTime = System.currentTimeMillis();
|
|
|
|
|
|
|
|
// 登录Google账户获取授权令牌
|
|
|
|
|
|
|
|
String authToken = loginGoogleAccount(activity, false);
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
if (authToken == null) {
|
|
|
|
if (authToken == null) {
|
|
|
|
Log.e(TAG, "login google account failed");
|
|
|
|
Log.e(TAG, "login google account failed");
|
|
|
|
return false; // 登录失败
|
|
|
|
return false; // 登录失败
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
// 如果为自定义域,则尝试进行登录
|
|
|
|
// 如果为自定义域,则尝试进行登录
|
|
|
|
if (!(mAccount.name.toLowerCase().endsWith("gmail.com") || mAccount.name.toLowerCase().endsWith("googlemail.com"))) {
|
|
|
|
if (!(mAccount.name.toLowerCase().endsWith("gmail.com") || mAccount.name.toLowerCase().endsWith("googlemail.com"))) {
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// 如果账户不是以gmail.com或googlemail.com结尾(可能是自定义域名),则使用自定义域名相关的URL进行登录
|
|
|
|
|
|
|
|
if (!(mAccount.name.toLowerCase().endsWith("gmail.com") || mAccount.name.toLowerCase()
|
|
|
|
|
|
|
|
.endsWith("googlemail.com"))) {
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
StringBuilder url = new StringBuilder(GTASK_URL).append("a/");
|
|
|
|
StringBuilder url = new StringBuilder(GTASK_URL).append("a/");
|
|
|
|
int index = mAccount.name.indexOf('@') + 1;
|
|
|
|
int index = mAccount.name.indexOf('@') + 1;
|
|
|
|
String suffix = mAccount.name.substring(index);
|
|
|
|
String suffix = mAccount.name.substring(index);
|
|
|
@ -157,7 +225,11 @@ public class GTaskClient {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
// 尝试以 Google 官方 URL 登录
|
|
|
|
// 尝试以 Google 官方 URL 登录
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// 如果使用自定义域名登录失败,则尝试使用Google官方URL登录
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
if (!mLoggedin) {
|
|
|
|
if (!mLoggedin) {
|
|
|
|
mGetUrl = GTASK_GET_URL; // 恢复默认的GET请求URL
|
|
|
|
mGetUrl = GTASK_GET_URL; // 恢复默认的GET请求URL
|
|
|
|
mPostUrl = GTASK_POST_URL; // 恢复默认的POST请求URL
|
|
|
|
mPostUrl = GTASK_POST_URL; // 恢复默认的POST请求URL
|
|
|
@ -170,11 +242,21 @@ public class GTaskClient {
|
|
|
|
return true;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
// 获取Google账户认证令牌的方法
|
|
|
|
// 获取Google账户认证令牌的方法
|
|
|
|
private String loginGoogleAccount(Activity activity, boolean invalidateToken) {
|
|
|
|
private String loginGoogleAccount(Activity activity, boolean invalidateToken) {
|
|
|
|
String authToken;
|
|
|
|
String authToken;
|
|
|
|
AccountManager accountManager = AccountManager.get(activity); // 获取账户管理器
|
|
|
|
AccountManager accountManager = AccountManager.get(activity); // 获取账户管理器
|
|
|
|
Account[] accounts = accountManager.getAccountsByType("com.google"); // 获取Google账户
|
|
|
|
Account[] accounts = accountManager.getAccountsByType("com.google"); // 获取Google账户
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// 登录Google账户获取授权令牌
|
|
|
|
|
|
|
|
private String loginGoogleAccount(Activity activity, boolean invalidateToken) {
|
|
|
|
|
|
|
|
String authToken;
|
|
|
|
|
|
|
|
// 获取账户管理器
|
|
|
|
|
|
|
|
AccountManager accountManager = AccountManager.get(activity);
|
|
|
|
|
|
|
|
// 获取所有Google类型的账户
|
|
|
|
|
|
|
|
Account[] accounts = accountManager.getAccountsByType("com.google");
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
|
|
|
|
|
|
|
|
// 如果没有可用的Google账户,日志记录并返回null
|
|
|
|
// 如果没有可用的Google账户,日志记录并返回null
|
|
|
|
if (accounts.length == 0) {
|
|
|
|
if (accounts.length == 0) {
|
|
|
@ -182,7 +264,12 @@ public class GTaskClient {
|
|
|
|
return null;
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
String accountName = NotesPreferenceActivity.getSyncAccountName(activity); // 获取同步的账户名
|
|
|
|
String accountName = NotesPreferenceActivity.getSyncAccountName(activity); // 获取同步的账户名
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// 获取设置中的同步账户名称
|
|
|
|
|
|
|
|
String accountName = NotesPreferenceActivity.getSyncAccountName(activity);
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
Account account = null;
|
|
|
|
Account account = null;
|
|
|
|
|
|
|
|
|
|
|
|
// 找到设置中与账户名匹配的账户
|
|
|
|
// 找到设置中与账户名匹配的账户
|
|
|
@ -199,14 +286,21 @@ public class GTaskClient {
|
|
|
|
return null; // 找不到匹配账户,返回null
|
|
|
|
return null; // 找不到匹配账户,返回null
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
// 获取认证令牌
|
|
|
|
// 获取认证令牌
|
|
|
|
AccountManagerFuture<Bundle> accountManagerFuture = accountManager.getAuthToken(account, "goanna_mobile", null, activity, null, null);
|
|
|
|
AccountManagerFuture<Bundle> accountManagerFuture = accountManager.getAuthToken(account, "goanna_mobile", null, activity, null, null);
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// 获取授权令牌
|
|
|
|
|
|
|
|
AccountManagerFuture<Bundle> accountManagerFuture = accountManager.getAuthToken(account,
|
|
|
|
|
|
|
|
"goanna_mobile", null, activity, null, null);
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
Bundle authTokenBundle = accountManagerFuture.getResult(); // 获取结果
|
|
|
|
Bundle authTokenBundle = accountManagerFuture.getResult(); // 获取结果
|
|
|
|
authToken = authTokenBundle.getString(AccountManager.KEY_AUTHTOKEN); // 读取令牌
|
|
|
|
authToken = authTokenBundle.getString(AccountManager.KEY_AUTHTOKEN); // 读取令牌
|
|
|
|
|
|
|
|
|
|
|
|
// 如果需要无效化令牌,则重新获取
|
|
|
|
// 如果需要无效化令牌,则重新获取
|
|
|
|
if (invalidateToken) {
|
|
|
|
if (invalidateToken) {
|
|
|
|
|
|
|
|
// 如果需要使令牌失效,则先失效再重新获取
|
|
|
|
accountManager.invalidateAuthToken("com.google", authToken);
|
|
|
|
accountManager.invalidateAuthToken("com.google", authToken);
|
|
|
|
loginGoogleAccount(activity, false); // 递归调用获取新令牌
|
|
|
|
loginGoogleAccount(activity, false); // 递归调用获取新令牌
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -218,10 +312,17 @@ public class GTaskClient {
|
|
|
|
return authToken; // 返回令牌
|
|
|
|
return authToken; // 返回令牌
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
// 尝试登录到GTask
|
|
|
|
// 尝试登录到GTask
|
|
|
|
private boolean tryToLoginGtask(Activity activity, String authToken) {
|
|
|
|
private boolean tryToLoginGtask(Activity activity, String authToken) {
|
|
|
|
if (!loginGtask(authToken)) {
|
|
|
|
if (!loginGtask(authToken)) {
|
|
|
|
// 如果认证令牌过期,则无效化并尝试重新登录
|
|
|
|
// 如果认证令牌过期,则无效化并尝试重新登录
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// 尝试登录Google Tasks
|
|
|
|
|
|
|
|
private boolean tryToLoginGtask(Activity activity, String authToken) {
|
|
|
|
|
|
|
|
if (!loginGtask(authToken)) {
|
|
|
|
|
|
|
|
// 如果登录失败,可能是授权令牌过期,先使令牌失效再重新尝试登录Google账户获取新令牌,然后再次登录Google Tasks
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
authToken = loginGoogleAccount(activity, true);
|
|
|
|
authToken = loginGoogleAccount(activity, true);
|
|
|
|
if (authToken == null) {
|
|
|
|
if (authToken == null) {
|
|
|
|
Log.e(TAG, "login google account failed");
|
|
|
|
Log.e(TAG, "login google account failed");
|
|
|
@ -236,6 +337,7 @@ public class GTaskClient {
|
|
|
|
return true; // 登录成功
|
|
|
|
return true; // 登录成功
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
// 使用认证令牌登录到GTask
|
|
|
|
// 使用认证令牌登录到GTask
|
|
|
|
private boolean loginGtask(String authToken) {
|
|
|
|
private boolean loginGtask(String authToken) {
|
|
|
|
int timeoutConnection = 10000; // 连接超时设置
|
|
|
|
int timeoutConnection = 10000; // 连接超时设置
|
|
|
@ -249,12 +351,32 @@ public class GTaskClient {
|
|
|
|
HttpProtocolParams.setUseExpectContinue(mHttpClient.getParams(), false); // 设置HTTP协议参数
|
|
|
|
HttpProtocolParams.setUseExpectContinue(mHttpClient.getParams(), false); // 设置HTTP协议参数
|
|
|
|
|
|
|
|
|
|
|
|
// 登录GTask
|
|
|
|
// 登录GTask
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// 实际执行登录Google Tasks的操作,获取相关信息(如客户端版本号等)
|
|
|
|
|
|
|
|
private boolean loginGtask(String authToken) {
|
|
|
|
|
|
|
|
int timeoutConnection = 10000;
|
|
|
|
|
|
|
|
int timeoutSocket = 15000;
|
|
|
|
|
|
|
|
// 设置HTTP请求的参数,包括连接超时和读取超时时间
|
|
|
|
|
|
|
|
HttpParams httpParameters = new BasicHttpParams();
|
|
|
|
|
|
|
|
HttpConnectionParams.setConnectionTimeout(httpParameters, timeoutConnection);
|
|
|
|
|
|
|
|
HttpConnectionParams.setSoTimeout(httpParameters, timeoutSocket);
|
|
|
|
|
|
|
|
mHttpClient = new DefaultHttpClient(httpParameters);
|
|
|
|
|
|
|
|
BasicCookieStore localBasicCookieStore = new BasicCookieStore();
|
|
|
|
|
|
|
|
mHttpClient.setCookieStore(localBasicCookieStore);
|
|
|
|
|
|
|
|
HttpProtocolParams.setUseExpectContinue(mHttpClient.getParams(), false);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 登录Google Tasks,发送带有授权令牌的GET请求
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
String loginUrl = mGetUrl + "?auth=" + authToken; // 创建登录URL
|
|
|
|
String loginUrl = mGetUrl + "?auth=" + authToken; // 创建登录URL
|
|
|
|
HttpGet httpGet = new HttpGet(loginUrl); // 创建GET请求
|
|
|
|
HttpGet httpGet = new HttpGet(loginUrl); // 创建GET请求
|
|
|
|
HttpResponse response = mHttpClient.execute(httpGet); // 执行请求
|
|
|
|
HttpResponse response = mHttpClient.execute(httpGet); // 执行请求
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
// 获取Cookie
|
|
|
|
// 获取Cookie
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// 获取登录后的Cookie信息,检查是否包含认证相关的Cookie(名称包含"GTL")
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
List<Cookie> cookies = mHttpClient.getCookieStore().getCookies();
|
|
|
|
List<Cookie> cookies = mHttpClient.getCookieStore().getCookies();
|
|
|
|
boolean hasAuthCookie = false; // 验证是否存在认证Cookie
|
|
|
|
boolean hasAuthCookie = false; // 验证是否存在认证Cookie
|
|
|
|
for (Cookie cookie : cookies) {
|
|
|
|
for (Cookie cookie : cookies) {
|
|
|
@ -266,7 +388,11 @@ public class GTaskClient {
|
|
|
|
Log.w(TAG, "it seems that there is no auth cookie"); // 没有认证Cookie的警告
|
|
|
|
Log.w(TAG, "it seems that there is no auth cookie"); // 没有认证Cookie的警告
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
// 从响应中获取客户端版本
|
|
|
|
// 从响应中获取客户端版本
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// 从响应中获取客户端版本号等信息,通过解析返回的JavaScript代码中的相关数据
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
String resString = getResponseContent(response.getEntity());
|
|
|
|
String resString = getResponseContent(response.getEntity());
|
|
|
|
String jsBegin = "_setup(";
|
|
|
|
String jsBegin = "_setup(";
|
|
|
|
String jsEnd = ")}</script>";
|
|
|
|
String jsEnd = ")}</script>";
|
|
|
@ -283,6 +409,10 @@ public class GTaskClient {
|
|
|
|
e.printStackTrace();
|
|
|
|
e.printStackTrace();
|
|
|
|
return false; // 处理JSON异常,返回登录失败
|
|
|
|
return false; // 处理JSON异常,返回登录失败
|
|
|
|
} catch (Exception e) {
|
|
|
|
} catch (Exception e) {
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// 捕获其他所有异常,若发生异常则登录失败
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
Log.e(TAG, "httpget gtask_url failed");
|
|
|
|
Log.e(TAG, "httpget gtask_url failed");
|
|
|
|
return false; // 处理其他异常,返回登录失败
|
|
|
|
return false; // 处理其他异常,返回登录失败
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -290,12 +420,20 @@ public class GTaskClient {
|
|
|
|
return true; // 登录成功
|
|
|
|
return true; // 登录成功
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
// 获取下一个动作ID
|
|
|
|
// 获取下一个动作ID
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// 获取下一个操作的ID
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
private int getActionId() {
|
|
|
|
private int getActionId() {
|
|
|
|
return mActionId++; // 返回当前ID并递增
|
|
|
|
return mActionId++; // 返回当前ID并递增
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
// 创建HTTP POST请求
|
|
|
|
// 创建HTTP POST请求
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// 创建用于发送POST请求的HttpPost对象,并设置相关请求头
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
private HttpPost createHttpPost() {
|
|
|
|
private HttpPost createHttpPost() {
|
|
|
|
HttpPost httpPost = new HttpPost(mPostUrl); // 创建POST请求
|
|
|
|
HttpPost httpPost = new HttpPost(mPostUrl); // 创建POST请求
|
|
|
|
httpPost.setHeader("Content-Type", "application/x-www-form-urlencoded;charset=utf-8"); // 设置请求头
|
|
|
|
httpPost.setHeader("Content-Type", "application/x-www-form-urlencoded;charset=utf-8"); // 设置请求头
|
|
|
@ -303,7 +441,11 @@ public class GTaskClient {
|
|
|
|
return httpPost; // 返回POST请求
|
|
|
|
return httpPost; // 返回POST请求
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
// 获取HTTP响应内容
|
|
|
|
// 获取HTTP响应内容
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// 从HTTP实体中获取响应内容,根据内容编码(如gzip、deflate等)进行相应的解压处理
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
private String getResponseContent(HttpEntity entity) throws IOException {
|
|
|
|
private String getResponseContent(HttpEntity entity) throws IOException {
|
|
|
|
String contentEncoding = null; // 声明内容编码
|
|
|
|
String contentEncoding = null; // 声明内容编码
|
|
|
|
if (entity.getContentEncoding() != null) {
|
|
|
|
if (entity.getContentEncoding() != null) {
|
|
|
@ -338,7 +480,11 @@ public class GTaskClient {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
// 发送POST请求
|
|
|
|
// 发送POST请求
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// 发送POST请求,将JSON数据发送到Google Tasks服务器,并处理响应返回的JSON数据
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
private JSONObject postRequest(JSONObject js) throws NetworkFailureException {
|
|
|
|
private JSONObject postRequest(JSONObject js) throws NetworkFailureException {
|
|
|
|
if (!mLoggedin) {
|
|
|
|
if (!mLoggedin) {
|
|
|
|
Log.e(TAG, "please login first"); // 如果未登录,记录错误
|
|
|
|
Log.e(TAG, "please login first"); // 如果未登录,记录错误
|
|
|
@ -352,7 +498,11 @@ public class GTaskClient {
|
|
|
|
UrlEncodedFormEntity entity = new UrlEncodedFormEntity(list, "UTF-8"); // 创建实体
|
|
|
|
UrlEncodedFormEntity entity = new UrlEncodedFormEntity(list, "UTF-8"); // 创建实体
|
|
|
|
httpPost.setEntity(entity); // 设置POST实体
|
|
|
|
httpPost.setEntity(entity); // 设置POST实体
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
// 执行POST请求并获取响应
|
|
|
|
// 执行POST请求并获取响应
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// 执行POST请求并获取响应,然后解析响应内容为JSONObject返回
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
HttpResponse response = mHttpClient.execute(httpPost);
|
|
|
|
HttpResponse response = mHttpClient.execute(httpPost);
|
|
|
|
String jsString = getResponseContent(response.getEntity()); // 获取响应内容
|
|
|
|
String jsString = getResponseContent(response.getEntity()); // 获取响应内容
|
|
|
|
return new JSONObject(jsString); // 返回响应的JSON对象
|
|
|
|
return new JSONObject(jsString); // 返回响应的JSON对象
|
|
|
@ -376,21 +526,36 @@ public class GTaskClient {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
// 创建任务
|
|
|
|
// 创建任务
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// 创建一个任务并发送到Google Tasks服务器
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
public void createTask(Task task) throws NetworkFailureException {
|
|
|
|
public void createTask(Task task) throws NetworkFailureException {
|
|
|
|
commitUpdate(); // 提交更新
|
|
|
|
commitUpdate(); // 提交更新
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
JSONObject jsPost = new JSONObject(); // 创建JSON对象
|
|
|
|
JSONObject jsPost = new JSONObject(); // 创建JSON对象
|
|
|
|
JSONArray actionList = new JSONArray(); // 创建动作列表
|
|
|
|
JSONArray actionList = new JSONArray(); // 创建动作列表
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
// 添加创建动作到动作列表
|
|
|
|
// 添加创建动作到动作列表
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// 将任务的创建操作添加到操作列表中
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
actionList.put(task.getCreateAction(getActionId()));
|
|
|
|
actionList.put(task.getCreateAction(getActionId()));
|
|
|
|
jsPost.put(GTaskStringUtils.GTASK_JSON_ACTION_LIST, actionList); // 添加动作列表到JSON对象
|
|
|
|
jsPost.put(GTaskStringUtils.GTASK_JSON_ACTION_LIST, actionList); // 添加动作列表到JSON对象
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
// 添加客户端版本到JSON对象
|
|
|
|
// 添加客户端版本到JSON对象
|
|
|
|
jsPost.put(GTaskStringUtils.GTASK_JSON_CLIENT_VERSION, mClientVersion);
|
|
|
|
jsPost.put(GTaskStringUtils.GTASK_JSON_CLIENT_VERSION, mClientVersion);
|
|
|
|
|
|
|
|
|
|
|
|
// 执行POST请求
|
|
|
|
// 执行POST请求
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// 设置客户端版本号
|
|
|
|
|
|
|
|
jsPost.put(GTaskStringUtils.GTASK_JSON_CLIENT_VERSION, mClientVersion);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 发送POST请求并处理响应,获取新创建任务的ID并设置到任务对象中
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
JSONObject jsResponse = postRequest(jsPost);
|
|
|
|
JSONObject jsResponse = postRequest(jsPost);
|
|
|
|
JSONObject jsResult = (JSONObject) jsResponse.getJSONArray(GTaskStringUtils.GTASK_JSON_RESULTS).get(0); // 获取返回结果
|
|
|
|
JSONObject jsResult = (JSONObject) jsResponse.getJSONArray(GTaskStringUtils.GTASK_JSON_RESULTS).get(0); // 获取返回结果
|
|
|
|
task.setGid(jsResult.getString(GTaskStringUtils.GTASK_JSON_NEW_ID)); // 设置任务的ID
|
|
|
|
task.setGid(jsResult.getString(GTaskStringUtils.GTASK_JSON_NEW_ID)); // 设置任务的ID
|
|
|
@ -402,21 +567,36 @@ public class GTaskClient {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
// 创建任务列表
|
|
|
|
// 创建任务列表
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// 创建一个任务列表并发送到Google Tasks服务器
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
public void createTaskList(TaskList tasklist) throws NetworkFailureException {
|
|
|
|
public void createTaskList(TaskList tasklist) throws NetworkFailureException {
|
|
|
|
commitUpdate(); // 提交更新
|
|
|
|
commitUpdate(); // 提交更新
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
JSONObject jsPost = new JSONObject(); // 创建JSON对象
|
|
|
|
JSONObject jsPost = new JSONObject(); // 创建JSON对象
|
|
|
|
JSONArray actionList = new JSONArray(); // 创建动作列表
|
|
|
|
JSONArray actionList = new JSONArray(); // 创建动作列表
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
// 添加创建动作到动作列表
|
|
|
|
// 添加创建动作到动作列表
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// 将任务列表的创建操作添加到操作列表中
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
actionList.put(tasklist.getCreateAction(getActionId()));
|
|
|
|
actionList.put(tasklist.getCreateAction(getActionId()));
|
|
|
|
jsPost.put(GTaskStringUtils.GTASK_JSON_ACTION_LIST, actionList); // 添加动作列表到JSON对象
|
|
|
|
jsPost.put(GTaskStringUtils.GTASK_JSON_ACTION_LIST, actionList); // 添加动作列表到JSON对象
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
// 添加客户端版本到JSON对象
|
|
|
|
// 添加客户端版本到JSON对象
|
|
|
|
jsPost.put(GTaskStringUtils.GTASK_JSON_CLIENT_VERSION, mClientVersion);
|
|
|
|
jsPost.put(GTaskStringUtils.GTASK_JSON_CLIENT_VERSION, mClientVersion);
|
|
|
|
|
|
|
|
|
|
|
|
// 执行POST请求
|
|
|
|
// 执行POST请求
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// 设置客户端版本号
|
|
|
|
|
|
|
|
jsPost.put(GTaskStringUtils.GTASK_JSON_CLIENT_VERSION, mClientVersion);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 发送POST请求并处理响应,获取新创建任务列表的ID并设置到任务列表对象中
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
JSONObject jsResponse = postRequest(jsPost);
|
|
|
|
JSONObject jsResponse = postRequest(jsPost);
|
|
|
|
JSONObject jsResult = (JSONObject) jsResponse.getJSONArray(GTaskStringUtils.GTASK_JSON_RESULTS).get(0); // 获取返回结果
|
|
|
|
JSONObject jsResult = (JSONObject) jsResponse.getJSONArray(GTaskStringUtils.GTASK_JSON_RESULTS).get(0); // 获取返回结果
|
|
|
|
tasklist.setGid(jsResult.getString(GTaskStringUtils.GTASK_JSON_NEW_ID)); // 设置任务列表的ID
|
|
|
|
tasklist.setGid(jsResult.getString(GTaskStringUtils.GTASK_JSON_NEW_ID)); // 设置任务列表的ID
|
|
|
@ -428,16 +608,27 @@ public class GTaskClient {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
// 提交更新
|
|
|
|
// 提交更新
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// 提交更新操作,将暂存的更新操作数组发送到服务器
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
public void commitUpdate() throws NetworkFailureException {
|
|
|
|
public void commitUpdate() throws NetworkFailureException {
|
|
|
|
// 如果存在更新数组
|
|
|
|
// 如果存在更新数组
|
|
|
|
if (mUpdateArray != null) {
|
|
|
|
if (mUpdateArray != null) {
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
JSONObject jsPost = new JSONObject(); // 创建JSON对象
|
|
|
|
JSONObject jsPost = new JSONObject(); // 创建JSON对象
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
// 添加动作列表到JSON对象
|
|
|
|
// 添加动作列表到JSON对象
|
|
|
|
jsPost.put(GTaskStringUtils.GTASK_JSON_ACTION_LIST, mUpdateArray);
|
|
|
|
jsPost.put(GTaskStringUtils.GTASK_JSON_ACTION_LIST, mUpdateArray);
|
|
|
|
// 添加客户端版本到JSON对象
|
|
|
|
// 添加客户端版本到JSON对象
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// 设置操作列表
|
|
|
|
|
|
|
|
jsPost.put(GTaskStringUtils.GTASK_JSON_ACTION_LIST, mUpdateArray);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 设置客户端版本号
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
jsPost.put(GTaskStringUtils.GTASK_JSON_CLIENT_VERSION, mClientVersion);
|
|
|
|
jsPost.put(GTaskStringUtils.GTASK_JSON_CLIENT_VERSION, mClientVersion);
|
|
|
|
|
|
|
|
|
|
|
|
postRequest(jsPost); // 执行POST请求
|
|
|
|
postRequest(jsPost); // 执行POST请求
|
|
|
@ -450,15 +641,25 @@ public class GTaskClient {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
// 添加更新节点
|
|
|
|
// 添加更新节点
|
|
|
|
public void addUpdateNode(Node node) throws NetworkFailureException {
|
|
|
|
public void addUpdateNode(Node node) throws NetworkFailureException {
|
|
|
|
if (node != null) {
|
|
|
|
if (node != null) {
|
|
|
|
// 更新项目过多可能会导致错误,最多设为10个项目
|
|
|
|
// 更新项目过多可能会导致错误,最多设为10个项目
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// 添加一个节点的更新操作到暂存的更新操作数组中,限制最多10个更新项
|
|
|
|
|
|
|
|
// 将节点的更新操作添加到更新数组中,如果更新数组中的元素超过10个,则先提交更新
|
|
|
|
|
|
|
|
public void addUpdateNode(Node node) throws NetworkFailureException {
|
|
|
|
|
|
|
|
if (node != null) {
|
|
|
|
|
|
|
|
// 过多的更新项可能会导致错误,所以设置最大更新项数量为10个
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
if (mUpdateArray != null && mUpdateArray.length() > 10) {
|
|
|
|
if (mUpdateArray != null && mUpdateArray.length() > 10) {
|
|
|
|
commitUpdate(); // 提交更新
|
|
|
|
commitUpdate(); // 提交更新
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 如果更新数组为空,则创建一个新的JSONArray对象用于存放更新操作
|
|
|
|
if (mUpdateArray == null)
|
|
|
|
if (mUpdateArray == null)
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
mUpdateArray = new JSONArray(); // 初始化更新数组
|
|
|
|
mUpdateArray = new JSONArray(); // 初始化更新数组
|
|
|
|
mUpdateArray.put(node.getUpdateAction(getActionId())); // 将更新的节点添加到数组
|
|
|
|
mUpdateArray.put(node.getUpdateAction(getActionId())); // 将更新的节点添加到数组
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -467,11 +668,24 @@ public class GTaskClient {
|
|
|
|
// 移动任务
|
|
|
|
// 移动任务
|
|
|
|
public void moveTask(Task task, TaskList preParent, TaskList curParent) throws NetworkFailureException {
|
|
|
|
public void moveTask(Task task, TaskList preParent, TaskList curParent) throws NetworkFailureException {
|
|
|
|
commitUpdate(); // 提交更新
|
|
|
|
commitUpdate(); // 提交更新
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
mUpdateArray = new JSONArray();
|
|
|
|
|
|
|
|
// 将节点的更新操作(通过节点获取,操作ID使用当前的操作ID)添加到更新数组中
|
|
|
|
|
|
|
|
mUpdateArray.put(node.getUpdateAction(getActionId()));
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 移动任务,将任务从一个任务列表移动到另一个任务列表(可能是同一个列表内移动位置)
|
|
|
|
|
|
|
|
public void moveTask(Task task, TaskList preParent, TaskList curParent)
|
|
|
|
|
|
|
|
throws NetworkFailureException {
|
|
|
|
|
|
|
|
commitUpdate();
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
JSONObject jsPost = new JSONObject(); // 创建JSON对象
|
|
|
|
JSONObject jsPost = new JSONObject(); // 创建JSON对象
|
|
|
|
JSONArray actionList = new JSONArray(); // 创建动作列表
|
|
|
|
JSONArray actionList = new JSONArray(); // 创建动作列表
|
|
|
|
JSONObject action = new JSONObject(); // 创建动作对象
|
|
|
|
JSONObject action = new JSONObject(); // 创建动作对象
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
// 构建移动动作
|
|
|
|
// 构建移动动作
|
|
|
|
action.put(GTaskStringUtils.GTASK_JSON_ACTION_TYPE, GTaskStringUtils.GTASK_JSON_ACTION_TYPE_MOVE);
|
|
|
|
action.put(GTaskStringUtils.GTASK_JSON_ACTION_TYPE, GTaskStringUtils.GTASK_JSON_ACTION_TYPE_MOVE);
|
|
|
|
action.put(GTaskStringUtils.GTASK_JSON_ACTION_ID, getActionId());
|
|
|
|
action.put(GTaskStringUtils.GTASK_JSON_ACTION_ID, getActionId());
|
|
|
@ -495,21 +709,64 @@ public class GTaskClient {
|
|
|
|
jsPost.put(GTaskStringUtils.GTASK_JSON_CLIENT_VERSION, mClientVersion);
|
|
|
|
jsPost.put(GTaskStringUtils.GTASK_JSON_CLIENT_VERSION, mClientVersion);
|
|
|
|
|
|
|
|
|
|
|
|
postRequest(jsPost); // 执行POST请求
|
|
|
|
postRequest(jsPost); // 执行POST请求
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// 操作列表相关设置
|
|
|
|
|
|
|
|
// 设置操作类型为移动任务(对应预定义的移动操作类型常量)
|
|
|
|
|
|
|
|
action.put(GTaskStringUtils.GTASK_JSON_ACTION_TYPE,
|
|
|
|
|
|
|
|
GTaskStringUtils.GTASK_JSON_ACTION_TYPE_MOVE);
|
|
|
|
|
|
|
|
// 设置操作的唯一ID,通过获取下一个可用的操作ID来赋值
|
|
|
|
|
|
|
|
action.put(GTaskStringUtils.GTASK_JSON_ACTION_ID, getActionId());
|
|
|
|
|
|
|
|
// 设置要移动的任务的全局唯一ID
|
|
|
|
|
|
|
|
action.put(GTaskStringUtils.GTASK_JSON_ID, task.getGid());
|
|
|
|
|
|
|
|
// 如果移动前后的父任务列表相同(即在同一个任务列表内移动),并且任务不是该列表中的第一个任务,
|
|
|
|
|
|
|
|
// 则设置其前一个兄弟任务的ID,用于确定移动后的顺序
|
|
|
|
|
|
|
|
if (preParent == curParent && task.getPriorSibling() != null) {
|
|
|
|
|
|
|
|
action.put(GTaskStringUtils.GTASK_JSON_PRIOR_SIBLING_ID, task.getPriorSibling());
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
// 设置任务原来所在的任务列表的全局唯一ID(源列表)
|
|
|
|
|
|
|
|
action.put(GTaskStringUtils.GTASK_JSON_SOURCE_LIST, preParent.getGid());
|
|
|
|
|
|
|
|
// 设置任务要移动到的目标任务列表的父级任务列表的全局唯一ID(目标父列表)
|
|
|
|
|
|
|
|
action.put(GTaskStringUtils.GTASK_JSON_DEST_PARENT, curParent.getGid());
|
|
|
|
|
|
|
|
// 如果移动是在不同的任务列表之间进行,则设置目标任务列表的全局唯一ID(目标列表)
|
|
|
|
|
|
|
|
if (preParent != curParent) {
|
|
|
|
|
|
|
|
action.put(GTaskStringUtils.GTASK_JSON_DEST_LIST, curParent.getGid());
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
// 将这个移动操作添加到操作列表中
|
|
|
|
|
|
|
|
actionList.put(action);
|
|
|
|
|
|
|
|
// 将操作列表添加到要发送的JSON数据对象中,对应预定义的操作列表的JSON键
|
|
|
|
|
|
|
|
jsPost.put(GTaskStringUtils.GTASK_JSON_ACTION_LIST, actionList);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 设置客户端版本号,对应预定义的客户端版本号的JSON键
|
|
|
|
|
|
|
|
jsPost.put(GTaskStringUtils.GTASK_JSON_CLIENT_VERSION, mClientVersion);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 发送POST请求,将包含移动任务操作信息的JSON数据发送到服务器进行处理
|
|
|
|
|
|
|
|
postRequest(jsPost);
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
|
|
|
|
|
|
|
|
} catch (JSONException e) {
|
|
|
|
} catch (JSONException e) {
|
|
|
|
Log.e(TAG, e.toString());
|
|
|
|
Log.e(TAG, e.toString());
|
|
|
|
e.printStackTrace();
|
|
|
|
e.printStackTrace();
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
throw new ActionFailureException("move task: handing jsonobject failed"); // 抛出JSON处理异常
|
|
|
|
throw new ActionFailureException("move task: handing jsonobject failed"); // 抛出JSON处理异常
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// 删除节点
|
|
|
|
// 删除节点
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// 如果JSON处理出现异常,抛出操作失败异常,并说明是移动任务时处理JSON对象失败
|
|
|
|
|
|
|
|
throw new ActionFailureException("move task: handing jsonobject failed");
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 删除节点(比如任务、任务列表等),通过设置节点的删除标记为true,并将其更新操作发送到服务器来实现删除
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
public void deleteNode(Node node) throws NetworkFailureException {
|
|
|
|
public void deleteNode(Node node) throws NetworkFailureException {
|
|
|
|
commitUpdate(); // 提交更新
|
|
|
|
commitUpdate(); // 提交更新
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
JSONObject jsPost = new JSONObject(); // 创建JSON对象
|
|
|
|
JSONObject jsPost = new JSONObject(); // 创建JSON对象
|
|
|
|
JSONArray actionList = new JSONArray(); // 创建动作列表
|
|
|
|
JSONArray actionList = new JSONArray(); // 创建动作列表
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
// 标记节点为已删除并添加到动作列表
|
|
|
|
// 标记节点为已删除并添加到动作列表
|
|
|
|
node.setDeleted(true);
|
|
|
|
node.setDeleted(true);
|
|
|
|
actionList.put(node.getUpdateAction(getActionId())); // 获取节点更新动作并添加到列表
|
|
|
|
actionList.put(node.getUpdateAction(getActionId())); // 获取节点更新动作并添加到列表
|
|
|
@ -528,6 +785,32 @@ public class GTaskClient {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// 获取任务列表
|
|
|
|
// 获取任务列表
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// 操作列表相关设置
|
|
|
|
|
|
|
|
// 将节点标记为已删除
|
|
|
|
|
|
|
|
node.setDeleted(true);
|
|
|
|
|
|
|
|
// 将节点的更新操作(此时因为已标记为删除,对应的就是删除操作)添加到操作列表中
|
|
|
|
|
|
|
|
actionList.put(node.getUpdateAction(getActionId()));
|
|
|
|
|
|
|
|
// 将操作列表添加到要发送的JSON数据对象中,对应预定义的操作列表的JSON键
|
|
|
|
|
|
|
|
jsPost.put(GTaskStringUtils.GTASK_JSON_ACTION_LIST, actionList);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 设置客户端版本号,对应预定义的客户端版本号的JSON键
|
|
|
|
|
|
|
|
jsPost.put(GTaskStringUtils.GTASK_JSON_CLIENT_VERSION, mClientVersion);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 发送POST请求,将包含删除节点操作信息的JSON数据发送到服务器进行处理
|
|
|
|
|
|
|
|
postRequest(jsPost);
|
|
|
|
|
|
|
|
// 发送成功后,将更新数组置空,因为相关更新操作已提交完成
|
|
|
|
|
|
|
|
mUpdateArray = null;
|
|
|
|
|
|
|
|
} catch (JSONException e) {
|
|
|
|
|
|
|
|
Log.e(TAG, e.toString());
|
|
|
|
|
|
|
|
e.printStackTrace();
|
|
|
|
|
|
|
|
// 如果JSON处理出现异常,抛出操作失败异常,并说明是删除节点时处理JSON对象失败
|
|
|
|
|
|
|
|
throw new ActionFailureException("delete node: handing jsonobject failed");
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 获取所有的任务列表信息,前提是已经登录成功,否则会抛出异常提示需要先登录
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
public JSONArray getTaskLists() throws NetworkFailureException {
|
|
|
|
public JSONArray getTaskLists() throws NetworkFailureException {
|
|
|
|
if (!mLoggedin) {
|
|
|
|
if (!mLoggedin) {
|
|
|
|
Log.e(TAG, "please login first"); // 如果未登录,记录错误
|
|
|
|
Log.e(TAG, "please login first"); // 如果未登录,记录错误
|
|
|
@ -535,11 +818,22 @@ public class GTaskClient {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
HttpGet httpGet = new HttpGet(mGetUrl); // 创建GET请求
|
|
|
|
HttpGet httpGet = new HttpGet(mGetUrl); // 创建GET请求
|
|
|
|
HttpResponse response = mHttpClient.execute(httpGet); // 执行请求
|
|
|
|
HttpResponse response = mHttpClient.execute(httpGet); // 执行请求
|
|
|
|
|
|
|
|
|
|
|
|
// 获取任务列表
|
|
|
|
// 获取任务列表
|
|
|
|
String resString = getResponseContent(response.getEntity()); // 获取响应内容
|
|
|
|
String resString = getResponseContent(response.getEntity()); // 获取响应内容
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// 创建一个HTTP GET请求对象,用于获取任务列表数据,请求的URL是之前设置好的获取数据的URL
|
|
|
|
|
|
|
|
HttpGet httpGet = new HttpGet(mGetUrl);
|
|
|
|
|
|
|
|
HttpResponse response = null;
|
|
|
|
|
|
|
|
// 执行HTTP GET请求,获取服务器的响应
|
|
|
|
|
|
|
|
response = mHttpClient.execute(httpGet);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 从响应的实体中获取内容,并进行处理,提取出包含任务列表信息的JSON数据部分
|
|
|
|
|
|
|
|
String resString = getResponseContent(response.getEntity());
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
String jsBegin = "_setup(";
|
|
|
|
String jsBegin = "_setup(";
|
|
|
|
String jsEnd = ")}</script>";
|
|
|
|
String jsEnd = ")}</script>";
|
|
|
|
int begin = resString.indexOf(jsBegin);
|
|
|
|
int begin = resString.indexOf(jsBegin);
|
|
|
@ -549,6 +843,7 @@ public class GTaskClient {
|
|
|
|
if (begin != -1 && end != -1 && begin < end) {
|
|
|
|
if (begin != -1 && end != -1 && begin < end) {
|
|
|
|
jsString = resString.substring(begin + jsBegin.length(), end);
|
|
|
|
jsString = resString.substring(begin + jsBegin.length(), end);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
JSONObject js = new JSONObject(jsString); // 创建JSON对象
|
|
|
|
JSONObject js = new JSONObject(jsString); // 创建JSON对象
|
|
|
|
return js.getJSONObject("t").getJSONArray(GTaskStringUtils.GTASK_JSON_LISTS); // 返回任务列表
|
|
|
|
return js.getJSONObject("t").getJSONArray(GTaskStringUtils.GTASK_JSON_LISTS); // 返回任务列表
|
|
|
|
} catch (ClientProtocolException e) {
|
|
|
|
} catch (ClientProtocolException e) {
|
|
|
@ -567,6 +862,30 @@ public class GTaskClient {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// 获取指定任务列表
|
|
|
|
// 获取指定任务列表
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
JSONObject js = new JSONObject(jsString);
|
|
|
|
|
|
|
|
// 从解析后的JSON对象中获取任务列表数组并返回,对应预定义的任务列表的JSON键
|
|
|
|
|
|
|
|
return js.getJSONObject("t").getJSONArray(GTaskStringUtils.GTASK_JSON_LISTS);
|
|
|
|
|
|
|
|
} catch (ClientProtocolException e) {
|
|
|
|
|
|
|
|
Log.e(TAG, e.toString());
|
|
|
|
|
|
|
|
e.printStackTrace();
|
|
|
|
|
|
|
|
// 如果HTTP协议相关操作出现异常,抛出网络失败异常,并说明是获取任务列表时HTTP GET请求失败
|
|
|
|
|
|
|
|
throw new NetworkFailureException("gettasklists: httpget failed");
|
|
|
|
|
|
|
|
} catch (IOException e) {
|
|
|
|
|
|
|
|
Log.e(TAG, e.toString());
|
|
|
|
|
|
|
|
e.printStackTrace();
|
|
|
|
|
|
|
|
// 如果输入输出操作出现异常,抛出网络失败异常,并说明是获取任务列表时HTTP GET请求失败
|
|
|
|
|
|
|
|
throw new NetworkFailureException("gettasklists: httpget failed");
|
|
|
|
|
|
|
|
} catch (JSONException e) {
|
|
|
|
|
|
|
|
Log.e(TAG, e.toString());
|
|
|
|
|
|
|
|
e.printStackTrace();
|
|
|
|
|
|
|
|
// 如果JSON处理出现异常,抛出操作失败异常,并说明是获取任务列表时处理JSON对象失败
|
|
|
|
|
|
|
|
throw new ActionFailureException("get task lists: handing jasonobject failed");
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 根据给定的任务列表全局唯一ID,获取该任务列表中的任务信息,需要先提交之前暂存的更新操作
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
public JSONArray getTaskList(String listGid) throws NetworkFailureException {
|
|
|
|
public JSONArray getTaskList(String listGid) throws NetworkFailureException {
|
|
|
|
commitUpdate(); // 提交更新
|
|
|
|
commitUpdate(); // 提交更新
|
|
|
|
try {
|
|
|
|
try {
|
|
|
@ -574,6 +893,7 @@ public class GTaskClient {
|
|
|
|
JSONArray actionList = new JSONArray(); // 创建动作列表
|
|
|
|
JSONArray actionList = new JSONArray(); // 创建动作列表
|
|
|
|
JSONObject action = new JSONObject(); // 创建动作对象
|
|
|
|
JSONObject action = new JSONObject(); // 创建动作对象
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
// 构建获取所有任务的动作
|
|
|
|
// 构建获取所有任务的动作
|
|
|
|
action.put(GTaskStringUtils.GTASK_JSON_ACTION_TYPE, GTaskStringUtils.GTASK_JSON_ACTION_TYPE_GETALL);
|
|
|
|
action.put(GTaskStringUtils.GTASK_JSON_ACTION_TYPE, GTaskStringUtils.GTASK_JSON_ACTION_TYPE_GETALL);
|
|
|
|
action.put(GTaskStringUtils.GTASK_JSON_ACTION_ID, getActionId());
|
|
|
|
action.put(GTaskStringUtils.GTASK_JSON_ACTION_ID, getActionId());
|
|
|
@ -595,12 +915,52 @@ public class GTaskClient {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// 获取同步账户
|
|
|
|
// 获取同步账户
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// 操作列表相关设置
|
|
|
|
|
|
|
|
// 设置操作类型为获取所有任务(对应预定义的获取所有任务操作类型常量)
|
|
|
|
|
|
|
|
action.put(GTaskStringUtils.GTASK_JSON_ACTION_TYPE,
|
|
|
|
|
|
|
|
GTaskStringUtils.GTASK_JSON_ACTION_TYPE_GETALL);
|
|
|
|
|
|
|
|
// 设置操作的唯一ID,通过获取下一个可用的操作ID来赋值
|
|
|
|
|
|
|
|
action.put(GTaskStringUtils.GTASK_JSON_ACTION_ID, getActionId());
|
|
|
|
|
|
|
|
// 设置要获取任务的任务列表的全局唯一ID
|
|
|
|
|
|
|
|
action.put(GTaskStringUtils.GTASK_JSON_LIST_ID, listGid);
|
|
|
|
|
|
|
|
// 设置是否获取已删除的任务,这里设置为false,表示不获取已删除任务
|
|
|
|
|
|
|
|
action.put(GTaskStringUtils.GTASK_JSON_GET_DELETED, false);
|
|
|
|
|
|
|
|
// 将这个获取任务操作添加到操作列表中
|
|
|
|
|
|
|
|
actionList.put(action);
|
|
|
|
|
|
|
|
// 将操作列表添加到要发送的JSON数据对象中,对应预定义的操作列表的JSON键
|
|
|
|
|
|
|
|
jsPost.put(GTaskStringUtils.GTASK_JSON_ACTION_LIST, actionList);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 设置客户端版本号,对应预定义的客户端版本号的JSON键
|
|
|
|
|
|
|
|
jsPost.put(GTaskStringUtils.GTASK_JSON_CLIENT_VERSION, mClientVersion);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 发送POST请求,将包含获取任务列表中任务操作信息的JSON数据发送到服务器进行处理
|
|
|
|
|
|
|
|
JSONObject jsResponse = postRequest(jsPost);
|
|
|
|
|
|
|
|
// 从服务器响应的JSON数据中获取任务数组并返回,对应预定义的任务的JSON键
|
|
|
|
|
|
|
|
return jsResponse.getJSONArray(GTaskStringUtils.GTASK_JSON_TASKS);
|
|
|
|
|
|
|
|
} catch (JSONException e) {
|
|
|
|
|
|
|
|
Log.e(TAG, e.toString());
|
|
|
|
|
|
|
|
e.printStackTrace();
|
|
|
|
|
|
|
|
// 如果JSON处理出现异常,抛出操作失败异常,并说明是获取任务列表时处理JSON对象失败
|
|
|
|
|
|
|
|
throw new ActionFailureException("get task list: handing jsonobject failed");
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 获取当前用于同步的账户信息
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|
public Account getSyncAccount() {
|
|
|
|
public Account getSyncAccount() {
|
|
|
|
return mAccount; // 返回账户信息
|
|
|
|
return mAccount; // 返回账户信息
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<<<<<<< HEAD
|
|
|
|
// 重置更新数组
|
|
|
|
// 重置更新数组
|
|
|
|
public void resetUpdateArray() {
|
|
|
|
public void resetUpdateArray() {
|
|
|
|
mUpdateArray = null; // 清空更新数组
|
|
|
|
mUpdateArray = null; // 清空更新数组
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
=======
|
|
|
|
|
|
|
|
// 重置更新数组,即将其置为空,一般用于清除之前暂存的更新操作相关数据
|
|
|
|
|
|
|
|
public void resetUpdateArray() {
|
|
|
|
|
|
|
|
mUpdateArray = null;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
>>>>>>> a495b394fa4686564cc2bfe7d054eb66276713ae
|
|
|
|