smartcert/dist/index.js

72 lines
11 KiB
JavaScript

"use strict";
var plugins = require("./cert.plugins");
var paths = require("./cert.paths");
var Cert = (function () {
function Cert(optionsArg) {
this._cfEmail = optionsArg.cfEmail;
this._cfKey = optionsArg.cfKey;
this._sslDir = optionsArg.sslDir;
this.gitOriginRepo = optionsArg.gitOriginRepo;
var config = {
cfEmail: this._cfEmail,
cfKey: this._cfKey
};
plugins.smartfile.memory.toFsSync(JSON.stringify(config), plugins.path.join(__dirname, "assets/config.json"));
}
;
Cert.prototype.getDomainCert = function (domainNameArg, optionsArg) {
var 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 + "\"");
var fetchedCertsArray = 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;
};
;
return Cert;
}());
exports.Cert = Cert;
var Certificate = (function () {
function Certificate() {
}
;
return Certificate;
}());
exports.Certificate = Certificate;
var checkDomainsStillValid = function (domainNameArg) {
return false;
};
var updateSslDirSync = function (sslDirArg, domainNameArg) {
plugins.smartfile.fs.ensureDirSync(sslDirArg);
var 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
var certRegex = /.*\-([0-9]*)\.pem/;
var certFileNameWithTime = plugins.smartfile.fs.listFilesSync(domainCertFolder, certRegex)[0];
var certTime = parseInt(certRegex.exec(certFileNameWithTime)[1]);
var certConfig = {
domainName: domainNameArg,
created: certTime,
expires: certTime + 7776000
};
plugins.smartfile.memory.toFs(JSON.stringify(certConfig), plugins.path.join(sslDirArg, domainNameArg, "config.json"));
}
;
};
var updateGitOrigin = function () {
};
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["index.ts"],"names":[],"mappings":"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","file":"index.js","sourcesContent":["import * as plugins from \"./cert.plugins\";\nimport * as paths from \"./cert.paths\";\n\nexport class Cert {\n    private _cfEmail: string;\n    private _cfKey: string;\n    private _sslDir: string;\n    certificatesPresent:Certificate[];\n    certificatesValid:Certificate[];\n    gitOriginRepo;\n    constructor(optionsArg: {\n        cfEmail: string,\n        cfKey: string,\n        sslDir: string,\n        gitOriginRepo?: string\n    }) {\n        this._cfEmail = optionsArg.cfEmail;\n        this._cfKey = optionsArg.cfKey;\n        this._sslDir = optionsArg.sslDir;\n        this.gitOriginRepo = optionsArg.gitOriginRepo;\n        let config = {\n            cfEmail: this._cfEmail,\n            cfKey: this._cfKey\n        }\n        plugins.smartfile.memory.toFsSync(JSON.stringify(config),plugins.path.join(__dirname, \"assets/config.json\"));\n    };\n    getDomainCert(domainNameArg: string,optionsArg?:{force:boolean}) {\n        let done = plugins.q.defer();\n        if (!checkDomainsStillValid(domainNameArg) || optionsArg.force) {\n            plugins.shelljs.exec(\"chmod 700 \" + paths.letsencryptSh);\n            plugins.shelljs.exec(\"chmod 700 \" + paths.certHook);\n            plugins.shelljs.exec(\"bash -c \\\"\" + paths.letsencryptSh + \" -c -d \" + domainNameArg + \" -t dns-01 -k \" + paths.certHook + \" -o \" + paths.certDir + \"\\\"\");\n            let fetchedCertsArray:string[] = plugins.smartfile.fs.listFoldersSync(paths.certDir);\n            if(fetchedCertsArray.indexOf(domainNameArg) != -1){\n                updateSslDirSync(this._sslDir,domainNameArg);\n            }\n            done.resolve();\n        } else {\n            plugins.beautylog.info(\"certificate for \" + domainNameArg + \" is still valid! Not fetching new one!\");\n            done.resolve();\n        }\n        return done.promise;\n    };\n}\n\nexport class Certificate {\n    domainName: string;\n    creationDate: Date;\n    expiryDate: Date;\n    constructor() {\n\n    };\n}\n\ninterface certConfig {\n    domainName:string;\n    created:number;\n    expires:number;\n}\n\nlet checkDomainsStillValid = (domainNameArg: string): boolean => {\n    return false;\n}\n\nlet updateSslDirSync = (sslDirArg:string,domainNameArg:string) => {\n    plugins.smartfile.fs.ensureDirSync(sslDirArg);\n    let domainCertFolder = plugins.path.join(paths.certDir,domainNameArg)\n    if(plugins.smartfile.fs.listFoldersSync(paths.certDir).indexOf(domainNameArg) != -1) {\n        plugins.smartfile.fs.copySync(\n            plugins.path.join(domainCertFolder,\"fullchain.pem\"),\n            plugins.path.join(sslDirArg,domainNameArg,\"fullchain.pem\")\n        );\n        plugins.smartfile.fs.copySync(\n            plugins.path.join(domainCertFolder,\"privkey.pem\"),\n            plugins.path.join(sslDirArg,domainNameArg,\"privkey.pem\")\n        );\n        // create cert config\n        let certRegex = /.*\\-([0-9]*)\\.pem/;\n        let certFileNameWithTime:string = plugins.smartfile.fs.listFilesSync(domainCertFolder,certRegex)[0];\n        let certTime = parseInt(certRegex.exec(certFileNameWithTime)[1]);\n        let certConfig:certConfig = {\n            domainName: domainNameArg,\n            created: certTime,\n            expires: certTime + 7776000\n        };\n        plugins.smartfile.memory.toFs(\n            JSON.stringify(certConfig),\n            plugins.path.join(sslDirArg,domainNameArg,\"config.json\")\n        );\n    };\n}\n\nlet updateGitOrigin = () => {\n\n}"]}