Research
Security News
Kill Switch Hidden in npm Packages Typosquatting Chalk and Chokidar
Socket researchers found several malicious npm packages typosquatting Chalk and Chokidar, targeting Node.js developers with kill switches and data theft.
osmtogeojson
Advanced tools
Converts OSM data to GeoJSON. Try the demo!
This code is used in and maintained by the overpass turbo project.
as a command line tool:
$ npm install -g osmtogeojson
$ osmtogeojson file.osm > file.geojson
When working with extra large data files (≳ 100 MB) it is recommended to run the programm with a little extra memory to avoid process out of memory errors. The easiest way to do this is by running the command as node <path-to-osmtogeojson>
and setting the --max_old_space_size=…
parameter to the available memory size in MB (osmtogeojson typically needs about 4-5 times the input data size):
$ node --max_old_space_size=8192 `which osmtogeojson` large.osm > large.geojson
as a nodejs library:
$ npm install osmtogeojson
var osmtogeojson = require('osmtogeojson');
osmtogeojson(osm_data);
as a browser library:
<script src='osmtogeojson.js'></script>
osmtogeojson(osm_data);
osmtogeojson( data, options )
Converts OSM data into GeoJSON.
data
: the OSM data. Either as a XML DOM or in OSM JSON.options
: optional. The following options can be used:
flatProperties
: If true, the resulting GeoJSON feature's properties will be a simple key-value list instead of a structured json object (with separate tags and metadata). default: falseuninterestingTags
: Either a blacklist of tag keys or a callback function. Will be used to decide if a feature is interesting enough for its own GeoJSON feature.polygonFeatures
: Either a json object or callback function that is used to determine if a closed way should be treated as a Polygon or LineString. read moreThe result is a javascript object of GeoJSON data:
The GeoJSON produced by this library will include exactly one GeoJSON-feature for each of the following OSM objects (that is everything that is also visible in overpass turbo's map view):
All data is given as a FeatureCollection. Each Feature in the collection has an id
property that is formed from the type and id of the original OSM object (e.g. node/123
) and has the member properties
containing the following data:
type
: the OSM data typeid
: the OSM idtags
: a collection of all tagsmeta
: metainformaton about the feature (e.g. version, timestamp, user, etc.)relations
: an array of relations the feature is member of. Each relation is encoded as an object literal containing the following properties: role
(membership role), rel
(the relation's id) and reltags
(contains all tags of the relation)tainted
: this flag is set when the feature's geometry is incomplete (e.g. missing nodes of a way or missing ways of a multipolygon)If the option flatProperties
is set to true, the properties
object will not contain any nested object literals, but directly provide a concise id, meta data and the tags of the respective OSM object.
FAQs
convert OSM to geojson
The npm package osmtogeojson receives a total of 3,579 weekly downloads. As such, osmtogeojson popularity was classified as popular.
We found that osmtogeojson demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Research
Security News
Socket researchers found several malicious npm packages typosquatting Chalk and Chokidar, targeting Node.js developers with kill switches and data theft.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.