varEOL=require('os').EOL;// \n if used on Linux, \r\n if used on Windows.
constnpath=require('../utils/nginxPath');
constconf=require('../utils/nginxConf');
constnginxReload=require('../utils/nginxReload');
const{appendToList}=require('../utils/listFile');
const{EOL}=require('os');// \n if used on Linux, \r\n if used on Windows.
functioncreateProxyServer(domain,inPort,outPort){
functioncreateProxyServer(domain,inPort,outPort){
outPort=outPort||80;
outPort=outPort||80;
@ -30,11 +32,14 @@ function createProxyServer(domain, inPort, outPort) {
"}"
"}"
);
);
shell.mkdir('-p',npath.confD());
shell.mkdir('-p',npath.confD());
shell.mkdir('-p',npath.enabledSites());// Creates directories if doesn't exist
shell.mkdir('-p',npath.enabledSites());
shell.ln('-sf',conf(npath.confD(),domain,outPort),conf(npath.enabledSites(),domain,outPort));// Symlink the conf file from sites-available to sites-enabled
// Check for requirements such as OS version and nginx install. Throw and exit if requirements not found.
// Check for requirements such as OS version and nginx install.
// Throw and exit if requirements not found.
// #Roadmap: Add ability to satisfy any possible requirements.
// #Roadmap: Add ability to satisfy any possible requirements.
requirements();// Comment in development and uncomment this line in production. This should check whether the OS is compatible with this version of `up`
requirements();// Comment in development and uncomment this line in production.
// This should check whether the OS is compatible with this version of `up`
program
program
.version('0.1.5');
.version('0.1.5');
@ -29,23 +33,40 @@ program
program
program
.command('static <domain> [outPort]')
.command('static <domain> [outPort]')
.description('Create a static server at this folder.')
.description('Create a static server at this folder.')
.action(function(domain,outPort){//If outport is not given, 80 is set as default. Later, change this default to reflect nginx's settings.
.action(function(domain,outPort){
outPort=outPort||"80";// This is a string because regex needs to validate it.
// If outport is not given, 80 is set as default.
if(!validate(domain,outPort))return;//Validates domain and outport, and if invalid, throws and returns.
// Later, change this default to reflect nginx's settings.
outPort=outPort||"80";
// This is a string because regex needs to validate it.
if(!validate(domain,outPort))return;
// Validates domain and outport, and if invalid, throws and returns.
console.log("\nDone! Your static server has been set up!\nPoint your domain to this server and check "+chalk.cyan(domain)+" to verify!");
console.log(EOL+[
"Done! Your static server has been set up!",
"Point your domain to this server and check "+
chalk.cyan(domain)+
" to verify!"
].join(EOL));
});
});
program
program
.command('proxy <domain> <inPort> [outPort]')
.command('proxy <domain> <inPort> [outPort]')
.description('Create a proxy server, listening at port number.')
.description('Create a proxy server, listening at port number.')
.action(function(domain,inPort,outPort){//Inbound port is necessary, but outbound is set to 80 by default. Again, will change this to reflect nginx's settings.
.action(function(domain,inPort,outPort){
outPort=outPort||"80";// This is a string because regex needs to validate it.
// Inbound port is necessary, but outbound is set to 80 by default.
// Again, will change this to reflect nginx's settings.
outPort=outPort||"80";
// This is a string because regex needs to validate it.
// Throw if OS is not Linux or BSD. This should be changed to throw if not Debian based distro. Eventually, we can add more exceptions as `up` handles more cases.
// Throw if OS is not Linux or BSD.
// This should be changed to throw if not Debian based distro.
// Eventually, we can add more exceptions as `up` handles more cases.
if(!isLin){
if(!isLin){
shell.echo("\nThis is not a Linux or freeBSD distribution. This tool not written for this distro. Please raise an issue at "+chalk.cyan("https://github.com/codefeathers/up-serve")+" if you want `up` to be ported for your distro");
@ -10,15 +14,27 @@ function validate(domain, inPort, outPort) {
outPort=outPort||80;
outPort=outPort||80;
// Error messages
// Error messages
vardomainInvalidMsg=["\nPlease use a domain name instead of an IP address.","\nDomain is not valid. Please use a valid domain name."];
constdomainInvalidMsg=[
varportInvalidMsg=["\nPort should be a number.","\nPort should be a number from 1 and 65535."];
EOL+"Please use a domain name instead of an IP address.",
EOL+"Domain is not valid. Please use a valid domain name."
];
constportInvalidMsg=[
EOL+"Port should be a number.",
EOL+"Port should be a number from 1 and 65535."
];
// ARGV returns a string as input. Port numbers should be parsed to int to validate them. If validation fails, these will return undefined and will fail the subsequent test.
// ARGV returns a string as input.
varvalidInPort=parseToInt(inPort);
// Port numbers should be parsed to int to validate them.
varvalidOutPort=parseToInt(outPort);
// If validation fails, these will return undefined and
// will fail the subsequent test.
constvalidInPort=parseToInt(inPort);
constvalidOutPort=parseToInt(outPort);
// The value of isInvalid will be returned back. If none of the `if`s are true, the default value `true` is returned `domain`, `inPort` and `outPort` are considered validated.
// The value of isInvalid will be returned back.
varisValid=true;
// If none of the `if`s are true, the default
// value `true` is returned `domain`, `inPort` and `outPort` are considered
// validated.
letisValid=true;
// Throw if IP is given instead of domain name.
// Throw if IP is given instead of domain name.
if(isIP(domain)){
if(isIP(domain)){
@ -32,32 +48,42 @@ function validate(domain, inPort, outPort) {
returnisValid=false;
returnisValid=false;
}
}
// Enter if `inPort` is not defined. This happens for `up static` where no inbound ports are required.
// Enter if `inPort` is not defined.
// This happens for `up static` where no inbound ports are required.
if(typeofinPort==undefined){
if(typeofinPort==undefined){
if(!validOutPort){
if(!validOutPort){
console.log(portInvalidMsg[0]);// `outPort` is not an integer.
console.log(portInvalidMsg[0]);// `outPort` is not an integer.
returnisValid=false;
returnisValid=false;
}
}
if(!(validOutPort>0&&validOutPort<=65535)){
if(!(validOutPort>0&&validOutPort<=65535)){
console.log(portInvalidMsg[1]);// `outPort` is not within port range.
console.log(portInvalidMsg[1]);
// `outPort` is not within port range.
returnisValid=false;
returnisValid=false;
}
}
}
}
// Enter if `inPort` is defined. This happens for `up proxy` where inbound port is required.
// Enter if `inPort` is defined. This happens for `up proxy` where
// inbound port is required.
if(typeofinPort!==undefined){
if(typeofinPort!==undefined){
if(!validInPort||!validOutPort){
if(!validInPort||!validOutPort){
console.log(portInvalidMsg[0]);// Either `inPort` or `outPort` is not an integer.
console.log(portInvalidMsg[0]);
// Either `inPort` or `outPort` is not an integer.