package org.average.whereami;
+import org.average.whereami.APIBase;
+import org.average.whereami.Oracle;
+import org.average.whereami.Utterance;
import org.average.whereami.PersistentStore;
import org.average.whereami.SayWhen;
import java.io.IOException;
+import java.net.UnknownHostException;
+import org.apache.http.conn.HttpHostConnectException;
import com.google.api.client.googleapis.json.GoogleJsonResponseException;
import com.google.api.client.http.HttpResponseException;
final String TAG = getClass().getName();
- private PersistentStore store;
private String calendar_name;
private String peer_name;
private String calendar_id;
private SayWhen sayWhen;
private Calendar calendar;
- public PhoneLog(final Resources res, final PersistentStore store) {
- super(res, store);
- this.store = store;
- nocalendar = res.getString(R.string.nocalendar);
- noevents = res.getString(R.string.noevents);
- last_call = res.getString(R.string.last_call);
- in_call = res.getString(R.string.in_call);
- out_call = res.getString(R.string.out_call);
- duration = res.getString(R.string.duration);
- lessthan = res.getString(R.string.lessthan);
- minutes1 = res.getString(R.string.minutes1);
- minutes2to4 = res.getString(R.string.minutes2to4);
- minutes5up = res.getString(R.string.minutes5up);
- sayWhen = new SayWhen(res);
- calendar_name = store.get("calendar_name");
- peer_name = store.get("peer_name");
- calendar_id = store.get("calendar_id");
- calendar = Calendar.builder(httpTransport, jsonFactory)
+ public PhoneLog(APIBase base) {
+ super(base);
+ nocalendar = base.res.getString(R.string.nocalendar);
+ noevents = base.res.getString(R.string.noevents);
+ last_call = base.res.getString(R.string.last_call);
+ in_call = base.res.getString(R.string.in_call);
+ out_call = base.res.getString(R.string.out_call);
+ duration = base.res.getString(R.string.duration);
+ lessthan = base.res.getString(R.string.lessthan);
+ minutes1 = base.res.getString(R.string.minutes1);
+ minutes2to4 = base.res.getString(R.string.minutes2to4);
+ minutes5up = base.res.getString(R.string.minutes5up);
+ sayWhen = new SayWhen(base.res);
+ calendar_name = base.store.get("calendar_name");
+ peer_name = base.store.get("peer_name");
+ calendar_id = base.store.get("calendar_id");
+ calendar = Calendar.builder(base.httpTransport,
+ base.jsonFactory)
.setHttpRequestInitializer(
- newMyAccessProtectedResource())
+ base.accessProtectedResource)
.setApplicationName("WhereAmI/1.0").build();
}
@Override
- public final String getResult() {
+ public final Utterance getResult() {
try {
Log.v(TAG, "entering getResult");
if (calendar_id == null || calendar_id == "") {
calendar_id = scanCalendars(calendar_name);
}
if (calendar_id == null || calendar_id == "") {
- return nocalendar + " \"" +
- calendar_name + "\"";
+ return new Utterance(true,
+ nocalendar + " \"" +
+ calendar_name + "\"");
} else {
- store.put("calendar_id", calendar_id);
- return scanEvents(calendar_id, peer_name);
+ base.store.put("calendar_id", calendar_id);
+ return new Utterance(true,
+ scanEvents(calendar_id, peer_name));
}
} catch (GoogleJsonResponseException e) {
Log.e(TAG, "GoogleJsonResponseException: " + e);
if (e.getResponse().getStatusCode() == 401) {
- return authErrorMessage;
+ return new Utterance(false,
+ base.authErrorMessage + "\n" +
+ e.getMessage());
} else {
- return e.getMessage();
+ return new Utterance(false,
+ e.getMessage());
}
} catch (HttpResponseException e) {
Log.e(TAG, "HttpResponseException: " + e);
- return e.getMessage();
+ return new Utterance(false, e.getMessage());
+ } catch (UnknownHostException e) {
+ Log.e(TAG, "UnknownHostException: " + e);
+ return new Utterance(false,
+ base.connectErrorMessage + "\n" +
+ e.getMessage());
+ } catch (HttpHostConnectException e) {
+ Log.e(TAG, "HttpHostConnectException: " + e);
+ return new Utterance(false,
+ base.connectErrorMessage + "\n" +
+ e.getMessage());
} catch (IOException e) {
- e.printStackTrace();
- return e.getMessage();
+ Log.e(TAG, "IOException: " + e);
+ return new Utterance(false, e.getMessage());
}
}