Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Release #212

Merged
merged 116 commits into from
Jul 17, 2019
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
116 commits
Select commit Hold shift + click to select a range
ccf435e
feat(gis-export): add gis export for stops/routes
landonreed Jun 8, 2017
fa9ec49
initial work on merge feeds for MTC
landonreed Oct 11, 2018
8f8f6c4
Merge branch 'dev' into merge-feed-versions-mtc
landonreed Jan 28, 2019
9e76476
refactor(feed-merge): handle merging projects + two versions for feed…
landonreed Feb 1, 2019
cf7208c
Merge remote-tracking branch 'origin/fix-gtfs-plus-upload-job-fixes' …
landonreed Feb 5, 2019
17f651e
docs(github): add item about referencing PRs in PRs to master
evansiroky Feb 12, 2019
7bcbda7
ci: cache yarn stuff and preemptively fix semantic-release to v15
evansiroky Feb 14, 2019
88a57cd
refactor(auth0): log response body when an error from auth0 is received
evansiroky Feb 15, 2019
b6d1058
feat(merge-feeds): add MTC merge feeds strategy
landonreed Feb 15, 2019
2fc62d1
refactor(job): remove unused job type
landonreed Feb 15, 2019
1e7014b
refactor(merge-feeds): improve comments, add job#validationResult
landonreed Feb 15, 2019
ecf8388
Merge pull request #182 from conveyal/ci-improvements
Feb 15, 2019
4c93b80
Merge pull request #175 from conveyal/pr-template-addition
Feb 15, 2019
065c1ec
Merge pull request #184 from conveyal/auth0-error-response-logging
Feb 15, 2019
3b14e94
fix(users): pass through relevant auth0 failures to user API responses
evansiroky Feb 16, 2019
551a684
test(user): add CRUD tests for UserController
evansiroky Feb 16, 2019
e174aa3
refactor(test): change argument order for junit v4 compatibility
evansiroky Feb 16, 2019
c4109c4
refactor: address PR comments
landonreed Feb 18, 2019
f84dd4c
build(pom): update gtfs-lib to snapshot version for testing
landonreed Feb 19, 2019
114fc65
refactor: isolate Auth0 error handling changes
evansiroky Feb 21, 2019
5943dfb
test(user): add CRUD tests for auth0 endpoints
evansiroky Feb 21, 2019
adb9b0d
Merge branch 'dev' into merge-feed-versions-mtc
Mar 1, 2019
c5950c1
refactor(user): create methods for enabling test behavior and address…
evansiroky Mar 6, 2019
6919e14
refactor(auth0): move testing string literals into constants
landonreed Mar 7, 2019
e4bfe79
refactor(test): use PORT constant
landonreed Mar 7, 2019
c6eac0c
Merge pull request #190 from conveyal/auth0-test-tweaks
Mar 7, 2019
1e75f61
Merge pull request #187 from conveyal/auth0-error-response-improvements
Mar 11, 2019
c60b5a0
feat(project): add pinned deployments to projects
evansiroky Mar 22, 2019
f5ae65a
refactor(project): add comments about pinned deployment
evansiroky Mar 22, 2019
85661e4
feat(editor): add normalize stop times API endpoint
landonreed Mar 28, 2019
bc0b450
test(merge-feeds): add tests for MTC and REGIONAL merge types
landonreed Mar 28, 2019
9969a56
refactor(project): improve comment about pinned deployments
evansiroky Mar 28, 2019
d5e4e49
chore(pom): update gtfs-lib to 4.3.0
Apr 1, 2019
e4f089e
refactor(editor): remove unused editor controller hooks
landonreed Apr 1, 2019
a90940e
chore(pom): update gtfs-lib to 4.3.0
Apr 1, 2019
6802380
Merge pull request #193 from conveyal/gtfs-lib_4.3.0
Apr 1, 2019
566e4da
Merge pull request #191 from conveyal/pinned-deployments
Apr 1, 2019
10c253f
Merge branch 'dev' into merge-feed-versions-mtc
Apr 1, 2019
fb3a2d8
refactor(junit): refactor tests to use junit4
landonreed Apr 1, 2019
72c57f6
build(pom): add junit 4
landonreed Apr 1, 2019
6b06107
test: create database if not exists
landonreed Apr 1, 2019
c3b9c9e
test: add log
landonreed Apr 1, 2019
b0f0260
test(ci): create database using travis
landonreed Apr 1, 2019
54b0c0e
Merge pull request #192 from conveyal/normalize-stop_times
Apr 2, 2019
97e742f
build(travis): always create postgres db for tests
Apr 3, 2019
026f577
build(pom): bump gtfs-lib to 4.3.1
Apr 3, 2019
97dffea
refactor(feedValidationResultSummary): add FeedSource#publishedValida…
landonreed Apr 4, 2019
4d2d0e4
refactor(feedsource): publishedValidation -> publishedValidationSummary
landonreed Apr 4, 2019
853ddb8
Merge pull request #194 from conveyal/gtfs-lib-4.3.1
Apr 4, 2019
f5c6778
refactor(FeedSource): retrievePublished --> retrievePublishedVersion
landonreed Apr 8, 2019
f7eb459
refactor(FeedSource): add clarifying comments
landonreed Apr 8, 2019
ae95442
Merge pull request #195 from conveyal/add-published-validation
Apr 8, 2019
99e7f77
build(pom): bump gtfs-lib to 4.3.2
Apr 8, 2019
d3e8267
Merge pull request #196 from conveyal/gtfs-lib-4.3.2
Apr 8, 2019
9860110
Merge branch 'dev' into merge-feed-versions-mtc
landonreed Apr 11, 2019
c639c36
fix(users): update auth0 search engine to v3
robbi5 Apr 13, 2019
d94f40e
refactor(merge-feeds): address PR comments
landonreed Apr 23, 2019
126f61d
fix(merge-feeds): address remaining PR comments
landonreed Apr 24, 2019
9eeaac0
Merge branch 'dev' into gis-export
landonreed Apr 24, 2019
d2276a2
build(pom): bump gtfs-lib to 4.3.3
Apr 25, 2019
eccd433
feat(shapefile-export): add .shp export for routes or stops
landonreed Apr 26, 2019
98f2531
test(shp-export): re-add non-null geom assertion
landonreed Apr 26, 2019
08e5d95
Merge branch 'dev' into auth0-testing
evansiroky Apr 26, 2019
5361439
refactor(auth0): update so auth0 API calls work during testing
evansiroky Apr 26, 2019
7c03086
refactor(auth0): consolidate URI builder code
evansiroky Apr 27, 2019
11df612
refactor(test): update to latest java-snapshot-matcher
evansiroky Apr 29, 2019
6d9db08
fix(merge-feeds): add test for errors; fix missing stop_code bug
landonreed May 2, 2019
bcc5cbb
build(travis): remove oraclejdk8 to fix build
May 2, 2019
04c9c47
build(travis): use jdk 8 and linux trusty dist
landonreed May 2, 2019
5c42853
Merge pull request #198 from conveyal/snapshot-update
landonreed May 2, 2019
7f69f67
refactor(merge-feeds): improve error message for agency_id mismatch
landonreed May 2, 2019
a590fc3
build(pom): update gtfs-lib to 4.3.4
landonreed May 3, 2019
f81ba52
Merge branch 'dev' into merge-feed-versions-mtc
landonreed May 3, 2019
c43f697
refactor(export-gis): fix geotools version; add controller
landonreed May 6, 2019
6239db4
fix(permissions): use enum to check request action types
landonreed May 6, 2019
976d672
refactor(gis-export): generate shape from stops if shape missing
landonreed May 6, 2019
462d3dc
fix(export-gis): fix shapefile from pattern stops; update test
landonreed May 6, 2019
f7f6de6
build(travis): use jdk 8 and linux trusty dist
landonreed May 2, 2019
8645ab8
ci(travis): create postgres db before install
landonreed May 6, 2019
b9e95a0
refactor(merge-feeds): add description for exception
landonreed May 6, 2019
8be5e4a
Merge pull request #186 from conveyal/merge-feed-versions-mtc
landonreed May 6, 2019
d2c4703
Merge pull request #197 from robbi5/auth0-search-engine-v3
landonreed May 6, 2019
3d87e05
refactor(user): improve test readability and add comments
evansiroky May 7, 2019
8c7c051
Merge branch 'dev' into auth0-testing
evansiroky May 7, 2019
c88517c
refactor(test): update snapshots with latest snapshotter
evansiroky May 7, 2019
56589dc
Merge pull request #188 from conveyal/auth0-testing
landonreed May 7, 2019
defa58a
test(export-gis): address PR comments
landonreed May 9, 2019
e272c56
Merge branch 'dev' into gis-export
landonreed May 9, 2019
aaf1575
Merge pull request #199 from conveyal/gis-export
landonreed May 9, 2019
1bee80e
build(pom): update gtfs-lib to 4.3.5
landonreed May 21, 2019
6e304e4
Merge pull request #200 from conveyal/gtfs-lib-4.3.5
landonreed May 22, 2019
2aca2a9
fix(pom): fix jackson-databind security vuln.
landonreed May 23, 2019
e66a97e
fix(pom): fix jackson-databind to 2.9.9
landonreed May 23, 2019
6b36529
Merge pull request #201 from ibi-group/jackson-patch
landonreed May 28, 2019
8ae8498
fix(GisExportJob): fix projection for stops and routes export
landonreed May 31, 2019
9fd302d
refactor(GisExportJob): fix a few things
landonreed May 31, 2019
bdda525
test(GisExportJob): add test to check for CRS
landonreed May 31, 2019
768b7f7
fix(MergeFeedsJob): various fixes for MTC feed merge
landonreed Jun 3, 2019
b8617fd
test(GisExportJobTest): refactor CRS assertion
landonreed Jun 3, 2019
1169a5a
chore(pom): bump gtfs-lib to 4.3.6
landonreed Jun 4, 2019
47edfe4
ci(travis): change repo name for deploy
landonreed Jun 4, 2019
976aa66
Merge pull request #205 from ibi-group/mtc-merge-fixes
landonreed Jun 4, 2019
f367375
Merge pull request #204 from ibi-group/fix-shp-export
landonreed Jun 4, 2019
4fcb583
fix(GTFS+): add check for missing, but required columns
landonreed Jun 7, 2019
da07433
style: white space formatting
landonreed Jun 7, 2019
87a4769
refactor(GTFS+): move GTFS+ files around
landonreed Jun 7, 2019
4f9ef60
test(GTFS+): add basic test for GTFS+ validation
landonreed Jun 7, 2019
57e87fd
fix: remove unused/bad import
landonreed Jun 7, 2019
3bb1858
ci(travis): create GTFS+ dir before script
landonreed Jun 7, 2019
a99a4f6
Merge pull request #207 from ibi-group/gtfs+-check-missing-column
landonreed Jun 7, 2019
9f5b3f3
fix(MTC-sync): fix feed sync with MTC RTD database
landonreed Jun 24, 2019
0054341
style(MTC-sync): enhance comment
landonreed Jun 24, 2019
289ed0e
refactor(MTC-sync): address PR comments
landonreed Jun 24, 2019
eedf4e7
Merge pull request #209 from ibi-group/fix-mtc-sync
landonreed Jun 24, 2019
f8d393d
fix(MtcFeedResource): properly initialize external feed props on create
landonreed Jun 28, 2019
a68aa5f
Merge pull request #211 from ibi-group/fix-MTC-feed-source-created
landonreed Jun 28, 2019
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 2 additions & 1 deletion .github/pull_request_template.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,9 +5,10 @@
- [ ] The description lists all applicable issues this PR seeks to resolve
- [ ] The description lists any configuration setting(s) that differ from the default settings
- [ ] All tests and CI builds passing
- [ ] The description lists all relevant PRs included in this release _(remove this if not merging to master)_
- [ ] e2e tests are all passing _(remove this if not merging to master)_
- [ ] Code coverage improves or is at 100% _(remove this if not merging to master)_

