Compare commits
15 Commits
Author | SHA1 | Date | |
---|---|---|---|
4bcf925b28 | |||
484e75ac34 | |||
ad792f32dd | |||
05b7c7ab45 | |||
d94a097443 | |||
645e46dc01 | |||
5c87851ab8 | |||
0fd3bd262b | |||
732e35d295 | |||
e9135c42af | |||
a850243c59 | |||
8dc75feb8d | |||
ac7160c3a3 | |||
1cdcd332d4 | |||
5e10df8e5a |
3
.gitignore
vendored
3
.gitignore
vendored
@ -1,3 +1,6 @@
|
|||||||
node_modules
|
node_modules
|
||||||
docs/
|
docs/
|
||||||
coverage/
|
coverage/
|
||||||
|
.nogit/
|
||||||
|
dist/assets/
|
||||||
|
test/assets/
|
@ -1,29 +1,26 @@
|
|||||||
image: hosttoday/ht-docker-node:npmts
|
image: hosttoday/ht-docker-node:npmts
|
||||||
|
|
||||||
stages:
|
stages:
|
||||||
- test
|
- test1
|
||||||
|
- test2
|
||||||
- release
|
- release
|
||||||
|
|
||||||
testLEGACY:
|
|
||||||
stage: test
|
|
||||||
script:
|
|
||||||
- npmci test legacy
|
|
||||||
tags:
|
|
||||||
- docker
|
|
||||||
- lossless
|
|
||||||
|
|
||||||
testLTS:
|
testLTS:
|
||||||
stage: test
|
stage: test1
|
||||||
script:
|
script:
|
||||||
- npmci test lts
|
- npmci test lts
|
||||||
|
only:
|
||||||
|
- tags
|
||||||
tags:
|
tags:
|
||||||
- docker
|
- docker
|
||||||
- lossless
|
- lossless
|
||||||
|
|
||||||
testSTABLE:
|
testSTABLE:
|
||||||
stage: test
|
stage: test2
|
||||||
script:
|
script:
|
||||||
- npmci test stable
|
- npmci test stable
|
||||||
|
only:
|
||||||
|
- tags
|
||||||
tags:
|
tags:
|
||||||
- docker
|
- docker
|
||||||
- lossless
|
- lossless
|
||||||
|
13
README.md
13
README.md
@ -1,8 +1,6 @@
|
|||||||
# Cert
|
# Cert
|
||||||
Easily obain SSL certificates from LetsEncrypt. Supports DNS-01 challenge. TypeScript ready.
|
Easily obain SSL certificates from LetsEncrypt. Supports DNS-01 challenge. TypeScript ready.
|
||||||
|
|
||||||
> Note: this package is in pre-alpha stage and will be ready soon.
|
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
|
|
||||||
```typescript
|
```typescript
|
||||||
@ -12,7 +10,7 @@ let myCert = new Cert({
|
|||||||
cfEmail: "some@cloudflare.email",
|
cfEmail: "some@cloudflare.email",
|
||||||
cfKey: "someCloudflareApiKey",
|
cfKey: "someCloudflareApiKey",
|
||||||
sslDir: "someOutputPath", // NOTE: if you already have certificates, make sure you put them in here, so cert only requires the missing ones
|
sslDir: "someOutputPath", // NOTE: if you already have certificates, make sure you put them in here, so cert only requires the missing ones
|
||||||
gitOriginRepo: "git@githhub.com/someuser/somereopo" // good for pesistence in highly volatile environments like docker
|
gitOriginRepo: "git@githhub.com/someuser/somereopo" // good for persistence in highly volatile environments like docker
|
||||||
});
|
});
|
||||||
|
|
||||||
myCert.getDomainCert("example.com");
|
myCert.getDomainCert("example.com");
|
||||||
@ -20,3 +18,12 @@ myCert.getDomainCert("example.com");
|
|||||||
|
|
||||||
### sslDir
|
### sslDir
|
||||||
to use the certificates it is important to understand what the structure of the ssl directory looks like.
|
to use the certificates it is important to understand what the structure of the ssl directory looks like.
|
||||||
|
|
||||||
|
### using a git origin repo.
|
||||||
|
Often times you want to keep track of certificates in order to keep them
|
||||||
|
even if the point of initial certificate request is gone. Imagine you have a dockerenvironement
|
||||||
|
and you keep starting new container versions for the same domain. YOu ideally want to use a proxy
|
||||||
|
that handles SSL managemet for you. But even the proxy needs to be updated from time to time.
|
||||||
|
|
||||||
|
So you need some kind of persistence between versions. This is why you can sync up all certificates to a git repo over ssh
|
||||||
|
Just make sure your id_rsa is in place for the node user and is allowed for the origin repo.
|
1
dist/cert.hook.d.ts
vendored
1
dist/cert.hook.d.ts
vendored
@ -0,0 +1 @@
|
|||||||
|
import "typings-global";
|
||||||
|
66
dist/cert.hook.js
vendored
Normal file → Executable file
66
dist/cert.hook.js
vendored
Normal file → Executable file
File diff suppressed because one or more lines are too long
5
dist/cert.paths.d.ts
vendored
5
dist/cert.paths.d.ts
vendored
@ -1,2 +1,5 @@
|
|||||||
import "typings-global";
|
import "typings-global";
|
||||||
export import path = require("path");
|
export declare let certHook: string;
|
||||||
|
export declare let config: string;
|
||||||
|
export declare let letsencryptSh: string;
|
||||||
|
export declare let certDir: string;
|
||||||
|
8
dist/cert.paths.js
vendored
8
dist/cert.paths.js
vendored
@ -1,5 +1,9 @@
|
|||||||
"use strict";
|
"use strict";
|
||||||
require("typings-global");
|
require("typings-global");
|
||||||
exports.path = require("path");
|
var plugins = require("./cert.plugins");
|
||||||
|
exports.certHook = plugins.path.join(__dirname, "cert.hook.js");
|
||||||
|
exports.config = plugins.path.join(__dirname, "assets/config.json");
|
||||||
|
exports.letsencryptSh = plugins.path.join(__dirname, "assets/letsencrypt.sh");
|
||||||
|
exports.certDir = plugins.path.join(__dirname, "/assets/certs");
|
||||||
|
|
||||||
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNlcnQucGF0aHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLFFBQU8sZ0JBQWdCLENBQUMsQ0FBQTtBQUNWLFlBQUksV0FBVyxNQUFNLENBQUMsQ0FBQyIsImZpbGUiOiJjZXJ0LnBhdGhzLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFwidHlwaW5ncy1nbG9iYWxcIjtcbmV4cG9ydCBpbXBvcnQgcGF0aCA9IHJlcXVpcmUoXCJwYXRoXCIpO1xuXG4iXX0=
|
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNlcnQucGF0aHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLFFBQU8sZ0JBQWdCLENBQUMsQ0FBQTtBQUN4QixJQUFZLE9BQU8sV0FBTSxnQkFBZ0IsQ0FBQyxDQUFBO0FBRS9CLGdCQUFRLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFDLGNBQWMsQ0FBQyxDQUFDO0FBQ3ZELGNBQU0sR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUMsb0JBQW9CLENBQUMsQ0FBQztBQUMzRCxxQkFBYSxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBQyx1QkFBdUIsQ0FBQyxDQUFDO0FBQ3JFLGVBQU8sR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUMsZUFBZSxDQUFDLENBQUMiLCJmaWxlIjoiY2VydC5wYXRocy5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBcInR5cGluZ3MtZ2xvYmFsXCI7XG5pbXBvcnQgKiBhcyBwbHVnaW5zIGZyb20gXCIuL2NlcnQucGx1Z2luc1wiO1xuXG5leHBvcnQgbGV0IGNlcnRIb29rID0gcGx1Z2lucy5wYXRoLmpvaW4oX19kaXJuYW1lLFwiY2VydC5ob29rLmpzXCIpO1xuZXhwb3J0IGxldCBjb25maWcgPSBwbHVnaW5zLnBhdGguam9pbihfX2Rpcm5hbWUsXCJhc3NldHMvY29uZmlnLmpzb25cIik7XG5leHBvcnQgbGV0IGxldHNlbmNyeXB0U2ggPSBwbHVnaW5zLnBhdGguam9pbihfX2Rpcm5hbWUsXCJhc3NldHMvbGV0c2VuY3J5cHQuc2hcIik7XG5leHBvcnQgbGV0IGNlcnREaXIgPSBwbHVnaW5zLnBhdGguam9pbihfX2Rpcm5hbWUsXCIvYXNzZXRzL2NlcnRzXCIpOyJdfQ==
|
||||||
|
11
dist/cert.plugins.d.ts
vendored
11
dist/cert.plugins.d.ts
vendored
@ -0,0 +1,11 @@
|
|||||||
|
import "typings-global";
|
||||||
|
export import beautylog = require("beautylog");
|
||||||
|
export import cflare = require("cflare");
|
||||||
|
export declare let fs: any;
|
||||||
|
export import path = require("path");
|
||||||
|
export declare let q: any;
|
||||||
|
export declare let shelljs: any;
|
||||||
|
export import smartcli = require("smartcli");
|
||||||
|
export import smartfile = require("smartfile");
|
||||||
|
export import smartgit = require("smartgit");
|
||||||
|
export import smartstring = require("smartstring");
|
||||||
|
15
dist/cert.plugins.js
vendored
15
dist/cert.plugins.js
vendored
@ -1,3 +1,14 @@
|
|||||||
|
"use strict";
|
||||||
|
require("typings-global");
|
||||||
|
exports.beautylog = require("beautylog");
|
||||||
|
exports.cflare = require("cflare");
|
||||||
|
exports.fs = require("fs-extra");
|
||||||
|
exports.path = require("path");
|
||||||
|
exports.q = require("q");
|
||||||
|
exports.shelljs = require("shelljs");
|
||||||
|
exports.smartcli = require("smartcli");
|
||||||
|
exports.smartfile = require("smartfile");
|
||||||
|
exports.smartgit = require("smartgit");
|
||||||
|
exports.smartstring = require("smartstring");
|
||||||
|
|
||||||
|
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNlcnQucGx1Z2lucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsUUFBTyxnQkFBZ0IsQ0FBQyxDQUFBO0FBQ1YsaUJBQVMsV0FBVyxXQUFXLENBQUMsQ0FBQztBQUNqQyxjQUFNLFdBQVcsUUFBUSxDQUFDLENBQUM7QUFDOUIsVUFBRSxHQUFHLE9BQU8sQ0FBQyxVQUFVLENBQUMsQ0FBQztBQUN0QixZQUFJLFdBQVcsTUFBTSxDQUFDLENBQUM7QUFDMUIsU0FBQyxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQztBQUNqQixlQUFPLEdBQUcsT0FBTyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0FBQzFCLGdCQUFRLFdBQVcsVUFBVSxDQUFDLENBQUM7QUFDL0IsaUJBQVMsV0FBVyxXQUFXLENBQUMsQ0FBQztBQUNqQyxnQkFBUSxXQUFXLFVBQVUsQ0FBQyxDQUFDO0FBQy9CLG1CQUFXLFdBQVcsYUFBYSxDQUFDLENBQUMiLCJmaWxlIjoiY2VydC5wbHVnaW5zLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFwidHlwaW5ncy1nbG9iYWxcIjtcbmV4cG9ydCBpbXBvcnQgYmVhdXR5bG9nID0gcmVxdWlyZShcImJlYXV0eWxvZ1wiKTtcbmV4cG9ydCBpbXBvcnQgY2ZsYXJlID0gcmVxdWlyZShcImNmbGFyZVwiKTtcbmV4cG9ydCBsZXQgZnMgPSByZXF1aXJlKFwiZnMtZXh0cmFcIik7XG5leHBvcnQgaW1wb3J0IHBhdGggPSByZXF1aXJlKFwicGF0aFwiKTtcbmV4cG9ydCBsZXQgcSA9IHJlcXVpcmUoXCJxXCIpO1xuZXhwb3J0IGxldCBzaGVsbGpzID0gcmVxdWlyZShcInNoZWxsanNcIik7XG5leHBvcnQgaW1wb3J0IHNtYXJ0Y2xpID0gcmVxdWlyZShcInNtYXJ0Y2xpXCIpO1xuZXhwb3J0IGltcG9ydCBzbWFydGZpbGUgPSByZXF1aXJlKFwic21hcnRmaWxlXCIpO1xuZXhwb3J0IGltcG9ydCBzbWFydGdpdCA9IHJlcXVpcmUoXCJzbWFydGdpdFwiKTtcbmV4cG9ydCBpbXBvcnQgc21hcnRzdHJpbmcgPSByZXF1aXJlKFwic21hcnRzdHJpbmdcIik7XG5cbiJdfQ==
|
||||||
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsImZpbGUiOiJjZXJ0LnBsdWdpbnMuanMiLCJzb3VyY2VzQ29udGVudCI6W119
|
|
||||||
|
19
dist/index.d.ts
vendored
19
dist/index.d.ts
vendored
@ -1,18 +1,23 @@
|
|||||||
export declare class Cert {
|
export declare class Cert {
|
||||||
cfEmail: string;
|
private _cfEmail;
|
||||||
cfKey: string;
|
private _cfKey;
|
||||||
sslDir: string;
|
private _sslDir;
|
||||||
certificatesPresent: any;
|
certificatesPresent: Certificate[];
|
||||||
certificatesValid: any;
|
certificatesValid: Certificate[];
|
||||||
gitOriginRepo: any;
|
gitOriginRepo: any;
|
||||||
constructor(optionsArg: {
|
constructor(optionsArg: {
|
||||||
cfEmail: string;
|
cfEmail: string;
|
||||||
cfKey: string;
|
cfKey: string;
|
||||||
sslDir: string;
|
sslDir: string;
|
||||||
gitOriginRepo: string;
|
gitOriginRepo?: string;
|
||||||
});
|
});
|
||||||
getDomainCert(): void;
|
getDomainCert(domainNameArg: string, optionsArg?: {
|
||||||
|
force: boolean;
|
||||||
|
}): any;
|
||||||
}
|
}
|
||||||
export declare class Certificate {
|
export declare class Certificate {
|
||||||
|
domainName: string;
|
||||||
|
creationDate: Date;
|
||||||
|
expiryDate: Date;
|
||||||
constructor();
|
constructor();
|
||||||
}
|
}
|
||||||
|
58
dist/index.js
vendored
58
dist/index.js
vendored
File diff suppressed because one or more lines are too long
1
dist/install.d.ts
vendored
1
dist/install.d.ts
vendored
@ -0,0 +1 @@
|
|||||||
|
export declare let startInstall: () => any;
|
||||||
|
26
dist/install.js
vendored
26
dist/install.js
vendored
@ -1,10 +1,20 @@
|
|||||||
"use strict";
|
"use strict";
|
||||||
var beautylog = require("beautylog");
|
var plugins = require("./cert.plugins");
|
||||||
var path = require("path");
|
var paths = require("./cert.paths");
|
||||||
var smartfile = require("smartfile");
|
exports.startInstall = function () {
|
||||||
beautylog.info("installing letsencrypt.sh locally...");
|
var done = plugins.q.defer();
|
||||||
smartfile.remote.toFs("https://raw.githubusercontent.com/lukas2511/letsencrypt.sh/master/letsencrypt.sh", path.join(__dirname, "assets/", "le.sh")).then(function () {
|
plugins.beautylog.info("installing letsencrypt.sh locally...");
|
||||||
beautylog.success("Done!");
|
plugins.fs.ensureDir(plugins.path.join(__dirname, "assets/"));
|
||||||
});
|
plugins.smartfile.remote.toFs("https://raw.githubusercontent.com/lukas2511/letsencrypt.sh/master/letsencrypt.sh", paths.letsencryptSh).then(function () {
|
||||||
|
plugins.beautylog.success("Done!");
|
||||||
|
done.resolve();
|
||||||
|
});
|
||||||
|
return done.promise;
|
||||||
|
};
|
||||||
|
var smartcli = new plugins.smartcli.Smartcli();
|
||||||
|
smartcli.addCommand({
|
||||||
|
commandName: "install"
|
||||||
|
}).then(exports.startInstall);
|
||||||
|
smartcli.startParse();
|
||||||
|
|
||||||
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluc3RhbGwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLElBQVksU0FBUyxXQUFNLFdBQVcsQ0FBQyxDQUFBO0FBQ3ZDLElBQVksSUFBSSxXQUFNLE1BQU0sQ0FBQyxDQUFBO0FBQzdCLElBQVksU0FBUyxXQUFNLFdBQVcsQ0FBQyxDQUFBO0FBQ3ZDLFNBQVMsQ0FBQyxJQUFJLENBQUMsc0NBQXNDLENBQUMsQ0FBQztBQUN2RCxTQUFTLENBQUMsTUFBTSxDQUFDLElBQUksQ0FDakIsa0ZBQWtGLEVBQ2xGLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFDLFNBQVMsRUFBQyxPQUFPLENBQUMsQ0FDekMsQ0FBQyxJQUFJLENBQUM7SUFDSCxTQUFTLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0FBQy9CLENBQUMsQ0FBQyxDQUFDIiwiZmlsZSI6Imluc3RhbGwuanMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBiZWF1dHlsb2cgZnJvbSBcImJlYXV0eWxvZ1wiO1xuaW1wb3J0ICogYXMgcGF0aCBmcm9tIFwicGF0aFwiO1xuaW1wb3J0ICogYXMgc21hcnRmaWxlIGZyb20gXCJzbWFydGZpbGVcIjtcbmJlYXV0eWxvZy5pbmZvKFwiaW5zdGFsbGluZyBsZXRzZW5jcnlwdC5zaCBsb2NhbGx5Li4uXCIpO1xuc21hcnRmaWxlLnJlbW90ZS50b0ZzKFxuICAgIFwiaHR0cHM6Ly9yYXcuZ2l0aHVidXNlcmNvbnRlbnQuY29tL2x1a2FzMjUxMS9sZXRzZW5jcnlwdC5zaC9tYXN0ZXIvbGV0c2VuY3J5cHQuc2hcIixcbiAgICBwYXRoLmpvaW4oX19kaXJuYW1lLFwiYXNzZXRzL1wiLFwibGUuc2hcIilcbikudGhlbigoKSA9PiB7XG4gICAgYmVhdXR5bG9nLnN1Y2Nlc3MoXCJEb25lIVwiKTtcbn0pOyJdfQ==
|
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImluc3RhbGwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLElBQVksT0FBTyxXQUFNLGdCQUFnQixDQUFDLENBQUE7QUFDMUMsSUFBWSxLQUFLLFdBQU0sY0FBYyxDQUFDLENBQUE7QUFFM0Isb0JBQVksR0FBRztJQUN0QixJQUFJLElBQUksR0FBRyxPQUFPLENBQUMsQ0FBQyxDQUFDLEtBQUssRUFBRSxDQUFDO0lBQzdCLE9BQU8sQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLHNDQUFzQyxDQUFDLENBQUM7SUFFL0QsT0FBTyxDQUFDLEVBQUUsQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLFNBQVMsQ0FBQyxDQUFDLENBQUM7SUFDOUQsT0FBTyxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUN6QixrRkFBa0YsRUFDbEYsS0FBSyxDQUFDLGFBQWEsQ0FDdEIsQ0FBQyxJQUFJLENBQUM7UUFDSCxPQUFPLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUNuQyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDbkIsQ0FBQyxDQUFDLENBQUM7SUFDSCxNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQztBQUN4QixDQUFDLENBQUM7QUFFRixJQUFJLFFBQVEsR0FBRyxJQUFJLE9BQU8sQ0FBQyxRQUFRLENBQUMsUUFBUSxFQUFFLENBQUM7QUFDL0MsUUFBUSxDQUFDLFVBQVUsQ0FBQztJQUNoQixXQUFXLEVBQUMsU0FBUztDQUN4QixDQUFDLENBQUMsSUFBSSxDQUFDLG9CQUFZLENBQUMsQ0FBQztBQUN0QixRQUFRLENBQUMsVUFBVSxFQUFFLENBQUMiLCJmaWxlIjoiaW5zdGFsbC5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIHBsdWdpbnMgZnJvbSBcIi4vY2VydC5wbHVnaW5zXCI7XG5pbXBvcnQgKiBhcyBwYXRocyBmcm9tIFwiLi9jZXJ0LnBhdGhzXCI7XG5cbmV4cG9ydCBsZXQgc3RhcnRJbnN0YWxsID0gKCkgPT4ge1xuICAgIGxldCBkb25lID0gcGx1Z2lucy5xLmRlZmVyKCk7XG4gICAgcGx1Z2lucy5iZWF1dHlsb2cuaW5mbyhcImluc3RhbGxpbmcgbGV0c2VuY3J5cHQuc2ggbG9jYWxseS4uLlwiKTtcblxuICAgIHBsdWdpbnMuZnMuZW5zdXJlRGlyKHBsdWdpbnMucGF0aC5qb2luKF9fZGlybmFtZSwgXCJhc3NldHMvXCIpKTtcbiAgICBwbHVnaW5zLnNtYXJ0ZmlsZS5yZW1vdGUudG9GcyhcbiAgICAgICAgXCJodHRwczovL3Jhdy5naXRodWJ1c2VyY29udGVudC5jb20vbHVrYXMyNTExL2xldHNlbmNyeXB0LnNoL21hc3Rlci9sZXRzZW5jcnlwdC5zaFwiLFxuICAgICAgICBwYXRocy5sZXRzZW5jcnlwdFNoXG4gICAgKS50aGVuKCgpID0+IHtcbiAgICAgICAgcGx1Z2lucy5iZWF1dHlsb2cuc3VjY2VzcyhcIkRvbmUhXCIpO1xuICAgICAgICBkb25lLnJlc29sdmUoKTtcbiAgICB9KTtcbiAgICByZXR1cm4gZG9uZS5wcm9taXNlO1xufTtcblxubGV0IHNtYXJ0Y2xpID0gbmV3IHBsdWdpbnMuc21hcnRjbGkuU21hcnRjbGkoKTtcbnNtYXJ0Y2xpLmFkZENvbW1hbmQoe1xuICAgIGNvbW1hbmROYW1lOlwiaW5zdGFsbFwiXG59KS50aGVuKHN0YXJ0SW5zdGFsbCk7XG5zbWFydGNsaS5zdGFydFBhcnNlKCk7Il19
|
||||||
|
23
package.json
23
package.json
@ -1,10 +1,11 @@
|
|||||||
{
|
{
|
||||||
"name": "cert",
|
"name": "cert",
|
||||||
"version": "0.0.6",
|
"version": "0.0.10",
|
||||||
"description": "Easily obain SSL certificates from LetsEncrypt. Supports DNS-01 challenge. TypeScript ready.",
|
"description": "Easily obain SSL certificates from LetsEncrypt. Supports DNS-01 challenge. TypeScript ready.",
|
||||||
"main": "dist/index.js",
|
"main": "dist/index.js",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"test": "(npmts)"
|
"test": "(npmts)",
|
||||||
|
"install": "node dist/install.js install"
|
||||||
},
|
},
|
||||||
"repository": {
|
"repository": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
@ -24,14 +25,20 @@
|
|||||||
"homepage": "https://gitlab.com/pushrocks/cert#readme",
|
"homepage": "https://gitlab.com/pushrocks/cert#readme",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"beautylog": "^5.0.12",
|
"beautylog": "^5.0.12",
|
||||||
"cflare": "0.0.2",
|
"cflare": "0.0.9",
|
||||||
"letsencrypt": "^1.4.4",
|
"fs-extra": "^0.30.0",
|
||||||
"smartcli": "^1.0.2",
|
"q": "^1.4.1",
|
||||||
"smartfile": "^3.0.10",
|
"shelljs": "^0.7.0",
|
||||||
"smartgit": "0.0.10",
|
"smartcli": "^1.0.4",
|
||||||
|
"smartfile": "^4.0.8",
|
||||||
|
"smartgit": "0.1.0",
|
||||||
|
"smartstring": "^2.0.10",
|
||||||
"typings-global": "^1.0.3"
|
"typings-global": "^1.0.3"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"npmts-g": "^5.2.6"
|
"npmts-g": "^5.2.6",
|
||||||
|
"qenv": "^1.0.8",
|
||||||
|
"should": "^9.0.2",
|
||||||
|
"typings-test": "^1.0.1"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
2
test/test.d.ts
vendored
Normal file
2
test/test.d.ts
vendored
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
import "typings-test";
|
||||||
|
import "should";
|
37
test/test.js
Normal file
37
test/test.js
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
"use strict";
|
||||||
|
require("typings-test");
|
||||||
|
require("should");
|
||||||
|
var qenv_1 = require("qenv");
|
||||||
|
var path = require("path");
|
||||||
|
var install_1 = require("../dist/install");
|
||||||
|
var cert = require("../dist/index");
|
||||||
|
var testQenv = new qenv_1.Qenv(process.cwd(), process.cwd() + "/.nogit");
|
||||||
|
var testCert;
|
||||||
|
describe("cert", function () {
|
||||||
|
describe("install", function () {
|
||||||
|
it("should download letsencrypt.sh", function (done) {
|
||||||
|
this.timeout(5000);
|
||||||
|
install_1.startInstall().then(function () {
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
describe("Cert", function () {
|
||||||
|
it("should create a new Cert object from class", function () {
|
||||||
|
testCert = new cert.Cert({
|
||||||
|
cfEmail: process.env.CF_EMAIL,
|
||||||
|
cfKey: process.env.CF_KEY,
|
||||||
|
sslDir: path.join(process.cwd(), "test/assets")
|
||||||
|
});
|
||||||
|
testCert.should.be.instanceof(cert.Cert);
|
||||||
|
});
|
||||||
|
it("should get a valid certificate", function (done) {
|
||||||
|
this.timeout(120000);
|
||||||
|
testCert.getDomainCert("sub9.bleu.de").then(function () {
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLFFBQU8sY0FBYyxDQUFDLENBQUE7QUFDdEIsUUFBTyxRQUFRLENBQUMsQ0FBQTtBQUNoQixxQkFBbUIsTUFBTSxDQUFDLENBQUE7QUFDMUIsSUFBTyxJQUFJLFdBQVcsTUFBTSxDQUFDLENBQUM7QUFFOUIsd0JBQTJCLGlCQUFpQixDQUFDLENBQUE7QUFDN0MsSUFBWSxJQUFJLFdBQU0sZUFBZSxDQUFDLENBQUE7QUFHdEMsSUFBSSxRQUFRLEdBQUcsSUFBSSxXQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsRUFBRSxFQUFFLE9BQU8sQ0FBQyxHQUFHLEVBQUUsR0FBRyxTQUFTLENBQUMsQ0FBQztBQUVsRSxJQUFJLFFBQWtCLENBQUM7QUFFdkIsUUFBUSxDQUFDLE1BQU0sRUFBQztJQUNaLFFBQVEsQ0FBQyxTQUFTLEVBQUM7UUFDZixFQUFFLENBQUMsZ0NBQWdDLEVBQUMsVUFBUyxJQUFJO1lBQzdDLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUM7WUFDbkIsc0JBQVksRUFBRSxDQUFDLElBQUksQ0FBQztnQkFDaEIsSUFBSSxFQUFFLENBQUM7WUFDWCxDQUFDLENBQUMsQ0FBQTtRQUNOLENBQUMsQ0FBQyxDQUFBO0lBQ04sQ0FBQyxDQUFDLENBQUE7SUFDRixRQUFRLENBQUMsTUFBTSxFQUFDO1FBQ1osRUFBRSxDQUFDLDRDQUE0QyxFQUFDO1lBQzVDLFFBQVEsR0FBRyxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUM7Z0JBQ3JCLE9BQU8sRUFBRSxPQUFPLENBQUMsR0FBRyxDQUFDLFFBQVE7Z0JBQzdCLEtBQUssRUFBRSxPQUFPLENBQUMsR0FBRyxDQUFDLE1BQU07Z0JBQ3pCLE1BQU0sRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLEVBQUUsRUFBQyxhQUFhLENBQUM7YUFDakQsQ0FBQyxDQUFDO1lBQ0gsUUFBUSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUM3QyxDQUFDLENBQUMsQ0FBQTtRQUNGLEVBQUUsQ0FBQyxnQ0FBZ0MsRUFBQyxVQUFTLElBQUk7WUFDN0MsSUFBSSxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUNyQixRQUFRLENBQUMsYUFBYSxDQUFDLGNBQWMsQ0FBQyxDQUFDLElBQUksQ0FBQztnQkFDeEMsSUFBSSxFQUFFLENBQUM7WUFDWCxDQUFDLENBQUMsQ0FBQztRQUNQLENBQUMsQ0FBQyxDQUFBO0lBQ04sQ0FBQyxDQUFDLENBQUE7QUFDTixDQUFDLENBQUMsQ0FBQyIsImZpbGUiOiJ0ZXN0LmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFwidHlwaW5ncy10ZXN0XCI7XG5pbXBvcnQgXCJzaG91bGRcIjtcbmltcG9ydCB7UWVudn0gZnJvbSBcInFlbnZcIjtcbmltcG9ydCBwYXRoID0gcmVxdWlyZShcInBhdGhcIik7XG5cbmltcG9ydCB7c3RhcnRJbnN0YWxsfSBmcm9tIFwiLi4vZGlzdC9pbnN0YWxsXCI7XG5pbXBvcnQgKiBhcyBjZXJ0IGZyb20gXCIuLi9kaXN0L2luZGV4XCI7XG5cblxubGV0IHRlc3RRZW52ID0gbmV3IFFlbnYocHJvY2Vzcy5jd2QoKSwgcHJvY2Vzcy5jd2QoKSArIFwiLy5ub2dpdFwiKTtcblxubGV0IHRlc3RDZXJ0OmNlcnQuQ2VydDtcblxuZGVzY3JpYmUoXCJjZXJ0XCIsZnVuY3Rpb24oKXtcbiAgICBkZXNjcmliZShcImluc3RhbGxcIixmdW5jdGlvbigpe1xuICAgICAgICBpdChcInNob3VsZCBkb3dubG9hZCBsZXRzZW5jcnlwdC5zaFwiLGZ1bmN0aW9uKGRvbmUpe1xuICAgICAgICAgICAgdGhpcy50aW1lb3V0KDUwMDApO1xuICAgICAgICAgICAgc3RhcnRJbnN0YWxsKCkudGhlbigoKSA9PiB7XG4gICAgICAgICAgICAgICAgZG9uZSgpO1xuICAgICAgICAgICAgfSlcbiAgICAgICAgfSlcbiAgICB9KVxuICAgIGRlc2NyaWJlKFwiQ2VydFwiLGZ1bmN0aW9uKCl7XG4gICAgICAgIGl0KFwic2hvdWxkIGNyZWF0ZSBhIG5ldyBDZXJ0IG9iamVjdCBmcm9tIGNsYXNzXCIsZnVuY3Rpb24oKXtcbiAgICAgICAgICAgIHRlc3RDZXJ0ID0gbmV3IGNlcnQuQ2VydCh7XG4gICAgICAgICAgICAgICAgY2ZFbWFpbDogcHJvY2Vzcy5lbnYuQ0ZfRU1BSUwsXG4gICAgICAgICAgICAgICAgY2ZLZXk6IHByb2Nlc3MuZW52LkNGX0tFWSxcbiAgICAgICAgICAgICAgICBzc2xEaXI6IHBhdGguam9pbihwcm9jZXNzLmN3ZCgpLFwidGVzdC9hc3NldHNcIilcbiAgICAgICAgICAgIH0pO1xuICAgICAgICAgICAgdGVzdENlcnQuc2hvdWxkLmJlLmluc3RhbmNlb2YoY2VydC5DZXJ0KTtcbiAgICAgICAgfSlcbiAgICAgICAgaXQoXCJzaG91bGQgZ2V0IGEgdmFsaWQgY2VydGlmaWNhdGVcIixmdW5jdGlvbihkb25lKXtcbiAgICAgICAgICAgIHRoaXMudGltZW91dCgxMjAwMDApO1xuICAgICAgICAgICAgdGVzdENlcnQuZ2V0RG9tYWluQ2VydChcInN1YjkuYmxldS5kZVwiKS50aGVuKCgpID0+IHtcbiAgICAgICAgICAgICAgICBkb25lKCk7XG4gICAgICAgICAgICB9KTtcbiAgICAgICAgfSlcbiAgICB9KVxufSk7Il19
|
39
test/test.ts
Normal file
39
test/test.ts
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
import "typings-test";
|
||||||
|
import "should";
|
||||||
|
import {Qenv} from "qenv";
|
||||||
|
import path = require("path");
|
||||||
|
|
||||||
|
import {startInstall} from "../dist/install";
|
||||||
|
import * as cert from "../dist/index";
|
||||||
|
|
||||||
|
|
||||||
|
let testQenv = new Qenv(process.cwd(), process.cwd() + "/.nogit");
|
||||||
|
|
||||||
|
let testCert:cert.Cert;
|
||||||
|
|
||||||
|
describe("cert",function(){
|
||||||
|
describe("install",function(){
|
||||||
|
it("should download letsencrypt.sh",function(done){
|
||||||
|
this.timeout(5000);
|
||||||
|
startInstall().then(() => {
|
||||||
|
done();
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
describe("Cert",function(){
|
||||||
|
it("should create a new Cert object from class",function(){
|
||||||
|
testCert = new cert.Cert({
|
||||||
|
cfEmail: process.env.CF_EMAIL,
|
||||||
|
cfKey: process.env.CF_KEY,
|
||||||
|
sslDir: path.join(process.cwd(),"test/assets")
|
||||||
|
});
|
||||||
|
testCert.should.be.instanceof(cert.Cert);
|
||||||
|
})
|
||||||
|
it("should get a valid certificate",function(done){
|
||||||
|
this.timeout(120000);
|
||||||
|
testCert.getDomainCert("sub9.bleu.de").then(() => {
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
})
|
||||||
|
})
|
||||||
|
});
|
@ -1,2 +1,74 @@
|
|||||||
import * as smartcli from "smartcli";
|
#!/usr/bin/env node
|
||||||
import * as cflare from "cflare";
|
// the shebang line above makes sure this script will get interpreted by node
|
||||||
|
|
||||||
|
import "typings-global";
|
||||||
|
import * as plugins from "./cert.plugins";
|
||||||
|
import * as paths from "./cert.paths";
|
||||||
|
|
||||||
|
let smartcli = new plugins.smartcli.Smartcli();
|
||||||
|
|
||||||
|
let config = plugins.smartfile.fs.toObjectSync(paths.config);
|
||||||
|
let cflare = new plugins.cflare.CflareAccount();
|
||||||
|
cflare.auth({
|
||||||
|
email: config.cfEmail,
|
||||||
|
key: config.cfKey
|
||||||
|
});
|
||||||
|
|
||||||
|
let setChallenge = (domainNameArg: string, challengeArg: string) => {
|
||||||
|
let done = plugins.q.defer();
|
||||||
|
plugins.beautylog.log("setting challenge for " + domainNameArg);
|
||||||
|
cflare.createRecord(prefixName(domainNameArg), "TXT", challengeArg).then(() => {
|
||||||
|
plugins.beautylog.ok("Challenge has been set!");
|
||||||
|
plugins.beautylog.info("We need to cool down to let DNS propagate to edge locations!");
|
||||||
|
cooldown().then(() => {
|
||||||
|
done.resolve();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
return done.promise;
|
||||||
|
}
|
||||||
|
|
||||||
|
let cleanChallenge = (domainNameArg) => {
|
||||||
|
let done = plugins.q.defer();
|
||||||
|
plugins.beautylog.log("cleaning challenge for " + domainNameArg);
|
||||||
|
cflare.removeRecord(prefixName(domainNameArg), "TXT");
|
||||||
|
return done.promise;
|
||||||
|
}
|
||||||
|
|
||||||
|
let cooldown = () => {
|
||||||
|
let done = plugins.q.defer();
|
||||||
|
let cooldowntime = 40000;
|
||||||
|
let passedTime = 0;
|
||||||
|
plugins.beautylog.log("Cooling down! " + (cooldowntime/1000).toString() + " seconds left");
|
||||||
|
let coolDownCounter = () => {
|
||||||
|
setTimeout(() => {
|
||||||
|
if(cooldowntime <= passedTime){
|
||||||
|
plugins.beautylog.ok("Cooled down!");
|
||||||
|
done.resolve();
|
||||||
|
} else {
|
||||||
|
passedTime = passedTime + 5000;
|
||||||
|
plugins.beautylog.log("Cooling down! " + ((cooldowntime - passedTime)/1000).toString() + " seconds left");
|
||||||
|
coolDownCounter();
|
||||||
|
}
|
||||||
|
}, 5000);
|
||||||
|
}
|
||||||
|
coolDownCounter();
|
||||||
|
return done.promise;
|
||||||
|
}
|
||||||
|
|
||||||
|
let prefixName = (domainNameArg: string): string => {
|
||||||
|
return "_acme-challenge." + domainNameArg;
|
||||||
|
}
|
||||||
|
|
||||||
|
smartcli.addCommand({
|
||||||
|
commandName: "deploy_challenge"
|
||||||
|
}).then((argv) => {
|
||||||
|
setChallenge(argv._[1], argv._[3]);
|
||||||
|
});
|
||||||
|
|
||||||
|
smartcli.addCommand({
|
||||||
|
commandName: "clean_challenge"
|
||||||
|
}).then((argv) => {
|
||||||
|
cleanChallenge(argv._[1]);
|
||||||
|
});
|
||||||
|
|
||||||
|
smartcli.startParse();
|
||||||
|
@ -1,3 +1,7 @@
|
|||||||
import "typings-global";
|
import "typings-global";
|
||||||
export import path = require("path");
|
import * as plugins from "./cert.plugins";
|
||||||
|
|
||||||
|
export let certHook = plugins.path.join(__dirname,"cert.hook.js");
|
||||||
|
export let config = plugins.path.join(__dirname,"assets/config.json");
|
||||||
|
export let letsencryptSh = plugins.path.join(__dirname,"assets/letsencrypt.sh");
|
||||||
|
export let certDir = plugins.path.join(__dirname,"/assets/certs");
|
@ -0,0 +1,12 @@
|
|||||||
|
import "typings-global";
|
||||||
|
export import beautylog = require("beautylog");
|
||||||
|
export import cflare = require("cflare");
|
||||||
|
export let fs = require("fs-extra");
|
||||||
|
export import path = require("path");
|
||||||
|
export let q = require("q");
|
||||||
|
export let shelljs = require("shelljs");
|
||||||
|
export import smartcli = require("smartcli");
|
||||||
|
export import smartfile = require("smartfile");
|
||||||
|
export import smartgit = require("smartgit");
|
||||||
|
export import smartstring = require("smartstring");
|
||||||
|
|
||||||
|
99
ts/index.ts
99
ts/index.ts
@ -1,28 +1,95 @@
|
|||||||
|
import * as plugins from "./cert.plugins";
|
||||||
import * as paths from "./cert.paths";
|
import * as paths from "./cert.paths";
|
||||||
|
|
||||||
export class Cert {
|
export class Cert {
|
||||||
cfEmail:string;
|
private _cfEmail: string;
|
||||||
cfKey:string;
|
private _cfKey: string;
|
||||||
sslDir:string;
|
private _sslDir: string;
|
||||||
certificatesPresent;
|
certificatesPresent:Certificate[];
|
||||||
certificatesValid;
|
certificatesValid:Certificate[];
|
||||||
gitOriginRepo;
|
gitOriginRepo;
|
||||||
constructor(optionsArg:{
|
constructor(optionsArg: {
|
||||||
cfEmail:string,
|
cfEmail: string,
|
||||||
cfKey:string,
|
cfKey: string,
|
||||||
sslDir:string,
|
sslDir: string,
|
||||||
gitOriginRepo:string
|
gitOriginRepo?: string
|
||||||
}){
|
}) {
|
||||||
this.cfEmail = optionsArg.cfEmail;
|
this._cfEmail = optionsArg.cfEmail;
|
||||||
this.cfKey = optionsArg.cfKey;
|
this._cfKey = optionsArg.cfKey;
|
||||||
this.sslDir = optionsArg.sslDir;
|
this._sslDir = optionsArg.sslDir;
|
||||||
this.gitOriginRepo = optionsArg.gitOriginRepo;
|
this.gitOriginRepo = optionsArg.gitOriginRepo;
|
||||||
|
let config = {
|
||||||
|
cfEmail: this._cfEmail,
|
||||||
|
cfKey: this._cfKey
|
||||||
|
}
|
||||||
|
plugins.smartfile.memory.toFsSync(JSON.stringify(config),plugins.path.join(__dirname, "assets/config.json"));
|
||||||
|
};
|
||||||
|
getDomainCert(domainNameArg: string,optionsArg?:{force:boolean}) {
|
||||||
|
let done = plugins.q.defer();
|
||||||
|
if (!checkDomainsStillValid(domainNameArg) || optionsArg.force) {
|
||||||
|
plugins.shelljs.exec("chmod 700 " + paths.letsencryptSh);
|
||||||
|
plugins.shelljs.exec("chmod 700 " + paths.certHook);
|
||||||
|
plugins.shelljs.exec("bash -c \"" + paths.letsencryptSh + " -c -d " + domainNameArg + " -t dns-01 -k " + paths.certHook + " -o " + paths.certDir + "\"");
|
||||||
|
let fetchedCertsArray:string[] = plugins.smartfile.fs.listFoldersSync(paths.certDir);
|
||||||
|
if(fetchedCertsArray.indexOf(domainNameArg) != -1){
|
||||||
|
updateSslDirSync(this._sslDir,domainNameArg);
|
||||||
|
}
|
||||||
|
done.resolve();
|
||||||
|
} else {
|
||||||
|
plugins.beautylog.info("certificate for " + domainNameArg + " is still valid! Not fetching new one!");
|
||||||
|
done.resolve();
|
||||||
|
}
|
||||||
|
return done.promise;
|
||||||
};
|
};
|
||||||
getDomainCert(){};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export class Certificate {
|
export class Certificate {
|
||||||
constructor(){
|
domainName: string;
|
||||||
|
creationDate: Date;
|
||||||
|
expiryDate: Date;
|
||||||
|
constructor() {
|
||||||
|
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
interface certConfig {
|
||||||
|
domainName:string;
|
||||||
|
created:number;
|
||||||
|
expires:number;
|
||||||
|
}
|
||||||
|
|
||||||
|
let checkDomainsStillValid = (domainNameArg: string): boolean => {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
let updateSslDirSync = (sslDirArg:string,domainNameArg:string) => {
|
||||||
|
plugins.smartfile.fs.ensureDirSync(sslDirArg);
|
||||||
|
let domainCertFolder = plugins.path.join(paths.certDir,domainNameArg)
|
||||||
|
if(plugins.smartfile.fs.listFoldersSync(paths.certDir).indexOf(domainNameArg) != -1) {
|
||||||
|
plugins.smartfile.fs.copySync(
|
||||||
|
plugins.path.join(domainCertFolder,"fullchain.pem"),
|
||||||
|
plugins.path.join(sslDirArg,domainNameArg,"fullchain.pem")
|
||||||
|
);
|
||||||
|
plugins.smartfile.fs.copySync(
|
||||||
|
plugins.path.join(domainCertFolder,"privkey.pem"),
|
||||||
|
plugins.path.join(sslDirArg,domainNameArg,"privkey.pem")
|
||||||
|
);
|
||||||
|
// create cert config
|
||||||
|
let certRegex = /.*\-([0-9]*)\.pem/;
|
||||||
|
let certFileNameWithTime:string = plugins.smartfile.fs.listFilesSync(domainCertFolder,certRegex)[0];
|
||||||
|
let certTime = parseInt(certRegex.exec(certFileNameWithTime)[1]);
|
||||||
|
let certConfig:certConfig = {
|
||||||
|
domainName: domainNameArg,
|
||||||
|
created: certTime,
|
||||||
|
expires: certTime + 7776000
|
||||||
|
};
|
||||||
|
plugins.smartfile.memory.toFs(
|
||||||
|
JSON.stringify(certConfig),
|
||||||
|
plugins.path.join(sslDirArg,domainNameArg,"config.json")
|
||||||
|
);
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
let updateGitOrigin = () => {
|
||||||
|
|
||||||
|
}
|
@ -1,10 +1,23 @@
|
|||||||
import * as beautylog from "beautylog";
|
import * as plugins from "./cert.plugins";
|
||||||
import * as path from "path";
|
import * as paths from "./cert.paths";
|
||||||
import * as smartfile from "smartfile";
|
|
||||||
beautylog.info("installing letsencrypt.sh locally...");
|
export let startInstall = () => {
|
||||||
smartfile.remote.toFs(
|
let done = plugins.q.defer();
|
||||||
"https://raw.githubusercontent.com/lukas2511/letsencrypt.sh/master/letsencrypt.sh",
|
plugins.beautylog.info("installing letsencrypt.sh locally...");
|
||||||
path.join(__dirname,"assets/","le.sh")
|
|
||||||
).then(() => {
|
plugins.fs.ensureDir(plugins.path.join(__dirname, "assets/"));
|
||||||
beautylog.success("Done!");
|
plugins.smartfile.remote.toFs(
|
||||||
});
|
"https://raw.githubusercontent.com/lukas2511/letsencrypt.sh/master/letsencrypt.sh",
|
||||||
|
paths.letsencryptSh
|
||||||
|
).then(() => {
|
||||||
|
plugins.beautylog.success("Done!");
|
||||||
|
done.resolve();
|
||||||
|
});
|
||||||
|
return done.promise;
|
||||||
|
};
|
||||||
|
|
||||||
|
let smartcli = new plugins.smartcli.Smartcli();
|
||||||
|
smartcli.addCommand({
|
||||||
|
commandName:"install"
|
||||||
|
}).then(startInstall);
|
||||||
|
smartcli.startParse();
|
Reference in New Issue
Block a user