2.4.0 • Published 6 months ago

duckcloud-cli v2.4.0

Weekly downloads
-
License
GPL3.0
Repository
github
Last release
6 months ago

duckcloud-cli

DuckCloud command line interface

Install

$ npm i --location-global duckcloud-cli
$ pnpm add -g duckcloud-cli # pnpm install
$ yarn add -g duckcloud-cli # yarn install

Usage

$ duckcl --help
duckcl <command>

Commands:
  duckcl login [username]                  Login with duckcloud
  duckcl container <id>                    Select a container
  duckcl sh                                Open shell in selected container
  duckcl powerctl <action>                 power control
  duckcl script <path>                     Run script on selected container (*wi
                                           ll run as if the user typed it, sheba
                                           ng is not necessary)
  duckcl rm                                Delete selected container (cannot be
                                           undone)
  duckcl create                            Create a new container
  duckcl ls                                List all containers
  duckcl config [path]                     Modify/view configuration
  duckcl forward <remotePort> <localpath>  Forwards a TCP port from a DuckCloud
                                           container to your local machine
  duckcl proxycmd <port>                   Proxy stdin/stdout to a TCP connectio
                                           n (can be used for ssh)
  duckcl pro                               pro control

Options:
  --help     Show help                                                 [boolean]
  --version  Show version number                                       [boolean]

Where is the config

At ~/.duckcl.json5

Ultimatelogon

Ultimatelogon login is in beta and doesn't work right now, please don't try using it.

How do I update my configuration?

If you upgraded to a newer version of duckcloud-cli with new configuration entries, you'll need to run duckcl config --reset to reset your configuration back to the newer defaults.

How do I exit vim the shell?

Press Ctrl+] and .

API Wrapper Documentation

You can use the API wrapper like this:

import { DuckCloud, Distro } from "duckcloud-cli";

const duckc = new DuckCloud("https://duckcloud.pcprojects.tk");
console.log(await duckc.Login(process.argv[2], process.argv[3]));
const containers = await duckc.User.GetContainers();
const shell = containers[0].Shell();
shell.on('data', (data: string) => {
	process.stdout.write(data);
})
shell.on('disconnect', () => { console.log('disconnect'); process.exit(0) });
  • <DuckCloud>.Login(username: string, password: string): Promise<boolean> Logs into a account
  • <DuckCloud>.User User object
  • <User>.GetContainers(): Container[] Get all containers from the user
  • <User>.CreateContainer(name: string, network: boolean, pro: boolean, distro: Distro): Promise<number> Create a container on the user account
  • Distro.debian Debian
  • Distro.archlinux Arch Linux
  • Distro["duckcloud/suspiral"] Suspiral (custom debian)
  • Status.online Online status
  • Status.offline Offline status
  • <Container>.id Id of the container
  • <Container>.name Name of the container
  • <Container>.status Status of the container
  • <Container>.TogglePower() Toggle the container's power
  • <Container>.Remove() Remove the container from existence
  • <Container>.Shell() Get the container's shell
2.4.0

6 months ago

2.3.0

1 year ago

2.2.1

1 year ago

2.2.0

1 year ago

2.1.0

1 year ago

2.0.1

1 year ago

2.0.0

1 year ago

1.0.2

1 year ago

1.0.1

1 year ago

1.0.0

1 year ago