Skip to content
forked from sergi/jsftp

Light and complete FTP client implementation for Node.js

License

Notifications You must be signed in to change notification settings

HeyPuter/puter-jsftp

 
 

Repository files navigation

jsftp for puter

travis npm downloads styled with prettier

A client FTP library for NodeJS that focuses on correctness, clarity and conciseness. It doesn't get in the way and plays nice with streaming APIs.

Starting it up

const jsftp = require("jsftp");

const Ftp = new jsftp({
  host: "myserver.com",
  port: 3331, // defaults to 21
  user: "user", // defaults to "anonymous"
  pass: "1234" // defaults to "@anonymous"
});

jsftp gives you access to all the raw commands of the FTP protocol in form of methods in the Ftp object. It also provides several convenience methods for actions that require complex chains of commands (e.g. uploading and retrieving files, passive operations), as shown below.

When raw commands succeed they always pass the response of the server to the callback, in the form of an object that contains two properties: code, which is the response code of the FTP operation, and text, which is the complete text of the response.

Raw (or native) commands are accessible in the form Ftp.raw(command, params, callback)

Thus, a command like QUIT will be called like this:

const data = await Ftp.raw("quit", "/new_dir");

and a command like MKD (make directory), which accepts parameters, looks like this:

const data = await Ftp.raw("mkd", "/new_dir");
console.log(data.text); 
console.log(data.code);

API and examples

new Ftp(options)

  • options is an object with the following properties:
{
  host: 'localhost', // Host name for the current FTP server.
  port: 3333, // Port number for the current FTP server (defaults to 21).
  user: 'user', // Username
  pass: 'pass', // Password
}
  • options.createSocket could be used to implement a proxy for the ftp socket, e.g. socksv5
const {SocksClient} = require('socks');
const ftp = new Ffp({
  host: 'localhost',
  port: 3333,
  user: 'user',
  pass: 'password'
})

Creates a new Ftp instance.

Ftp.host

Host name for the current FTP server.

Ftp.port

Port number for the current FTP server (defaults to 21).

Ftp.socket

NodeJS socket for the current FTP server.

Ftp.features

Array of feature names for the current FTP server. It is generated when the user authenticates with the auth method.

Ftp.system

Contains the system identification string for the remote FTP server.

Methods

await Ftp.raw(command, [...args])

With the raw method you can send any FTP command to the server. The method response coming from the server (usually a 4xx or 5xx error code) and the data It resolves with a promise that contains two properties: code and text. code is an integer indicating the response code of the response and text is the response string itself.

Ftp.auth(username, password)

Authenticates the user with the given username and password. If null or empty values are passed for those, auth will use anonymous credentials. Promise will be resolved with the response text in case of successful login or with an error as a first parameter, in normal Node fashion.

Ftp.ls(filePath, callback)

Lists information about files or directories and yields an array of file objects with parsed file properties to the You should use this function instead of stat or list in case you need to do something with the individual file properties.

ftp.ls(".", (err, res) => {
  res.forEach(file => console.log(file.name));
});

Ftp.list(filePath, callback)

Lists filePath contents using a passive connection. Calls callback with a string containing the directory contents in long list format.

ftp.list(remoteCWD, (err, res) => {
  console.log(res);
  // Prints something like
  // -rw-r--r--   1 sergi    staff           4 Jun 03 09:32 testfile1.txt
  // -rw-r--r--   1 sergi    staff           4 Jun 03 09:31 testfile2.txt
  // -rw-r--r--   1 sergi    staff           0 May 29 13:05 testfile3.txt
  // ...
});

Ftp.get(remotePath)

Gives back a File (extension of blob) of the file you requested

var str = ""; // Will store the contents of the file
str = await (await ftp.get("remote/path/file.txt")).text();

Ftp.put(source, remotePath, callback)

Uploads a file to filePath. It accepts a Uint8array, or a Blob.

ftp.put(buffer, "path/to/remote/file.txt", err => {
  if (!err) {
    console.log("File transferred successfully!");
  }
});

Ftp.rename(from, to, callback)

Renames a file in the server. from and to are both filepaths.

ftp.rename(from, to, (err, res) => {
  if (!err) {
    console.log("Renaming successful!");
  }
});

Ftp.keepAlive([wait])

Refreshes the interval thats keep the server connection active. wait is an optional time period (in milliseconds) to wait between intervals.

You can find more usage examples in the unit tests. This documentation will grow as jsftp evolves.

Installation

npm install jsftp

Tests and Coverage

JSFtp tests against ProFTPD by default. To accomplish that, it uses a Docker set-up, so you'll need Docker installed in your machine in order to run tests.

Please note that the first time you run the tests it will take a while, given that it has to download, configure and run the containerized ProFTPD server.

To run tests and coverage reports:

npm test

...
43 passing (10s)

|-----------|----------|----------|----------|----------|----------------|
|File       |  % Stmts | % Branch |  % Funcs |  % Lines |Uncovered Lines |
|-----------|----------|----------|----------|----------|----------------|
|All files  |    86.47 |    73.17 |    95.45 |    86.47 |                |
|jsftp      |      100 |      100 |      100 |      100 |                |
|  index.js |      100 |      100 |      100 |      100 |                |
|jsftp/lib  |    86.43 |    73.17 |    95.45 |    86.43 |                |
|  jsftp.js |    86.43 |    73.17 |    95.45 |    86.43 |... 722,724,733 |
|-----------|----------|----------|----------|----------|----------------|

License

See LICENSE.

About

Light and complete FTP client implementation for Node.js

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 99.8%
  • Dockerfile 0.2%