
Research
Security News
Lazarus Strikes npm Again with New Wave of Malicious Packages
The Socket Research Team has discovered six new malicious npm packages linked to North Korea’s Lazarus Group, designed to steal credentials and deploy backdoors.
@signalk/nmea0183-signalk
Advanced tools
A node.js/javascript parser for NMEA0183 sentences. Sentences are parsed to Signal K format.
A node.js/JavaScript parser of NMEA0183 sentences. Sentences are parsed to Signal K delta format.
Note: at this time, unknown sentences will be silently discarded.
You can add custom sentence parsers via the Signal K Server plugin mechanism. A plugin can register custom parsers by emitting nmea0183sentenceParser
PropertyValues with a value that has the properties
({ id, sentence, parts, tags }, session) => delta
See custom-sentence-plugin for an example.
const Parser = require('@signalk/nmea0183-signalk')
const parser = new Parser()
try {
const delta = parser.parse('$SDDBT,17.0,f,5.1,M,2.8,F*3E')
if (delta !== null) {
console.log(`[delta] ${JSON.stringify(delta, null, 2)}`)
}
}
catch (e) {
console.error(`[error] ${e.message}`)
}
In addition to usage in your code, the parser can be used on the command-line if installed globally (npm install --global
). This allows you to pipe data from one program into the parser directly, without using a Signal K server. The parser holds no Signal K tree in memory (a big change vs. 1.x), so the output will be stringified Signal K delta messages.
$ echo '$SDDBT,17.0,f,5.1,M,2.8,F*3E' | nmea0183-signalk
This parser has (limited) support of NMEA0183v4 tag blocks (e.g. \s:airmar dst800,c:1438489697*13\$SDDBT,17.0,f,5.1,M,2.8,F*3E
).
Example:
const Parser = require('@signalk/nmea0183-signalk')
const parser = new Parser()
try {
// backslash starts an escape sequence in JavaScript code, so they need to be double in string literals
const delta = parser.parse('\\s:airmar dst800,c:1438489697*13\\$SDDBT,17.0,f,5.1,M,2.8,F*3E')
if (delta !== null) {
console.log(`[delta] ${JSON.stringify(delta, null, 2)}`)
}
}
catch (e) {
console.error(`[error] ${e.message}`)
}
Output:
[delta] {
"updates": [
{
"source": {
"sentence": "DBT",
"talker": "airmar dst800",
"type": "NMEA0183"
},
"timestamp": "2015-08-02T04:28:17.000Z",
"values": [
{
"path": "environment.depth.belowTransducer",
"value": 5.1
}
]
}
]
}
Note: at this time, the checksum of the tag block (c:1438489697*13
) is not validated.
Copyright 2016/2017 Signal K and Fabian Tollenaar <fabian@signalk.org>.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
FAQs
A node.js/javascript parser for NMEA0183 sentences. Sentences are parsed to Signal K format.
The npm package @signalk/nmea0183-signalk receives a total of 371 weekly downloads. As such, @signalk/nmea0183-signalk popularity was classified as not popular.
We found that @signalk/nmea0183-signalk demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers 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
The Socket Research Team has discovered six new malicious npm packages linked to North Korea’s Lazarus Group, designed to steal credentials and deploy backdoors.
Security News
Socket CEO Feross Aboukhadijeh discusses the open web, open source security, and how Socket tackles software supply chain attacks on The Pair Program podcast.
Security News
Opengrep continues building momentum with the alpha release of its Playground tool, demonstrating the project's rapid evolution just two months after its initial launch.