HiveSsh
![github](https://img.shields.io/badge/dynamic/json?style=plastic&color=darkviolet&label=GitHub&prefix=v&query=version&url=https%3A%2F%2Fraw.githubusercontent.com%2Fnoblemajo%2Fhivessh%2Fmain%2Fpackage.json)
![](https://img.shields.io/badge/dynamic/json?color=darkred&label=open%20issues&query=open_issues&suffix=x&url=https%3A%2F%2Fapi.github.com%2Frepos%2Fnoblemajo%2Fhivessh)
Table of Contents
About
HiveSsh simplifies SSH2 connections via promise-based task execution on Linux servers with built-in server utilities and powerful command execution functions.
HiveSsh is a library designed to streamline SSH2 connections and task execution on Linux servers. It provides user-friendly promise-based functions for efficient server operations without the need for a client application.
Key Features
HiveSsh offers the following key features:
-
All-Distributions: SSH2 and SFTP operations for all Linux servers
-
Promisified: Promise-based functions for ease of use
-
AbstractPackageManager: Built-in abstract package manager with support for apt, dnf, and yum, with additional configurability
-
Exec: Command execution utilities for event or promise-based error handling and output parsing, filtering, and mapping
Requirements
HiveSsh requires the following server environments:
- SSH2 server
- SFTP support
- Linux distribution
Getting started
npm i hivessh
import { SshHost } from "hivelib"
const myHost = await SshHost.connect({
host: "127.0.0.1",
password: "123456789",
})
const myHost = await SshHost.connect({
host: "127.0.0.1",
privateKey: "..."
})
const myHost = await SshHost.connect({
host: "127.0.0.1",
privateKeyPath:"/home/user/.ssh/id_rsa",
})
Here are some using examples:
Promisified
Execute and assets
After connecting an SshHost
, you can use the promisified execution (and other asset features) directly on the SshHost
instance.
const homeDirFiles = await myHost.exec("ls -al")
console.log("Home dir files:\n", homeDirFiles.out)
Get the hosts public ip address:
const curlExists = await myHost.exists("curl")
if(!curlExists){
myHost.close()
throw new Error("Curl is not installed on: " + myHost.settings.id)
}
const myIp = await myHost.exec("curl ifconfig.me")
console.log("Host public ip: " + myIp.out)
You can also execute commands on absolut path:
const etcDirFiles = await myHost.exec(
"ls -al",
{ pwd: "/etc" }
)
console.log("Etc files: ", etcDirFiles.out)
Also a git example:
const gitExists = await myHost.exists("git")
if(!gitExists){
myHost.close()
throw new Error("Git is not installed on: " + myHost.settings.id)
}
const gitStatus = await myHost.exec(
"git status",
{
pwd: "/home/tester/myrepo"
}
)
console.log("Git status:\n", gitStatus.out)
Sftp
You can also use the promisified SFTP features via SshHost.sftp
.
const myBinary: Buffer = await myHost.sftp.readFile("/home/tester/my-binary")
const exampleConfig: string = await myHost.sftp.readFile("/etc/example/config.yml", "utf8")
AbstractPackageManager
With the abstract package manager (apm
) you can use apt
, dnf
, yum
or a custom implemented package manager
via one interface.
The apm features are limited and general, but you can update your system and install, delete and list your packages.
const apm = await myHost.getApm()
await apm.updateCache()
await apm.upgradeAll()
await apm.install("git")
Custom package manager
For creating a custon apm you need to implement the following typescript interface:
https://github.com/NobleMajo/hivessh/blob/main/src/apm/ApmInterface.ts
Register package manager
After implementing the custom package manager you need to register it global via a checker function:
import { apmChecker, AbstractPackageManager } from "./apm/apm.js"
apmChecker.push(async (host) => {
if (await host.cmdExists("myapm")) {
const myApm: AbstractPackageManager = { ... }
return myApm
}
})
This function is called when the getApm()
is called and can return a package manager depending on the host.
Exec Session
Sessions are available so that the PWD (process working directory) and environment do not have to be specified for every single command.
These sessions store that persistent settings across multiple executions and can even resolve relative paths.
const session = host.session("/etc/example")
session.exec("ls -al")
session.exec("./myApp")
Example with more options:
const session = host.session("/etc/someapp")
session.sudo = true
session.env.TZ = "Europe/Berlin"
session.env.NODE_ENV = "production"
session.cd("/etc/someapp/dist")
session.exec("node myApp.js")
Technologies
HiveSsh is built using the following technologies:
Contributing
Contributions to HiveSsh are welcome!
Interested users can refer to the guidelines provided in the CONTRIBUTING.md file to contribute to the project and help improve its functionality and features.
License
HiveSsh is licensed under the MIT license, providing users with flexibility and freedom to use and modify the software according to their needs.
Disclaimer
HiveSsh is provided without warranties.
Users are advised to review the accompanying license for more information on the terms of use and limitations of liability.