+ calendar = Calendar.builder(httpTransport, jsonFactory)
+ .setHttpRequestInitializer(accessProtectedResource())
+ .setApplicationName("WhereAmI/1.0").build();
+ 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 + "\"";
+ } else {
+ store.put("calendar_id", calendar_id);
+ return scanEvents(calendar_id, peer_name);
+ }
+ } catch (GoogleJsonResponseException e) {
+ Log.e(TAG, "GoogleJsonResponseException: " + e);
+ if (e.getResponse().getStatusCode() == 401) {
+ return authErrorMessage;
+ } else {
+ return e.getMessage();
+ }
+ } catch (HttpResponseException e) {
+ Log.e(TAG, "HttpResponseException: " + e);
+ return e.getMessage();
+ } catch (IOException e) {
+ e.printStackTrace();
+ return e.getMessage();
+ }
+ }
+
+ private String scanCalendars(String calendar_name)
+ throws java.io.IOException {
+ String res = "";
+ Log.v(TAG, "Entering scanCalendars for \"" +
+ calendar_name + "\"");
+
+ CalendarList cl = calendar.calendarList().list().execute();
+ while (true) {
+ String pt = cl.getNextPageToken();
+ Log.v(TAG, "got cl with pt=" + pt);
+ for (CalendarListEntry le : cl.getItems()) {
+ Log.v(TAG, "entry " + le.getId() + ":\"" +
+ le.getSummary() + "\"");
+ if (le.getSummary().equals(calendar_name)) {
+ res = le.getId();
+ //break; // get all in the log
+ }
+ }
+ if (pt != null && pt != "") {
+ cl = calendar.calendarList().list()
+ .setPageToken(pt).execute();
+ } else {
+ break;
+ }
+ }
+
+ return res;
+ }
+
+ private String scanEvents(String calendar_id, String peer_name)
+ throws java.io.IOException {
+ Log.v(TAG, "Entering scanEvents for \"" +
+ peer_name + "\" in \"" + calendar_id + "\"");
+ Integer count = 0;
+ Time ago = new Time();
+ ago.set(System.currentTimeMillis() - 604800000L);
+ Long latestStartTime = 0L;
+ Long latestStopTime = 0L;
+ Boolean latestWasOutgoing = false;
+ Boolean wasFound = false;
+
+ Events events = calendar.events().list(calendar_id)
+ .setTimeMin(ago.format3339(false))
+ .setQ(peer_name)
+ .execute();
+ while (true) {
+ String pt = events.getNextPageToken();
+ Log.v(TAG, "got events with pt=" + pt);
+ for (Event event : events.getItems()) {
+ count++;
+ String evSummary = event.getSummary();
+ Long evStart = event.getStart()
+ .getDateTime().getValue();
+ Long evStop = event.getEnd()
+ .getDateTime().getValue();
+ Log.v(TAG, "event " + evStart +
+ " - " + evStop +
+ " : \"" + evSummary + "\"");
+ if ((evSummary.startsWith("Call To ") ||
+ evSummary.startsWith("Call From ")) &&
+ evStart > latestStartTime) {
+ latestStartTime = evStart;
+ latestStopTime = evStop;
+ latestWasOutgoing = evSummary
+ .startsWith("Call To ");
+ wasFound = true;
+ }
+ }
+ if (count < 100 && pt != null && pt != "") {
+ events = calendar.events().list(calendar_id)
+ .setTimeMin(ago.format3339(false))
+ .setQ(peer_name)
+ .setPageToken(pt).execute();
+ } else {
+ break;
+ }
+ }
+
+ if (wasFound) {
+ return makeMessage(latestStartTime, latestStopTime,
+ latestWasOutgoing);
+ } else {
+ return noevents;
+ }
+ }
+
+ private String makeMessage(Long latestStartTime, Long latestStopTime,
+ Boolean latestWasOutgoing) {
+ Time stime = new Time();
+ stime.set(latestStartTime);
+ Long dur = (latestStopTime - latestStartTime) / 60000L;
+ Log.v(TAG, "Chosen event: start " + stime +
+ " for " + dur + " min");
+ String minutes;
+ String howlong = dur.toString();
+ if (dur == 0) {
+ howlong = lessthan;
+ minutes = minutes2to4;
+ } else if ((dur / 10) == 1) {
+ minutes = minutes5up;
+ } else if ((dur % 10) == 1) {
+ minutes = minutes1;
+ } else if ((dur % 10) < 5) {
+ minutes = minutes2to4;
+ } else {
+ minutes = minutes5up;
+ }
+ return last_call +
+ " " + (latestWasOutgoing?out_call:in_call) +
+ " " + sayWhen.say(latestStartTime) +
+ " " + duration + " " + howlong + " " + minutes;