diff --git a/src/de/schildbach/pte/AbstractEfaProvider.java b/src/de/schildbach/pte/AbstractEfaProvider.java index c63908c9..3928befb 100644 --- a/src/de/schildbach/pte/AbstractEfaProvider.java +++ b/src/de/schildbach/pte/AbstractEfaProvider.java @@ -161,8 +161,8 @@ public abstract class AbstractEfaProvider implements NetworkProvider type = LocationType.ANY; id = 0; } - else if ("postcode".equals(anyType) || "street".equals(anyType) || "address".equals(anyType) || "singlehouse".equals(anyType) - || "buildingname".equals(anyType)) + else if ("postcode".equals(anyType) || "street".equals(anyType) || "crossing".equals(anyType) || "address".equals(anyType) + || "singlehouse".equals(anyType) || "buildingname".equals(anyType)) { type = LocationType.ADDRESS; id = 0; @@ -680,6 +680,12 @@ public abstract class AbstractEfaProvider implements NetworkProvider return 'T' + str; if (type.equals("STR")) // Nordhausen return 'T' + str; + if ("California Cable Car".equals(name)) // San Francisco + return 'T' + name; + if ("Muni Rail".equals(noTrainName)) // San Francisco + return 'T' + name; + if ("Cable Car".equals(noTrainName)) // San Francisco + return 'T' + name; if (type.equals("BUS")) return 'B' + str; @@ -1293,9 +1299,17 @@ public abstract class AbstractEfaProvider implements NetworkProvider } if (key.equals("FOR_RIDER")) - type = Type.valueOf(value.split(" ")[0].toUpperCase()); + { + final String typeStr = value.split(" ")[0].toUpperCase(); + if (typeStr.equals("REGULAR")) + type = Type.ADULT; + else + type = Type.valueOf(typeStr); + } else if (key.equals("PRICE")) - fare = Float.parseFloat(value); + { + fare = Float.parseFloat(value) * (currency.getCurrencyCode().equals("US$") ? 0.01f : 1); + } XmlPullUtil.exit(pp, "itdGenericTicket"); } diff --git a/src/de/schildbach/pte/NetworkId.java b/src/de/schildbach/pte/NetworkId.java index f65bb857..dd09114a 100644 --- a/src/de/schildbach/pte/NetworkId.java +++ b/src/de/schildbach/pte/NetworkId.java @@ -44,5 +44,8 @@ public enum NetworkId MARIBOR, // United Arab Emirates - DUB + DUB, + + // United States + SF } diff --git a/src/de/schildbach/pte/SfProvider.java b/src/de/schildbach/pte/SfProvider.java new file mode 100644 index 00000000..85c98f33 --- /dev/null +++ b/src/de/schildbach/pte/SfProvider.java @@ -0,0 +1,139 @@ +/* + * Copyright 2010 the original author or authors. + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see . + */ + +package de.schildbach.pte; + +import java.text.DateFormat; +import java.text.SimpleDateFormat; +import java.util.Date; +import java.util.TimeZone; + +import de.schildbach.pte.dto.Location; +import de.schildbach.pte.util.ParserUtils; + +/** + * @author Andreas Schildbach + */ +public class SfProvider extends AbstractEfaProvider +{ + public static final NetworkId NETWORK_ID = NetworkId.SF; + private final static String API_BASE = "http://tripplanner.transit.511.org/mtc/"; + + public NetworkId id() + { + return NETWORK_ID; + } + + @Override + protected TimeZone timeZone() + { + return TimeZone.getTimeZone("PST"); + } + + public boolean hasCapabilities(Capability... capabilities) + { + for (final Capability capability : capabilities) + if (capability == Capability.DEPARTURES || capability == Capability.CONNECTIONS) + return true; + + return false; + } + + private static final String AUTOCOMPLETE_URI = API_BASE + + "XSLT_TRIP_REQUEST2?outputFormat=XML&coordOutputFormat=WGS84&locationServerActive=1&type_origin=any&name_origin=%s"; + + @Override + protected String autocompleteUri(final CharSequence constraint) + { + return String.format(AUTOCOMPLETE_URI, ParserUtils.urlEncode(constraint.toString(), "ISO-8859-1")); + } + + @Override + protected String nearbyLatLonUri(final int lat, final int lon) + { + return null; + } + + private static final String NEARBY_STATION_URI = API_BASE + + "XSLT_DM_REQUEST" + + "?outputFormat=XML&coordOutputFormat=WGS84&name_dm=%s&type_dm=stop&itOptionsActive=1&ptOptionsActive=1&useProxFootSearch=1&mergeDep=1&useAllStops=1&mode=direct"; + + @Override + protected String nearbyStationUri(final String stationId) + { + return String.format(NEARBY_STATION_URI, ParserUtils.urlEncode(stationId)); + } + + @Override + protected String departuresQueryUri(final String stationId, final int maxDepartures) + { + final StringBuilder uri = new StringBuilder(); + uri.append(API_BASE).append("XSLT_DM_REQUEST"); + uri.append("?outputFormat=XML"); + uri.append("&coordOutputFormat=WGS84"); + uri.append("&type_dm=stop"); + uri.append("&name_dm=").append(stationId); + uri.append("&mode=direct"); + uri.append("&useRealtime=1"); + return uri.toString(); + } + + @Override + protected String connectionsQueryUri(final Location from, final Location via, final Location to, final Date date, final boolean dep, + final String products, final WalkSpeed walkSpeed) + { + final DateFormat DATE_FORMAT = new SimpleDateFormat("yyyyMMdd"); + final DateFormat TIME_FORMAT = new SimpleDateFormat("HHmm"); + + final StringBuilder uri = new StringBuilder(); + uri.append(API_BASE); + uri.append("XSLT_TRIP_REQUEST2"); + + uri.append("?language=de"); + appendCommonConnectionParams(uri); + + appendLocation(uri, from, "origin"); + appendLocation(uri, to, "destination"); + if (via != null) + appendLocation(uri, via, "via"); + + uri.append("&itdDate=").append(ParserUtils.urlEncode(DATE_FORMAT.format(date))); + uri.append("&itdTime=").append(ParserUtils.urlEncode(TIME_FORMAT.format(date))); + uri.append("&itdTripDateTimeDepArr=").append(dep ? "dep" : "arr"); + + uri.append("&ptOptionsActive=1"); + uri.append("&changeSpeed=").append(WALKSPEED_MAP.get(walkSpeed)); + uri.append(productParams(products)); + + uri.append("&locationServerActive=1"); + uri.append("&useRealtime=1"); + + return uri.toString(); + } + + @Override + protected String commandLink(final String sessionId, final String command) + { + final StringBuilder uri = new StringBuilder(); + uri.append(API_BASE); + uri.append("XSLT_TRIP_REQUEST2"); + uri.append("?sessionID=").append(sessionId); + appendCommonConnectionParams(uri); + uri.append("&command=").append(command); + return uri.toString(); + } +} diff --git a/src/de/schildbach/pte/dto/Fare.java b/src/de/schildbach/pte/dto/Fare.java index 1757e00e..ce37e86b 100644 --- a/src/de/schildbach/pte/dto/Fare.java +++ b/src/de/schildbach/pte/dto/Fare.java @@ -27,7 +27,7 @@ public final class Fare implements Serializable { public enum Type { - ADULT, CHILD, STUDENT, SENIOR + ADULT, CHILD, YOUTH, STUDENT, MILITARY, SENIOR, DISABLED } public final String network; diff --git a/test/de/schildbach/pte/live/SfProviderLiveTest.java b/test/de/schildbach/pte/live/SfProviderLiveTest.java new file mode 100644 index 00000000..6ee220b3 --- /dev/null +++ b/test/de/schildbach/pte/live/SfProviderLiveTest.java @@ -0,0 +1,48 @@ +/* + * Copyright 2010 the original author or authors. + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see . + */ + +package de.schildbach.pte.live; + +import org.junit.Test; + +import de.schildbach.pte.SfProvider; +import de.schildbach.pte.dto.NearbyStationsResult; +import de.schildbach.pte.dto.QueryDeparturesResult; + +/** + * @author Andreas Schildbach + */ +public class SfProviderLiveTest +{ + private final SfProvider provider = new SfProvider(); + + @Test + public void nearbyStation() throws Exception + { + final NearbyStationsResult result = provider.nearbyStations("San Franzisco", 0, 0, 0, 0); + + System.out.println(result.stations.size() + " " + result.stations); + } + + @Test + public void queryDepartures() throws Exception + { + final QueryDeparturesResult result = provider.queryDepartures("10010813", 0); + + System.out.println(result.departures.size() + " " + result.departures); + } +}