Compare commits
49 Commits
Author | SHA1 | Date | |
---|---|---|---|
eccc6294a8 | |||
f8a75a8d42 | |||
d5c2bc1b53 | |||
d577a82a7b | |||
f0b52c8da7 | |||
4cb6aa03e6 | |||
8b85b6c8bc | |||
c032ff69d0 | |||
0454eef45f | |||
def368f8ab | |||
6853fa28b6 | |||
56318f28cf | |||
32b26f21cd | |||
32c2698af7 | |||
27237f14c7 | |||
8f29f234f1 | |||
5091625953 | |||
f74b3a51b0 | |||
062f3ad060 | |||
ecd0fd8fad | |||
742bf694e4 | |||
38165f11db | |||
ef2b31b4b2 | |||
5b1f800067 | |||
6339a3ed9b | |||
bf27aaf167 | |||
9bc3aea59c | |||
f5ff302d4d | |||
cac8203bf5 | |||
e4532271cc | |||
faf6c91199 | |||
d0009e7a9c | |||
da76df2c3e | |||
a43976110a | |||
c3ee35a699 | |||
a0ce759552 | |||
201d5cc6d7 | |||
e5bdfff743 | |||
967c9fd9d1 | |||
35da2f0b73 | |||
5e991a4e4f | |||
0f75f5238c | |||
e8f3047ac0 | |||
812d28ee3d | |||
fa301eea71 | |||
48ccf317d6 | |||
9b3af8a50a | |||
78aa36c2be | |||
09d96fd94c |
25
.gitignore
vendored
25
.gitignore
vendored
@ -1,7 +1,20 @@
|
|||||||
.idea/
|
.nogit/
|
||||||
node_modules/
|
|
||||||
|
# artifacts
|
||||||
coverage/
|
coverage/
|
||||||
docs/
|
public/
|
||||||
ts/typings/
|
pages/
|
||||||
ts/*.js
|
|
||||||
ts/*.js.map
|
# installs
|
||||||
|
node_modules/
|
||||||
|
|
||||||
|
# caches
|
||||||
|
.yarn/
|
||||||
|
.cache/
|
||||||
|
.rpt2_cache
|
||||||
|
|
||||||
|
# builds
|
||||||
|
dist/
|
||||||
|
dist_*/
|
||||||
|
|
||||||
|
# custom
|
142
.gitlab-ci.yml
142
.gitlab-ci.yml
@ -1,46 +1,128 @@
|
|||||||
image: hosttoday/ht-docker-node:latest
|
# gitzone ci_default
|
||||||
|
image: registry.gitlab.com/hosttoday/ht-docker-node:npmci
|
||||||
|
|
||||||
|
cache:
|
||||||
|
paths:
|
||||||
|
- .npmci_cache/
|
||||||
|
key: '$CI_BUILD_STAGE'
|
||||||
|
|
||||||
stages:
|
stages:
|
||||||
- test
|
- security
|
||||||
- release
|
- test
|
||||||
- page
|
- release
|
||||||
|
- metadata
|
||||||
|
|
||||||
testLTS:
|
before_script:
|
||||||
stage: test
|
- npm install -g @shipzone/npmci
|
||||||
|
|
||||||
|
# ====================
|
||||||
|
# security stage
|
||||||
|
# ====================
|
||||||
|
auditProductionDependencies:
|
||||||
|
image: registry.gitlab.com/hosttoday/ht-docker-node:npmci
|
||||||
|
stage: security
|
||||||
script:
|
script:
|
||||||
- npmci test lts
|
- npmci npm prepare
|
||||||
|
- npmci command npm install --production --ignore-scripts
|
||||||
|
- npmci command npm config set registry https://registry.npmjs.org
|
||||||
|
- npmci command npm audit --audit-level=high --only=prod --production
|
||||||
tags:
|
tags:
|
||||||
- docker
|
- docker
|
||||||
|
|
||||||
testSTABLE:
|
|
||||||
stage: test
|
|
||||||
script:
|
|
||||||
- npmci test stable
|
|
||||||
tags:
|
|
||||||
- docker
|
|
||||||
|
|
||||||
testLEGACY:
|
|
||||||
stage: test
|
|
||||||
script:
|
|
||||||
- npmci test 0
|
|
||||||
allow_failure: true
|
allow_failure: true
|
||||||
|
|
||||||
|
auditDevDependencies:
|
||||||
|
image: registry.gitlab.com/hosttoday/ht-docker-node:npmci
|
||||||
|
stage: security
|
||||||
|
script:
|
||||||
|
- npmci npm prepare
|
||||||
|
- npmci command npm install --ignore-scripts
|
||||||
|
- npmci command npm config set registry https://registry.npmjs.org
|
||||||
|
- npmci command npm audit --audit-level=high --only=dev
|
||||||
|
tags:
|
||||||
|
- docker
|
||||||
|
allow_failure: true
|
||||||
|
|
||||||
|
# ====================
|
||||||
|
# test stage
|
||||||
|
# ====================
|
||||||
|
|
||||||
|
testStable:
|
||||||
|
stage: test
|
||||||
|
script:
|
||||||
|
- npmci npm prepare
|
||||||
|
- npmci node install stable
|
||||||
|
- npmci npm install
|
||||||
|
- npmci npm test
|
||||||
|
coverage: /\d+.?\d+?\%\s*coverage/
|
||||||
|
tags:
|
||||||
|
- docker
|
||||||
|
|
||||||
|
testBuild:
|
||||||
|
stage: test
|
||||||
|
script:
|
||||||
|
- npmci npm prepare
|
||||||
|
- npmci node install stable
|
||||||
|
- npmci npm install
|
||||||
|
- npmci command npm run build
|
||||||
|
coverage: /\d+.?\d+?\%\s*coverage/
|
||||||
|
tags:
|
||||||
|
- docker
|
||||||
|
|
||||||
release:
|
release:
|
||||||
stage: release
|
stage: release
|
||||||
script:
|
script:
|
||||||
- npmci publish
|
- npmci node install stable
|
||||||
|
- npmci npm publish
|
||||||
only:
|
only:
|
||||||
- tags
|
- tags
|
||||||
tags:
|
tags:
|
||||||
|
- lossless
|
||||||
- docker
|
- docker
|
||||||
|
- notpriv
|
||||||
pages:
|
|
||||||
stage: page
|
# ====================
|
||||||
script:
|
# metadata stage
|
||||||
- mkdir public
|
# ====================
|
||||||
- npmci npmpage
|
codequality:
|
||||||
artifacts:
|
stage: metadata
|
||||||
paths:
|
allow_failure: true
|
||||||
- public
|
|
||||||
only:
|
only:
|
||||||
- tags
|
- tags
|
||||||
|
script:
|
||||||
|
- npmci command npm install -g typescript
|
||||||
|
- npmci npm prepare
|
||||||
|
- npmci npm install
|
||||||
|
tags:
|
||||||
|
- lossless
|
||||||
|
- docker
|
||||||
|
- priv
|
||||||
|
|
||||||
|
trigger:
|
||||||
|
stage: metadata
|
||||||
|
script:
|
||||||
|
- npmci trigger
|
||||||
|
only:
|
||||||
|
- tags
|
||||||
|
tags:
|
||||||
|
- lossless
|
||||||
|
- docker
|
||||||
|
- notpriv
|
||||||
|
|
||||||
|
pages:
|
||||||
|
stage: metadata
|
||||||
|
script:
|
||||||
|
- npmci node install stable
|
||||||
|
- npmci npm prepare
|
||||||
|
- npmci npm install
|
||||||
|
- npmci command npm run buildDocs
|
||||||
|
tags:
|
||||||
|
- lossless
|
||||||
|
- docker
|
||||||
|
- notpriv
|
||||||
|
only:
|
||||||
|
- tags
|
||||||
|
artifacts:
|
||||||
|
expire_in: 1 week
|
||||||
|
paths:
|
||||||
|
- public
|
||||||
|
allow_failure: true
|
||||||
|
12
.travis.yml
12
.travis.yml
@ -1,12 +0,0 @@
|
|||||||
language: node_js
|
|
||||||
node_js:
|
|
||||||
- '4'
|
|
||||||
- stable
|
|
||||||
deploy:
|
|
||||||
provider: npm
|
|
||||||
email: npm@lossless.digital
|
|
||||||
api_key:
|
|
||||||
secure: xApCMlDyZcTOgq+iomxR2A/2aMBhhPpgEBxdFYqXDNC/AGkr+NQJhGt67W4840FMrSUFEDZNQhOS+t6gYMqxUHv+vJFc0cHskFSuLDnAH2MS45TqtFYNcP+GARs1suuM9Il5hXNEvjVJ6XF0lYlNlK8mJstKQscdEKWyBHj42oSsgWRcuzBgqps8Vnbp+Ey2Bpfaw1yV+P1fyv8dNnkwG5dSt3EIxAcbGiMOhCz0u6oMroKfAYfNTxMJjja2uJJOqoTTShzeMyIYx+YwxorcZGfchI+TOPHHeVc+fByCHfzTZJYCy9qTSSTvWcKD/H7q3RGciEXHzhwMj0d8dlY3WPHC6BBliD6bLwVgDmToD3cdHm8OLsxW7hjFLO51vOIbhJZrWBVztlusuLwuyVAlIgeAsV8Yb5FxetxZmBU42qr5itykPl45rNd7talI0ZcoFPRTAWxxmCD8hp0d3ZLdjcEdbCzc5GYmEFN0NwKLTZF3Q1G4UbsHMgN8Pe4ohjdaYYhJ7RKgbmLR0J4NBrWIAUOhDaUTkZhgsHFyEmtbKI6JkxQtwCEBBBursemZWFQSIdtj2+O/RBaBCgoUNIpxUDBFq+D3Pir7BZP7DK2m3Otl0F9aCdqJmhCc7rOn3MueLpmndjtO1RFteXAdAkDxKp2RehIB6yohxbRmQ1O9PsA=
|
|
||||||
on:
|
|
||||||
tags: true
|
|
||||||
repo: pushrocks/smartssh
|
|
11
.vscode/launch.json
vendored
Normal file
11
.vscode/launch.json
vendored
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
{
|
||||||
|
"version": "0.2.0",
|
||||||
|
"configurations": [
|
||||||
|
{
|
||||||
|
"command": "npm test",
|
||||||
|
"name": "Run npm test",
|
||||||
|
"request": "launch",
|
||||||
|
"type": "node-terminal"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
26
.vscode/settings.json
vendored
Normal file
26
.vscode/settings.json
vendored
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
{
|
||||||
|
"json.schemas": [
|
||||||
|
{
|
||||||
|
"fileMatch": ["/npmextra.json"],
|
||||||
|
"schema": {
|
||||||
|
"type": "object",
|
||||||
|
"properties": {
|
||||||
|
"npmci": {
|
||||||
|
"type": "object",
|
||||||
|
"description": "settings for npmci"
|
||||||
|
},
|
||||||
|
"gitzone": {
|
||||||
|
"type": "object",
|
||||||
|
"description": "settings for gitzone",
|
||||||
|
"properties": {
|
||||||
|
"projectType": {
|
||||||
|
"type": "string",
|
||||||
|
"enum": ["website", "element", "service", "npm", "wcc"]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
2
LICENSE
2
LICENSE
@ -1,6 +1,6 @@
|
|||||||
The MIT License (MIT)
|
The MIT License (MIT)
|
||||||
|
|
||||||
Copyright (c) 2016 Push.Rocks
|
Copyright (c) 2016 Lossless GmbH
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
of this software and associated documentation files (the "Software"), to deal
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
|
34
README.md
34
README.md
@ -1,34 +0,0 @@
|
|||||||
# smartssh
|
|
||||||
setups SSH quickly and in a painless manner
|
|
||||||
|
|
||||||
> Attention: This is still alpha, so some things won't work, not all things are inplemented.
|
|
||||||
|
|
||||||
## Usage
|
|
||||||
|
|
||||||
```javascript
|
|
||||||
var smartssh = require("smartssh");
|
|
||||||
var sshInstance = new smartssh.sshInstance({
|
|
||||||
sshDir: "/some/path/.ssh", // the standard ssh directory, optional, defaults to "~./.ssh"
|
|
||||||
sshSync: true // sync ssh this instance will represent the status of an ssh dir if set to true;
|
|
||||||
});
|
|
||||||
|
|
||||||
sshInstance.addKey(new smartssh.sshKey({
|
|
||||||
private: "somestring",
|
|
||||||
public: "somestring", // optional
|
|
||||||
host:"github.com",
|
|
||||||
encoding: "base64" // optional, defaults to "utf8", can be "utf8" or "base64", useful for reading ssh keys from environment variables
|
|
||||||
}));
|
|
||||||
|
|
||||||
sshInstance.removeKey(sshInstance.getKey("github.com")); // removes key for host "github.com" is present
|
|
||||||
|
|
||||||
sshInstance.createKey({
|
|
||||||
host:"gitlab.com" // returns new key in the form sshKey, read more about the sshKey class below
|
|
||||||
})
|
|
||||||
|
|
||||||
sshInstance.getKey({ // returns ssh key in the form sshKey, read more about the sshKey class below
|
|
||||||
host:"github.com"
|
|
||||||
});
|
|
||||||
|
|
||||||
sshInstance.getKeys() // returns array of all available getKeys. Each key is in form of class sshKey
|
|
||||||
|
|
||||||
```
|
|
5
dist/index.d.ts
vendored
5
dist/index.d.ts
vendored
@ -1,5 +0,0 @@
|
|||||||
import "typings-global";
|
|
||||||
export { SshInstance } from "./smartssh.classes.sshinstance";
|
|
||||||
export { SshKey } from "./smartssh.classes.sshkey";
|
|
||||||
export { SshDir } from "./smartssh.classes.sshdir";
|
|
||||||
export { SshConfig } from "./smartssh.classes.sshconfig";
|
|
12
dist/index.js
vendored
12
dist/index.js
vendored
@ -1,12 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
require("typings-global");
|
|
||||||
var smartssh_classes_sshinstance_1 = require("./smartssh.classes.sshinstance");
|
|
||||||
exports.SshInstance = smartssh_classes_sshinstance_1.SshInstance;
|
|
||||||
var smartssh_classes_sshkey_1 = require("./smartssh.classes.sshkey");
|
|
||||||
exports.SshKey = smartssh_classes_sshkey_1.SshKey;
|
|
||||||
var smartssh_classes_sshdir_1 = require("./smartssh.classes.sshdir");
|
|
||||||
exports.SshDir = smartssh_classes_sshdir_1.SshDir;
|
|
||||||
var smartssh_classes_sshconfig_1 = require("./smartssh.classes.sshconfig");
|
|
||||||
exports.SshConfig = smartssh_classes_sshconfig_1.SshConfig;
|
|
||||||
|
|
||||||
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxRQUFPLGdCQUNQLENBQUMsQ0FEc0I7QUFHdkIsNkNBQTBCLGdDQUFnQyxDQUFDO0FBQW5ELGlFQUFtRDtBQUMzRCx3Q0FBcUIsMkJBQTJCLENBQUM7QUFBekMsa0RBQXlDO0FBQ2pELHdDQUFxQiwyQkFBMkIsQ0FBQztBQUF6QyxrREFBeUM7QUFDakQsMkNBQXdCLDhCQUE4QixDQUFDO0FBQS9DLDJEQUErQyIsImZpbGUiOiJpbmRleC5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBcInR5cGluZ3MtZ2xvYmFsXCJcclxuaW1wb3J0ICogYXMgcGx1Z2lucyBmcm9tIFwiLi9zbWFydHNzaC5wbHVnaW5zXCI7XHJcblxyXG5leHBvcnQge1NzaEluc3RhbmNlfSBmcm9tIFwiLi9zbWFydHNzaC5jbGFzc2VzLnNzaGluc3RhbmNlXCI7XHJcbmV4cG9ydCB7U3NoS2V5fSBmcm9tIFwiLi9zbWFydHNzaC5jbGFzc2VzLnNzaGtleVwiO1xyXG5leHBvcnQge1NzaERpcn0gZnJvbSBcIi4vc21hcnRzc2guY2xhc3Nlcy5zc2hkaXJcIjtcclxuZXhwb3J0IHtTc2hDb25maWd9IGZyb20gXCIuL3NtYXJ0c3NoLmNsYXNzZXMuc3NoY29uZmlnXCI7Il19
|
|
4
dist/smartssh.classes.helpers.d.ts
vendored
4
dist/smartssh.classes.helpers.d.ts
vendored
@ -1,4 +0,0 @@
|
|||||||
import "typings-global";
|
|
||||||
import { SshKey } from "./smartssh.classes.sshkey";
|
|
||||||
export declare let sshKeyArrayFromDir: (dirArg: string) => SshKey[];
|
|
||||||
export declare let getKeyIndex: (hostArg: string) => number;
|
|
11
dist/smartssh.classes.helpers.js
vendored
11
dist/smartssh.classes.helpers.js
vendored
@ -1,11 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
require("typings-global");
|
|
||||||
exports.sshKeyArrayFromDir = function (dirArg) {
|
|
||||||
var sshKeyArray = []; //TODO
|
|
||||||
return sshKeyArray;
|
|
||||||
};
|
|
||||||
exports.getKeyIndex = function (hostArg) {
|
|
||||||
return 0; //TODO
|
|
||||||
};
|
|
||||||
|
|
||||||
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNtYXJ0c3NoLmNsYXNzZXMuaGVscGVycy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsUUFBTyxnQkFDUCxDQUFDLENBRHNCO0FBSVosMEJBQWtCLEdBQUcsVUFBUyxNQUFhO0lBQ2xELElBQUksV0FBVyxHQUFHLEVBQUUsQ0FBQyxDQUFDLE1BQU07SUFDNUIsTUFBTSxDQUFDLFdBQVcsQ0FBQztBQUN2QixDQUFDLENBQUE7QUFFVSxtQkFBVyxHQUFHLFVBQVMsT0FBYztJQUM1QyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsT0FBTztBQUNyQixDQUFDLENBQUEiLCJmaWxlIjoic21hcnRzc2guY2xhc3Nlcy5oZWxwZXJzLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFwidHlwaW5ncy1nbG9iYWxcIlxyXG5pbXBvcnQgKiBhcyBwbHVnaW5zIGZyb20gXCIuL3NtYXJ0c3NoLnBsdWdpbnNcIjtcclxuaW1wb3J0IHtTc2hLZXl9IGZyb20gXCIuL3NtYXJ0c3NoLmNsYXNzZXMuc3Noa2V5XCI7XHJcblxyXG5leHBvcnQgbGV0IHNzaEtleUFycmF5RnJvbURpciA9IGZ1bmN0aW9uKGRpckFyZzpzdHJpbmcpOlNzaEtleVtde1xyXG4gICAgbGV0IHNzaEtleUFycmF5ID0gW107IC8vVE9ET1xyXG4gICAgcmV0dXJuIHNzaEtleUFycmF5O1xyXG59XHJcblxyXG5leHBvcnQgbGV0IGdldEtleUluZGV4ID0gZnVuY3Rpb24oaG9zdEFyZzpzdHJpbmcpe1xyXG4gICAgcmV0dXJuIDA7IC8vVE9ETyBcclxufSJdfQ==
|
|
4
dist/smartssh.classes.sshconfig.d.ts
vendored
4
dist/smartssh.classes.sshconfig.d.ts
vendored
@ -1,4 +0,0 @@
|
|||||||
import "typings-global";
|
|
||||||
export declare class SshConfig {
|
|
||||||
constructor();
|
|
||||||
}
|
|
10
dist/smartssh.classes.sshconfig.js
vendored
10
dist/smartssh.classes.sshconfig.js
vendored
@ -1,10 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
require("typings-global");
|
|
||||||
var SshConfig = (function () {
|
|
||||||
function SshConfig() {
|
|
||||||
}
|
|
||||||
return SshConfig;
|
|
||||||
}());
|
|
||||||
exports.SshConfig = SshConfig;
|
|
||||||
|
|
||||||
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNtYXJ0c3NoLmNsYXNzZXMuc3NoY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxRQUFPLGdCQUFnQixDQUFDLENBQUE7QUFHeEI7SUFDSTtJQUVBLENBQUM7SUFDTCxnQkFBQztBQUFELENBSkEsQUFJQyxJQUFBO0FBSlksaUJBQVMsWUFJckIsQ0FBQSIsImZpbGUiOiJzbWFydHNzaC5jbGFzc2VzLnNzaGNvbmZpZy5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBcInR5cGluZ3MtZ2xvYmFsXCI7XHJcbmltcG9ydCAqIGFzIHBsdWdpbnMgZnJvbSBcIi4vc21hcnRzc2gucGx1Z2luc1wiO1xyXG5pbXBvcnQgKiBhcyBoZWxwZXJzIGZyb20gXCIuL3NtYXJ0c3NoLmNsYXNzZXMuaGVscGVyc1wiO1xyXG5leHBvcnQgY2xhc3MgU3NoQ29uZmlnIHtcclxuICAgIGNvbnN0cnVjdG9yKCl7XHJcbiAgICAgICAgXHJcbiAgICB9XHJcbn0iXX0=
|
|
10
dist/smartssh.classes.sshdir.d.ts
vendored
10
dist/smartssh.classes.sshdir.d.ts
vendored
@ -1,10 +0,0 @@
|
|||||||
import "typings-global";
|
|
||||||
import { SshInstance } from "./smartssh.classes.sshinstance";
|
|
||||||
import { SshKey } from "./smartssh.classes.sshkey";
|
|
||||||
export declare class SshDir {
|
|
||||||
path: string;
|
|
||||||
constructor(sshDirPathArg: string);
|
|
||||||
syncToDir(sshInstanceArg: SshInstance): void;
|
|
||||||
syncFromDir(): void;
|
|
||||||
getKeys(): SshKey[];
|
|
||||||
}
|
|
28
dist/smartssh.classes.sshdir.js
vendored
28
dist/smartssh.classes.sshdir.js
vendored
@ -1,28 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
require("typings-global");
|
|
||||||
var plugins = require("./smartssh.plugins");
|
|
||||||
var helpers = require("./smartssh.classes.helpers");
|
|
||||||
var SshDir = (function () {
|
|
||||||
function SshDir(sshDirPathArg) {
|
|
||||||
var sshDirPath;
|
|
||||||
if (sshDirPathArg) {
|
|
||||||
sshDirPath = sshDirPathArg;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
sshDirPath = plugins.smartpath.get.home();
|
|
||||||
}
|
|
||||||
this.path = sshDirPath;
|
|
||||||
}
|
|
||||||
SshDir.prototype.syncToDir = function (sshInstanceArg) {
|
|
||||||
};
|
|
||||||
;
|
|
||||||
SshDir.prototype.syncFromDir = function () {
|
|
||||||
};
|
|
||||||
SshDir.prototype.getKeys = function () {
|
|
||||||
return helpers.sshKeyArrayFromDir(this.path);
|
|
||||||
};
|
|
||||||
return SshDir;
|
|
||||||
}());
|
|
||||||
exports.SshDir = SshDir;
|
|
||||||
|
|
||||||
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNtYXJ0c3NoLmNsYXNzZXMuc3NoZGlyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxRQUFPLGdCQUFnQixDQUFDLENBQUE7QUFDeEIsSUFBWSxPQUFPLFdBQU0sb0JBQW9CLENBQUMsQ0FBQTtBQUM5QyxJQUFZLE9BQU8sV0FBTSw0QkFBNEIsQ0FBQyxDQUFBO0FBSXREO0lBRUksZ0JBQVksYUFBb0I7UUFDNUIsSUFBSSxVQUFpQixDQUFDO1FBQ3RCLEVBQUUsQ0FBQSxDQUFDLGFBQWEsQ0FBQyxDQUFBLENBQUM7WUFDZCxVQUFVLEdBQUcsYUFBYSxDQUFDO1FBQy9CLENBQUM7UUFBQyxJQUFJLENBQUMsQ0FBQztZQUNKLFVBQVUsR0FBRyxPQUFPLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUM5QyxDQUFDO1FBQ0QsSUFBSSxDQUFDLElBQUksR0FBRyxVQUFVLENBQUM7SUFDM0IsQ0FBQztJQUNELDBCQUFTLEdBQVQsVUFBVSxjQUEwQjtJQUVwQyxDQUFDOztJQUNELDRCQUFXLEdBQVg7SUFFQSxDQUFDO0lBQ0Qsd0JBQU8sR0FBUDtRQUNJLE1BQU0sQ0FBQyxPQUFPLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ2pELENBQUM7SUFDTCxhQUFDO0FBQUQsQ0FwQkEsQUFvQkMsSUFBQTtBQXBCWSxjQUFNLFNBb0JsQixDQUFBIiwiZmlsZSI6InNtYXJ0c3NoLmNsYXNzZXMuc3NoZGlyLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFwidHlwaW5ncy1nbG9iYWxcIjtcclxuaW1wb3J0ICogYXMgcGx1Z2lucyBmcm9tIFwiLi9zbWFydHNzaC5wbHVnaW5zXCI7XHJcbmltcG9ydCAqIGFzIGhlbHBlcnMgZnJvbSBcIi4vc21hcnRzc2guY2xhc3Nlcy5oZWxwZXJzXCI7XHJcbmltcG9ydCB7U3NoSW5zdGFuY2V9IGZyb20gXCIuL3NtYXJ0c3NoLmNsYXNzZXMuc3NoaW5zdGFuY2VcIjtcclxuaW1wb3J0IHtTc2hLZXl9IGZyb20gXCIuL3NtYXJ0c3NoLmNsYXNzZXMuc3Noa2V5XCI7XHJcbmltcG9ydCB7U3NoQ29uZmlnfSBmcm9tIFwiLi9zbWFydHNzaC5jbGFzc2VzLnNzaGNvbmZpZ1wiO1xyXG5leHBvcnQgY2xhc3MgU3NoRGlyIHsgLy8gc3NoRGlyIGNsYXNzIC0+IE5PVCBFWFBPUlRFRCwgT05MWSBGT1IgSU5URVJOQUwgVVNFXHJcbiAgICBwYXRoOnN0cmluZzsgLy8gdGhlIHBhdGggb2YgdGhlIHNzaCBkaXJlY3RvcnlcclxuICAgIGNvbnN0cnVjdG9yKHNzaERpclBhdGhBcmc6c3RyaW5nKXtcclxuICAgICAgICBsZXQgc3NoRGlyUGF0aDpzdHJpbmc7XHJcbiAgICAgICAgaWYoc3NoRGlyUGF0aEFyZyl7XHJcbiAgICAgICAgICAgIHNzaERpclBhdGggPSBzc2hEaXJQYXRoQXJnO1xyXG4gICAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgICAgIHNzaERpclBhdGggPSBwbHVnaW5zLnNtYXJ0cGF0aC5nZXQuaG9tZSgpO1xyXG4gICAgICAgIH1cclxuICAgICAgICB0aGlzLnBhdGggPSBzc2hEaXJQYXRoO1xyXG4gICAgfVxyXG4gICAgc3luY1RvRGlyKHNzaEluc3RhbmNlQXJnOlNzaEluc3RhbmNlKXsgLy9zeW5jcyBcclxuICAgICAgICBcclxuICAgIH07XHJcbiAgICBzeW5jRnJvbURpcigpe1xyXG4gICAgICAgIFxyXG4gICAgfVxyXG4gICAgZ2V0S2V5cygpe1xyXG4gICAgICAgIHJldHVybiBoZWxwZXJzLnNzaEtleUFycmF5RnJvbURpcih0aGlzLnBhdGgpO1xyXG4gICAgfVxyXG59Il19
|
|
18
dist/smartssh.classes.sshinstance.d.ts
vendored
18
dist/smartssh.classes.sshinstance.d.ts
vendored
@ -1,18 +0,0 @@
|
|||||||
import "typings-global";
|
|
||||||
import { SshKey } from "./smartssh.classes.sshkey";
|
|
||||||
export declare class SshInstance {
|
|
||||||
private sshConfig;
|
|
||||||
private sshDir;
|
|
||||||
private sshKeys;
|
|
||||||
private sshSync;
|
|
||||||
constructor(optionsArg?: {
|
|
||||||
sshDir?: string;
|
|
||||||
sshSync?: boolean;
|
|
||||||
});
|
|
||||||
addKey(sshKeyArg: SshKey): void;
|
|
||||||
getKey(hostArg: string): SshKey;
|
|
||||||
getKeys(): SshKey[];
|
|
||||||
removeKey(sshKeyArg: SshKey): void;
|
|
||||||
replaceKey(sshKeyOldArg: SshKey, sshKeyNewArg: SshKey): void;
|
|
||||||
sync(): void;
|
|
||||||
}
|
|
56
dist/smartssh.classes.sshinstance.js
vendored
56
dist/smartssh.classes.sshinstance.js
vendored
File diff suppressed because one or more lines are too long
18
dist/smartssh.classes.sshkey.d.ts
vendored
18
dist/smartssh.classes.sshkey.d.ts
vendored
@ -1,18 +0,0 @@
|
|||||||
import "typings-global";
|
|
||||||
export declare class SshKey {
|
|
||||||
private privKey;
|
|
||||||
private pubKey;
|
|
||||||
private hostVar;
|
|
||||||
constructor(optionsArg?: {
|
|
||||||
private?: string;
|
|
||||||
public?: string;
|
|
||||||
host?: string;
|
|
||||||
});
|
|
||||||
host: string;
|
|
||||||
privateKey: string;
|
|
||||||
privateKeyBase64: any;
|
|
||||||
publicKey: string;
|
|
||||||
publicKeyBase64: any;
|
|
||||||
type: string;
|
|
||||||
store(filePathArg?: string): void;
|
|
||||||
}
|
|
98
dist/smartssh.classes.sshkey.js
vendored
98
dist/smartssh.classes.sshkey.js
vendored
File diff suppressed because one or more lines are too long
7
dist/smartssh.plugins.d.ts
vendored
7
dist/smartssh.plugins.d.ts
vendored
@ -1,7 +0,0 @@
|
|||||||
import "typings-global";
|
|
||||||
export declare let beautylog: any;
|
|
||||||
export declare let base64: any;
|
|
||||||
export declare let fs: any;
|
|
||||||
export declare let path: any;
|
|
||||||
export declare let smartfile: any;
|
|
||||||
export import smartpath = require("smartpath");
|
|
10
dist/smartssh.plugins.js
vendored
10
dist/smartssh.plugins.js
vendored
@ -1,10 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
require("typings-global");
|
|
||||||
exports.beautylog = require("beautylog");
|
|
||||||
exports.base64 = require("js-base64").Base64;
|
|
||||||
exports.fs = require("fs-extra");
|
|
||||||
exports.path = require("path");
|
|
||||||
exports.smartfile = require("smartfile");
|
|
||||||
exports.smartpath = require("smartpath");
|
|
||||||
|
|
||||||
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNtYXJ0c3NoLnBsdWdpbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLFFBQU8sZ0JBQ1AsQ0FBQyxDQURzQjtBQUNaLGlCQUFTLEdBQUcsT0FBTyxDQUFDLFdBQVcsQ0FBQyxDQUFDO0FBQ2pDLGNBQU0sR0FBRyxPQUFPLENBQUMsV0FBVyxDQUFDLENBQUMsTUFBTSxDQUFDO0FBQ3JDLFVBQUUsR0FBRyxPQUFPLENBQUMsVUFBVSxDQUFDLENBQUM7QUFDekIsWUFBSSxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQztBQUN2QixpQkFBUyxHQUFHLE9BQU8sQ0FBQyxXQUFXLENBQUMsQ0FBQztBQUM5QixpQkFBUyxXQUFXLFdBQVcsQ0FBQyxDQUFDIiwiZmlsZSI6InNtYXJ0c3NoLnBsdWdpbnMuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgXCJ0eXBpbmdzLWdsb2JhbFwiXHJcbmV4cG9ydCBsZXQgYmVhdXR5bG9nID0gcmVxdWlyZShcImJlYXV0eWxvZ1wiKTtcclxuZXhwb3J0IGxldCBiYXNlNjQgPSByZXF1aXJlKFwianMtYmFzZTY0XCIpLkJhc2U2NDtcclxuZXhwb3J0IGxldCBmcyA9IHJlcXVpcmUoXCJmcy1leHRyYVwiKTtcclxuZXhwb3J0IGxldCBwYXRoID0gcmVxdWlyZShcInBhdGhcIik7XHJcbmV4cG9ydCBsZXQgc21hcnRmaWxlID0gcmVxdWlyZShcInNtYXJ0ZmlsZVwiKTtcclxuZXhwb3J0IGltcG9ydCBzbWFydHBhdGggPSByZXF1aXJlKFwic21hcnRwYXRoXCIpOyJdfQ==
|
|
17
npmextra.json
Normal file
17
npmextra.json
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
{
|
||||||
|
"npmci": {
|
||||||
|
"npmGlobalTools": [],
|
||||||
|
"npmAccessLevel": "public"
|
||||||
|
},
|
||||||
|
"gitzone": {
|
||||||
|
"projectType": "npm",
|
||||||
|
"module": {
|
||||||
|
"githost": "gitlab.com",
|
||||||
|
"gitscope": "pushrocks",
|
||||||
|
"gitrepo": "smartssh",
|
||||||
|
"description": "setups SSH quickly and in a painless manner",
|
||||||
|
"npmPackagename": "@pushrocks/smartssh",
|
||||||
|
"license": "MIT"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -1,4 +0,0 @@
|
|||||||
{
|
|
||||||
"mode":"default",
|
|
||||||
"coverageTreshold":50
|
|
||||||
}
|
|
12983
package-lock.json
generated
Normal file
12983
package-lock.json
generated
Normal file
File diff suppressed because it is too large
Load Diff
60
package.json
60
package.json
@ -1,14 +1,20 @@
|
|||||||
{
|
{
|
||||||
"name": "smartssh",
|
"name": "@pushrocks/smartssh",
|
||||||
"version": "1.0.3",
|
"version": "1.2.6",
|
||||||
|
"private": false,
|
||||||
"description": "setups SSH quickly and in a painless manner",
|
"description": "setups SSH quickly and in a painless manner",
|
||||||
"main": "dist/index.js",
|
"main": "dist_ts/index.js",
|
||||||
|
"typings": "dist_ts/index.d.ts",
|
||||||
|
"type": "module",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"test": "(npmts)"
|
"test": "(tstest test/)",
|
||||||
|
"testDocker": "tsdocker",
|
||||||
|
"build": "(tsbuild)",
|
||||||
|
"buildDocs": "tsdoc"
|
||||||
},
|
},
|
||||||
"repository": {
|
"repository": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "git+https://github.com/pushrocks/smartssh.git"
|
"url": "git+https://gitlab.com/pushrocks/smartssh.git"
|
||||||
},
|
},
|
||||||
"keywords": [
|
"keywords": [
|
||||||
"SSH",
|
"SSH",
|
||||||
@ -18,20 +24,40 @@
|
|||||||
"author": "Lossless GmbH",
|
"author": "Lossless GmbH",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"bugs": {
|
"bugs": {
|
||||||
"url": "https://github.com/pushrocks/smartssh/issues"
|
"url": "https://gitlab.com/pushrocks/smartssh/issues"
|
||||||
},
|
},
|
||||||
"homepage": "https://github.com/pushrocks/smartssh#readme",
|
"homepage": "https://gitlab.com/pushrocks/smartssh#readme",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"beautylog": "^5.0.8",
|
"@pushrocks/smartfile": "^10.0.5",
|
||||||
"fs-extra": "^0.30.0",
|
"@pushrocks/smartpath": "^5.0.5",
|
||||||
"js-base64": "^2.1.9",
|
"@pushrocks/smartpromise": "^3.0.2",
|
||||||
"smartfile": "^3.0.10",
|
"@pushrocks/smartshell": "^2.0.23",
|
||||||
"smartpath": "^3.2.2",
|
"@pushrocks/smartstring": "^4.0.5",
|
||||||
"typings-global": "^1.0.3",
|
"@types/fs-extra": "^9.0.13",
|
||||||
"typings-test": "^1.0.1"
|
"@types/minimatch": "^5.1.2",
|
||||||
|
"fs-extra": "^10.1.0",
|
||||||
|
"minimatch": "^5.1.0"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"npmts": "^5.1.19",
|
"@gitzone/tsbuild": "^2.1.11",
|
||||||
"should": "^9.0.0"
|
"@gitzone/tsrun": "^1.2.6",
|
||||||
}
|
"@gitzone/tstest": "^1.0.24",
|
||||||
|
"@pushrocks/tapbundle": "^5.0.4",
|
||||||
|
"@types/node": "^18.8.4"
|
||||||
|
},
|
||||||
|
"files": [
|
||||||
|
"ts/**/*",
|
||||||
|
"ts_web/**/*",
|
||||||
|
"dist/**/*",
|
||||||
|
"dist_*/**/*",
|
||||||
|
"dist_ts/**/*",
|
||||||
|
"dist_ts_web/**/*",
|
||||||
|
"assets/**/*",
|
||||||
|
"cli.js",
|
||||||
|
"npmextra.json",
|
||||||
|
"readme.md"
|
||||||
|
],
|
||||||
|
"browserslist": [
|
||||||
|
"last 1 chrome versions"
|
||||||
|
]
|
||||||
}
|
}
|
||||||
|
4213
pnpm-lock.yaml
generated
Normal file
4213
pnpm-lock.yaml
generated
Normal file
File diff suppressed because it is too large
Load Diff
68
readme.md
Normal file
68
readme.md
Normal file
@ -0,0 +1,68 @@
|
|||||||
|
# @pushrocks/smartssh
|
||||||
|
setups SSH quickly and in a painless manner
|
||||||
|
|
||||||
|
## Availabililty and Links
|
||||||
|
* [npmjs.org (npm package)](https://www.npmjs.com/package/@pushrocks/smartssh)
|
||||||
|
* [gitlab.com (source)](https://gitlab.com/pushrocks/smartssh)
|
||||||
|
* [github.com (source mirror)](https://github.com/pushrocks/smartssh)
|
||||||
|
* [docs (typedoc)](https://pushrocks.gitlab.io/smartssh/)
|
||||||
|
|
||||||
|
## Status for master
|
||||||
|
|
||||||
|
Status Category | Status Badge
|
||||||
|
-- | --
|
||||||
|
GitLab Pipelines | [](https://lossless.cloud)
|
||||||
|
GitLab Pipline Test Coverage | [](https://lossless.cloud)
|
||||||
|
npm | [](https://lossless.cloud)
|
||||||
|
Snyk | [](https://lossless.cloud)
|
||||||
|
TypeScript Support | [](https://lossless.cloud)
|
||||||
|
node Support | [](https://nodejs.org/dist/latest-v10.x/docs/api/)
|
||||||
|
Code Style | [](https://lossless.cloud)
|
||||||
|
PackagePhobia (total standalone install weight) | [](https://lossless.cloud)
|
||||||
|
PackagePhobia (package size on registry) | [](https://lossless.cloud)
|
||||||
|
BundlePhobia (total size when bundled) | [](https://lossless.cloud)
|
||||||
|
Platform support | [](https://lossless.cloud) [](https://lossless.cloud)
|
||||||
|
|
||||||
|
## Usage
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
var smartssh = require('smartssh');
|
||||||
|
var sshInstance = new smartssh.sshInstance({
|
||||||
|
sshDir: '/some/path/.ssh', // the standard ssh directory, optional, defaults to "~./.ssh"
|
||||||
|
sshSync: true, // sync ssh this instance will represent the status of an ssh dir if set to true;
|
||||||
|
});
|
||||||
|
|
||||||
|
sshInstance.addKey(
|
||||||
|
new smartssh.sshKey({
|
||||||
|
private: 'somestring',
|
||||||
|
public: 'somestring', // optional
|
||||||
|
host: 'github.com',
|
||||||
|
encoding: 'base64', // optional, defaults to "utf8", can be "utf8" or "base64", useful for reading ssh keys from environment variables
|
||||||
|
})
|
||||||
|
);
|
||||||
|
|
||||||
|
sshInstance.removeKey(sshInstance.getKey('github.com')); // removes key for host "github.com" is present
|
||||||
|
|
||||||
|
sshInstance.createKey({
|
||||||
|
host: 'gitlab.com', // returns new key in the form sshKey, read more about the sshKey class below
|
||||||
|
});
|
||||||
|
|
||||||
|
sshInstance.getKey({
|
||||||
|
// returns ssh key in the form sshKey, read more about the sshKey class below
|
||||||
|
host: 'github.com',
|
||||||
|
});
|
||||||
|
|
||||||
|
sshInstance.getKeys(); // returns array of all available getKeys. Each key is in form of class sshKey
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
## Contribution
|
||||||
|
|
||||||
|
We are always happy for code contributions. If you are not the code contributing type that is ok. Still, maintaining Open Source repositories takes considerable time and thought. If you like the quality of what we do and our modules are useful to you we would appreciate a little monthly contribution: You can [contribute one time](https://lossless.link/contribute-onetime) or [contribute monthly](https://lossless.link/contribute). :)
|
||||||
|
|
||||||
|
For further information read the linked docs at the top of this readme.
|
||||||
|
|
||||||
|
> MIT licensed | **©** [Lossless GmbH](https://lossless.gmbh)
|
||||||
|
| By using this npm module you agree to our [privacy policy](https://lossless.gmbH/privacy)
|
||||||
|
|
||||||
|
[](https://maintainedby.lossless.com)
|
1
test/temp/bitbucket.org
Normal file
1
test/temp/bitbucket.org
Normal file
@ -0,0 +1 @@
|
|||||||
|
somePrivateKey
|
1
test/temp/bitbucket.org.pub
Normal file
1
test/temp/bitbucket.org.pub
Normal file
@ -0,0 +1 @@
|
|||||||
|
somePublicKey
|
15
test/temp/config
Normal file
15
test/temp/config
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
Host gitlab.com
|
||||||
|
HostName gitlab.com
|
||||||
|
IdentityFile ~/.ssh/gitlab.com
|
||||||
|
StrictHostKeyChecking no
|
||||||
|
|
||||||
|
Host bitbucket.org
|
||||||
|
HostName bitbucket.org
|
||||||
|
IdentityFile ~/.ssh/bitbucket.org
|
||||||
|
StrictHostKeyChecking no
|
||||||
|
|
||||||
|
Host github.com
|
||||||
|
HostName github.com
|
||||||
|
IdentityFile ~/.ssh/github.com
|
||||||
|
StrictHostKeyChecking no
|
||||||
|
|
1
test/temp/example.com
Normal file
1
test/temp/example.com
Normal file
@ -0,0 +1 @@
|
|||||||
|
someExamplePrivateKey
|
1
test/temp/example.com.pub
Normal file
1
test/temp/example.com.pub
Normal file
@ -0,0 +1 @@
|
|||||||
|
someExamplePublicKey
|
1
test/temp/github.com
Normal file
1
test/temp/github.com
Normal file
@ -0,0 +1 @@
|
|||||||
|
someGitHubPrivateKey
|
1
test/temp/github.com.pub
Normal file
1
test/temp/github.com.pub
Normal file
@ -0,0 +1 @@
|
|||||||
|
someGitHubPublicKey
|
1
test/temp/gitlab.com
Normal file
1
test/temp/gitlab.com
Normal file
@ -0,0 +1 @@
|
|||||||
|
somePrivateKey
|
1
test/temp/gitlab.com.pub
Normal file
1
test/temp/gitlab.com.pub
Normal file
@ -0,0 +1 @@
|
|||||||
|
somePublicKey
|
2
test/test.d.ts
vendored
2
test/test.d.ts
vendored
@ -1,2 +0,0 @@
|
|||||||
import "typings-test";
|
|
||||||
import "should";
|
|
36
test/test.js
36
test/test.js
@ -1,36 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
require("typings-test");
|
|
||||||
require("should");
|
|
||||||
var smartssh = require("../dist/index");
|
|
||||||
describe("smartssh", function () {
|
|
||||||
var testSshInstance;
|
|
||||||
var testSshKey;
|
|
||||||
describe("SshInstance", function () {
|
|
||||||
it("should create a new SshInstance object from class", function () {
|
|
||||||
testSshInstance = new smartssh.SshInstance();
|
|
||||||
testSshInstance.should.be.instanceof(smartssh.SshInstance);
|
|
||||||
});
|
|
||||||
it("should accept a new SshKey object", function () {
|
|
||||||
testSshInstance.addKey(new smartssh.SshKey({
|
|
||||||
public: "somePublicKey",
|
|
||||||
private: "somePrivateKey",
|
|
||||||
host: "gitlab.com"
|
|
||||||
}));
|
|
||||||
testSshInstance.addKey(new smartssh.SshKey({
|
|
||||||
public: "somePublicKey",
|
|
||||||
private: "somePrivateKey",
|
|
||||||
host: "bitbucket.org"
|
|
||||||
}));
|
|
||||||
testSshInstance.addKey(new smartssh.SshKey({
|
|
||||||
public: "somePublicKey",
|
|
||||||
private: "somePrivateKey",
|
|
||||||
host: "github.com"
|
|
||||||
}));
|
|
||||||
});
|
|
||||||
it("should return an array of sshKeys", function () {
|
|
||||||
testSshInstance.getKeys();
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLFFBQU8sY0FDUCxDQUFDLENBRG9CO0FBQ3JCLFFBQU8sUUFBUSxDQUFDLENBQUE7QUFDaEIsSUFBTyxRQUFRLFdBQVcsZUFBZSxDQUFDLENBQUM7QUFDM0MsUUFBUSxDQUFDLFVBQVUsRUFBQztJQUNoQixJQUFJLGVBQW9DLENBQUM7SUFDekMsSUFBSSxVQUEwQixDQUFDO0lBQy9CLFFBQVEsQ0FBQyxhQUFhLEVBQUM7UUFDbkIsRUFBRSxDQUFDLG1EQUFtRCxFQUFDO1lBQ25ELGVBQWUsR0FBRyxJQUFJLFFBQVEsQ0FBQyxXQUFXLEVBQUUsQ0FBQztZQUM3QyxlQUFlLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxVQUFVLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQy9ELENBQUMsQ0FBQyxDQUFDO1FBQ0gsRUFBRSxDQUFDLG1DQUFtQyxFQUFDO1lBQ25DLGVBQWUsQ0FBQyxNQUFNLENBQUMsSUFBSSxRQUFRLENBQUMsTUFBTSxDQUFDO2dCQUN2QyxNQUFNLEVBQUMsZUFBZTtnQkFDdEIsT0FBTyxFQUFDLGdCQUFnQjtnQkFDeEIsSUFBSSxFQUFDLFlBQVk7YUFDcEIsQ0FBQyxDQUFDLENBQUM7WUFDSixlQUFlLENBQUMsTUFBTSxDQUFDLElBQUksUUFBUSxDQUFDLE1BQU0sQ0FBQztnQkFDdkMsTUFBTSxFQUFDLGVBQWU7Z0JBQ3RCLE9BQU8sRUFBQyxnQkFBZ0I7Z0JBQ3hCLElBQUksRUFBQyxlQUFlO2FBQ3ZCLENBQUMsQ0FBQyxDQUFDO1lBQ0osZUFBZSxDQUFDLE1BQU0sQ0FBQyxJQUFJLFFBQVEsQ0FBQyxNQUFNLENBQUM7Z0JBQ3ZDLE1BQU0sRUFBQyxlQUFlO2dCQUN0QixPQUFPLEVBQUMsZ0JBQWdCO2dCQUN4QixJQUFJLEVBQUMsWUFBWTthQUNwQixDQUFDLENBQUMsQ0FBQztRQUNSLENBQUMsQ0FBQyxDQUFDO1FBQ0gsRUFBRSxDQUFDLG1DQUFtQyxFQUFDO1lBQ25DLGVBQWUsQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUM5QixDQUFDLENBQUMsQ0FBQztJQUNQLENBQUMsQ0FBQyxDQUFBO0FBQ04sQ0FBQyxDQUFDLENBQUEiLCJmaWxlIjoidGVzdC5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBcInR5cGluZ3MtdGVzdFwiXHJcbmltcG9ydCBcInNob3VsZFwiO1xyXG5pbXBvcnQgc21hcnRzc2ggPSByZXF1aXJlKFwiLi4vZGlzdC9pbmRleFwiKTtcclxuZGVzY3JpYmUoXCJzbWFydHNzaFwiLGZ1bmN0aW9uKCl7XHJcbiAgICBsZXQgdGVzdFNzaEluc3RhbmNlOnNtYXJ0c3NoLlNzaEluc3RhbmNlO1xyXG4gICAgbGV0IHRlc3RTc2hLZXk6c21hcnRzc2guU3NoS2V5O1xyXG4gICAgZGVzY3JpYmUoXCJTc2hJbnN0YW5jZVwiLGZ1bmN0aW9uKCl7XHJcbiAgICAgICAgaXQoXCJzaG91bGQgY3JlYXRlIGEgbmV3IFNzaEluc3RhbmNlIG9iamVjdCBmcm9tIGNsYXNzXCIsZnVuY3Rpb24oKXtcclxuICAgICAgICAgICAgdGVzdFNzaEluc3RhbmNlID0gbmV3IHNtYXJ0c3NoLlNzaEluc3RhbmNlKCk7XHJcbiAgICAgICAgICAgIHRlc3RTc2hJbnN0YW5jZS5zaG91bGQuYmUuaW5zdGFuY2VvZihzbWFydHNzaC5Tc2hJbnN0YW5jZSk7XHJcbiAgICAgICAgfSk7XHJcbiAgICAgICAgaXQoXCJzaG91bGQgYWNjZXB0IGEgbmV3IFNzaEtleSBvYmplY3RcIixmdW5jdGlvbigpe1xyXG4gICAgICAgICAgICB0ZXN0U3NoSW5zdGFuY2UuYWRkS2V5KG5ldyBzbWFydHNzaC5Tc2hLZXkoe1xyXG4gICAgICAgICAgICAgICAgcHVibGljOlwic29tZVB1YmxpY0tleVwiLFxyXG4gICAgICAgICAgICAgICAgcHJpdmF0ZTpcInNvbWVQcml2YXRlS2V5XCIsXHJcbiAgICAgICAgICAgICAgICBob3N0OlwiZ2l0bGFiLmNvbVwiXHJcbiAgICAgICAgICAgIH0pKTtcclxuICAgICAgICAgICAgdGVzdFNzaEluc3RhbmNlLmFkZEtleShuZXcgc21hcnRzc2guU3NoS2V5KHtcclxuICAgICAgICAgICAgICAgIHB1YmxpYzpcInNvbWVQdWJsaWNLZXlcIixcclxuICAgICAgICAgICAgICAgIHByaXZhdGU6XCJzb21lUHJpdmF0ZUtleVwiLFxyXG4gICAgICAgICAgICAgICAgaG9zdDpcImJpdGJ1Y2tldC5vcmdcIlxyXG4gICAgICAgICAgICB9KSk7XHJcbiAgICAgICAgICAgIHRlc3RTc2hJbnN0YW5jZS5hZGRLZXkobmV3IHNtYXJ0c3NoLlNzaEtleSh7XHJcbiAgICAgICAgICAgICAgICBwdWJsaWM6XCJzb21lUHVibGljS2V5XCIsXHJcbiAgICAgICAgICAgICAgICBwcml2YXRlOlwic29tZVByaXZhdGVLZXlcIixcclxuICAgICAgICAgICAgICAgIGhvc3Q6XCJnaXRodWIuY29tXCJcclxuICAgICAgICAgICAgfSkpO1xyXG4gICAgICAgIH0pO1xyXG4gICAgICAgIGl0KFwic2hvdWxkIHJldHVybiBhbiBhcnJheSBvZiBzc2hLZXlzXCIsZnVuY3Rpb24oKXtcclxuICAgICAgICAgICAgdGVzdFNzaEluc3RhbmNlLmdldEtleXMoKTtcclxuICAgICAgICB9KTtcclxuICAgIH0pXHJcbn0pIl19
|
|
115
test/test.ts
115
test/test.ts
@ -1,33 +1,84 @@
|
|||||||
import "typings-test"
|
import { expect, tap } from '@pushrocks/tapbundle';
|
||||||
import "should";
|
import * as smartssh from '../ts/index.js';
|
||||||
import smartssh = require("../dist/index");
|
import * as path from 'path';
|
||||||
describe("smartssh",function(){
|
|
||||||
let testSshInstance:smartssh.SshInstance;
|
let testSshInstance: smartssh.SshInstance;
|
||||||
let testSshKey:smartssh.SshKey;
|
let testSshKey: smartssh.SshKey;
|
||||||
describe("SshInstance",function(){
|
tap.test('should create a valid SshKey object', async () => {
|
||||||
it("should create a new SshInstance object from class",function(){
|
testSshKey = new smartssh.SshKey({
|
||||||
testSshInstance = new smartssh.SshInstance();
|
host: 'example.com',
|
||||||
testSshInstance.should.be.instanceof(smartssh.SshInstance);
|
private: 'someExamplePrivateKey',
|
||||||
});
|
public: 'someExamplePublicKey',
|
||||||
it("should accept a new SshKey object",function(){
|
});
|
||||||
testSshInstance.addKey(new smartssh.SshKey({
|
expect(testSshKey).toBeInstanceOf(smartssh.SshKey);
|
||||||
public:"somePublicKey",
|
});
|
||||||
private:"somePrivateKey",
|
tap.test('.type should be a valid type', async () => {
|
||||||
host:"gitlab.com"
|
expect(testSshKey.type).toEqual('duplex');
|
||||||
}));
|
});
|
||||||
testSshInstance.addKey(new smartssh.SshKey({
|
tap.test('.publicKey should be public key', async () => {
|
||||||
public:"somePublicKey",
|
expect(testSshKey.pubKey).toEqual('someExamplePublicKey');
|
||||||
private:"somePrivateKey",
|
});
|
||||||
host:"bitbucket.org"
|
tap.test('.privateKey should be private key', async () => {
|
||||||
}));
|
expect(testSshKey.privKey).toEqual('someExamplePrivateKey');
|
||||||
testSshInstance.addKey(new smartssh.SshKey({
|
});
|
||||||
public:"somePublicKey",
|
tap.test('.publicKeyBase64 should be public key base 64 encoded', async () => {
|
||||||
private:"somePrivateKey",
|
// tslint:disable-next-line:no-unused-expression
|
||||||
host:"github.com"
|
testSshKey.pubKeyBase64;
|
||||||
}));
|
});
|
||||||
});
|
tap.test('.store() should store the file to disk', async () => {
|
||||||
it("should return an array of sshKeys",function(){
|
testSshKey.store(path.join(process.cwd(), 'test/temp'));
|
||||||
testSshInstance.getKeys();
|
});
|
||||||
});
|
|
||||||
|
// SSH INstance
|
||||||
|
tap.test("'new' keyword should create a new SshInstance object from class", async () => {
|
||||||
|
testSshInstance = new smartssh.SshInstance({
|
||||||
|
sshDirPath: path.join(process.cwd(), 'test/temp/'),
|
||||||
|
});
|
||||||
|
expect(testSshInstance).toBeInstanceOf(smartssh.SshInstance);
|
||||||
|
});
|
||||||
|
tap.test('.addKey() should accept a new SshKey object', async () => {
|
||||||
|
testSshInstance.addKey(
|
||||||
|
new smartssh.SshKey({
|
||||||
|
public: 'somePublicKey',
|
||||||
|
private: 'somePrivateKey',
|
||||||
|
host: 'gitlab.com',
|
||||||
})
|
})
|
||||||
})
|
);
|
||||||
|
testSshInstance.addKey(
|
||||||
|
new smartssh.SshKey({
|
||||||
|
public: 'somePublicKey',
|
||||||
|
private: 'somePrivateKey',
|
||||||
|
host: 'bitbucket.org',
|
||||||
|
})
|
||||||
|
);
|
||||||
|
testSshInstance.addKey(
|
||||||
|
new smartssh.SshKey({
|
||||||
|
public: 'someGitHubPublicKey',
|
||||||
|
private: 'someGitHubPrivateKey',
|
||||||
|
host: 'github.com',
|
||||||
|
})
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
tap.test('.sshKeys should point to an array of sshKeys', async () => {
|
||||||
|
let sshKeyArray = testSshInstance.sshKeys;
|
||||||
|
expect(sshKeyArray).toBeInstanceOf(Array);
|
||||||
|
expect(sshKeyArray[0].host).toEqual('gitlab.com');
|
||||||
|
expect(sshKeyArray[1].host).toEqual('bitbucket.org');
|
||||||
|
expect(sshKeyArray[2].host).toEqual('github.com');
|
||||||
|
});
|
||||||
|
|
||||||
|
tap.test('.getKey() should get a specific key selected by host', async () => {
|
||||||
|
expect(testSshInstance.getKey('github.com').pubKey).toEqual('someGitHubPublicKey');
|
||||||
|
});
|
||||||
|
|
||||||
|
tap.test('.removeKey() should remove a key', async () => {
|
||||||
|
testSshInstance.removeKey(testSshInstance.getKey('bitbucket.org'));
|
||||||
|
expect(testSshInstance.sshKeys[1].host).toEqual('github.com');
|
||||||
|
});
|
||||||
|
|
||||||
|
tap.test('it should store to disk', async () => {
|
||||||
|
testSshInstance.writeToDisk();
|
||||||
|
});
|
||||||
|
|
||||||
|
tap.start();
|
||||||
|
8
ts/00_commitinfo_data.ts
Normal file
8
ts/00_commitinfo_data.ts
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
/**
|
||||||
|
* autocreated commitinfo by @pushrocks/commitinfo
|
||||||
|
*/
|
||||||
|
export const commitinfo = {
|
||||||
|
name: '@pushrocks/smartssh',
|
||||||
|
version: '1.2.6',
|
||||||
|
description: 'setups SSH quickly and in a painless manner'
|
||||||
|
}
|
11
ts/index.ts
11
ts/index.ts
@ -1,7 +1,6 @@
|
|||||||
import "typings-global"
|
import * as plugins from './smartssh.plugins.js';
|
||||||
import * as plugins from "./smartssh.plugins";
|
|
||||||
|
|
||||||
export {SshInstance} from "./smartssh.classes.sshinstance";
|
export { SshInstance } from './smartssh.classes.sshinstance.js';
|
||||||
export {SshKey} from "./smartssh.classes.sshkey";
|
export { SshKey } from './smartssh.classes.sshkey.js';
|
||||||
export {SshDir} from "./smartssh.classes.sshdir";
|
export { SshDir } from './smartssh.classes.sshdir.js';
|
||||||
export {SshConfig} from "./smartssh.classes.sshconfig";
|
export { SshConfig } from './smartssh.classes.sshconfig.js';
|
||||||
|
@ -1,12 +1,7 @@
|
|||||||
import "typings-global"
|
import * as plugins from './smartssh.plugins.js';
|
||||||
import * as plugins from "./smartssh.plugins";
|
import { SshKey } from './smartssh.classes.sshkey.js';
|
||||||
import {SshKey} from "./smartssh.classes.sshkey";
|
|
||||||
|
|
||||||
export let sshKeyArrayFromDir = function(dirArg:string):SshKey[]{
|
export let sshKeyArrayFromDir = function (dirArg: string): SshKey[] {
|
||||||
let sshKeyArray = []; //TODO
|
let sshKeyArray = []; // TODO
|
||||||
return sshKeyArray;
|
return sshKeyArray;
|
||||||
}
|
};
|
||||||
|
|
||||||
export let getKeyIndex = function(hostArg:string){
|
|
||||||
return 0; //TODO
|
|
||||||
}
|
|
||||||
|
@ -1,8 +1,60 @@
|
|||||||
import "typings-global";
|
import * as plugins from './smartssh.plugins.js';
|
||||||
import * as plugins from "./smartssh.plugins";
|
import * as helpers from './smartssh.classes.helpers.js';
|
||||||
import * as helpers from "./smartssh.classes.helpers";
|
import { SshKey } from './smartssh.classes.sshkey.js';
|
||||||
|
|
||||||
export class SshConfig {
|
export class SshConfig {
|
||||||
constructor(){
|
private _sshKeyArray: SshKey[];
|
||||||
|
constructor(sshKeyArrayArg: SshKey[]) {
|
||||||
|
this._sshKeyArray = sshKeyArrayArg;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* stores a config file
|
||||||
|
*/
|
||||||
|
store(dirPathArg: string) {
|
||||||
|
let done = plugins.smartpromise.defer();
|
||||||
|
let configArray: configObject[] = [];
|
||||||
|
let configString;
|
||||||
|
for (let key in this._sshKeyArray) {
|
||||||
|
let sshKey = this._sshKeyArray[key];
|
||||||
|
if (sshKey.host) {
|
||||||
|
configString =
|
||||||
|
'Host ' +
|
||||||
|
sshKey.host +
|
||||||
|
'\n' +
|
||||||
|
' HostName ' +
|
||||||
|
sshKey.host +
|
||||||
|
'\n' +
|
||||||
|
' IdentityFile ~/.ssh/' +
|
||||||
|
sshKey.host +
|
||||||
|
'\n' +
|
||||||
|
' StrictHostKeyChecking no' +
|
||||||
|
'\n';
|
||||||
|
}
|
||||||
|
configArray.push({
|
||||||
|
configString: configString,
|
||||||
|
authorized: sshKey.authorized,
|
||||||
|
sshKey: sshKey,
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
let configFile: string = '';
|
||||||
|
for (let key in configArray) {
|
||||||
|
configFile = configFile + configArray[key].configString + '\n';
|
||||||
|
}
|
||||||
|
plugins.smartfile.memory.toFsSync(configFile, plugins.path.join(dirPathArg, 'config'));
|
||||||
|
return done.promise;
|
||||||
|
}
|
||||||
|
read(dirPathArg) {
|
||||||
|
let done = plugins.smartpromise.defer();
|
||||||
|
let configArray: configObject[];
|
||||||
|
plugins.smartfile.fs.toStringSync(plugins.path.join(dirPathArg, 'config'));
|
||||||
|
|
||||||
|
return done.promise;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface configObject {
|
||||||
|
configString: string;
|
||||||
|
authorized: boolean;
|
||||||
|
sshKey: SshKey;
|
||||||
|
}
|
||||||
|
@ -1,27 +1,47 @@
|
|||||||
import "typings-global";
|
import * as plugins from './smartssh.plugins.js';
|
||||||
import * as plugins from "./smartssh.plugins";
|
import * as helpers from './smartssh.classes.helpers.js';
|
||||||
import * as helpers from "./smartssh.classes.helpers";
|
import { SshInstance } from './smartssh.classes.sshinstance.js';
|
||||||
import {SshInstance} from "./smartssh.classes.sshinstance";
|
import { SshKey } from './smartssh.classes.sshkey.js';
|
||||||
import {SshKey} from "./smartssh.classes.sshkey";
|
import { SshConfig } from './smartssh.classes.sshconfig.js';
|
||||||
import {SshConfig} from "./smartssh.classes.sshconfig";
|
|
||||||
export class SshDir { // sshDir class -> NOT EXPORTED, ONLY FOR INTERNAL USE
|
export class SshDir {
|
||||||
path:string; // the path of the ssh directory
|
// sshDir class -> NOT EXPORTED, ONLY FOR INTERNAL USE
|
||||||
constructor(sshDirPathArg:string){
|
private _path: string; // the path of the ssh directory
|
||||||
let sshDirPath:string;
|
private _sshKeyArray: SshKey[];
|
||||||
if(sshDirPathArg){
|
private _sshConfig: SshConfig;
|
||||||
sshDirPath = sshDirPathArg;
|
constructor(sshKeyArray: SshKey[], sshConfig: SshConfig, sshDirPathArg?: string) {
|
||||||
} else {
|
this._sshKeyArray = sshKeyArray;
|
||||||
sshDirPath = plugins.smartpath.get.home();
|
this._sshConfig = sshConfig;
|
||||||
}
|
if (sshDirPathArg) {
|
||||||
this.path = sshDirPath;
|
this._path = sshDirPathArg;
|
||||||
|
} else {
|
||||||
|
this._path = plugins.path.join(plugins.smartpath.get.home(), '.ssh/');
|
||||||
}
|
}
|
||||||
syncToDir(sshInstanceArg:SshInstance){ //syncs
|
}
|
||||||
|
|
||||||
};
|
writeToDir(dirPathArg?: string) {
|
||||||
syncFromDir(){
|
// syncs sshInstance to directory
|
||||||
|
let path = this._path;
|
||||||
}
|
if (dirPathArg) path = dirPathArg;
|
||||||
getKeys(){
|
this._sshKeyArray.forEach((sshKeyArg) => {
|
||||||
return helpers.sshKeyArrayFromDir(this.path);
|
sshKeyArg.store(path);
|
||||||
}
|
});
|
||||||
}
|
this._sshConfig.store(path);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* TODO: implement reading of directories
|
||||||
|
*/
|
||||||
|
readFromDir(dirPathArg?: string) {
|
||||||
|
// syncs sshInstance from directory
|
||||||
|
let path = this._path;
|
||||||
|
if (dirPathArg) path = dirPathArg;
|
||||||
|
}
|
||||||
|
updateDirPath(dirPathArg: string) {
|
||||||
|
this._path = dirPathArg;
|
||||||
|
}
|
||||||
|
|
||||||
|
getKeys() {
|
||||||
|
return helpers.sshKeyArrayFromDir(this._path);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@ -1,56 +1,102 @@
|
|||||||
import "typings-global"
|
import * as plugins from './smartssh.plugins.js';
|
||||||
import * as plugins from "./smartssh.plugins";
|
import * as helpers from './smartssh.classes.helpers.js';
|
||||||
import * as helpers from "./smartssh.classes.helpers";
|
|
||||||
|
|
||||||
import {SshDir} from "./smartssh.classes.sshdir";
|
import { SshDir } from './smartssh.classes.sshdir.js';
|
||||||
import {SshConfig} from "./smartssh.classes.sshconfig";
|
import { SshConfig } from './smartssh.classes.sshconfig.js';
|
||||||
import {SshKey} from "./smartssh.classes.sshkey";
|
import { SshKey } from './smartssh.classes.sshkey.js';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* SshInstance is the main class dealing with ssh management
|
||||||
|
*/
|
||||||
export class SshInstance {
|
export class SshInstance {
|
||||||
private sshConfig:SshConfig; // sshConfig (e.g. represents ~/.ssh/config)
|
private _sshKeyArray: SshKey[]; // holds all ssh keys
|
||||||
private sshDir:SshDir; // points to sshDir class instance.
|
private _sshConfig: SshConfig; // sshConfig (e.g. represents ~/.ssh/config)
|
||||||
private sshKeys:SshKey[]; //holds all ssh keys
|
private _sshDir: SshDir; // points to sshDir class instance.
|
||||||
private sshSync:boolean; // if set to true, the ssh dir will be kept in sync automatically
|
private _sshSync: boolean; // if set to true, the ssh dir will be kept in sync automatically
|
||||||
constructor(optionsArg:{sshDir?:string,sshSync?:boolean}={}){
|
constructor(optionsArg: { sshDirPath?: string; sshSync?: boolean } = {}) {
|
||||||
optionsArg ? void(0) : optionsArg = {};
|
optionsArg ? void 0 : (optionsArg = {});
|
||||||
this.sshDir = new SshDir(optionsArg.sshDir);
|
this._sshKeyArray = [];
|
||||||
this.sshKeys = this.sshDir.getKeys();
|
this._sshConfig = new SshConfig(this._sshKeyArray);
|
||||||
this.sshSync = optionsArg.sshSync;
|
this._sshDir = new SshDir(this._sshKeyArray, this._sshConfig, optionsArg.sshDirPath);
|
||||||
};
|
this._sshSync = optionsArg.sshSync;
|
||||||
addKey(sshKeyArg:SshKey){
|
}
|
||||||
this.sshKeys.push(sshKeyArg);
|
|
||||||
this.sync();
|
// altering methods
|
||||||
};
|
addKey(sshKeyArg: SshKey) {
|
||||||
getKey(hostArg:string){
|
this._syncAuto('from');
|
||||||
let filteredArray = this.sshKeys.filter(function(keyArg){
|
this._sshKeyArray.push(sshKeyArg);
|
||||||
return (keyArg.host == hostArg);
|
this._syncAuto('to');
|
||||||
});
|
}
|
||||||
if(filteredArray.length > 0){
|
removeKey(sshKeyArg: SshKey) {
|
||||||
return filteredArray[0];
|
this._syncAuto('from');
|
||||||
} else {
|
let filteredArray = this._sshKeyArray.filter((sshKeyArg2: SshKey) => {
|
||||||
return undefined;
|
return sshKeyArg != sshKeyArg2;
|
||||||
}
|
});
|
||||||
};
|
this._sshKeyArray = filteredArray;
|
||||||
|
this._syncAuto('to');
|
||||||
getKeys(){
|
}
|
||||||
return this.sshKeys;
|
replaceKey(sshKeyOldArg: SshKey, sshKeyNewArg: SshKey) {
|
||||||
|
this._syncAuto('from');
|
||||||
|
this.removeKey(sshKeyOldArg);
|
||||||
|
this.addKey(sshKeyNewArg);
|
||||||
|
this._syncAuto('to');
|
||||||
|
}
|
||||||
|
|
||||||
|
// non altering methods
|
||||||
|
getKey(hostArg: string): SshKey {
|
||||||
|
this._syncAuto('from');
|
||||||
|
let filteredArray = this._sshKeyArray.filter(function (keyArg) {
|
||||||
|
return keyArg.host === hostArg;
|
||||||
|
});
|
||||||
|
if (filteredArray.length > 0) {
|
||||||
|
return filteredArray[0];
|
||||||
|
} else {
|
||||||
|
return undefined;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
removeKey(sshKeyArg:SshKey){
|
get sshKeys(): SshKey[] {
|
||||||
let keyIndex = helpers.getKeyIndex(sshKeyArg.host);
|
this._syncAuto('from');
|
||||||
this.sshKeys.splice(keyIndex,1);
|
return this._sshKeyArray;
|
||||||
this.sync();
|
}
|
||||||
};
|
|
||||||
replaceKey(sshKeyOldArg:SshKey,sshKeyNewArg:SshKey){
|
// FS methods
|
||||||
let keyIndex = helpers.getKeyIndex(sshKeyOldArg.host);
|
|
||||||
this.sshKeys.splice(keyIndex,1,sshKeyNewArg);
|
/**
|
||||||
this.sync();
|
* write SshInstance to disk
|
||||||
};
|
*/
|
||||||
sync(){
|
writeToDisk(dirPathArg?: string) {
|
||||||
if(this.sshSync){
|
this._sync('to', dirPathArg);
|
||||||
this.sshDir.sync(this.sshConfig,this.sshKeys); // call sync method of sshDir class;
|
}
|
||||||
}
|
|
||||||
};
|
/**
|
||||||
|
* read ab SshInstance from disk
|
||||||
|
*/
|
||||||
|
readFromDisk(dirPathArg?: string) {
|
||||||
|
this._sync('from', dirPathArg);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* ===============================================================
|
||||||
|
========================= Private Methods ========================
|
||||||
|
================================================================*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* method to invoke SshInstance _sync automatically when sshSync is true
|
||||||
|
*/
|
||||||
|
private _syncAuto(directionArg: 'from' | 'to') {
|
||||||
|
if (this._sshSync) {
|
||||||
|
// if auto sync is not enabled, do nothing
|
||||||
|
this._sync(directionArg);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* private method to sync SshInstance
|
||||||
|
*/
|
||||||
|
private _sync(directionArg: 'from' | 'to', dirPathArg?: string) {
|
||||||
|
if (directionArg === 'from') {
|
||||||
|
this._sshDir.readFromDir(dirPathArg); // call sync method of sshDir class;
|
||||||
|
} else if (directionArg === 'to') {
|
||||||
|
this._sshDir.writeToDir(dirPathArg);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,65 +1,106 @@
|
|||||||
import "typings-global";
|
import * as plugins from './smartssh.plugins.js';
|
||||||
import * as plugins from "./smartssh.plugins";
|
import * as helpers from './smartssh.classes.helpers.js';
|
||||||
import * as helpers from "./smartssh.classes.helpers";
|
|
||||||
|
|
||||||
export class SshKey {
|
export class SshKey {
|
||||||
private privKey:string;
|
private _privKey: string;
|
||||||
private pubKey:string;
|
private _pubKey: string;
|
||||||
private hostVar:string;
|
private _hostVar: string;
|
||||||
constructor(optionsArg:{private?:string,public?:string,host?:string}={}){
|
private _authorized: boolean;
|
||||||
this.privKey = optionsArg.private;
|
|
||||||
this.pubKey = optionsArg.public;
|
private _smarthshellInstance = new plugins.shelljs.Smartshell({
|
||||||
this.hostVar = optionsArg.host;
|
executor: 'bash',
|
||||||
};
|
});
|
||||||
|
|
||||||
// getters
|
/**
|
||||||
get host(){
|
* the constructor for class SshKey
|
||||||
return this.hostVar;
|
*/
|
||||||
};
|
constructor(
|
||||||
get privateKey(){
|
optionsArg: { private?: string; public?: string; host?: string; authorized?: boolean } = {}
|
||||||
return this.privKey;
|
) {
|
||||||
};
|
this._privKey = optionsArg.private;
|
||||||
get privateKeyBase64(){
|
this._pubKey = optionsArg.public;
|
||||||
return plugins.base64.encode(this.privKey);
|
this._hostVar = optionsArg.host;
|
||||||
|
this._authorized = optionsArg.authorized;
|
||||||
|
}
|
||||||
|
|
||||||
|
// this.host
|
||||||
|
get host() {
|
||||||
|
return this._hostVar;
|
||||||
|
}
|
||||||
|
set host(hostArg: string) {
|
||||||
|
this._hostVar = hostArg;
|
||||||
|
}
|
||||||
|
|
||||||
|
// this.privKey
|
||||||
|
get privKey() {
|
||||||
|
return this._privKey;
|
||||||
|
}
|
||||||
|
set privKey(privateKeyArg: string) {
|
||||||
|
this._privKey = privateKeyArg;
|
||||||
|
}
|
||||||
|
|
||||||
|
// this.privKeyBase64
|
||||||
|
get privKeyBase64() {
|
||||||
|
return plugins.smartstring.base64.encode(this._privKey);
|
||||||
|
}
|
||||||
|
set privKeyBase64(privateKeyArg: string) {
|
||||||
|
this._privKey = plugins.smartstring.base64.decode(privateKeyArg);
|
||||||
|
}
|
||||||
|
|
||||||
|
// this.pubKey
|
||||||
|
get pubKey() {
|
||||||
|
return this._pubKey;
|
||||||
|
}
|
||||||
|
set pubKey(publicKeyArg: string) {
|
||||||
|
this._pubKey = publicKeyArg;
|
||||||
|
}
|
||||||
|
|
||||||
|
// this.pubKeyBase64
|
||||||
|
get pubKeyBase64() {
|
||||||
|
return plugins.smartstring.base64.encode(this._pubKey);
|
||||||
|
}
|
||||||
|
set pubKeyBase64(publicKeyArg: string) {
|
||||||
|
this._pubKey = plugins.smartstring.base64.decode(publicKeyArg);
|
||||||
|
}
|
||||||
|
|
||||||
|
get authorized() {
|
||||||
|
return this._authorized;
|
||||||
|
}
|
||||||
|
set authorized(authorizedArg: boolean) {
|
||||||
|
this._authorized = authorizedArg;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* returns wether there is a private, a public or both keys
|
||||||
|
*/
|
||||||
|
get type() {
|
||||||
|
if (this._privKey && this._pubKey) {
|
||||||
|
return 'duplex';
|
||||||
|
} else if (this._privKey) {
|
||||||
|
return 'private';
|
||||||
|
} else if (this._pubKey) {
|
||||||
|
return 'public';
|
||||||
}
|
}
|
||||||
get publicKey(){
|
}
|
||||||
return this.publicKey;
|
set type(someVlueArg: any) {
|
||||||
|
console.log('the type of an SshKey connot be set. This value is autocomputed.');
|
||||||
|
}
|
||||||
|
|
||||||
|
// methods
|
||||||
|
read(filePathArg) {}
|
||||||
|
|
||||||
|
async store(dirPathArg: string) {
|
||||||
|
plugins.fs.ensureDirSync(dirPathArg);
|
||||||
|
let fileNameBase = this.host;
|
||||||
|
if (this._privKey) {
|
||||||
|
let filePath = plugins.path.join(dirPathArg, fileNameBase);
|
||||||
|
plugins.smartfile.memory.toFsSync(this._privKey, filePath);
|
||||||
|
await this._smarthshellInstance.exec(`chmod 0600 ${filePath}`);
|
||||||
}
|
}
|
||||||
get publicKeyBase64(){
|
if (this._pubKey) {
|
||||||
return plugins.base64.encode(this.pubKey);
|
let filePath = plugins.path.join(dirPathArg, fileNameBase + '.pub');
|
||||||
|
plugins.smartfile.memory.toFsSync(this._pubKey, filePath);
|
||||||
|
await this._smarthshellInstance.exec(`chmod 0600 ${filePath}`);
|
||||||
}
|
}
|
||||||
get type(){
|
}
|
||||||
if(this.privKey && this.pubKey){
|
}
|
||||||
return "duplex";
|
|
||||||
} else if(this.privKey){
|
|
||||||
return "private";
|
|
||||||
} else if(this.pubKey){
|
|
||||||
return "public";
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// setters
|
|
||||||
set host(hostArg:string){
|
|
||||||
this.hostVar = hostArg;
|
|
||||||
};
|
|
||||||
set privateKey(privateKeyArg:string){
|
|
||||||
this.privKey = privateKeyArg;
|
|
||||||
};
|
|
||||||
// setters
|
|
||||||
set publicKey(publicKeyArg:string){
|
|
||||||
this.pubKey = publicKeyArg;
|
|
||||||
};
|
|
||||||
|
|
||||||
store(filePathArg?:string){
|
|
||||||
let filePathObj = plugins.path.parse(filePathArg);
|
|
||||||
if(filePathObj.ext = ".priv"){
|
|
||||||
plugins.smartfile.memory.toFsSync(this.privKey,{fileName:filePathObj.name + filePathObj.ext,filePath:filePathObj.dir});
|
|
||||||
} else if (filePathObj.ext = ".pub"){
|
|
||||||
plugins.smartfile.memory.toFsSync(this.pubKey,{fileName:filePathObj.name + filePathObj.ext,filePath:filePathObj.dir});
|
|
||||||
} else { //we assume we are given a directory as filePathArg, so we store the whole key
|
|
||||||
plugins.fs.ensureDirSync(filePathObj.dir);
|
|
||||||
this.store(plugins.path.join(filePathObj.dir,"key.priv")); // call this function recursivly
|
|
||||||
this.store(plugins.path.join(filePathObj.dir,"key.priv")); // call this function recursivly
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
@ -1,7 +1,10 @@
|
|||||||
import "typings-global"
|
import * as fs from 'fs-extra';
|
||||||
export let beautylog = require("beautylog");
|
import * as minimatch from 'minimatch';
|
||||||
export let base64 = require("js-base64").Base64;
|
import * as path from 'path';
|
||||||
export let fs = require("fs-extra");
|
import * as smartpromise from '@pushrocks/smartpromise';
|
||||||
export let path = require("path");
|
import * as shelljs from '@pushrocks/smartshell';
|
||||||
export let smartfile = require("smartfile");
|
import * as smartfile from '@pushrocks/smartfile';
|
||||||
export import smartpath = require("smartpath");
|
import * as smartpath from '@pushrocks/smartpath';
|
||||||
|
import * as smartstring from '@pushrocks/smartstring';
|
||||||
|
|
||||||
|
export { fs, minimatch, path, smartpromise, shelljs, smartfile, smartpath, smartstring };
|
||||||
|
@ -1,8 +0,0 @@
|
|||||||
{
|
|
||||||
"version": false,
|
|
||||||
"dependencies": {},
|
|
||||||
"ambientDependencies": {
|
|
||||||
"colors": "registry:dt/colors#0.6.0-1+20160317120654",
|
|
||||||
"node": "registry:dt/node#4.0.0+20160423143914"
|
|
||||||
}
|
|
||||||
}
|
|
10
tsconfig.json
Normal file
10
tsconfig.json
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
{
|
||||||
|
"compilerOptions": {
|
||||||
|
"experimentalDecorators": true,
|
||||||
|
"useDefineForClassFields": false,
|
||||||
|
"target": "ES2022",
|
||||||
|
"module": "ES2022",
|
||||||
|
"moduleResolution": "nodenext",
|
||||||
|
"esModuleInterop": true
|
||||||
|
}
|
||||||
|
}
|
Reference in New Issue
Block a user