with Bitwarden and SSH (key-based auth)?
Executes a command on a remote device. See SSH lib docs here
The Bitwarden API provides a gateway to interact with your secure vault programmatically, enabling the automation of credential management and security operations. Through Pipedream, you can leverage this API to create workflows that enhance your security practices by integrating with other services, triggering actions based on vault events, or even conducting periodic security audits. By harnessing the Bitwarden API, you can streamline password rotation, audit access, and synchronize secrets across your applications automatically.
import { axios } from "@pipedream/platform"
export default defineComponent({
props: {
bitwarden: {
type: "app",
app: "bitwarden",
}
},
async run({steps, $}) {
return await axios($, {
url: `${this.bitwarden.$auth.base_url}/public/members`,
headers: {
Authorization: `Bearer ${this.bitwarden.$auth.oauth_access_token}`,
},
})
},
})
The SSH (Secure Shell) key-based authentication API allows you to execute commands on a remote server securely. With Pipedream, leverage this capability to automate server management tasks, execute deployment scripts, or gather data from your server infrastructure. By integrating with other apps on Pipedream, you can create seamless workflows that trigger actions on your servers in response to various events.
module.exports = defineComponent({
props: {
ssh: {
type: "app",
app: "ssh",
}
},
async run({steps, $}) {
const SSH2Promise = require('ssh2-promise')
const {
host,
port,
username,
privateKey,
} = this.ssh.$auth
const ssh = new SSH2Promise({
host,
port,
username,
privateKey,
})
await ssh.connect()
console.log("Connection established")
// Replace this with the command you'd like to run
const resp = await ssh.exec("whoami")
console.log(resp)
await ssh.close()
},
})