package org.fluxtream.connectors.sleep_as_android; import com.google.gdata.util.common.base.Pair; import org.fluxtream.core.SimpleTimeInterval; import org.fluxtream.core.TimeInterval; import org.fluxtream.core.TimeUnit; import org.fluxtream.core.connectors.Connector; import org.fluxtream.core.connectors.ObjectType; import org.fluxtream.core.connectors.bodytrackResponders.AbstractBodytrackResponder; import org.fluxtream.core.connectors.vos.AbstractFacetVO; import org.fluxtream.core.domain.AbstractFacet; import org.fluxtream.core.domain.ApiKey; import org.fluxtream.core.domain.ChannelMapping; import org.fluxtream.core.domain.GuestSettings; import org.fluxtream.core.mvc.models.TimespanModel; import org.springframework.stereotype.Component; import java.util.ArrayList; import java.util.List; import java.util.TimeZone; @Component public class SleepAsAndroidBodytrackResponder extends AbstractBodytrackResponder { @Override public List<TimespanModel> getTimespans(long startMillis, long endMillis, ApiKey apiKey, String channelName) { List<TimespanModel> items = new ArrayList<TimespanModel>(); final TimeInterval timeInterval = new SimpleTimeInterval(startMillis, endMillis, TimeUnit.ARBITRARY, TimeZone.getTimeZone("UTC")); Connector connector = apiKey.getConnector(); final ObjectType sleep_type = ObjectType.getObjectType(connector, "sleep"); String objectTypeName = apiKey.getConnector().getName() + "-" + sleep_type.getName(); List<AbstractFacet> facets = getFacetsInTimespan(timeInterval,apiKey, sleep_type); for (AbstractFacet facet : facets) { SleepFacet sleepFacet = (SleepFacet) facet; TimespanModel buildingLightModel = null; TimespanModel buildingDeepModel = null; TimespanModel buildingRemModel = null; //since we know these are sorted by time we won't need to worry about an end before a start for (Pair<String,Long> eventLabel : sleepFacet.getEventLabels()) { String s = eventLabel.getFirst(); if (s.equals("DEEP_START")) { buildingDeepModel = new TimespanModel(eventLabel.getSecond(),eventLabel.getSecond(),"deep",objectTypeName); } else if (s.equals("DEEP_END")) { buildingDeepModel.setEnd(eventLabel.getSecond()/1000); items.add(buildingDeepModel); buildingDeepModel = null; } else if (s.equals("LIGHT_START")) { buildingLightModel = new TimespanModel(eventLabel.getSecond(),eventLabel.getSecond(),"light",objectTypeName); } else if (s.equals("LIGHT_END")) { buildingLightModel.setEnd(eventLabel.getSecond()/1000); items.add(buildingLightModel); buildingLightModel = null; } else if (s.equals("REM_START")) { buildingRemModel = new TimespanModel(eventLabel.getSecond(),eventLabel.getSecond(),"rem",objectTypeName); } else if (s.equals("REM_END")) { buildingRemModel.setEnd(eventLabel.getSecond()/1000); items.add(buildingRemModel); buildingRemModel = null; } } } return items; } @Override public List<AbstractFacetVO<AbstractFacet>> getFacetVOs(GuestSettings guestSettings, ApiKey apiKey, String objectTypeName, long start, long end, String value) { Connector connector = apiKey.getConnector(); TimeInterval timeInterval = metadataService.getArbitraryTimespanMetadata(apiKey.getGuestId(), start, end).getTimeInterval(); final ObjectType recent_track = ObjectType.getObjectType(connector, "sleep"); List<AbstractFacet> facets = getFacetsInTimespan(timeInterval, apiKey, recent_track); return getFacetVOsForFacets(facets,timeInterval,guestSettings); } @Override public void addToDeclaredChannelMappings(ApiKey apiKey, List<ChannelMapping> mappings) { ChannelMapping movesDataChannelMapping = new ChannelMapping( apiKey.getId(), apiKey.getGuestId(), ChannelMapping.ChannelType.timespan, ChannelMapping.TimeType.gmt, ObjectType.getObjectType(apiKey.getConnector(), "sleep").value(), apiKey.getConnector().getDeviceNickname(), "sleep", apiKey.getConnector().getDeviceNickname(), "sleep"); mappings.add(movesDataChannelMapping); } }