### Description

Please explain the changes you made here and, if not immediately obvious from the code, how they resolve any referenced issues. Be sure to include all issues being resolved and any special configuration settings that are need for the software to run properly with these changes.
Please explain the changes you made here and, if not immediately obvious from the code, how they resolve any referenced issues. Be sure to include all issues being resolved and any special configuration settings that are need for the software to run properly with these changes. If merging to master, please also list the PRs that are to be included.
22 changes: 16 additions & 6 deletions .travis.yml
Original file line number Diff line number Diff line change
@@ -1,21 +1,31 @@
dist: trusty # jdk 8 not available on xenial
language: java
jdk:
- oraclejdk8
java:
- oraclejdk8
install: true
sudo: false
# Install mongoDB to perform persistence tests
services: mongodb
services:
- mongodb
- postgresql
addons:
postgresql: 9.6
cache:
directories:
- "$HOME/.m2"
- $HOME/.m2
- $HOME/.cache/yarn
# Install semantic-release
before_script:
- yarn global add @conveyal/maven-semantic-release semantic-release
- yarn global add @conveyal/maven-semantic-release semantic-release@15
# Create dir for GTFS+ files (used during testing)
- mkdir /tmp/gtfsplus
before_install:
#- sed -i.bak -e 's|https://nexus.codehaus.org/snapshots/|https://oss.sonatype.org/content/repositories/codehaus-snapshots/|g' ~/.m2/settings.xml
# set region in AWS config for S3 setup
- mkdir ~/.aws && printf '%s\n' '[default]' 'aws_access_key_id=foo' 'aws_secret_access_key=bar' 'region=us-east-1' > ~/.aws/config
- cp configurations/default/server.yml.tmp configurations/default/server.yml
# create database for tests
- psql -U postgres -c 'CREATE DATABASE catalogue;'
script:
# package jar
- mvn package
Expand Down Expand Up @@ -65,5 +75,5 @@ deploy:
local-dir: deploy
acl: public_read
on:
repo: conveyal/datatools-server
repo: ibi-group/datatools-server
all_branches: true
6 changes: 6 additions & 0 deletions configurations/default/server.yml.tmp
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,9 @@ modules:
enabled: false
user_admin:
enabled: true
# Enable GTFS+ module for testing purposes
gtfsplus:
enabled: true
gtfsapi:
enabled: true
load_on_fetch: false
Expand All @@ -29,3 +32,6 @@ extensions:
enabled: true
api: http://api.transitfeeds.com/v1/getFeeds
key: your-api-key
# Enable MTC for testing purposes
mtc:
enabled: true
85 changes: 57 additions & 28 deletions pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,10 @@
<url>https://github.com/conveyal/datatools-server.git</url>
</scm>
<properties>
<jackson.version>2.9.8</jackson.version>
<jackson.version>2.9.9</jackson.version>
<!-- Using the latest version of geotools (e.g, 20) seems to cause issues with the shapefile
plugin where the_geom for each feature is null. -->
<geotools.version>17.5</geotools.version>
</properties>
<build>
<resources>
Expand Down Expand Up @@ -158,23 +161,6 @@
</execution>
</executions>
</plugin>
<!-- This plugin makes sure junit 5 tests run -->
<plugin>
<artifactId>maven-surefire-plugin</artifactId>
<version>2.22.0</version>
<dependencies>
<dependency>
<groupId>org.junit.platform</groupId>
<artifactId>junit-platform-surefire-provider</artifactId>
<version>1.3.1</version>
</dependency>
<dependency>
<groupId>org.junit.jupiter</groupId>
<artifactId>junit-jupiter-engine</artifactId>
<version>5.3.1</version>
</dependency>
</dependencies>
</plugin>
</plugins>
</build>
<repositories>
Expand Down Expand Up @@ -218,6 +204,11 @@
<updatePolicy>always</updatePolicy>
</snapshots>
</repository>
<!-- used for importing java projects from github -->
<repository>
<id>jitpack.io</id>
<url>https://jitpack.io</url>
</repository>
</repositories>

