SoslSyncDownTarget.java
/*
* Copyright (c) 2015-present, salesforce.com, inc.
* All rights reserved.
* Redistribution and use of this software in source and binary forms, with or
* without modification, are permitted provided that the following conditions
* are met:
* - Redistributions of source code must retain the above copyright notice, this
* list of conditions and the following disclaimer.
* - Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
* - Neither the name of salesforce.com, inc. nor the names of its contributors
* may be used to endorse or promote products derived from this software without
* specific prior written permission of salesforce.com, inc.
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*/
package com.salesforce.androidsdk.smartsync.util;
import android.util.Log;
import com.salesforce.androidsdk.rest.RestRequest;
import com.salesforce.androidsdk.rest.RestResponse;
import com.salesforce.androidsdk.smartsync.manager.SyncManager;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;
import java.io.IOException;
import java.util.HashSet;
import java.util.Set;
/**
* Target for sync defined by a SOSL query
*/
public class SoslSyncDownTarget extends SyncDownTarget {
public static final String QUERY = "query";
private static final String TAG = "SoslSyncDownTarget";
private String query;
/**
* Construct SoslSyncDownTarget from json
* @param target
* @throws JSONException
*/
public SoslSyncDownTarget(JSONObject target) throws JSONException {
super(target);
this.query = target.getString(QUERY);
}
/**
* Construct SoslSyncDownTarget from sosl query
* @param query
*/
public SoslSyncDownTarget(String query) {
super();
this.queryType = QueryType.sosl;
this.query = query;
}
/**
* @return json representation of target
* @throws JSONException
*/
public JSONObject asJSON() throws JSONException {
JSONObject target = super.asJSON();
target.put(QUERY, query);
return target;
}
@Override
public JSONArray startFetch(SyncManager syncManager, long maxTimeStamp) throws IOException, JSONException {
return startFetch(syncManager, maxTimeStamp, query);
}
private JSONArray startFetch(SyncManager syncManager, long maxTimeStamp, String queryRun) throws IOException, JSONException {
RestRequest request = RestRequest.getRequestForSearch(syncManager.apiVersion, queryRun);
RestResponse response = syncManager.sendSyncWithSmartSyncUserAgent(request);
JSONArray records = response.asJSONArray();
// Recording total size
totalSize = records.length();
return records;
}
@Override
public JSONArray continueFetch(SyncManager syncManager) throws IOException, JSONException {
return null;
}
@Override
public Set<String> getListOfRemoteIds(SyncManager syncManager, Set<String> localIds) {
if (localIds == null) {
return null;
}
final Set<String> remoteIds = new HashSet<String>();
// Makes network request and parses the response.
try {
final JSONArray records = startFetch(syncManager, 0, query);
remoteIds.addAll(parseIdsFromResponse(records));
} catch (IOException e) {
Log.e(TAG, "IOException thrown while fetching records", e);
} catch (JSONException e) {
Log.e(TAG, "JSONException thrown while fetching records", e);
}
return remoteIds;
}
/**
* @return sosl query for this target
*/
public String getQuery() {
return query;
}
}