sujinwen
2017-07-25 cf69a29aebf61307ef333d141b403370628f2a60
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
package cn.com.basic.face.service.sync.up;
 
 
import com.alibaba.fastjson.JSONArray;
 
import org.xutils.http.RequestParams;
import org.xutils.x;
 
import java.util.List;
 
import cn.com.basic.face.base.BaseApplication;
import cn.com.basic.face.discern.common.BaseCommonCallBack;
import cn.com.basic.face.discern.common.SqliteSqlBean;
import cn.com.basic.face.service.sqlite.DeviceDao;
import cn.com.basic.face.service.sqlite.SynchronRecordDao;
import cn.com.basic.face.util.AppApi;
import cn.com.basic.face.util.SqliteSqlUtil;
 
/**
 *
 * device双向同步
 * Created by SJW on 2017/7/25 0025.
 */
 
public class DeviceUpSync extends BaseSync {
 
    public static  DeviceUpSync instance=new DeviceUpSync();
    public static DeviceUpSync getInstance(){
        return instance;
    }
 
 
    /***
     * device表双向同步
     */
    public void doSync() {
        try{
            String tableName = "device";
            RequestParams params = new RequestParams(AppApi.BASE_URL + AppApi.TWO_WAY_SYNCHRON);
            params.addBodyParameter("tableName", tableName);
            params.addBodyParameter("synDate", SynchronRecordDao.getInstance().getSynRecord(tableName)==null?"":SynchronRecordDao.getInstance().getSynRecord(tableName).getSynchronTime());
            params.addBodyParameter("data", JSONArray.toJSONString(DeviceDao.getInstance().getDeviceList(BaseApplication.getInstance().getAndroidDevice().getCompanyId())));
            params.addBodyParameter("deviceCompanyId",BaseApplication.getInstance().getAndroidDevice().getCompanyId());
            x.http().post(params, new BaseCommonCallBack() {
                public void success() {
                    DeviceDao.getInstance().delDevice();
                    List<SqliteSqlBean> result= getExtraList(SqliteSqlBean.class);
                    SqliteSqlUtil.insert(getExtraList(SqliteSqlBean.class));
                    sync();
                }
            });
        }catch(Exception e){
            e.printStackTrace();
        }
    }
 
    /***
     * 查询deivice表是否有需要同步的数据
     * @return
     */
    public boolean hasMore() {
        int count= DeviceDao.getInstance().getSynDataCount();
        if(count==0){
            return false;
        }
        return true;
    }
 
}