<dependencies>
Expand Down Expand Up @@ -255,11 +246,22 @@
<version>2.1.0</version>
</dependency>

<!-- Used for loading/fetching/writing GTFS entities (also provides access to commons-io and AWS S3 SDK). -->
<!-- Used for testing (note: this should match the version in gtfs-lib). -->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
<scope>test</scope>
</dependency>

<!-- Used for loading/fetching/writing GTFS entities. gtfs-lib also provides access to:
- commons-io - generic utilities
- AWS S3 SDK - putting/getting objects into/out of S3.
-->
<dependency>
<groupId>com.conveyal</groupId>
<artifactId>gtfs-lib</artifactId>
<version>4.2.5</version>
<version>4.3.6</version>
</dependency>

<!-- Used for data-tools application database -->
Expand Down Expand Up @@ -322,15 +324,18 @@
<dependency>
<groupId>org.geotools</groupId>
<artifactId>gt-shapefile</artifactId>
<version>19.2</version>
<version>${geotools.version}</version>
</dependency>

<!-- Unit testing -->
<!-- gt-metadata and gt-api contains some dependencies required by gt-shapefile -->
<dependency>
<groupId>org.junit.jupiter</groupId>
<artifactId>junit-jupiter-api</artifactId>
<version>5.3.1</version>
<scope>test</scope>
<groupId>org.geotools</groupId>
<artifactId>gt-metadata</artifactId>
<version>${geotools.version}</version>
</dependency>
<dependency>
<groupId>org.geotools</groupId>
<artifactId>gt-api</artifactId>
<version>${geotools.version}</version>
</dependency>

