node-mavlink-ftp
v0.0.1
Published
MavLink ftp services
Downloads
5
Readme
MavFTP services node-mavlink
Mavlink is a great protocol. It's versatile and allows for quite complex workflows. One example is the MavFTP protocol.
Why would you use it? Of course reading log files from the SD card is one possibility. But there is more. For example, you can download a virtual file that contains the list of currently running threads, or another that has a list of active serial ports!
One very special file goes by the name of @PARAM/param.pck?withDefaults=1
. This one is virtual and contains a tightly packed list of all currently active parameters. Downloading it and decoding is like a 1000x faster than requesting each parameter separately.
Installation
To install the package issue the following command:
$ npm install --save node-mavlink-ftp
Usage
There are 2 parts: the user interface and the server-part.
The server part
Let's get over this one really quick. It's a filter that you pipe your stream of packets. It's transparent. It will react to MavFTP packages, but will not filter them out and you'll still be able to process them if you so desire.
import { SerialPort } from 'serialport'
import {
MavLinkPacket,
MavLinkPacketParser,
MavLinkPacketSplitter
} from 'node-mavlink'
import { MavFTP } from 'node-mavlink-ftp'
const ftp = new MavFTP()
new SerialPort({ path: '/dev/ttyACM0', baudRate: 115200 })
.pipe(new MavLinkPacketSplitter())
.pipe(new MavLinkPacketParser())
.pipe(ftp)
.resume()
That's it! Let's now see what we can do with it.
The client side of things
Using the ftp
instance is quite simple. It comes with easy to understand functions such as downloadFile(filename)
or listDirectory()
async resetSessions()
This async function just resets everything. It's good to call it at the start. Don't forget to await
!
async listDirectory(path: string): MavFTPDirectoryListingEntry[]
This async function returns a list of entries containing information about files and folders under the specified path.
async removeFile(filename)
This async function removes a file. That's it - nothing more. It'll throw an error if the file wasn't there to begin with.
async downloadFile(filename, options?: DownloadFileOptions): Buffer
This async function downloads the content of the specified file into the buffer it returns.
DownloadFileOptions
The following options are possible when downloading a file:
- onProgress?: ProgressCallback - this is a callback function that will be called multiple times when the file is being downloaded
Closing thoughts
That's the first approach into making working with MavFTP approachable. It's still lacking a few parts to be complete. The burst download would be nice... I think that in the future this package will grow substantially, so stay tuned!
Happy coding!