node-scp v0.0.23
New SCP module for NodeJS
A lightweight, fast and secure module to perform SCP commands for NodeJS based on SSH2
What's new
All functionalities are written using Promise. That means you can use it with Promise or Async/Await (No more callback hell, Yeah :) )
And other new features:
- Scp a directory from local to remote server and from remote to local
- Perform commands on remote server:
mkdir,stat, check if path exists
Table of Contents
- Installation
- Guide
- Scp file from local to remote server
- Scp file from remote server to local
- Scp a directory from local to remote server
- Scp a directory from remote server to local
- Create a directory on remote server
- Check if a path exists on remote server
- Get stats of a path on remote server
- Sets the attributes defined in attributes for path
- List all files in remote directory
- Convert relative path to absolute path on remote server
- Remove file in remote server
- Remove a directory in remote server
- Clean a directory in remote server
- Write data to a file in remote server
- Set the access time and modified time for path
- Create a symlink
- Rename/Move a source to destination
- Retrieve the target for a symlink
- Read a file in memory and returns its contents
- Retrieve attributes for path
- Append data to a file
- Set the mode for a path
- Set the owner for a path
- Connection options
Installation
npm install --save node-scp
# or
yarn add node-scpGuide
Scp file from local to remote server
Using Promise
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
}).then(client => {
client.uploadFile(
'./test.txt',
'/workspace/test.txt',
// options?: TransferOptions
)
.then(response => {
client.close() // remember to close connection after you finish
})
.catch(error => {})
}).catch(e => console.log(e))Using async/await:
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
async function test() {
try {
const client = await Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
})
await client.uploadFile(
'./test.txt',
'/workspace/test.txt',
// options?: TransferOptions
)
// you can perform upload multiple times
await client.uploadFile('./test1.txt', '/workspace/test1.txt')
client.close() // remember to close connection after you finish
} catch (e) {
console.log(e)
}
}
test()Scp file from remote server to local
Using Promise
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
}).then(client => {
client.downloadFile(
'/workspace/test.txt',
'./test.txt',
// options?: TransferOptions
)
.then(response => {
client.close() // remember to close connection after you finish
})
.catch(error => {})
}).catch(e => console.log(e))Using async/await:
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
async function test () {
try {
const client = await Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
})
await client.downloadFile(
'/workspace/test.txt',
'./test.txt',
// options?: TransferOptions
)
client.close() // remember to close connection after you finish
} catch(e) {
console.log(e)
}
}
test()Scp a directory from local to remote server
Using Promise
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
}).then(client => {
client.uploadDir('./local/dir', '/server/path')
.then(response => {
client.close() // remember to close connection after you finish
})
.catch(error => {})
}).catch(e => console.log(e))Using async/await:
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
async funtion test () {
try {
const client = await Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
})
await client.uploadDir('./local/dir', '/server/path')
client.close() // remember to close connection after you finish
} catch (e) {
console.log(e)
}
}
test()Scp a directory from remote server to local
Using Promise
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
}).then(client => {
client.downloadDir('/server/path', 'local/path')
.then(response => {
client.close() // remember to close connection after you finish
})
.catch(error => {})
}).catch(e => console.log(e))Using async/await:
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
async funtion test () {
try {
const client = await Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
})
await client.downloadDir('/server/path', './local/dir')
client.close() // remember to close connection after you finish
} catch (e) {
console.log(e)
}
}
test()Create a directory on remote server
Using Promise
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
}).then(client => {
client.mkdir(
'/server/path',
// attributes?: InputAttributes
)
.then(response => {
client.close() // remember to close connection after you finish
})
.catch(error => {})
}).catch(e => console.log(e))Using async/await:
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
async function test() {
try {
const client = await Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
})
await client.mkdir(
'/server/path',
// attributes: InputAttributes
)
client.close() // remember to close connection after you finish
} catch (e) {
console.log(e)
}
}
test()Check if a path exists on remote server
Using Promise
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
}).then(client => {
const result = client.exists('/server/path')
.then(result => {
console.log(result)
client.close() // remember to close connection after you finish
})
.catch(error => {})
}).catch(e => console.log(e))Using async/await:
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
async function test() {
try {
const client = await Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
})
const result = await client.exists('/server/path')
console.log(result)
client.close() // remember to close connection after you finish
} catch (e) {
console.log(e)
}
}
test()Get stats of a path on remote server
Using Promise
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
}).then(client => {
client.stat('/server/path')
.then(result => {
console.log(result)
client.close() // remember to close connection after you finish
})
.catch(error => {})
}).catch(e => console.log(e))Using async/await:
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
async function test() {
try {
const client = await Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
})
const result = await client.stat('/server/path')
console.log(result)
client.close() // remember to close connection after you finish
} catch (e) {
console.log(e)
}
}
test()Sets the attributes defined in attributes for path
Using Promise
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
}).then(client => {
client.setstat('/server/path', {/* InputAttributes */})
.then(() => {
client.close() // remember to close connection after you finish
})
.catch(error => {})
}).catch(e => console.log(e))Using async/await:
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
async function test() {
try {
const client = await Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
})
await client.setstat('/server/path', {/* InputAttributes */})
client.close() // remember to close connection after you finish
} catch (e) {
console.log(e)
}
}
test()List all files in remote directory
Using Promise
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
}).then(client => {
client.list('/server/path')
.then(result => {
console.log(result)
client.close() // remember to close connection after you finish
})
.catch(error => {})
}).catch(e => console.log(e))Using async/await:
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
async function test() {
try {
const client = await Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
})
const result = await client.list('/server/path')
console.log(result)
client.close() // remember to close connection after you finish
} catch (e) {
console.log(e)
}
}
test()Convert relative path to absolute path on remote server
Using Promise
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
}).then(client => {
client.realPath('/server/path')
.then(result => {
console.log(result)
client.close() // remember to close connection after you finish
})
.catch(error => {})
}).catch(e => console.log(e))Using async/await:
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
async function test() {
try {
const client = await Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
})
const result = await client.realPath('/server/path')
console.log(result)
client.close() // remember to close connection after you finish
} catch (e) {
console.log(e)
}
}
test()Remove file in remote server
Using Promise
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
}).then(client => {
client.unlink('/server/path/myfile.txt')
.then(() => {
client.close() // remember to close connection after you finish
})
.catch(error => {})
}).catch(e => console.log(e))Using async/await:
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
async function test() {
try {
const client = await Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
})
await client.unlink('/server/path/myfile.txt')
client.close() // remember to close connection after you finish
} catch (e) {
console.log(e)
}
}
test()Remove a directory in remote server
Using Promise
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
}).then(client => {
client.rmdir('/server/path')
.then(() => {
client.close() // remember to close connection after you finish
})
.catch(error => {})
}).catch(e => console.log(e))Using async/await:
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
async function test() {
try {
const client = await Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
})
await client.rmdir('/server/path')
client.close() // remember to close connection after you finish
} catch (e) {
console.log(e)
}
}
test()Clean a directory in remote server
Using Promise
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
}).then(client => {
client.emptyDir('/server/path')
.then(() => {
client.close() // remember to close connection after you finish
})
.catch(error => {})
}).catch(e => console.log(e))Using async/await:
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
async function test() {
try {
const client = await Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
})
await client.emptyDir('/server/path')
client.close() // remember to close connection after you finish
} catch (e) {
console.log(e)
}
}
test()Write data to a file in remote server
Using Promise
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
}).then(client => {
client.writeFile('/server/path/test.txt', 'some data', { /* WriteFileOptions */ })
.then(() => {
client.close() // remember to close connection after you finish
})
.catch(error => {})
}).catch(e => console.log(e))Using async/await:
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
async function test() {
try {
const client = await Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
})
await client.writeFile('/server/path/test.txt', 'some data', { /* WriteFileOptions */ })
client.close() // remember to close connection after you finish
} catch (e) {
console.log(e)
}
}
test()Sets the access time and modified time for path
Using Promise
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
}).then(client => {
client.utimes('/server/path/test.txt', 1663641640819, 1663641640819)
.then(() => {
client.close() // remember to close connection after you finish
})
.catch(error => {})
}).catch(e => console.log(e))Using async/await:
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
async function test() {
try {
const client = await Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
})
await client.utimes('/server/path/test.txt', 1663641640819, 1663641640819)
client.close() // remember to close connection after you finish
} catch (e) {
console.log(e)
}
}
test()Creates a symlink at linkPath to targetPath
Using Promise
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
}).then(client => {
client.symlink('/server/path1/test.txt', '/server/path2/test.txt')
.then(() => {
client.close() // remember to close connection after you finish
})
.catch(error => {})
}).catch(e => console.log(e))Using async/await:
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
async function test() {
try {
const client = await Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
})
await client.symlink('/server/path1/test.txt', '/server/path2/test.txt')
client.close() // remember to close connection after you finish
} catch (e) {
console.log(e)
}
}
test()Renames/moves srcPath to destPath
Using Promise
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
}).then(client => {
client.rename('/server/path1/test.txt', '/server/path2/test.txt')
.then(() => {
client.close() // remember to close connection after you finish
})
.catch(error => {})
}).catch(e => console.log(e))Using async/await:
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
async function test() {
try {
const client = await Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
})
await client.rename('/server/path1/test.txt', '/server/path2/test.txt')
client.close() // remember to close connection after you finish
} catch (e) {
console.log(e)
}
}
test()Retrieves the target for a symlink at path
Using Promise
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
}).then(client => {
client.readlink('/server/path1/test.txt')
.then((result) => {
console.log(result)
client.close() // remember to close connection after you finish
})
.catch(error => {})
}).catch(e => console.log(e))Using async/await:
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
async function test() {
try {
const client = await Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
})
const result = await client.readlink('/server/path1/test.txt')
console.log(result)
client.close() // remember to close connection after you finish
} catch (e) {
console.log(e)
}
}
test()Reads a file in memory and returns its contents
Using Promise
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
}).then(client => {
client.readFile('/server/path1/test.txt')
.then((result) => {
console.log(result)
client.close() // remember to close connection after you finish
})
.catch(error => {})
}).catch(e => console.log(e))Using async/await:
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
async function test() {
try {
const client = await Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
})
const result = await client.readFile('/server/path1/test.txt')
console.log(result)
client.close() // remember to close connection after you finish
} catch (e) {
console.log(e)
}
}
test()Retrieves attributes for path
Using Promise
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
}).then(client => {
client.lstat('/server/path1/test.txt')
.then((result) => {
console.log(result)
client.close() // remember to close connection after you finish
})
.catch(error => {})
}).catch(e => console.log(e))Using async/await:
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
async function test() {
try {
const client = await Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
})
const result = await client.lstat('/server/path1/test.txt')
console.log(result)
client.close() // remember to close connection after you finish
} catch (e) {
console.log(e)
}
}
test()Appends data to a file
Using Promise
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
}).then(client => {
client.appendFile('/server/path1/test.txt', 'some data', {/* WriteFileOptions */})
.then(() => {
client.close() // remember to close connection after you finish
})
.catch(error => {})
}).catch(e => console.log(e))Using async/await:
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
async function test() {
try {
const client = await Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
})
await client.appendFile('/server/path1/test.txt', 'some data', {/* WriteFileOptions */})
client.close() // remember to close connection after you finish
} catch (e) {
console.log(e)
}
}
test()Sets the mode for path
Using Promise
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
}).then(client => {
client.chmod('/server/path1/test.txt', '+x')
.then(() => {
client.close() // remember to close connection after you finish
})
.catch(error => {})
}).catch(e => console.log(e))Using async/await:
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
async function test() {
try {
const client = await Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
})
await client.chmod('/server/path1/test.txt', '+x')
client.close() // remember to close connection after you finish
} catch (e) {
console.log(e)
}
}
test()Sets the owner for path
Using Promise
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
}).then(client => {
client.chown('/server/path1/test.txt', 1000, 1000)
.then(() => {
client.close() // remember to close connection after you finish
})
.catch(error => {})
}).catch(e => console.log(e))Using async/await:
// with commonJS
const { Client } = require('node-scp')
// with ES Module
import { Client } from 'node-scp'
async function test() {
try {
const client = await Client({
host: 'your host',
port: 22,
username: 'username',
password: 'password',
// privateKey: fs.readFileSync('./key.pem'),
// passphrase: 'your key passphrase',
})
await client.chown('/server/path1/test.txt', 1000, 1000)
client.close() // remember to close connection after you finish
} catch (e) {
console.log(e)
}
}
test()Events
You can listen for any event provided by SSH2 during an SSH session by passing events to Connection options
For example:
try {
const client = await Client({
host: "server_ip",
port: 22,
username: "username",
tryKeyboard: true,
events: {
"keyboard-interactive": (
name,
instructions,
instructionsLang,
prompts,
finish
) => {
finish(['my_password'])
},
},
});
client.close(); // remember to close connection after you finish
} catch (e) {
console.log(e);
}Connection options
Below are available options you can pass when connecting to server:
agent - string - Path to ssh-agent's UNIX socket for ssh-agent-based user authentication. Windows users: set to 'pageant' for authenticating with Pageant or (actual) path to a cygwin "UNIX socket." Default: (none)
agentForward - boolean - Set to
trueto use OpenSSH agent forwarding (auth-agent@openssh.com) for the life of the connection.agentmust also be set to use this feature. Default:falsealgorithms - object - This option allows you to explicitly override the default transport layer algorithms used for the connection. The value for each category must either be an array of valid algorithm names to set an exact list (with the most preferable first) or an object containing
append,prepend, and/orremoveproperties that each contain an array of algorithm names or RegExps to match to adjust default lists for each category. Valid keys:cipher - mixed - Ciphers.
- Default list (in order from most to least preferable):
chacha20-poly1305@openssh.com(priority of chacha20-poly1305 may vary depending upon CPU and/or optional binding availability)aes128-gcmaes128-gcm@openssh.comaes256-gcmaes256-gcm@openssh.comaes128-ctraes192-ctraes256-ctr
- Other supported names:
3des-cbcaes256-cbcaes192-cbcaes128-cbcarcfour256arcfour128arcfourblowfish-cbccast128-cbc
- Default list (in order from most to least preferable):
compress - mixed - Compression algorithms.
- Default list (in order from most to least preferable):
nonezlib@openssh.comzlib
- Other supported names:
- Default list (in order from most to least preferable):
hmac - mixed - (H)MAC algorithms.
- Default list (in order from most to least preferable):
hmac-sha2-256-etm@openssh.comhmac-sha2-512-etm@openssh.comhmac-sha1-etm@openssh.comhmac-sha2-256hmac-sha2-512hmac-sha1
- Other supported names:
hmac-md5hmac-sha2-256-96hmac-sha2-512-96hmac-ripemd160hmac-sha1-96hmac-md5-96
- Default list (in order from most to least preferable):
kex - mixed - Key exchange algorithms.
- Default list (in order from most to least preferable):
curve25519-sha256(node v14.0.0+)curve25519-sha256@libssh.org(node v14.0.0+)ecdh-sha2-nistp256ecdh-sha2-nistp384ecdh-sha2-nistp521diffie-hellman-group-exchange-sha256diffie-hellman-group14-sha256diffie-hellman-group15-sha512diffie-hellman-group16-sha512diffie-hellman-group17-sha512diffie-hellman-group18-sha512
- Other supported names:
diffie-hellman-group-exchange-sha1diffie-hellman-group14-sha1diffie-hellman-group1-sha1
- Default list (in order from most to least preferable):
serverHostKey - mixed - Server host key formats.
- Default list (in order from most to least preferable):
ssh-ed25519(node v12.0.0+)ecdsa-sha2-nistp256ecdsa-sha2-nistp384ecdsa-sha2-nistp521rsa-sha2-512rsa-sha2-256ssh-rsa
- Other supported names:
ssh-dss
- Default list (in order from most to least preferable):
authHandler - mixed - Either an array of objects as described below or a function with parameters
(methodsLeft, partialSuccess, callback)wheremethodsLeftandpartialSuccessarenullon the first authentication attempt, otherwise are an array and boolean respectively. Return or callcallback()with either the name of the authentication method or an object containing the method name along with method-specific details to try next (return/passfalseto signal no more methods to try). Valid method names are:'none', 'password', 'publickey', 'agent', 'keyboard-interactive', 'hostbased'. Default: function that follows a set method order: None -> Password -> Private Key -> Agent (-> keyboard-interactive iftryKeyboardistrue) -> HostbasedWhen returning or calling
callback()with an object, it can take one of the following forms:{ type: 'none', username: 'foo', }{ type: 'password' username: 'foo', password: 'bar', }{ type: 'publickey' username: 'foo', // Can be a string, Buffer, or parsed key containing a private key key: ..., // `passphrase` only required for encrypted keys passphrase: ..., }{ type: 'hostbased' username: 'foo', localHostname: 'baz', localUsername: 'quux', // Can be a string, Buffer, or parsed key containing a private key key: ..., // `passphrase` only required for encrypted keys passphrase: ..., }{ type: 'agent' username: 'foo', // Can be a string that is interpreted exactly like the `agent` // connection config option or can be a custom agent // object/instance that extends and implements `BaseAgent` agent: ..., }{ type: 'keyboard-interactive' username: 'foo', // This works exactly the same way as a 'keyboard-interactive' // Client event handler prompt: (name, instructions, instructionsLang, prompts, finish) => { // ... }, }
debug - function - Set this to a function that receives a single string argument to get detailed (local) debug information. Default: (none)
forceIPv4 - boolean - Only connect via resolved IPv4 address for
host. Default:falseforceIPv6 - boolean - Only connect via resolved IPv6 address for
host. Default:falsehost - string - Hostname or IP address of the server. Default:
'localhost'hostHash - string - Any valid hash algorithm supported by node. The host's key is hashed using this algorithm and passed to the hostVerifier function as a hex string. Default: (none)
hostVerifier - function - Function with parameters
(hashedKey[, callback])wherehashedKeyis a string hex hash of the host's key for verification purposes. Returntrueto continue with the handshake orfalseto reject and disconnect, or callcallback()withtrueorfalseif you need to perform asynchronous verification. Default: (auto-accept ifhostVerifieris not set)keepaliveCountMax - integer - How many consecutive, unanswered SSH-level keepalive packets that can be sent to the server before disconnection (similar to OpenSSH's ServerAliveCountMax config option). Default:
3keepaliveInterval - integer - How often (in milliseconds) to send SSH-level keepalive packets to the server (in a similar way as OpenSSH's ServerAliveInterval config option). Set to 0 to disable. Default:
0localAddress - string - IP address of the network interface to use to connect to the server. Default: (none -- determined by OS)
localHostname - string - Along with localUsername and privateKey, set this to a non-empty string for hostbased user authentication. Default: (none)
localPort - string - The local port number to connect from. Default: (none -- determined by OS)
localUsername - string - Along with localHostname and privateKey, set this to a non-empty string for hostbased user authentication. Default: (none)
passphrase - string - For an encrypted
privateKey, this is the passphrase used to decrypt it. Default: (none)password - string - Password for password-based user authentication. Default: (none)
port - integer - Port number of the server. Default:
22privateKey - mixed - Buffer or string that contains a private key for either key-based or hostbased user authentication (OpenSSH format). Default: (none)
readyTimeout - integer - How long (in milliseconds) to wait for the SSH handshake to complete. Default:
20000sock - ReadableStream - A ReadableStream to use for communicating with the server instead of creating and using a new TCP connection (useful for connection hopping).
strictVendor - boolean - Performs a strict server vendor check before sending vendor-specific requests, etc. (e.g. check for OpenSSH server when using
openssh_noMoreSessions()) Default:truetryKeyboard - boolean - Try keyboard-interactive user authentication if primary user authentication method fails. If you set this to
true, you need to handle thekeyboard-interactiveevent. Default:falseusername - string - Username for authentication. Default: (none)
events - Object - List of events to listen to. Default: (none)
Support
If you like this project, give me 1 ⭐️
2 years ago
3 years ago
3 years ago
3 years ago
4 years ago
4 years ago
4 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
6 years ago
6 years ago
6 years ago