<!-- Error reporting -->
Expand Down Expand Up @@ -359,8 +364,32 @@
<groupId>org.hamcrest</groupId>
<artifactId>java-hamcrest</artifactId>
<version>2.0.0.0</version>
<scope>test</scope>
</dependency>
<!-- Snapshotting library for testing -->
<dependency>
<groupId>com.github.conveyal</groupId>
<artifactId>java-snapshot-matcher</artifactId>
<version>3495b32f7b4d3f82590e0a2284029214070b6984</version>
<scope>test</scope>
</dependency>
<!-- wiremock is used to mock http requests -->
<dependency>
<groupId>com.github.tomakehurst</groupId>
<artifactId>wiremock-standalone</artifactId>
<version>2.14.0</version>
<scope>test</scope>
</dependency>
<!-- Used for writing csv for merged feeds. Note: this appears to be one of the only
CSV libraries that will only quote values when necessary (e.g., there is a comma character
contained within the value) and that will work with an output stream writer when writing
directly to a zip output stream.
-->
<dependency>
<groupId>net.sf.supercsv</groupId>
<artifactId>super-csv</artifactId>
<version>2.4.0</version>
</dependency>

</dependencies>

</project>
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.io.File;
import java.time.LocalDateTime;
import java.time.format.DateTimeFormatter;
import java.util.ArrayList;
Expand All @@ -19,10 +20,11 @@
*/
public abstract class MonitorableJob implements Runnable {
private static final Logger LOG = LoggerFactory.getLogger(MonitorableJob.class);
protected final String owner;
public final String owner;

// Public fields will be serialized over HTTP API and visible to the web client
public final JobType type;
public File file;
public String parentJobId;
public JobType parentJobType;
// Status is not final to allow some jobs to have extra status fields.
Expand All @@ -48,6 +50,7 @@ public enum JobType {
LOAD_FEED,
VALIDATE_FEED,
DEPLOY_TO_OTP,
EXPORT_GIS,
FETCH_PROJECT_FEEDS,
FETCH_SINGLE_FEED,
MAKE_PROJECT_PUBLIC,
Expand All @@ -57,7 +60,7 @@ public enum JobType {
EXPORT_SNAPSHOT_TO_GTFS,
CONVERT_EDITOR_MAPDB_TO_SQL,
VALIDATE_ALL_FEEDS,
MERGE_PROJECT_FEEDS
MERGE_FEED_VERSIONS
}

public MonitorableJob(String owner, String name, JobType type) {
Expand Down Expand Up @@ -90,6 +93,10 @@ private void registerJob() {
DataManager.userJobsMap.put(this.owner, userJobs);
}

public File retrieveFile () {
return file;
}

/**
* This method should never be called directly or overridden. It is a standard clean up stage for all
* monitorable jobs.
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
package com.conveyal.datatools.editor.controllers.api;

import com.conveyal.datatools.common.utils.S3Utils;
import com.conveyal.datatools.common.utils.SparkUtils;
import com.conveyal.datatools.editor.controllers.EditorLockController;
import com.conveyal.datatools.manager.auth.Auth0UserProfile;
import com.conveyal.datatools.manager.models.FeedSource;
Expand Down Expand Up @@ -86,6 +87,7 @@ private void registerRoutes() {
// Handle update useFrequency field. Hitting this endpoint will delete all trips for a pattern and update the
// useFrequency field.
if ("pattern".equals(classToLowercase)) {
put(ROOT_ROUTE + ID_PARAM + "/stop_times", this::updateStopTimesFromPatternStops, json::write);
delete(ROOT_ROUTE + ID_PARAM + "/trips", this::deleteTripsForPattern, json::write);
}
}
Expand All @@ -112,7 +114,7 @@ private String deleteTripsForPattern(Request req, Response res) {
logMessageAndHalt(req, 500, "Error deleting entity", e);
return null;
} finally {
LOG.info("Delete operation took {} msec", System.currentTimeMillis() - startTime);
LOG.info("Delete trips for pattern operation took {} msec", System.currentTimeMillis() - startTime);
}
}

Expand All @@ -124,8 +126,9 @@ private String deleteMultipleTrips(Request req, Response res) {
long startTime = System.currentTimeMillis();
String namespace = getNamespaceAndValidateSession(req);
String[] tripIds = req.queryParams("tripIds").split(",");
JdbcTableWriter tableWriter = null;
try {
JdbcTableWriter tableWriter = new JdbcTableWriter(table, datasource, namespace);
tableWriter = new JdbcTableWriter(table, datasource, namespace);
for (String tripId: tripIds) {
// Delete each trip ID found in query param WITHOUT auto-committing.
int result = tableWriter.delete(Integer.parseInt(tripId), false);
Expand All @@ -135,14 +138,15 @@ private String deleteMultipleTrips(Request req, Response res) {
throw new SQLException(message);
}
}
// Commit the transaction after iterating over trip IDs (because the deletes where made without autocommit).
// Commit the transaction after iterating over trip IDs (because the deletes were made without autocommit).
tableWriter.commit();
LOG.info("Deleted {} trips", tripIds.length);
} catch (InvalidNamespaceException e) {
logMessageAndHalt(req, 400, "Invalid namespace");
} catch (Exception e) {
logMessageAndHalt(req, 500, "Error deleting entity", e);
} finally {
if (tableWriter != null) tableWriter.close();
LOG.info("Delete operation took {} msec", System.currentTimeMillis() - startTime);
}
return formatJSON(String.format("Deleted %d.", tripIds.length), 200);
Expand All @@ -159,7 +163,7 @@ private String deleteOne(Request req, Response res) {
JdbcTableWriter tableWriter = new JdbcTableWriter(table, datasource, namespace);
if (tableWriter.delete(id, true) == 1) {
// FIXME: change return message based on result value
return formatJSON(String.valueOf("Deleted one."), 200);
return formatJSON("Deleted one.", 200);
}
} catch (Exception e) {
logMessageAndHalt(req, 400, "Error deleting entity", e);
Expand All @@ -169,17 +173,37 @@ private String deleteOne(Request req, Response res) {
return null;
}

/**
* For a given pattern ID, update all its trips' stop times to conform to the default travel and dwell times. This
* is used, for instance, when a new pattern stop is added or inserted into an existing pattern that has trips which
* need the updated travel times applied in bulk.
*/
private String updateStopTimesFromPatternStops (Request req, Response res) {
long startTime = System.currentTimeMillis();
String namespace = getNamespaceAndValidateSession(req);
int patternId = getIdFromRequest(req);
try {
int beginStopSequence = Integer.parseInt(req.queryParams("stopSequence"));
JdbcTableWriter tableWriter = new JdbcTableWriter(table, datasource, namespace);
int stopTimesUpdated = tableWriter.normalizeStopTimesForPattern(patternId, beginStopSequence);
return SparkUtils.formatJSON("updateResult", stopTimesUpdated + " stop times updated.");
} catch (Exception e) {
logMessageAndHalt(req, 400, "Error normalizing stop times", e);
return null;
} finally {
LOG.info("Normalize stop times operation took {} msec", System.currentTimeMillis() - startTime);
}
}

/**
* HTTP endpoint to upload branding image to S3 for either agency or route entities. The endpoint also handles
* updating the branding URL field to match the S3 URL.
*/
private String uploadEntityBranding (Request req, Response res) {
int id = getIdFromRequest(req);
String url = null;
String url;
try {
// FIXME: remove cast to string.
String idAsString = String.valueOf(id);
url = S3Utils.uploadBranding(req, String.join("_", classToLowercase, idAsString));
url = S3Utils.uploadBranding(req, String.format("%s_%d", classToLowercase, id));
} catch (HaltException e) {
// Do not re-catch halts thrown for exceptions that have already been caught.
throw e;
Expand Down Expand Up @@ -300,10 +324,4 @@ private Integer getIdFromRequest(Request req) {
}
return id;
}

// TODO add hooks
abstract void getEntityHook(T entity);
abstract void createEntityHook(T entity);
abstract void updateEntityHook(T entity);
abstract void deleteEntityHook(T entity);
}
Original file line number Diff line number Diff line change
Expand Up @@ -9,24 +9,4 @@ public class EditorControllerImpl extends EditorController {
public EditorControllerImpl(String apiPrefix, Table table, DataSource dataSource){
super(apiPrefix, table, dataSource);
}

@Override
void getEntityHook(Entity entity) {

}

@Override
void createEntityHook(Entity entity) {

}

@Override
void updateEntityHook(Entity entity) {

}

@Override
void deleteEntityHook(Entity entity) {

}
}
Loading