Compare commits
92 Commits
Author | SHA1 | Date | |
---|---|---|---|
eec249d68f | |||
0f4a5b0cc1 | |||
20c23751a4 | |||
6aaae7683b | |||
826ae9f157 | |||
9dbeef0ed2 | |||
53f6daa5d5 | |||
9ee5cd2a3d | |||
13c27bb71e | |||
2be54dd505 | |||
2c5af1840e | |||
e5b75014af | |||
82f3b4bd7d | |||
4186e77ca0 | |||
6a05c0087f | |||
4206c9bc8a | |||
0aa6966dc1 | |||
5bbd773460 | |||
2c81f8b492 | |||
0fe7d586cf | |||
a4c8b789ad | |||
b4378e305a | |||
5ff0980908 | |||
e60257d761 | |||
e94f0edafb | |||
c417d96e48 | |||
c5b1dbb46e | |||
893a2e2709 | |||
01f0dc6b20 | |||
736a42066c | |||
44403863d1 | |||
5be21fa100 | |||
042167c01e | |||
db38d038ef | |||
a4d8a46360 | |||
84e5c10129 | |||
98a2871f08 | |||
9bb847210a | |||
91d4ba5715 | |||
3ee2988964 | |||
221f1f6237 | |||
0a6fbf588e | |||
1a8546af6e | |||
9e01bdb8e2 | |||
33833fbc6c | |||
97b5678fe4 | |||
9b96984413 | |||
0de412b842 | |||
64bcce9e23 | |||
390812ec33 | |||
a672bb920f | |||
c3fabb6107 | |||
b4ebdbae47 | |||
c55d2dcf10 | |||
7274d5ea8a | |||
1ec733c2a9 | |||
3ef14d8ac7 | |||
f332bf95fe | |||
6acad8a306 | |||
6ae672f707 | |||
3d263e2181 | |||
85639f29af | |||
85448a21fc | |||
3b85c4a37e | |||
67dd650dce | |||
92eaf5f19a | |||
fcf9a61b1d | |||
fbd258a876 | |||
c65b8fc1af | |||
b7b588d713 | |||
00d672c135 | |||
6a1e778b49 | |||
4cfb26f62f | |||
7ba3ad0b21 | |||
cd93ec2560 | |||
ede884930e | |||
1049920efd | |||
b7a34403c5 | |||
987e19372a | |||
0b97aaee91 | |||
b87ca1fa03 | |||
824f872fa5 | |||
80248c77d0 | |||
f592150646 | |||
f24652936a | |||
79af6c4a68 | |||
fafc757930 | |||
ead5e1a7bd | |||
ad57be180a | |||
7cc4ce02c9 | |||
70dace595b | |||
9b043d0e0d |
@ -1,4 +1,4 @@
|
|||||||
image: hosttoday/ht-docker-node:npmts
|
image: hosttoday/ht-docker-node:npmci
|
||||||
|
|
||||||
stages:
|
stages:
|
||||||
- test
|
- test
|
||||||
@ -10,17 +10,20 @@ before_script:
|
|||||||
testSTABLE:
|
testSTABLE:
|
||||||
stage: test
|
stage: test
|
||||||
script:
|
script:
|
||||||
- npmci test stable
|
- npmci npm install
|
||||||
|
- npmci npm test stable
|
||||||
only:
|
only:
|
||||||
- tags
|
- tags
|
||||||
tags:
|
tags:
|
||||||
- docker
|
- docker
|
||||||
|
- notpriv
|
||||||
|
|
||||||
release:
|
release:
|
||||||
stage: release
|
stage: release
|
||||||
environment: npmjs-com_registry
|
environment: npmjs-com_registry
|
||||||
script:
|
script:
|
||||||
- npmci publish
|
- npmci npm prepare
|
||||||
|
- npmci npm publish
|
||||||
only:
|
only:
|
||||||
- tags
|
- tags
|
||||||
tags:
|
tags:
|
||||||
|
25
README.md
25
README.md
@ -1,27 +1,30 @@
|
|||||||
# smartnginx
|
# smartnginx
|
||||||
|
|
||||||
control nginx from node, TypeScript ready
|
control nginx from node, TypeScript ready
|
||||||
|
|
||||||
## Status
|
## Status
|
||||||
|
|
||||||
[](https://gitlab.com/pushrocks/smartnginx/commits/master)
|
[](https://gitlab.com/pushrocks/smartnginx/commits/master)
|
||||||
|
|
||||||
## Features
|
## Features
|
||||||
|
|
||||||
* easy reverse configuration
|
- easy reverse configuration
|
||||||
* automatic letsencrypt DNS01 challenge based ssl cert generation
|
- automatic letsencrypt DNS01 challenge based ssl cert generation
|
||||||
* automatic nginx process handling zero-downtime config reloading
|
- automatic nginx process handling zero-downtime config reloading
|
||||||
* works in Docker environements
|
- works in Docker environements
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
|
|
||||||
We recommend the use of TypeScript! :)
|
We recommend the use of TypeScript! :)
|
||||||
|
|
||||||
```typescript
|
```typescript
|
||||||
import * as smartnginx from "smartnginx";
|
import * as smartnginx from 'smartnginx';
|
||||||
myNginxConfig = new smartnginx.NginxConfig();
|
const smartnginxInstance = new smartnginx.SmartNginx();
|
||||||
myNginxZone = new smartnginx.NginxZone({
|
myNginxHost = new smartnginx.NginxHost({
|
||||||
zoneName:"some.example.com",
|
hostName: 'some.example.com',
|
||||||
type:"reverseProxy",
|
type: 'reverseProxy',
|
||||||
destination:"192.192.192.192" // some destination IP
|
destination: '192.192.192.192' // some destination IP
|
||||||
});
|
});
|
||||||
myNginxConfig.addZone(myNginxZone); // adds the zone to the config
|
myNginxConfig.addZone(myNginxZone); // adds the zone to the config
|
||||||
myNginxConfig.deploy(); // deploys the referenced NginxConfig and gracefully reloads it
|
myNginxConfig.deploy(); // deploys the referenced NginxConfig and gracefully reloads it
|
||||||
```
|
```
|
||||||
|
3
dist/index.d.ts
vendored
3
dist/index.d.ts
vendored
@ -1,3 +0,0 @@
|
|||||||
export * from "./smartnginx.classes.nginxconfig";
|
|
||||||
export * from "./smartnginx.classes.nginxprocess";
|
|
||||||
export * from "./smartnginx.classes.nginxhost";
|
|
9
dist/index.js
vendored
9
dist/index.js
vendored
@ -1,9 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
function __export(m) {
|
|
||||||
for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p];
|
|
||||||
}
|
|
||||||
// classes
|
|
||||||
__export(require("./smartnginx.classes.nginxconfig"));
|
|
||||||
__export(require("./smartnginx.classes.nginxprocess"));
|
|
||||||
__export(require("./smartnginx.classes.nginxhost"));
|
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7O0FBRUEsVUFBVTtBQUNWLGlCQUFjLGtDQUFrQyxDQUFDLEVBQUE7QUFDakQsaUJBQWMsbUNBQW1DLENBQUMsRUFBQTtBQUNsRCxpQkFBYyxnQ0FBZ0MsQ0FBQyxFQUFBIn0=
|
|
19
dist/smartnginx.classes.nginxconfig.d.ts
vendored
19
dist/smartnginx.classes.nginxconfig.d.ts
vendored
@ -1,19 +0,0 @@
|
|||||||
/// <reference types="q" />
|
|
||||||
import * as plugins from "./smartnginx.plugins";
|
|
||||||
import { NginxHost } from "./smartnginx.classes.nginxhost";
|
|
||||||
import { NginxProcess } from "./smartnginx.classes.nginxprocess";
|
|
||||||
/**
|
|
||||||
* main class that manages a NginxInstance
|
|
||||||
*/
|
|
||||||
export declare class NginxConfig {
|
|
||||||
hosts: NginxHost[];
|
|
||||||
cert: plugins.cert.Cert;
|
|
||||||
nginxProcess: NginxProcess;
|
|
||||||
isDeployed: boolean;
|
|
||||||
constructor(optionsArg: plugins.cert.ICertConstructorOptions);
|
|
||||||
addHost(nginxHostArg: NginxHost): void;
|
|
||||||
listHosts(): NginxHost[];
|
|
||||||
removeHost(nginxHostArg: NginxHost): void;
|
|
||||||
clean(): void;
|
|
||||||
deploy(): plugins.q.Promise<{}>;
|
|
||||||
}
|
|
71
dist/smartnginx.classes.nginxconfig.js
vendored
71
dist/smartnginx.classes.nginxconfig.js
vendored
@ -1,71 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
const plugins = require("./smartnginx.plugins");
|
|
||||||
const paths = require("./smartnginx.paths");
|
|
||||||
const snippets = require("./smartnginx.snippets");
|
|
||||||
const smartnginx_classes_nginxprocess_1 = require("./smartnginx.classes.nginxprocess");
|
|
||||||
let allConfigs = [];
|
|
||||||
/**
|
|
||||||
* main class that manages a NginxInstance
|
|
||||||
*/
|
|
||||||
class NginxConfig {
|
|
||||||
constructor(optionsArg) {
|
|
||||||
this.hosts = [];
|
|
||||||
this.nginxProcess = new smartnginx_classes_nginxprocess_1.NginxProcess(this);
|
|
||||||
this.isDeployed = false;
|
|
||||||
this.cert = new plugins.cert.Cert({
|
|
||||||
cfEmail: optionsArg.cfEmail,
|
|
||||||
cfKey: optionsArg.cfKey,
|
|
||||||
sslDir: paths.nginxCertBase,
|
|
||||||
gitOriginRepo: optionsArg.gitOriginRepo,
|
|
||||||
testMode: optionsArg.testMode
|
|
||||||
});
|
|
||||||
}
|
|
||||||
;
|
|
||||||
// interact with Hosts
|
|
||||||
addHost(nginxHostArg) {
|
|
||||||
this.hosts.push(nginxHostArg);
|
|
||||||
}
|
|
||||||
listHosts() {
|
|
||||||
return this.hosts;
|
|
||||||
}
|
|
||||||
;
|
|
||||||
removeHost(nginxHostArg) {
|
|
||||||
}
|
|
||||||
clean() {
|
|
||||||
this.hosts = [];
|
|
||||||
}
|
|
||||||
// handle deployment of hosts
|
|
||||||
deploy() {
|
|
||||||
let done = plugins.q.defer();
|
|
||||||
plugins.smartfile.fs.ensureDirSync(paths.nginxConfigBase);
|
|
||||||
plugins.smartfile.fs.ensureDirSync(paths.nginxHostFileBase);
|
|
||||||
plugins.smartfile.fs.ensureDirSync(paths.nginxCertBase);
|
|
||||||
for (let config of allConfigs) {
|
|
||||||
config.isDeployed = false;
|
|
||||||
}
|
|
||||||
;
|
|
||||||
this.isDeployed = true;
|
|
||||||
// write base config
|
|
||||||
plugins.smartfile.memory.toFsSync(snippets.getBaseConfigString(), paths.nginxConfFile);
|
|
||||||
// deploy hosts
|
|
||||||
let promiseArray = [];
|
|
||||||
for (let host of this.hosts) {
|
|
||||||
let hostDeployedPromise = host.deploy(this.cert);
|
|
||||||
hostDeployedPromise.then(() => {
|
|
||||||
plugins.beautylog.info(`Host ${host.hostName} deployed!`);
|
|
||||||
this.nginxProcess.reloadConfig();
|
|
||||||
});
|
|
||||||
promiseArray.push(hostDeployedPromise);
|
|
||||||
}
|
|
||||||
;
|
|
||||||
plugins.q.all(promiseArray)
|
|
||||||
.then(() => {
|
|
||||||
done.resolve();
|
|
||||||
});
|
|
||||||
return done.promise;
|
|
||||||
}
|
|
||||||
;
|
|
||||||
}
|
|
||||||
exports.NginxConfig = NginxConfig;
|
|
||||||
;
|
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRuZ2lueC5jbGFzc2VzLm5naW54Y29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvc21hcnRuZ2lueC5jbGFzc2VzLm5naW54Y29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxNQUFZLE9BQU8sV0FBTSxzQkFBc0IsQ0FBQyxDQUFBO0FBQ2hELE1BQVksS0FBSyxXQUFNLG9CQUFvQixDQUFDLENBQUE7QUFDNUMsTUFBWSxRQUFRLFdBQU0sdUJBQXVCLENBQUMsQ0FBQTtBQUVsRCxrREFBNkIsbUNBQW1DLENBQUMsQ0FBQTtBQUNqRSxJQUFJLFVBQVUsR0FBa0IsRUFBRSxDQUFDO0FBRW5DOztHQUVHO0FBQ0g7SUFLSSxZQUFZLFVBQWdEO1FBSjVELFVBQUssR0FBZ0IsRUFBRSxDQUFDO1FBRXhCLGlCQUFZLEdBQWlCLElBQUksOENBQVksQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNwRCxlQUFVLEdBQVksS0FBSyxDQUFDO1FBRXhCLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQztZQUM5QixPQUFPLEVBQUUsVUFBVSxDQUFDLE9BQU87WUFDM0IsS0FBSyxFQUFFLFVBQVUsQ0FBQyxLQUFLO1lBQ3ZCLE1BQU0sRUFBRSxLQUFLLENBQUMsYUFBYTtZQUMzQixhQUFhLEVBQUUsVUFBVSxDQUFDLGFBQWE7WUFDdkMsUUFBUSxFQUFFLFVBQVUsQ0FBQyxRQUFRO1NBQ2hDLENBQUMsQ0FBQztJQUNQLENBQUM7O0lBRUQsc0JBQXNCO0lBQ3RCLE9BQU8sQ0FBQyxZQUF1QjtRQUMzQixJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUNsQyxDQUFDO0lBQ0QsU0FBUztRQUNMLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDO0lBQ3RCLENBQUM7O0lBQ0QsVUFBVSxDQUFDLFlBQXVCO0lBRWxDLENBQUM7SUFDRCxLQUFLO1FBQ0QsSUFBSSxDQUFDLEtBQUssR0FBRyxFQUFFLENBQUM7SUFDcEIsQ0FBQztJQUNELDZCQUE2QjtJQUM3QixNQUFNO1FBQ0YsSUFBSSxJQUFJLEdBQUcsT0FBTyxDQUFDLENBQUMsQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUM3QixPQUFPLENBQUMsU0FBUyxDQUFDLEVBQUUsQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDLGVBQWUsQ0FBQyxDQUFDO1FBQzFELE9BQU8sQ0FBQyxTQUFTLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsaUJBQWlCLENBQUMsQ0FBQztRQUM1RCxPQUFPLENBQUMsU0FBUyxDQUFDLEVBQUUsQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQ3hELEdBQUcsQ0FBQyxDQUFDLElBQUksTUFBTSxJQUFJLFVBQVUsQ0FBQyxDQUFDLENBQUM7WUFDNUIsTUFBTSxDQUFDLFVBQVUsR0FBRyxLQUFLLENBQUM7UUFDOUIsQ0FBQztRQUFBLENBQUM7UUFDRixJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQztRQUN2QixvQkFBb0I7UUFDcEIsT0FBTyxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUM3QixRQUFRLENBQUMsbUJBQW1CLEVBQUUsRUFDOUIsS0FBSyxDQUFDLGFBQWEsQ0FDdEIsQ0FBQztRQUNGLGVBQWU7UUFDZixJQUFJLFlBQVksR0FBRyxFQUFFLENBQUM7UUFDdEIsR0FBRyxDQUFDLENBQUMsSUFBSSxJQUFJLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7WUFDMUIsSUFBSSxtQkFBbUIsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUNqRCxtQkFBbUIsQ0FBQyxJQUFJLENBQUM7Z0JBQ3JCLE9BQU8sQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFFBQVEsSUFBSSxDQUFDLFFBQVEsWUFBWSxDQUFDLENBQUM7Z0JBQzFELElBQUksQ0FBQyxZQUFZLENBQUMsWUFBWSxFQUFFLENBQUM7WUFDckMsQ0FBQyxDQUFDLENBQUM7WUFDSCxZQUFZLENBQUMsSUFBSSxDQUFDLG1CQUFtQixDQUFDLENBQUM7UUFDM0MsQ0FBQztRQUFBLENBQUM7UUFDRixPQUFPLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxZQUFZLENBQUM7YUFDdEIsSUFBSSxDQUFDO1lBQ0YsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQ25CLENBQUMsQ0FBQyxDQUFDO1FBRVAsTUFBTSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUM7SUFDeEIsQ0FBQzs7QUFDTCxDQUFDO0FBNURZLG1CQUFXLGNBNER2QixDQUFBO0FBQUEsQ0FBQyJ9
|
|
25
dist/smartnginx.classes.nginxhost.d.ts
vendored
25
dist/smartnginx.classes.nginxhost.d.ts
vendored
@ -1,25 +0,0 @@
|
|||||||
/// <reference types="q" />
|
|
||||||
import * as plugins from "./smartnginx.plugins";
|
|
||||||
/**
|
|
||||||
* the host config data that NginxHost needs to create a valid instance
|
|
||||||
*/
|
|
||||||
export interface IHostConfigData {
|
|
||||||
hostName: string;
|
|
||||||
type: hostTypes;
|
|
||||||
destination: string;
|
|
||||||
}
|
|
||||||
export declare enum hostTypes {
|
|
||||||
reverseProxy = 0,
|
|
||||||
static = 1,
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* manages a single nginx host
|
|
||||||
*/
|
|
||||||
export declare class NginxHost {
|
|
||||||
hostName: string;
|
|
||||||
type: hostTypes;
|
|
||||||
destination: string;
|
|
||||||
configString: string;
|
|
||||||
constructor(optionsArg: IHostConfigData);
|
|
||||||
deploy(certInstanceArg: plugins.cert.Cert): plugins.q.Promise<{}>;
|
|
||||||
}
|
|
35
dist/smartnginx.classes.nginxhost.js
vendored
35
dist/smartnginx.classes.nginxhost.js
vendored
@ -1,35 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
const plugins = require("./smartnginx.plugins");
|
|
||||||
const paths = require("./smartnginx.paths");
|
|
||||||
const snippets = require("./smartnginx.snippets");
|
|
||||||
(function (hostTypes) {
|
|
||||||
hostTypes[hostTypes["reverseProxy"] = 0] = "reverseProxy";
|
|
||||||
hostTypes[hostTypes["static"] = 1] = "static";
|
|
||||||
})(exports.hostTypes || (exports.hostTypes = {}));
|
|
||||||
var hostTypes = exports.hostTypes;
|
|
||||||
/**
|
|
||||||
* manages a single nginx host
|
|
||||||
*/
|
|
||||||
class NginxHost {
|
|
||||||
constructor(optionsArg) {
|
|
||||||
this.hostName = optionsArg.hostName;
|
|
||||||
this.type = optionsArg.type;
|
|
||||||
this.destination = optionsArg.destination;
|
|
||||||
this.configString = snippets.getHostConfigString(optionsArg.hostName, optionsArg.destination);
|
|
||||||
}
|
|
||||||
;
|
|
||||||
deploy(certInstanceArg) {
|
|
||||||
let done = plugins.q.defer();
|
|
||||||
let filePath = plugins.path.join(paths.nginxHostFileBase, this.hostName + ".conf");
|
|
||||||
// writeConfig
|
|
||||||
plugins.smartfile.memory.toFsSync(this.configString, filePath);
|
|
||||||
// get cert
|
|
||||||
certInstanceArg.getDomainCert(this.hostName)
|
|
||||||
.then(done.resolve);
|
|
||||||
return done.promise;
|
|
||||||
}
|
|
||||||
;
|
|
||||||
}
|
|
||||||
exports.NginxHost = NginxHost;
|
|
||||||
;
|
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRuZ2lueC5jbGFzc2VzLm5naW54aG9zdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL3NtYXJ0bmdpbnguY2xhc3Nlcy5uZ2lueGhvc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE1BQVksT0FBTyxXQUFNLHNCQUFzQixDQUFDLENBQUE7QUFDaEQsTUFBWSxLQUFLLFdBQU0sb0JBQW9CLENBQUMsQ0FBQTtBQUM1QyxNQUFZLFFBQVEsV0FBTSx1QkFLMUIsQ0FBQyxDQUxnRDtBQVdqRCxXQUFZLFNBQVM7SUFDakIseURBQVksQ0FBQTtJQUNaLDZDQUFNLENBQUE7QUFDVixDQUFDLEVBSFcsaUJBQVMsS0FBVCxpQkFBUyxRQUdwQjtBQUhELElBQVksU0FBUyxHQUFULGlCQUdYLENBQUE7QUFFRDs7R0FFRztBQUNIO0lBS0ksWUFBWSxVQUEwQjtRQUNsQyxJQUFJLENBQUMsUUFBUSxHQUFHLFVBQVUsQ0FBQyxRQUFRLENBQUM7UUFDcEMsSUFBSSxDQUFDLElBQUksR0FBRyxVQUFVLENBQUMsSUFBSSxDQUFDO1FBQzVCLElBQUksQ0FBQyxXQUFXLEdBQUcsVUFBVSxDQUFDLFdBQVcsQ0FBQztRQUMxQyxJQUFJLENBQUMsWUFBWSxHQUFHLFFBQVEsQ0FBQyxtQkFBbUIsQ0FBQyxVQUFVLENBQUMsUUFBUSxFQUFFLFVBQVUsQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUNsRyxDQUFDOztJQUNELE1BQU0sQ0FBQyxlQUFrQztRQUNyQyxJQUFJLElBQUksR0FBRyxPQUFPLENBQUMsQ0FBQyxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQzdCLElBQUksUUFBUSxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxpQkFBaUIsRUFBRSxJQUFJLENBQUMsUUFBUSxHQUFHLE9BQU8sQ0FBQyxDQUFDO1FBQ25GLGNBQWM7UUFDZCxPQUFPLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFlBQVksRUFBRSxRQUFRLENBQUMsQ0FBQztRQUMvRCxXQUFXO1FBQ1gsZUFBZSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDO2FBQ3ZDLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDeEIsTUFBTSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUM7SUFDeEIsQ0FBQzs7QUFDTCxDQUFDO0FBckJZLGlCQUFTLFlBcUJyQixDQUFBO0FBQUEsQ0FBQyJ9
|
|
29
dist/smartnginx.classes.nginxprocess.d.ts
vendored
29
dist/smartnginx.classes.nginxprocess.d.ts
vendored
@ -1,29 +0,0 @@
|
|||||||
/// <reference types="node" />
|
|
||||||
/// <reference types="q" />
|
|
||||||
import * as plugins from "./smartnginx.plugins";
|
|
||||||
import { NginxConfig } from "./smartnginx.classes.nginxconfig";
|
|
||||||
/**
|
|
||||||
* manages a nginxprocess for an NginxConfig
|
|
||||||
*/
|
|
||||||
export declare class NginxProcess {
|
|
||||||
started: boolean;
|
|
||||||
nginxConfig: NginxConfig;
|
|
||||||
nginxChildProcess: plugins.childProcess.ChildProcess;
|
|
||||||
constructor(nginxConfigArg: any);
|
|
||||||
/**
|
|
||||||
* start nginx
|
|
||||||
*/
|
|
||||||
start(): plugins.q.Promise<{}>;
|
|
||||||
/**
|
|
||||||
* reload config
|
|
||||||
*/
|
|
||||||
reloadConfig(): plugins.q.Promise<{}>;
|
|
||||||
/**
|
|
||||||
* stop the nginx instance
|
|
||||||
*/
|
|
||||||
stop(): plugins.q.Promise<{}>;
|
|
||||||
/**
|
|
||||||
* checks if nginx is in path
|
|
||||||
*/
|
|
||||||
check(): boolean;
|
|
||||||
}
|
|
79
dist/smartnginx.classes.nginxprocess.js
vendored
79
dist/smartnginx.classes.nginxprocess.js
vendored
@ -1,79 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
const plugins = require("./smartnginx.plugins");
|
|
||||||
const paths = require("./smartnginx.paths");
|
|
||||||
/**
|
|
||||||
* manages a nginxprocess for an NginxConfig
|
|
||||||
*/
|
|
||||||
class NginxProcess {
|
|
||||||
constructor(nginxConfigArg) {
|
|
||||||
this.started = false;
|
|
||||||
this.nginxConfig = nginxConfigArg;
|
|
||||||
}
|
|
||||||
;
|
|
||||||
/**
|
|
||||||
* start nginx
|
|
||||||
*/
|
|
||||||
start() {
|
|
||||||
let done = plugins.q.defer();
|
|
||||||
if (typeof this.nginxChildProcess == "undefined") {
|
|
||||||
this.nginxChildProcess = plugins.childProcess.exec(`nginx -c ${paths.nginxConfFile}`, function (error, stdout, stderr) {
|
|
||||||
console.log(`stdout: ${stdout}`);
|
|
||||||
console.log(`stderr: ${stderr}`);
|
|
||||||
if (error !== null) {
|
|
||||||
console.log(`exec error: ${error}`);
|
|
||||||
}
|
|
||||||
;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
;
|
|
||||||
this.started = true;
|
|
||||||
plugins.beautylog.info("started Nginx!");
|
|
||||||
done.resolve();
|
|
||||||
return done.promise;
|
|
||||||
}
|
|
||||||
;
|
|
||||||
/**
|
|
||||||
* reload config
|
|
||||||
*/
|
|
||||||
reloadConfig() {
|
|
||||||
let done = plugins.q.defer();
|
|
||||||
if (this.started == false) {
|
|
||||||
this.start();
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
plugins.shelljs.exec("nginx -s reload");
|
|
||||||
}
|
|
||||||
;
|
|
||||||
plugins.beautylog.ok("NginxProcess has loaded the new config!");
|
|
||||||
done.resolve();
|
|
||||||
return done.promise;
|
|
||||||
}
|
|
||||||
;
|
|
||||||
/**
|
|
||||||
* stop the nginx instance
|
|
||||||
*/
|
|
||||||
stop() {
|
|
||||||
let done = plugins.q.defer();
|
|
||||||
if (typeof this.nginxChildProcess != "undefined") {
|
|
||||||
plugins.shelljs.exec("nginx -s quit");
|
|
||||||
this.started = false;
|
|
||||||
plugins.beautylog.info("stopped Nginx!");
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
plugins.beautylog.log("nginx already stopped!");
|
|
||||||
}
|
|
||||||
;
|
|
||||||
done.resolve();
|
|
||||||
return done.promise;
|
|
||||||
}
|
|
||||||
;
|
|
||||||
/**
|
|
||||||
* checks if nginx is in path
|
|
||||||
*/
|
|
||||||
check() {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
;
|
|
||||||
}
|
|
||||||
exports.NginxProcess = NginxProcess;
|
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRuZ2lueC5jbGFzc2VzLm5naW54cHJvY2Vzcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL3NtYXJ0bmdpbnguY2xhc3Nlcy5uZ2lueHByb2Nlc3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE1BQVksT0FBTyxXQUFNLHNCQUFzQixDQUFDLENBQUE7QUFDaEQsTUFBWSxLQUFLLFdBQU0sb0JBQW9CLENBQUMsQ0FBQTtBQUk1Qzs7R0FFRztBQUNIO0lBSUksWUFBWSxjQUFjO1FBSDFCLFlBQU8sR0FBWSxLQUFLLENBQUM7UUFJckIsSUFBSSxDQUFDLFdBQVcsR0FBRyxjQUFjLENBQUM7SUFDdEMsQ0FBQzs7SUFFRDs7T0FFRztJQUNILEtBQUs7UUFDRCxJQUFJLElBQUksR0FBRyxPQUFPLENBQUMsQ0FBQyxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQzdCLEVBQUUsQ0FBQyxDQUFDLE9BQU8sSUFBSSxDQUFDLGlCQUFpQixJQUFJLFdBQVcsQ0FBQyxDQUFBLENBQUM7WUFDOUMsSUFBSSxDQUFDLGlCQUFpQixHQUFHLE9BQU8sQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLFlBQVksS0FBSyxDQUFDLGFBQWEsRUFBRSxFQUFFLFVBQVUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNO2dCQUNqSCxPQUFPLENBQUMsR0FBRyxDQUFDLFdBQVcsTUFBTSxFQUFFLENBQUMsQ0FBQztnQkFDakMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxXQUFXLE1BQU0sRUFBRSxDQUFDLENBQUM7Z0JBQ2pDLEVBQUUsQ0FBQyxDQUFDLEtBQUssS0FBSyxJQUFJLENBQUMsQ0FBQyxDQUFDO29CQUNqQixPQUFPLENBQUMsR0FBRyxDQUFDLGVBQWUsS0FBSyxFQUFFLENBQUMsQ0FBQztnQkFDeEMsQ0FBQztnQkFBQSxDQUFDO1lBQ04sQ0FBQyxDQUFDLENBQUM7UUFDUCxDQUFDO1FBQUEsQ0FBQztRQUNGLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDO1FBQ3BCLE9BQU8sQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLENBQUM7UUFDekMsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQ2YsTUFBTSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUM7SUFDeEIsQ0FBQzs7SUFFRDs7T0FFRztJQUNILFlBQVk7UUFDUixJQUFJLElBQUksR0FBRyxPQUFPLENBQUMsQ0FBQyxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQzdCLEVBQUUsQ0FBQSxDQUFDLElBQUksQ0FBQyxPQUFPLElBQUksS0FBSyxDQUFDLENBQUEsQ0FBQztZQUN0QixJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDakIsQ0FBQztRQUFDLElBQUksQ0FBQyxDQUFDO1lBQ0osT0FBTyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsaUJBQWlCLENBQUMsQ0FBQztRQUM1QyxDQUFDO1FBQUEsQ0FBQztRQUNGLE9BQU8sQ0FBQyxTQUFTLENBQUMsRUFBRSxDQUFDLHlDQUF5QyxDQUFDLENBQUE7UUFDL0QsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQ2YsTUFBTSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUM7SUFDeEIsQ0FBQzs7SUFFRDs7T0FFRztJQUNILElBQUk7UUFDQSxJQUFJLElBQUksR0FBRyxPQUFPLENBQUMsQ0FBQyxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQzdCLEVBQUUsQ0FBQyxDQUFDLE9BQU8sSUFBSSxDQUFDLGlCQUFpQixJQUFJLFdBQVcsQ0FBQyxDQUFDLENBQUM7WUFDL0MsT0FBTyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDLENBQUM7WUFDdEMsSUFBSSxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUM7WUFDckIsT0FBTyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztRQUM3QyxDQUFDO1FBQUMsSUFBSSxDQUFDLENBQUM7WUFDSixPQUFPLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyx3QkFBd0IsQ0FBQyxDQUFDO1FBQ3BELENBQUM7UUFBQSxDQUFDO1FBQ0YsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQ2YsTUFBTSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUM7SUFDeEIsQ0FBQzs7SUFFRDs7T0FFRztJQUNILEtBQUs7UUFDRCxNQUFNLENBQUM7SUFDWCxDQUFDOztBQUNMLENBQUM7QUFqRVksb0JBQVksZUFpRXhCLENBQUEifQ==
|
|
5
dist/smartnginx.paths.d.ts
vendored
5
dist/smartnginx.paths.d.ts
vendored
@ -1,5 +0,0 @@
|
|||||||
export declare let packageBase: string;
|
|
||||||
export declare let nginxConfigBase: string;
|
|
||||||
export declare let nginxHostFileBase: string;
|
|
||||||
export declare let nginxCertBase: string;
|
|
||||||
export declare let nginxConfFile: string;
|
|
10
dist/smartnginx.paths.js
vendored
10
dist/smartnginx.paths.js
vendored
@ -1,10 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
const plugins = require("./smartnginx.plugins");
|
|
||||||
// directories
|
|
||||||
exports.packageBase = plugins.path.join(__dirname, "../");
|
|
||||||
exports.nginxConfigBase = plugins.path.join(exports.packageBase, "nginxconfig");
|
|
||||||
exports.nginxHostFileBase = plugins.path.join(exports.nginxConfigBase, "hosts");
|
|
||||||
exports.nginxCertBase = plugins.path.join(exports.nginxConfigBase, "cert");
|
|
||||||
// files
|
|
||||||
exports.nginxConfFile = plugins.path.join(exports.nginxConfigBase, "nginx.conf");
|
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRuZ2lueC5wYXRocy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL3NtYXJ0bmdpbngucGF0aHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE1BQVksT0FBTyxXQUFNLHNCQUd6QixDQUFDLENBSDhDO0FBRS9DLGNBQWM7QUFDSCxtQkFBVyxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBQyxLQUFLLENBQUMsQ0FBQztBQUNqRCx1QkFBZSxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLG1CQUFXLEVBQUMsYUFBYSxDQUFDLENBQUM7QUFDL0QseUJBQWlCLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsdUJBQWUsRUFBQyxPQUFPLENBQUMsQ0FBQztBQUMvRCxxQkFBYSxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLHVCQUFlLEVBQUMsTUFBTSxDQUFDLENBQUM7QUFFckUsUUFBUTtBQUNHLHFCQUFhLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsdUJBQWUsRUFBQyxZQUFZLENBQUMsQ0FBQyJ9
|
|
9
dist/smartnginx.plugins.d.ts
vendored
9
dist/smartnginx.plugins.d.ts
vendored
@ -1,9 +0,0 @@
|
|||||||
import "typings-global";
|
|
||||||
export import beautylog = require("beautylog");
|
|
||||||
export import cert = require("cert");
|
|
||||||
export import childProcess = require("child_process");
|
|
||||||
export import path = require("path");
|
|
||||||
export import q = require("q");
|
|
||||||
export import shelljs = require("shelljs");
|
|
||||||
export import smartfile = require("smartfile");
|
|
||||||
export import smartstring = require("smartstring");
|
|
11
dist/smartnginx.plugins.js
vendored
11
dist/smartnginx.plugins.js
vendored
@ -1,11 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
require("typings-global");
|
|
||||||
exports.beautylog = require("beautylog");
|
|
||||||
exports.cert = require("cert");
|
|
||||||
exports.childProcess = require("child_process");
|
|
||||||
exports.path = require("path");
|
|
||||||
exports.q = require("q");
|
|
||||||
exports.shelljs = require("shelljs");
|
|
||||||
exports.smartfile = require("smartfile");
|
|
||||||
exports.smartstring = require("smartstring");
|
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRuZ2lueC5wbHVnaW5zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvc21hcnRuZ2lueC5wbHVnaW5zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxRQUFPLGdCQUFnQixDQUFDLENBQUE7QUFDVixpQkFBUyxXQUFXLFdBQVcsQ0FBQyxDQUFDO0FBQ2pDLFlBQUksV0FBVyxNQUFNLENBQUMsQ0FBQztBQUN2QixvQkFBWSxXQUFXLGVBQWUsQ0FBQyxDQUFDO0FBQ3hDLFlBQUksV0FBVyxNQUFNLENBQUMsQ0FBQztBQUN2QixTQUFDLFdBQVcsR0FBRyxDQUFDLENBQUM7QUFDakIsZUFBTyxXQUFXLFNBQVMsQ0FBQyxDQUFDO0FBQzdCLGlCQUFTLFdBQVcsV0FBVyxDQUFDLENBQUM7QUFDakMsbUJBQVcsV0FBVyxhQUFhLENBQUMsQ0FBQyJ9
|
|
2
dist/smartnginx.snippets.d.ts
vendored
2
dist/smartnginx.snippets.d.ts
vendored
@ -1,2 +0,0 @@
|
|||||||
export declare let getBaseConfigString: () => string;
|
|
||||||
export declare let getHostConfigString: (hostNameArg: string, destinationIpArg: string) => string;
|
|
103
dist/smartnginx.snippets.js
vendored
103
dist/smartnginx.snippets.js
vendored
@ -1,103 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
const plugins = require("./smartnginx.plugins");
|
|
||||||
const paths = require("./smartnginx.paths");
|
|
||||||
exports.getBaseConfigString = () => {
|
|
||||||
let baseConfig = plugins.smartstring.indent.normalize(`
|
|
||||||
user www-data;
|
|
||||||
worker_processes auto;
|
|
||||||
pid /run/nginx.pid;
|
|
||||||
|
|
||||||
events {
|
|
||||||
worker_connections 768;
|
|
||||||
# multi_accept on;
|
|
||||||
}
|
|
||||||
|
|
||||||
http {
|
|
||||||
server_names_hash_bucket_size 128;
|
|
||||||
|
|
||||||
##
|
|
||||||
# Basic Settings
|
|
||||||
##
|
|
||||||
|
|
||||||
sendfile on;
|
|
||||||
tcp_nopush on;
|
|
||||||
tcp_nodelay on;
|
|
||||||
keepalive_timeout 65;
|
|
||||||
types_hash_max_size 2048;
|
|
||||||
# server_tokens off;
|
|
||||||
|
|
||||||
# server_names_hash_bucket_size 64;
|
|
||||||
# server_name_in_redirect off;
|
|
||||||
|
|
||||||
include /etc/nginx/mime.types;
|
|
||||||
default_type application/octet-stream;
|
|
||||||
|
|
||||||
##
|
|
||||||
# SSL Settings
|
|
||||||
##
|
|
||||||
|
|
||||||
ssl_protocols TLSv1 TLSv1.1 TLSv1.2; # Dropping SSLv3, ref: POODLE
|
|
||||||
ssl_prefer_server_ciphers on;
|
|
||||||
|
|
||||||
##
|
|
||||||
# Logging Settings
|
|
||||||
##
|
|
||||||
|
|
||||||
access_log /var/log/nginx/access.log;
|
|
||||||
error_log /var/log/nginx/error.log;
|
|
||||||
|
|
||||||
##
|
|
||||||
# Gzip Settings
|
|
||||||
##
|
|
||||||
|
|
||||||
gzip on;
|
|
||||||
gzip_disable "msie6";
|
|
||||||
|
|
||||||
# gzip_vary on;
|
|
||||||
# gzip_proxied any;
|
|
||||||
# gzip_comp_level 6;
|
|
||||||
# gzip_buffers 16 8k;
|
|
||||||
# gzip_http_version 1.1;
|
|
||||||
# gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript;
|
|
||||||
|
|
||||||
##
|
|
||||||
# Virtual Host Configs
|
|
||||||
##
|
|
||||||
|
|
||||||
include ${paths.nginxHostFileBase}/*.conf;
|
|
||||||
include /etc/nginx/sites-enabled/*;
|
|
||||||
}
|
|
||||||
daemon off;
|
|
||||||
`);
|
|
||||||
return baseConfig;
|
|
||||||
};
|
|
||||||
exports.getHostConfigString = (hostNameArg, destinationIpArg) => {
|
|
||||||
let hostConfig = plugins.smartstring.indent.normalize(`
|
|
||||||
upstream ${hostNameArg} {
|
|
||||||
server ${destinationIpArg};
|
|
||||||
}
|
|
||||||
|
|
||||||
server {
|
|
||||||
listen *:80 ;
|
|
||||||
server_name ${hostNameArg};
|
|
||||||
rewrite ^ https://${hostNameArg}$request_uri? permanent;
|
|
||||||
}
|
|
||||||
|
|
||||||
server {
|
|
||||||
listen *:443 ssl;
|
|
||||||
server_name ${hostNameArg};
|
|
||||||
ssl_certificate ${paths.nginxCertBase}/${hostNameArg}/fullchain.pem;
|
|
||||||
ssl_certificate_key ${paths.nginxCertBase}/${hostNameArg}/privkey.pem;
|
|
||||||
|
|
||||||
location / {
|
|
||||||
proxy_pass http://${hostNameArg};
|
|
||||||
include /etc/nginx/proxy_params;
|
|
||||||
}
|
|
||||||
location ~ /\.git {
|
|
||||||
deny all;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
`);
|
|
||||||
return hostConfig;
|
|
||||||
};
|
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRuZ2lueC5zbmlwcGV0cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL3NtYXJ0bmdpbnguc25pcHBldHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE1BQVksT0FBTyxXQUFNLHNCQUFzQixDQUFDLENBQUE7QUFDaEQsTUFBWSxLQUFLLFdBQU0sb0JBQW9CLENBQUMsQ0FBQTtBQUNqQywyQkFBbUIsR0FBRztJQUNoQyxJQUFJLFVBQVUsR0FBRyxPQUFPLENBQUMsV0FBVyxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUM7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O2FBOEQxQyxLQUFLLENBQUMsaUJBQWlCOzs7O0VBSWxDLENBQUMsQ0FBQztJQUNILE1BQU0sQ0FBQyxVQUFVLENBQUM7QUFDbkIsQ0FBQyxDQUFBO0FBR1UsMkJBQW1CLEdBQUcsQ0FBQyxXQUFrQixFQUFDLGdCQUF1QjtJQUMzRSxJQUFJLFVBQVUsR0FBRyxPQUFPLENBQUMsV0FBVyxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUM7YUFDMUMsV0FBVztZQUNaLGdCQUFnQjs7Ozs7aUJBS1gsV0FBVzs4QkFDRSxXQUFXOzs7OztpQkFLeEIsV0FBVztxQkFDUCxLQUFLLENBQUMsYUFBYSxJQUFJLFdBQVc7eUJBQzlCLEtBQUssQ0FBQyxhQUFhLElBQUksV0FBVzs7O3dCQUduQyxXQUFXOzs7Ozs7O0VBT2pDLENBQUMsQ0FBQztJQUNILE1BQU0sQ0FBQyxVQUFVLENBQUM7QUFDbkIsQ0FBQyxDQUFDIn0=
|
|
8
npmextra.json
Normal file
8
npmextra.json
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
{
|
||||||
|
"npmci": {
|
||||||
|
"npmAccessLevel": "public"
|
||||||
|
},
|
||||||
|
"npmdocker": {
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
1671
package-lock.json
generated
Normal file
1671
package-lock.json
generated
Normal file
File diff suppressed because it is too large
Load Diff
37
package.json
37
package.json
@ -1,12 +1,14 @@
|
|||||||
{
|
{
|
||||||
"name": "smartnginx",
|
"name": "@pushrocks/smartnginx",
|
||||||
"version": "1.0.6",
|
"version": "2.0.45",
|
||||||
|
"private": false,
|
||||||
"description": "control nginx from node, TypeScript ready",
|
"description": "control nginx from node, TypeScript ready",
|
||||||
"main": "dist/index.js",
|
"main": "dist/index.js",
|
||||||
"typings": "dist/index.d.ts",
|
"typings": "dist/index.d.ts",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"test": "(npmts)",
|
"test": "tstest test/",
|
||||||
"cleanTest": "(rm -r nginxconfig)"
|
"cleanTest": "(rm -r nginxconfig) && npm run test",
|
||||||
|
"build": "(tsbuild)"
|
||||||
},
|
},
|
||||||
"repository": {
|
"repository": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
@ -22,19 +24,22 @@
|
|||||||
},
|
},
|
||||||
"homepage": "https://gitlab.com/pushrocks/smartnginx#README",
|
"homepage": "https://gitlab.com/pushrocks/smartnginx#README",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@types/q": "0.x.x",
|
"@pushrocks/lik": "^3.0.4",
|
||||||
"@types/shelljs": "0.x.x",
|
"@pushrocks/smartfile": "^6.0.11",
|
||||||
"beautylog": "^5.0.20",
|
"@pushrocks/smartlog": "^2.0.11",
|
||||||
"cert": "^1.0.7",
|
"@pushrocks/smartpromise": "^2.0.5",
|
||||||
"q": "^1.4.1",
|
"@pushrocks/smartshell": "^2.0.13",
|
||||||
"shelljs": "^0.7.3",
|
"@pushrocks/smartstring": "^3.0.8",
|
||||||
"smartfile": "^4.0.13",
|
"@pushrocks/smartunique": "^3.0.1",
|
||||||
"smartstring": "^2.0.15"
|
"selfsigned": "^1.10.4"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"npmts-g": "^5.2.8",
|
"@gitzone/tsbuild": "^2.1.4",
|
||||||
"qenv": "^1.0.8",
|
"@gitzone/tsrun": "^1.1.17",
|
||||||
"should": "^10.0.0",
|
"@gitzone/tstest": "^1.0.18",
|
||||||
"typings-test": "^1.0.1"
|
"@pushrocks/qenv": "^4.0.0",
|
||||||
|
"@pushrocks/tapbundle": "^3.0.7",
|
||||||
|
"tslint": "^5.15.0",
|
||||||
|
"tslint-config-prettier": "^1.18.0"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
2
test/test.d.ts
vendored
2
test/test.d.ts
vendored
@ -1,2 +0,0 @@
|
|||||||
import "typings-test";
|
|
||||||
import "should";
|
|
61
test/test.js
61
test/test.js
@ -1,61 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
require("typings-test");
|
|
||||||
const path = require("path");
|
|
||||||
require("should");
|
|
||||||
const qenv_1 = require("qenv");
|
|
||||||
const smartnginx = require("../dist/index");
|
|
||||||
// setup environment
|
|
||||||
let testQenv = new qenv_1.Qenv(process.cwd(), path.join(process.cwd(), ".nogit"));
|
|
||||||
describe("smartnginx", function () {
|
|
||||||
let testNginxConfig;
|
|
||||||
let testNginxZone01;
|
|
||||||
let testNginxZone02;
|
|
||||||
describe("NginxZone", function () {
|
|
||||||
it(`"new NginxZone()" should produce an instance of NginxConfig`, function () {
|
|
||||||
testNginxZone01 = new smartnginx.NginxHost({
|
|
||||||
hostName: "test100.bleu.de",
|
|
||||||
type: smartnginx.hostTypes.reverseProxy,
|
|
||||||
destination: "192.192.192.191"
|
|
||||||
});
|
|
||||||
testNginxZone02 = new smartnginx.NginxHost({
|
|
||||||
hostName: "test102.bleu.de",
|
|
||||||
type: smartnginx.hostTypes.reverseProxy,
|
|
||||||
destination: "192.192.192.192"
|
|
||||||
});
|
|
||||||
testNginxZone01.should.be.instanceof(smartnginx.NginxHost);
|
|
||||||
console.log(testNginxZone01.configString);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
describe("NginxConfig", function () {
|
|
||||||
this.timeout(10000);
|
|
||||||
it(`"new NginxConfig()" should produce an instance of NginxConfig`, function () {
|
|
||||||
testNginxConfig = new smartnginx.NginxConfig({
|
|
||||||
cfEmail: process.env.CF_EMAIL,
|
|
||||||
cfKey: process.env.CF_KEY,
|
|
||||||
testMode: true
|
|
||||||
});
|
|
||||||
testNginxConfig.should.be.instanceof(smartnginx.NginxConfig);
|
|
||||||
});
|
|
||||||
describe(".addZone()", function () {
|
|
||||||
it("should add a zone to NginxConfig Object", function () {
|
|
||||||
testNginxConfig.addHost(testNginxZone01);
|
|
||||||
testNginxConfig.addHost(testNginxZone02);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
describe(".deploy()", function () {
|
|
||||||
this.timeout(600000);
|
|
||||||
it("should deploy a config from an instance", function (done) {
|
|
||||||
testNginxConfig.deploy()
|
|
||||||
.then(() => {
|
|
||||||
done();
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
||||||
describe(".stop", function () {
|
|
||||||
it("should end the process", function () {
|
|
||||||
testNginxConfig.nginxProcess.stop();
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInRlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLFFBQU8sY0FBYyxDQUFDLENBQUE7QUFDdEIsTUFBTyxJQUFJLFdBQVcsTUFBTSxDQUFDLENBQUM7QUFDOUIsUUFBTyxRQUFRLENBQUMsQ0FBQTtBQUNoQix1QkFBbUIsTUFBTSxDQUFDLENBQUE7QUFDMUIsTUFBWSxVQUFVLFdBQU0sZUFBZSxDQUFDLENBQUE7QUFFNUMsb0JBQW9CO0FBQ3BCLElBQUksUUFBUSxHQUFHLElBQUksV0FBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLEVBQUUsRUFBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLEVBQUUsRUFBQyxRQUFRLENBQUMsQ0FBQyxDQUFDO0FBQ3pFLFFBQVEsQ0FBQyxZQUFZLEVBQUM7SUFDbEIsSUFBSSxlQUFzQyxDQUFDO0lBQzNDLElBQUksZUFBb0MsQ0FBQztJQUN6QyxJQUFJLGVBQW9DLENBQUM7SUFDekMsUUFBUSxDQUFDLFdBQVcsRUFBQztRQUNqQixFQUFFLENBQUMsNkRBQTZELEVBQUM7WUFDN0QsZUFBZSxHQUFHLElBQUksVUFBVSxDQUFDLFNBQVMsQ0FBQztnQkFDdkMsUUFBUSxFQUFDLGlCQUFpQjtnQkFDMUIsSUFBSSxFQUFDLFVBQVUsQ0FBQyxTQUFTLENBQUMsWUFBWTtnQkFDdEMsV0FBVyxFQUFDLGlCQUFpQjthQUNoQyxDQUFDLENBQUM7WUFDSCxlQUFlLEdBQUcsSUFBSSxVQUFVLENBQUMsU0FBUyxDQUFDO2dCQUN2QyxRQUFRLEVBQUMsaUJBQWlCO2dCQUMxQixJQUFJLEVBQUMsVUFBVSxDQUFDLFNBQVMsQ0FBQyxZQUFZO2dCQUN0QyxXQUFXLEVBQUMsaUJBQWlCO2FBQ2hDLENBQUMsQ0FBQztZQUNILGVBQWUsQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLFVBQVUsQ0FBQyxVQUFVLENBQUMsU0FBUyxDQUFDLENBQUM7WUFDM0QsT0FBTyxDQUFDLEdBQUcsQ0FBQyxlQUFlLENBQUMsWUFBWSxDQUFDLENBQUM7UUFDOUMsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDLENBQUMsQ0FBQztJQUNILFFBQVEsQ0FBQyxhQUFhLEVBQUM7UUFDbkIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNwQixFQUFFLENBQUMsK0RBQStELEVBQUM7WUFDL0QsZUFBZSxHQUFHLElBQUksVUFBVSxDQUFDLFdBQVcsQ0FBQztnQkFDekMsT0FBTyxFQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUMsUUFBUTtnQkFDN0IsS0FBSyxFQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUMsTUFBTTtnQkFDekIsUUFBUSxFQUFDLElBQUk7YUFDaEIsQ0FBQyxDQUFDO1lBQ0gsZUFBZSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsVUFBVSxDQUFDLFVBQVUsQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUNqRSxDQUFDLENBQUMsQ0FBQztRQUNILFFBQVEsQ0FBQyxZQUFZLEVBQUM7WUFDbEIsRUFBRSxDQUFDLHlDQUF5QyxFQUFDO2dCQUN6QyxlQUFlLENBQUMsT0FBTyxDQUFDLGVBQWUsQ0FBQyxDQUFDO2dCQUN6QyxlQUFlLENBQUMsT0FBTyxDQUFDLGVBQWUsQ0FBQyxDQUFDO1lBQzdDLENBQUMsQ0FBQyxDQUFBO1FBQ04sQ0FBQyxDQUFDLENBQUM7UUFDSCxRQUFRLENBQUMsV0FBVyxFQUFDO1lBQ2pCLElBQUksQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLENBQUM7WUFDckIsRUFBRSxDQUFDLHlDQUF5QyxFQUFDLFVBQVMsSUFBSTtnQkFDdEQsZUFBZSxDQUFDLE1BQU0sRUFBRTtxQkFDbkIsSUFBSSxDQUFDO29CQUNGLElBQUksRUFBRSxDQUFDO2dCQUNYLENBQUMsQ0FBQyxDQUFDO1lBQ1gsQ0FBQyxDQUFDLENBQUE7UUFDTixDQUFDLENBQUMsQ0FBQztRQUNILFFBQVEsQ0FBQyxPQUFPLEVBQUM7WUFDYixFQUFFLENBQUMsd0JBQXdCLEVBQUM7Z0JBQ3hCLGVBQWUsQ0FBQyxZQUFZLENBQUMsSUFBSSxFQUFFLENBQUM7WUFDeEMsQ0FBQyxDQUFDLENBQUE7UUFDTixDQUFDLENBQUMsQ0FBQTtJQUNOLENBQUMsQ0FBQyxDQUFDO0FBQ1AsQ0FBQyxDQUFDLENBQUMifQ==
|
|
111
test/test.ts
111
test/test.ts
@ -1,60 +1,55 @@
|
|||||||
import "typings-test";
|
import { tap, expect } from '@pushrocks/tapbundle';
|
||||||
import path = require("path");
|
import path = require('path');
|
||||||
import "should";
|
|
||||||
import {Qenv} from "qenv";
|
|
||||||
import * as smartnginx from "../dist/index";
|
|
||||||
|
|
||||||
// setup environment
|
import { Qenv } from '@pushrocks/qenv';
|
||||||
let testQenv = new Qenv(process.cwd(),path.join(process.cwd(),".nogit"));
|
const testQenv = new Qenv('./', './.nogit/');
|
||||||
describe("smartnginx",function(){
|
|
||||||
let testNginxConfig:smartnginx.NginxConfig;
|
import * as smartnginx from '../ts/index';
|
||||||
let testNginxZone01:smartnginx.NginxHost;
|
|
||||||
let testNginxZone02:smartnginx.NginxHost;
|
let testSmartNginx: smartnginx.SmartNginx;
|
||||||
describe("NginxZone",function(){
|
let testNginxZone01: smartnginx.NginxHost;
|
||||||
it(`"new NginxZone()" should produce an instance of NginxConfig`,function(){
|
let testNginxZone02: smartnginx.NginxHost;
|
||||||
testNginxZone01 = new smartnginx.NginxHost({
|
|
||||||
hostName:"test100.bleu.de",
|
tap.test('should create a valid instance of SmartNginx', async () => {
|
||||||
type:smartnginx.hostTypes.reverseProxy,
|
testSmartNginx = new smartnginx.SmartNginx({defaultProxyUrl: 'https://git.zone'});
|
||||||
destination:"192.192.192.191"
|
expect(testSmartNginx).to.be.instanceof(smartnginx.SmartNginx);
|
||||||
});
|
|
||||||
testNginxZone02 = new smartnginx.NginxHost({
|
|
||||||
hostName:"test102.bleu.de",
|
|
||||||
type:smartnginx.hostTypes.reverseProxy,
|
|
||||||
destination:"192.192.192.192"
|
|
||||||
});
|
|
||||||
testNginxZone01.should.be.instanceof(smartnginx.NginxHost);
|
|
||||||
console.log(testNginxZone01.configString);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
describe("NginxConfig",function(){
|
|
||||||
this.timeout(10000);
|
|
||||||
it(`"new NginxConfig()" should produce an instance of NginxConfig`,function(){
|
|
||||||
testNginxConfig = new smartnginx.NginxConfig({
|
|
||||||
cfEmail: process.env.CF_EMAIL,
|
|
||||||
cfKey: process.env.CF_KEY,
|
|
||||||
testMode:true
|
|
||||||
});
|
|
||||||
testNginxConfig.should.be.instanceof(smartnginx.NginxConfig);
|
|
||||||
});
|
|
||||||
describe(".addZone()",function(){
|
|
||||||
it("should add a zone to NginxConfig Object",function(){
|
|
||||||
testNginxConfig.addHost(testNginxZone01);
|
|
||||||
testNginxConfig.addHost(testNginxZone02);
|
|
||||||
})
|
|
||||||
});
|
|
||||||
describe(".deploy()",function(){
|
|
||||||
this.timeout(600000);
|
|
||||||
it("should deploy a config from an instance",function(done){
|
|
||||||
testNginxConfig.deploy()
|
|
||||||
.then(() => {
|
|
||||||
done();
|
|
||||||
});
|
|
||||||
})
|
|
||||||
});
|
|
||||||
describe(".stop",function(){
|
|
||||||
it("should end the process",function(){
|
|
||||||
testNginxConfig.nginxProcess.stop();
|
|
||||||
})
|
|
||||||
})
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
|
|
||||||
|
tap.test(`should produce an instance of NginxConfig`, async () => {
|
||||||
|
testNginxZone01 = new smartnginx.NginxHost(testSmartNginx, {
|
||||||
|
hostName: 'test100.bleu.de',
|
||||||
|
destination: '192.192.192.191',
|
||||||
|
destinationPort: 3000,
|
||||||
|
privateKey: 'some private',
|
||||||
|
publicKey: 'some public'
|
||||||
|
});
|
||||||
|
testNginxZone02 = new smartnginx.NginxHost(testSmartNginx, {
|
||||||
|
hostName: 'test102.bleu.de',
|
||||||
|
destination: '192.192.192.192',
|
||||||
|
destinationPort: 3050,
|
||||||
|
privateKey: 'some private',
|
||||||
|
publicKey: 'some public'
|
||||||
|
});
|
||||||
|
expect(testNginxZone01).to.be.instanceof(smartnginx.NginxHost);
|
||||||
|
});
|
||||||
|
|
||||||
|
tap.test('.addHostCandidate() should add a zone to NginxConfig Object', async () => {
|
||||||
|
testSmartNginx.addHostCandidate(testNginxZone01);
|
||||||
|
testSmartNginx.addHostCandidate(testNginxZone02);
|
||||||
|
});
|
||||||
|
|
||||||
|
tap.test('.deploy() should deploy a config from an instance', async () => {
|
||||||
|
await testSmartNginx.deploy();
|
||||||
|
});
|
||||||
|
|
||||||
|
tap.test('should not redeploy', async () => {
|
||||||
|
testSmartNginx.addHostCandidate(testNginxZone01);
|
||||||
|
testSmartNginx.addHostCandidate(testNginxZone02);
|
||||||
|
await testSmartNginx.deploy();
|
||||||
|
});
|
||||||
|
|
||||||
|
tap.test('.stop() should end the process', async () => {
|
||||||
|
testSmartNginx.nginxProcess.stop();
|
||||||
|
});
|
||||||
|
|
||||||
|
tap.start();
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
import * as plugins from "./smartnginx.plugins";
|
import * as plugins from './smartnginx.plugins';
|
||||||
|
|
||||||
// classes
|
// classes
|
||||||
export * from "./smartnginx.classes.nginxconfig";
|
export * from './smartnginx.classes.smartnginx';
|
||||||
export * from "./smartnginx.classes.nginxprocess";
|
export * from './smartnginx.classes.nginxprocess';
|
||||||
export * from "./smartnginx.classes.nginxhost";
|
export * from './smartnginx.classes.nginxhost';
|
||||||
|
7
ts/interfaces/hostconfig.ts
Normal file
7
ts/interfaces/hostconfig.ts
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
export interface IHostConfig {
|
||||||
|
hostName: string;
|
||||||
|
destination: string;
|
||||||
|
destinationPort: number;
|
||||||
|
privateKey: string;
|
||||||
|
publicKey: string;
|
||||||
|
}
|
0
ts/interfaces/index.ts
Normal file
0
ts/interfaces/index.ts
Normal file
@ -1,71 +0,0 @@
|
|||||||
import * as plugins from "./smartnginx.plugins";
|
|
||||||
import * as paths from "./smartnginx.paths";
|
|
||||||
import * as snippets from "./smartnginx.snippets";
|
|
||||||
import { NginxHost } from "./smartnginx.classes.nginxhost";
|
|
||||||
import { NginxProcess } from "./smartnginx.classes.nginxprocess";
|
|
||||||
let allConfigs: NginxConfig[] = [];
|
|
||||||
|
|
||||||
/**
|
|
||||||
* main class that manages a NginxInstance
|
|
||||||
*/
|
|
||||||
export class NginxConfig {
|
|
||||||
hosts: NginxHost[] = [];
|
|
||||||
cert: plugins.cert.Cert; // the Cert Instance from which the config gets its certificates
|
|
||||||
nginxProcess: NginxProcess = new NginxProcess(this);
|
|
||||||
isDeployed: boolean = false;
|
|
||||||
constructor(optionsArg: plugins.cert.ICertConstructorOptions) {
|
|
||||||
this.cert = new plugins.cert.Cert({
|
|
||||||
cfEmail: optionsArg.cfEmail,
|
|
||||||
cfKey: optionsArg.cfKey,
|
|
||||||
sslDir: paths.nginxCertBase,
|
|
||||||
gitOriginRepo: optionsArg.gitOriginRepo,
|
|
||||||
testMode: optionsArg.testMode
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
// interact with Hosts
|
|
||||||
addHost(nginxHostArg: NginxHost){
|
|
||||||
this.hosts.push(nginxHostArg);
|
|
||||||
}
|
|
||||||
listHosts(): NginxHost[]{
|
|
||||||
return this.hosts;
|
|
||||||
};
|
|
||||||
removeHost(nginxHostArg: NginxHost) {
|
|
||||||
|
|
||||||
}
|
|
||||||
clean() {
|
|
||||||
this.hosts = [];
|
|
||||||
}
|
|
||||||
// handle deployment of hosts
|
|
||||||
deploy() {
|
|
||||||
let done = plugins.q.defer();
|
|
||||||
plugins.smartfile.fs.ensureDirSync(paths.nginxConfigBase);
|
|
||||||
plugins.smartfile.fs.ensureDirSync(paths.nginxHostFileBase);
|
|
||||||
plugins.smartfile.fs.ensureDirSync(paths.nginxCertBase);
|
|
||||||
for (let config of allConfigs) {
|
|
||||||
config.isDeployed = false;
|
|
||||||
};
|
|
||||||
this.isDeployed = true;
|
|
||||||
// write base config
|
|
||||||
plugins.smartfile.memory.toFsSync(
|
|
||||||
snippets.getBaseConfigString(),
|
|
||||||
paths.nginxConfFile
|
|
||||||
);
|
|
||||||
// deploy hosts
|
|
||||||
let promiseArray = [];
|
|
||||||
for (let host of this.hosts) {
|
|
||||||
let hostDeployedPromise = host.deploy(this.cert);
|
|
||||||
hostDeployedPromise.then(() => {
|
|
||||||
plugins.beautylog.info(`Host ${host.hostName} deployed!`);
|
|
||||||
this.nginxProcess.reloadConfig();
|
|
||||||
});
|
|
||||||
promiseArray.push(hostDeployedPromise);
|
|
||||||
};
|
|
||||||
plugins.q.all(promiseArray)
|
|
||||||
.then(() => {
|
|
||||||
done.resolve();
|
|
||||||
});
|
|
||||||
|
|
||||||
return done.promise;
|
|
||||||
};
|
|
||||||
};
|
|
@ -1,43 +1,57 @@
|
|||||||
import * as plugins from "./smartnginx.plugins";
|
import * as plugins from './smartnginx.plugins';
|
||||||
import * as paths from "./smartnginx.paths";
|
import * as paths from './smartnginx.paths';
|
||||||
import * as snippets from "./smartnginx.snippets"
|
import * as snippets from './smartnginx.snippets';
|
||||||
|
|
||||||
/**
|
import { SmartNginx } from './smartnginx.classes.smartnginx';
|
||||||
* the host config data that NginxHost needs to create a valid instance
|
|
||||||
*/
|
import { IHostConfig } from './interfaces/hostconfig';
|
||||||
export interface IHostConfigData {
|
|
||||||
hostName: string,
|
|
||||||
type: hostTypes,
|
|
||||||
destination: string
|
|
||||||
}
|
|
||||||
|
|
||||||
export enum hostTypes {
|
export enum hostTypes {
|
||||||
reverseProxy,
|
reverseProxy
|
||||||
static
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* manages a single nginx host
|
* manages a single nginx host
|
||||||
*/
|
*/
|
||||||
export class NginxHost {
|
export class NginxHost implements IHostConfig {
|
||||||
hostName: string; // the host name e.g. domain name
|
/**
|
||||||
type: hostTypes;
|
* smartnginxInstance this NginHost belongs to
|
||||||
destination: string;
|
*/
|
||||||
configString: string; // the actual host config file as string
|
public smartnginxInstance: SmartNginx;
|
||||||
constructor(optionsArg:IHostConfigData) {
|
|
||||||
this.hostName = optionsArg.hostName;
|
public hostName: string; // the host name e.g. domain name
|
||||||
this.type = optionsArg.type;
|
public destination: string;
|
||||||
this.destination = optionsArg.destination;
|
public destinationPort: number;
|
||||||
this.configString = snippets.getHostConfigString(optionsArg.hostName, optionsArg.destination);
|
public configString: string; // the actual host config file as string
|
||||||
};
|
public privateKey: string;
|
||||||
deploy(certInstanceArg: plugins.cert.Cert) {
|
public publicKey: string;
|
||||||
let done = plugins.q.defer();
|
|
||||||
let filePath = plugins.path.join(paths.nginxHostFileBase, this.hostName + ".conf");
|
constructor(smartnginxInstanceArg: SmartNginx, optionsArg: IHostConfig) {
|
||||||
// writeConfig
|
this.smartnginxInstance = smartnginxInstanceArg;
|
||||||
plugins.smartfile.memory.toFsSync(this.configString, filePath);
|
this.hostName = optionsArg.hostName;
|
||||||
// get cert
|
this.destination = optionsArg.destination;
|
||||||
certInstanceArg.getDomainCert(this.hostName)
|
this.destinationPort = optionsArg.destinationPort;
|
||||||
.then(done.resolve);
|
this.privateKey = optionsArg.privateKey;
|
||||||
return done.promise;
|
this.publicKey = optionsArg.publicKey;
|
||||||
};
|
}
|
||||||
};
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param certInstanceArg
|
||||||
|
*/
|
||||||
|
public async deploy() {
|
||||||
|
const filePathConfig = plugins.path.join(paths.nginxHostDirPath, `${this.hostName}.conf`);
|
||||||
|
const filePathPrivate = plugins.path.join(paths.nginxHostDirPath, `${this.hostName}.private.pem`);
|
||||||
|
const filePathPublic = plugins.path.join(paths.nginxHostDirPath, `${this.hostName}.public.pem`);
|
||||||
|
|
||||||
|
|
||||||
|
// writeConfig
|
||||||
|
this.configString = snippets.getHostConfigString(this.hostName, this.destination, this.destinationPort);
|
||||||
|
plugins.smartfile.memory.toFsSync(this.configString, filePathConfig);
|
||||||
|
|
||||||
|
// write ssl
|
||||||
|
plugins.smartfile.memory.toFsSync(this.privateKey, filePathPrivate);
|
||||||
|
plugins.smartfile.memory.toFsSync(this.publicKey, filePathPublic);
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@ -1,74 +1,69 @@
|
|||||||
import * as plugins from "./smartnginx.plugins";
|
import * as plugins from './smartnginx.plugins';
|
||||||
import * as paths from "./smartnginx.paths";
|
import * as paths from './smartnginx.paths';
|
||||||
import { NginxConfig } from "./smartnginx.classes.nginxconfig";
|
import { SmartNginx } from './smartnginx.classes.smartnginx';
|
||||||
import { NginxHost } from "./smartnginx.classes.nginxhost";
|
import { NginxHost } from './smartnginx.classes.nginxhost';
|
||||||
|
|
||||||
|
import { Smartshell } from '@pushrocks/smartshell';
|
||||||
|
|
||||||
|
import { ChildProcess } from 'child_process';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* manages a nginxprocess for an NginxConfig
|
* manages a nginxprocess for an NginxConfig
|
||||||
*/
|
*/
|
||||||
export class NginxProcess {
|
export class NginxProcess {
|
||||||
started: boolean = false;
|
public started: boolean = false;
|
||||||
nginxConfig:NginxConfig;
|
public smartNginxRef: SmartNginx;
|
||||||
nginxChildProcess: plugins.childProcess.ChildProcess;
|
private nginxChildProcess: ChildProcess;
|
||||||
constructor(nginxConfigArg) {
|
private smartshellInstance = new Smartshell({
|
||||||
this.nginxConfig = nginxConfigArg;
|
executor: 'bash'
|
||||||
};
|
});
|
||||||
|
|
||||||
/**
|
constructor(nginxRefArg: SmartNginx) {
|
||||||
* start nginx
|
this.smartNginxRef = nginxRefArg;
|
||||||
*/
|
}
|
||||||
start() {
|
|
||||||
let done = plugins.q.defer();
|
|
||||||
if (typeof this.nginxChildProcess == "undefined"){
|
|
||||||
this.nginxChildProcess = plugins.childProcess.exec(`nginx -c ${paths.nginxConfFile}`, function (error, stdout, stderr) {
|
|
||||||
console.log(`stdout: ${stdout}`);
|
|
||||||
console.log(`stderr: ${stderr}`);
|
|
||||||
if (error !== null) {
|
|
||||||
console.log(`exec error: ${error}`);
|
|
||||||
};
|
|
||||||
});
|
|
||||||
};
|
|
||||||
this.started = true;
|
|
||||||
plugins.beautylog.info("started Nginx!");
|
|
||||||
done.resolve();
|
|
||||||
return done.promise;
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* reload config
|
* start nginx
|
||||||
*/
|
*/
|
||||||
reloadConfig(){
|
public async start() {
|
||||||
let done = plugins.q.defer();
|
if (!this.nginxChildProcess) {
|
||||||
if(this.started == false){
|
this.nginxChildProcess = (await this.smartshellInstance.execStreaming(
|
||||||
this.start();
|
`nginx -c ${paths.nginxConfFile}`
|
||||||
} else {
|
)).childProcess;
|
||||||
plugins.shelljs.exec("nginx -s reload");
|
}
|
||||||
};
|
this.started = true;
|
||||||
plugins.beautylog.ok("NginxProcess has loaded the new config!")
|
plugins.smartlog.defaultLogger.log('info', 'started Nginx!');
|
||||||
done.resolve();
|
}
|
||||||
return done.promise;
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* stop the nginx instance
|
* reload config
|
||||||
*/
|
*/
|
||||||
stop() {
|
public async reloadConfig() {
|
||||||
let done = plugins.q.defer();
|
if (!this.started) {
|
||||||
if (typeof this.nginxChildProcess != "undefined") {
|
this.start();
|
||||||
plugins.shelljs.exec("nginx -s quit");
|
} else {
|
||||||
this.started = false;
|
await this.smartshellInstance.exec('nginx -s reload');
|
||||||
plugins.beautylog.info("stopped Nginx!");
|
}
|
||||||
} else {
|
this.smartNginxRef.logger.log('info', 'NginxProcess has loaded the new config!');
|
||||||
plugins.beautylog.log("nginx already stopped!");
|
}
|
||||||
};
|
|
||||||
done.resolve();
|
|
||||||
return done.promise;
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* checks if nginx is in path
|
* stop the nginx instance
|
||||||
*/
|
*/
|
||||||
check(): boolean {
|
public async stop() {
|
||||||
return;
|
if (this.nginxChildProcess) {
|
||||||
};
|
this.smartshellInstance.exec('nginx -s quit');
|
||||||
|
this.started = false;
|
||||||
|
this.smartNginxRef.logger.log('info', 'stopped Nginx!');
|
||||||
|
} else {
|
||||||
|
this.smartNginxRef.logger.log('info', 'nginx already stopped!');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* checks if nginx is in path
|
||||||
|
*/
|
||||||
|
public check(): boolean {
|
||||||
|
return;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
137
ts/smartnginx.classes.smartnginx.ts
Normal file
137
ts/smartnginx.classes.smartnginx.ts
Normal file
@ -0,0 +1,137 @@
|
|||||||
|
import * as plugins from './smartnginx.plugins';
|
||||||
|
import * as paths from './smartnginx.paths';
|
||||||
|
import * as snippets from './smartnginx.snippets';
|
||||||
|
import { NginxHost } from './smartnginx.classes.nginxhost';
|
||||||
|
import { NginxProcess } from './smartnginx.classes.nginxprocess';
|
||||||
|
import { IHostConfig } from './interfaces/hostconfig';
|
||||||
|
|
||||||
|
export interface ISmartNginxContructorOptions {
|
||||||
|
logger?: plugins.smartlog.Smartlog;
|
||||||
|
defaultProxyUrl: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* main class that manages a NginxInstance
|
||||||
|
*/
|
||||||
|
export class SmartNginx {
|
||||||
|
public options: ISmartNginxContructorOptions;
|
||||||
|
public logger: plugins.smartlog.Smartlog;
|
||||||
|
|
||||||
|
// the objectmaps
|
||||||
|
private deployedHosts = new plugins.lik.Objectmap<NginxHost>();
|
||||||
|
private hostCandidates = new plugins.lik.Objectmap<NginxHost>();
|
||||||
|
|
||||||
|
public nginxProcess: NginxProcess = new NginxProcess(this);
|
||||||
|
constructor(optionsArg: ISmartNginxContructorOptions) {
|
||||||
|
this.options = optionsArg;
|
||||||
|
this.options.logger
|
||||||
|
? (this.logger = this.options.logger)
|
||||||
|
: (this.logger = plugins.smartlog.defaultLogger);
|
||||||
|
}
|
||||||
|
|
||||||
|
// ===================
|
||||||
|
// interact with Hosts
|
||||||
|
// ===================
|
||||||
|
|
||||||
|
/**
|
||||||
|
* add a host
|
||||||
|
* @param nginxHostArg
|
||||||
|
*/
|
||||||
|
public addHostCandidate(optionsArg: IHostConfig): NginxHost {
|
||||||
|
const nginxHost = new NginxHost(this, optionsArg);
|
||||||
|
this.hostCandidates.add(nginxHost);
|
||||||
|
return nginxHost;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets a NginxHost by hostname
|
||||||
|
* @param hostNameArg
|
||||||
|
*/
|
||||||
|
public getDeployedNginxHostByHostName(hostNameArg: string): NginxHost {
|
||||||
|
return this.deployedHosts.find(nginxHost => {
|
||||||
|
return nginxHost.hostName === hostNameArg;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* listHosts
|
||||||
|
*/
|
||||||
|
public async listDeployedHosts(): Promise<NginxHost[]> {
|
||||||
|
return this.deployedHosts.getArray();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* remove a Host
|
||||||
|
* @param nginxHostArg
|
||||||
|
*/
|
||||||
|
public async removeDeployedHost(nginxHostArg: NginxHost) {
|
||||||
|
if (this.hostCandidates.isEmpty()) {
|
||||||
|
this.deployedHosts.forEach(hostArg => {
|
||||||
|
this.hostCandidates.add(hostArg);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
this.hostCandidates.remove(nginxHostArg);
|
||||||
|
this.deploy();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* check wether there has been a diverging host configuration
|
||||||
|
* this function will only redeploy the nginx configuration in case there has been a change
|
||||||
|
*/
|
||||||
|
private async areHostsDiverged(): Promise<boolean> {
|
||||||
|
let hostCounter = 0;
|
||||||
|
let unfoundHosts = 0;
|
||||||
|
await this.hostCandidates.forEach(async hostCandidateArg => {
|
||||||
|
let foundHost = false;
|
||||||
|
await this.deployedHosts.forEach(async deployedHostArg => {
|
||||||
|
if (
|
||||||
|
hostCandidateArg.hostName === deployedHostArg.hostName &&
|
||||||
|
hostCandidateArg.destination === deployedHostArg.destination &&
|
||||||
|
hostCandidateArg.destinationPort === deployedHostArg.destinationPort
|
||||||
|
) {
|
||||||
|
hostCounter++;
|
||||||
|
foundHost = true;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
if (!foundHost) {
|
||||||
|
unfoundHosts++;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
return (
|
||||||
|
this.deployedHosts.getArray().length !== this.hostCandidates.getArray().length ||
|
||||||
|
hostCounter !== this.deployedHosts.getArray().length ||
|
||||||
|
unfoundHosts !== 0
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* deploy the current stack and restart nginx
|
||||||
|
*/
|
||||||
|
public async deploy() {
|
||||||
|
if (await this.areHostsDiverged()) {
|
||||||
|
this.logger.log('ok', `hosts have diverged, trigger config deployment and nginx reload!`);
|
||||||
|
this.deployedHosts.wipe();
|
||||||
|
this.deployedHosts.addArray(this.hostCandidates.getArray());
|
||||||
|
this.hostCandidates.wipe();
|
||||||
|
|
||||||
|
// write base config
|
||||||
|
plugins.smartfile.fs.ensureDirSync(paths.nginxConfigDirPath);
|
||||||
|
plugins.smartfile.memory.toFsSync(snippets.getBaseConfigString(this.options.defaultProxyUrl), paths.nginxConfFile);
|
||||||
|
|
||||||
|
// write standard self signed certificate
|
||||||
|
const selfsignedCert = plugins.selfsigned.generate([{ name: 'commonName', value: 'selfsigned.git.zone' }], { days: 365});
|
||||||
|
plugins.smartfile.memory.toFsSync(selfsignedCert.private, plugins.path.join(paths.nginxHostDirPath, './default.private.pem'));
|
||||||
|
plugins.smartfile.memory.toFsSync(selfsignedCert.public, plugins.path.join(paths.nginxHostDirPath, './default.public.pem'));
|
||||||
|
|
||||||
|
// deploy hosts
|
||||||
|
plugins.smartfile.fs.ensureEmptyDirSync(paths.nginxHostDirPath);
|
||||||
|
for (const host of this.deployedHosts.getArray()) {
|
||||||
|
await host.deploy();
|
||||||
|
this.logger.log('info', `Host ${host.hostName} deployed!`);
|
||||||
|
}
|
||||||
|
this.nginxProcess.reloadConfig();
|
||||||
|
} else {
|
||||||
|
this.logger.log('info', `hosts have not diverged, skipping nginx reload`);
|
||||||
|
this.hostCandidates.wipe();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -1,10 +1,9 @@
|
|||||||
import * as plugins from "./smartnginx.plugins"
|
import * as plugins from './smartnginx.plugins';
|
||||||
|
|
||||||
// directories
|
// directories
|
||||||
export let packageBase = plugins.path.join(__dirname,"../");
|
export const packageBase = plugins.path.join(__dirname, '../');
|
||||||
export let nginxConfigBase = plugins.path.join(packageBase,"nginxconfig");
|
export const nginxConfigDirPath = plugins.path.join(packageBase, 'nginxconfig');
|
||||||
export let nginxHostFileBase = plugins.path.join(nginxConfigBase,"hosts");
|
export const nginxHostDirPath = plugins.path.join(nginxConfigDirPath, 'hosts');
|
||||||
export let nginxCertBase = plugins.path.join(nginxConfigBase,"cert");
|
|
||||||
|
|
||||||
// files
|
// files
|
||||||
export let nginxConfFile = plugins.path.join(nginxConfigBase,"nginx.conf");
|
export const nginxConfFile = plugins.path.join(nginxConfigDirPath, 'nginx.conf');
|
@ -1,9 +1,22 @@
|
|||||||
import "typings-global";
|
// native
|
||||||
export import beautylog = require("beautylog");
|
import * as path from 'path';
|
||||||
export import cert = require("cert");
|
|
||||||
export import childProcess = require("child_process");
|
export { path };
|
||||||
export import path = require("path");
|
|
||||||
export import q = require("q");
|
// @pushrocks scope
|
||||||
export import shelljs = require("shelljs");
|
import * as lik from '@pushrocks/lik';
|
||||||
export import smartfile = require("smartfile");
|
import * as smartlog from '@pushrocks/smartlog';
|
||||||
export import smartstring = require("smartstring");
|
import * as smartpromise from '@pushrocks/smartpromise';
|
||||||
|
import * as smartshell from '@pushrocks/smartshell';
|
||||||
|
import * as smartfile from '@pushrocks/smartfile';
|
||||||
|
import * as smartstring from '@pushrocks/smartstring';
|
||||||
|
import * as smartunique from '@pushrocks/smartunique';
|
||||||
|
|
||||||
|
export { lik, smartlog, smartpromise, smartshell, smartfile, smartstring, smartunique };
|
||||||
|
|
||||||
|
// thirdparty scope
|
||||||
|
import * as selfsigned from 'selfsigned';
|
||||||
|
|
||||||
|
export {
|
||||||
|
selfsigned
|
||||||
|
};
|
||||||
|
@ -1,10 +1,10 @@
|
|||||||
import * as plugins from "./smartnginx.plugins";
|
import * as plugins from './smartnginx.plugins';
|
||||||
import * as paths from "./smartnginx.paths";
|
import * as paths from './smartnginx.paths';
|
||||||
export let getBaseConfigString = () => {
|
export let getBaseConfigString = (defaultProxy: string) => {
|
||||||
let baseConfig = plugins.smartstring.indent.normalize(`
|
const baseConfig = plugins.smartstring.indent.normalize(`
|
||||||
user www-data;
|
user www-data;
|
||||||
worker_processes auto;
|
worker_processes auto;
|
||||||
pid /run/nginx.pid;
|
pid /run/nginx/nginx.pid;
|
||||||
|
|
||||||
events {
|
events {
|
||||||
worker_connections 768;
|
worker_connections 768;
|
||||||
@ -63,22 +63,39 @@ export let getBaseConfigString = () => {
|
|||||||
# Virtual Host Configs
|
# Virtual Host Configs
|
||||||
##
|
##
|
||||||
|
|
||||||
include ${paths.nginxHostFileBase}/*.conf;
|
server {
|
||||||
|
listen *:80 default_server;
|
||||||
|
server_name selfsigned.git.zone;
|
||||||
|
rewrite ^ ${defaultProxy} permanent;
|
||||||
|
}
|
||||||
|
|
||||||
|
server {
|
||||||
|
listen *:443 ssl default_server;
|
||||||
|
server_name selfsigned.git.zone;
|
||||||
|
ssl_certificate ${paths.nginxHostDirPath}/default.public.pem;
|
||||||
|
ssl_certificate_key ${paths.nginxHostDirPath}/default.private.pem;
|
||||||
|
rewrite ^ ${defaultProxy} permanent;
|
||||||
|
}
|
||||||
|
|
||||||
|
include ${paths.nginxHostDirPath}/*.conf;
|
||||||
include /etc/nginx/sites-enabled/*;
|
include /etc/nginx/sites-enabled/*;
|
||||||
}
|
}
|
||||||
daemon off;
|
daemon off;
|
||||||
`);
|
`);
|
||||||
return baseConfig;
|
return baseConfig;
|
||||||
}
|
};
|
||||||
|
|
||||||
|
export let getHostConfigString = (hostNameArg: string, destinationIpArg: string, destinationPortArg = 80) => {
|
||||||
export let getHostConfigString = (hostNameArg:string,destinationIpArg:string) => {
|
const hostConfig = plugins.smartstring.indent.normalize(`
|
||||||
let hostConfig = plugins.smartstring.indent.normalize(`
|
|
||||||
upstream ${hostNameArg} {
|
upstream ${hostNameArg} {
|
||||||
server ${destinationIpArg};
|
keepalive 100;
|
||||||
|
server ${destinationIpArg}:${destinationPortArg};
|
||||||
}
|
}
|
||||||
|
|
||||||
server {
|
server {
|
||||||
|
# The keepalive parameter sets the maximum number of idle keepalive connections
|
||||||
|
# to upstream servers that are preserved in the cache of each worker process. When
|
||||||
|
# this number is exceeded, the least recently used connections are closed.
|
||||||
listen *:80 ;
|
listen *:80 ;
|
||||||
server_name ${hostNameArg};
|
server_name ${hostNameArg};
|
||||||
rewrite ^ https://${hostNameArg}$request_uri? permanent;
|
rewrite ^ https://${hostNameArg}$request_uri? permanent;
|
||||||
@ -87,18 +104,20 @@ export let getHostConfigString = (hostNameArg:string,destinationIpArg:string) =>
|
|||||||
server {
|
server {
|
||||||
listen *:443 ssl;
|
listen *:443 ssl;
|
||||||
server_name ${hostNameArg};
|
server_name ${hostNameArg};
|
||||||
ssl_certificate ${paths.nginxCertBase}/${hostNameArg}/fullchain.pem;
|
ssl_certificate ${paths.nginxHostDirPath}/${hostNameArg}.public.pem;
|
||||||
ssl_certificate_key ${paths.nginxCertBase}/${hostNameArg}/privkey.pem;
|
ssl_certificate_key ${paths.nginxHostDirPath}/${hostNameArg}.private.pem;
|
||||||
|
|
||||||
location / {
|
location / {
|
||||||
proxy_pass http://${hostNameArg};
|
proxy_http_version 1.1;
|
||||||
include /etc/nginx/proxy_params;
|
proxy_buffering off;
|
||||||
}
|
proxy_redirect off;
|
||||||
location ~ /\.git {
|
proxy_set_header X-Real-IP $remote_addr;
|
||||||
deny all;
|
proxy_set_header X-Forwarded-For $remote_addr;
|
||||||
|
proxy_set_header X-Forwarded-Proto $scheme;
|
||||||
|
proxy_next_upstream error timeout http_404 http_429 http_500 http_502;
|
||||||
|
proxy_next_upstream_tries 5;
|
||||||
|
proxy_pass http://${hostNameArg};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
`);
|
`);
|
||||||
return hostConfig;
|
return hostConfig;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
17
tslint.json
Normal file
17
tslint.json
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
{
|
||||||
|
"extends": ["tslint:latest", "tslint-config-prettier"],
|
||||||
|
"rules": {
|
||||||
|
"semicolon": [true, "always"],
|
||||||
|
"no-console": false,
|
||||||
|
"ordered-imports": false,
|
||||||
|
"object-literal-sort-keys": false,
|
||||||
|
"member-ordering": {
|
||||||
|
"options":{
|
||||||
|
"order": [
|
||||||
|
"static-method"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"defaultSeverity": "warning"
|
||||||
|
}
|
Reference in New Issue
Block a user