2020-04-17 15:19:33 +02:00
|
|
|
/**
|
|
|
|
* @license
|
|
|
|
* Copyright 2016-2020 Balena Ltd.
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
import { flags } from '@oclif/command';
|
|
|
|
import Command from '../../command';
|
|
|
|
import { ExpectedError } from '../../errors';
|
|
|
|
import * as cf from '../../utils/common-flags';
|
2020-05-04 15:57:23 +01:00
|
|
|
import { getBalenaSdk, stripIndent } from '../../utils/lazy';
|
2020-04-17 15:19:33 +02:00
|
|
|
|
|
|
|
interface FlagsDef {
|
|
|
|
help: void;
|
|
|
|
}
|
|
|
|
|
|
|
|
interface ArgsDef {
|
|
|
|
name: string;
|
|
|
|
path: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
export default class KeyAddCmd extends Command {
|
|
|
|
public static description = stripIndent`
|
|
|
|
Add an SSH key to balenaCloud.
|
|
|
|
|
2020-09-16 14:53:46 +01:00
|
|
|
Add an SSH key to the balenaCloud account of the logged in user.
|
2020-04-17 15:19:33 +02:00
|
|
|
|
2020-09-16 14:53:46 +01:00
|
|
|
If \`path\` is omitted, the command will attempt to read the SSH key from stdin.
|
|
|
|
|
|
|
|
About SSH keys
|
|
|
|
An "SSH key" actually consists of a public/private key pair. A typical name
|
|
|
|
for the private key file is "id_rsa", and a typical name for the public key
|
|
|
|
file is "id_rsa.pub". Both key files are saved to your computer (with the
|
|
|
|
private key optionally protected by a password), but only the public key is
|
|
|
|
saved to your balena account. This means that if you change computers or
|
|
|
|
otherwise lose the private key, you cannot recover the private key through
|
|
|
|
your balena account. You can however add new keys, and delete the old ones.
|
|
|
|
|
|
|
|
To generate a new SSH key pair, a nice guide can be found in GitHub's docs:
|
|
|
|
https://help.github.com/en/articles/generating-a-new-ssh-key-and-adding-it-to-the-ssh-agent
|
|
|
|
Skip the step about adding the key to a GitHub account, and instead add it to
|
|
|
|
your balena account.
|
2020-04-17 15:19:33 +02:00
|
|
|
`;
|
|
|
|
|
|
|
|
public static examples = [
|
|
|
|
'$ balena key add Main ~/.ssh/id_rsa.pub',
|
|
|
|
'$ cat ~/.ssh/id_rsa.pub | balena key add Main',
|
2020-09-16 14:53:46 +01:00
|
|
|
'# Windows 10 (cmd.exe prompt) example',
|
|
|
|
'$ balena key add Main %userprofile%.sshid_rsa.pub',
|
2020-04-17 15:19:33 +02:00
|
|
|
];
|
|
|
|
|
|
|
|
public static args = [
|
|
|
|
{
|
|
|
|
name: 'name',
|
|
|
|
description: 'the SSH key name',
|
|
|
|
required: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: `path`,
|
|
|
|
description: `the path to the public key file`,
|
|
|
|
},
|
|
|
|
];
|
|
|
|
|
|
|
|
public static usage = 'key add <name> [path]';
|
|
|
|
|
|
|
|
public static flags: flags.Input<FlagsDef> = {
|
|
|
|
help: cf.help,
|
|
|
|
};
|
|
|
|
|
|
|
|
public static authenticated = true;
|
|
|
|
|
|
|
|
public static readStdin = true;
|
|
|
|
|
|
|
|
public async run() {
|
|
|
|
const { args: params } = this.parse<FlagsDef, ArgsDef>(KeyAddCmd);
|
|
|
|
|
|
|
|
let key: string;
|
|
|
|
if (params.path != null) {
|
2020-06-23 11:57:57 +01:00
|
|
|
const { readFile } = (await import('fs')).promises;
|
|
|
|
key = await readFile(params.path, 'utf8');
|
2020-04-17 15:19:33 +02:00
|
|
|
} else if (this.stdin.length > 0) {
|
|
|
|
key = this.stdin;
|
|
|
|
} else {
|
|
|
|
throw new ExpectedError('No public key file or path provided.');
|
|
|
|
}
|
|
|
|
|
|
|
|
await getBalenaSdk().models.key.create(params.name, key);
|
|
|
|
}
|
|
|
|
}
|