Skip to content

eskrug/ems-file-service

 
 

Repository files navigation

Elastic Map Service Data Sources

Machine readable and standardized data sources for use in Elastic Map Service.

Usage

Create a new JSON or Hjson file in the appropriate folder in sources. The source file must match the schema in schema/source_schema.json.

To validate data sources against the schema run

npm test

To build manifests and vector data files for all versions run

npm run build

Continuous Integration and Deployment

  • The manifest and vector files for all versions will be built automatically by Jenkins on every pull request using the build.sh script. Pull requests must be made against the master branch.
  • Once merged, Jenkins will run deployStaging.sh script, which will place the contents of the dist directory into the staging bucket.
  • Deploying to production requires manually triggering this Jenkins job to run the deployProduction.sh script. This will rsync files from the staging bucket to the production bucket. To trigger, log in and click the "Build with Parameters" link. Leave the branch_specifier field as default (refs/heads/master).

Adding a new country subdivision vector layer

Whenever possible new vector layers should be created using a SPARQL query in Sophox.

  1. If necessary, create a new folder in the sources directory with the corresponding two-digit country code (ex. ru for Russia).
  2. Copy and paste the template source file (templates/source_template.hjson) into the new directory you created in step 1. Give it a useful name (ex. states.hjson, provinces.hjson, etc).
  3. Complete the note and name fields in the new source file.
  4. Copy and paste the query.sparql value into the query box on http://sophox.org.
  5. Change the Q33 in the VALUES ?entity { wd:Q33 } to the corresponding Wikidata ID for the country for which you are adding subdivisions (ex. Q33 is the Wikidata ID for Finland).
  6. Run the SPARQL query and compare the iso_3166_2 results with the corresponding country's subdivision list on the ISO website looking for missing iso_3166_2 codes.
  7. The most common reason for missing iso_3166_2 codes in the query results is an incomplete "contains administrative territorial entity" property in the immediate parent region of the subdivision in Wikidata (usually, but not always, the country). You may need to add the subdivision Wikidata item to this property (ex. https://www.wikidata.org/wiki/Q33#P150).
  8. Add label_* fields for each official language of the country to the SPARQL query similar to the label_en field.
  9. Optionally, add unique subdivision code fields from other sources (ex. logianm in Ireland) to the query.
  10. Run the SPARQL query and check the map output.
  11. Optionally, click the "Simplify" link and drag the slider to reduce the number of vertices (smaller file size).
  12. Click the "Export" link on the top right of the map. Choose GeoJSON or TopoJSON as the File Format.
  13. Type rfc7946 ƒin the "command line options" to reduce the precision of the coordinates and click "Export" to download the vector file.
  14. Rename the downloaded file with the first supported EMS version number (ex. _v1, _v2, _v6.6) and the vector type (geo for GeoJSON, topo for TopoJSON) (ex. russia_states_v1.geo.json). Copy this file to the data directory.
  15. Complete the emsFormats properties: type is either geojson or topojson, file is the filename specified above, default is true when there is only one format. Subsequent formats can be added but only one item in the array can have default: true. The other items must be default: false or omit default entirely.
  16. Copy and paste the SPARQL query from Sophox to the query.sparql field in the source file.
  17. Use the scripts/wikidata-labels.js script to list the humanReadableName languages from Wikidata (e.g. node scripts/wikidata-labels.js Q33). You should spot check these translations as some languages might lack specificity (e.g. Provins rather than Kinas provinser).
  18. All fields used by sources that do not follow the label_<language_code> schema must have translations in (schema/fields.hjson). If necessary, use the scripts/wikidata-labels.js script to list translations and copy them to (schema/fields.hjson) (e.g. node scripts/wikidata-labels P5097).
  19. Use the following bash command to generate the timestamp for the createdAt field. Use gdate on Mac OSX. date -u +"%Y-%m-%dT%H:%M:%S.%6N"
  20. Generate a 17 digit number for the id field. A timestamp using the following bash command is suitable. Use gdate On Mac OSX. date +%s%6N
  21. The filename field in the source file should match the name of the file you added to the data directory.
  22. Run npm test to test for errors.
  23. Invalid or non-simple geometry errors that occur during testing can usually be fixed by running the clean-geom.js script against the GeoJSON file (e.g. node scripts/clean-geom.js data/usa_states_v1.geo.json).
  24. Run ./build.sh to build the manifest and blob files locally.

About

Data sources for Elastic Map Service

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 88.2%
  • Shell 11.8%