Updated cv

This commit is contained in:
Martin Donnelly 2016-05-25 16:48:55 +01:00
parent d3cfa85a86
commit 3015aac6d6
7 changed files with 441 additions and 72 deletions

2
docs/text.txt Normal file
View File

@ -0,0 +1,2 @@
http://pastebin.com/jNaZHVkE

View File

@ -11,6 +11,7 @@ Amazon AWS
``` ```
accessKeyId: 'AKIAJWJS75F7WNCGK64A', accessKeyId: 'AKIAJWJS75F7WNCGK64A',
secretAccessKey: '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' secretAccessKey: '8irYxThCp4xxyrbr00HzWcODe2qdNrR7X7S5BKup'
``` ```

216
scripts/nginx.conf Normal file
View File

@ -0,0 +1,216 @@
# Run as a less privileged user for security reasons.
#user www-data;
# The maximum number of connections for Nginx is calculated by:
# max_clients = worker_processes * worker_connections
# It is better if you set the worker_processes count 1 less than your cpu cores. You have other processes running as well!
worker_processes 1;
# Maximum open file descriptors per process;
# should be > worker_connections.
worker_rlimit_nofile 50000;
pid /run/nginx.pid;
events {
# When you need > 8000 * cpu_cores connections, you start optimizing your OS,
# and this is probably the point at which you hire people who are smarter than
# you, as this is *a lot* of requests.
worker_connections 4096 ;
use epoll;
# accept_mutex off;
# Accept as many connections as possible.
multi_accept on;
}
http {
############################################################################ General Settings
# Define the MIME types for files.
# Usually located at mime.types;
include mime.types;
default_type application/octet-stream;
# Update charset_types due to updated mime.types
charset_types text/xml text/plain text/vnd.wap.wml application/x-javascript application/rss+xml text/css application/javascript application/json;
client_max_body_size 20m;
client_body_buffer_size 128k;
large_client_header_buffers 2 1k;
## Hide the Nginx version number.
server_tokens off;
server_names_hash_bucket_size 512;
server_names_hash_max_size 512;
server_name_in_redirect off;
variables_hash_max_size 2048;
variables_hash_bucket_size 64;
# Speed up file transfers by using sendfile() to copy directly
# between descriptors rather than using read()/write().
sendfile on;
# Tell Nginx not to send out partial frames; this increases throughput
# since TCP frames are filled up before being sent out. (adds TCP_CORK)
tcp_nopush on;
# Tell Nginx to enable the Nagle buffering algorithm for TCP packets, which
# collates several smaller packets together into one larger packet, thus saving
# bandwidth at the cost of a nearly imperceptible increase to latency. (removes TCP_NODELAY)
tcp_nodelay on;
# Don't put the IP to the end of url when there's a redirection
port_in_redirect off;
# Let's make a lot of keepalive requests possible
keepalive_requests 100000;
# How long to allow each connection to stay idle; longer values are better
# for each individual client, particularly for SSL, but means that worker
# connections are tied up longer. (Default: 65)
keepalive_timeout 30;
client_body_timeout 30;
client_header_timeout 60;
send_timeout 30;
## Reset lingering timed out connections. Deflect DDoS.
reset_timedout_connection on;
############################################################################ Gzip Settings
# Enable Gzip compressed.
# Pagespeed might not allow us to turn it on
gzip on;
gzip_buffers 16 8k;
# This feature allow you to use static GZipped versions of your files (you need to create them yourself) and serve those gzipped files directly through Nginx. Nginx just looks for a filename identical to the one requested by the browsers, but with a “.gz” extension (eg. if 'index.html' is requested, nginx will look for a 'index.html.gz' file next to it). If it exists, Nginx serves this -already compressed- file and does not perform gzip compression, thus reducing CPU overhead and response time.
gzip_static on;
# Enable compression both for HTTP/1.0 and HTTP/1.1 (required for CloudFront).
gzip_http_version 1.1;
# Compression level (1-9).
# 5 is a perfect compromise between size and cpu usage, offering about
# 75% reduction for most ascii files (almost identical to level 9).
gzip_comp_level 7;
# Don't compress anything that's already small and unlikely to shrink much
# if at all (the default is 20 bytes, which is bad as that usually leads to
# larger files after gzipping).
gzip_min_length 1064;
# Compress data even for clients that are connecting to us via proxies,
# identified by the "Via" header (required for CloudFront).
gzip_proxied expired no-cache no-store private auth;
# Tell proxies to cache both the gzipped and regular version of a resource
# whenever the clients Accept-Encoding capabilities header varies;
# Avoids the issue where a non-gzip capable client (which is extremely rare
# today) would display gibberish if their proxy gave them the gzipped version.
gzip_vary on;
# Disable gzip for non-supporting browsers.
gzip_disable "MSIE [1-6]\.";
# Compress all output labeled with one of the following MIME-types.
gzip_types application/atom+xml
application/javascript
application/json
application/rss+xml
application/vnd.ms-fontobject
application/x-font-ttf
application/x-web-app-manifest+json
application/x-javascript
application/xhtml+xml
application/xml
font/opentype
image/svg+xml
image/x-icon
image/bmp
text/css
text/richtext
text/xsd
text/xsl
text/xml
text/plain
text/x-component
text/javascript;
#text/html is always compressed by HttpGzipModule
############################################################################ Caching
# Define a cache path for fastcgi caching under the zone name microcache
fastcgi_cache_path /var/cache/nginx/ levels=1:2 keys_zone=microcache:10m max_size=1000m inactive=60m;
proxy_cache_path /var/cache/nginx/proxy/ levels=1:2 keys_zone=proxy:10m;
# Improve static content handling by caching metadata, not the files itself
open_file_cache max=1000 inactive=1h;
open_file_cache_valid 2h;
open_file_cache_min_uses 1;
open_file_cache_errors on;
# Define a zone for limiting the number of simultaneous
# connections nginx accepts. 1m means 32000 simultaneous
# sessions. We need to define for each server the limit_conn
# value refering to this or other zones.
# ** This syntax requires nginx version >=
# ** 1.1.8. Cf. http://nginx.org/en/CHANGES. If using an older
# ** version then use the limit_zone directive below
# ** instead. Comment out this
# ** one if not using nginx version >= 1.1.8.
# limit_conn_zone $binary_remote_addr zone=arbeit:10m;
# For the filefield_nginx_progress module to work. From the
# README. Reserve 1MB under the name 'uploads' to track uploads.
# upload_progress uploads 1m;
############################################################################ Security
# Enable the builtin cross-site scripting (XSS) filter available
# in modern browsers. Usually enabled by default we just
# reinstate in case it has been somehow disabled for this
# particular server instance.
# https://www.owasp.org/index.php/List_of_useful_HTTP_headers.
add_header X-XSS-Protection '1; mode=block';
# Enable clickjacking protection in modern browsers. Available in
# IE8 also. See
# https://developer.mozilla.org/en/The_X-FRAME-OPTIONS_response_header
# This may conflicts with pseudo streaming (at least with Nginx version 1.0.12).
# Uncomment the line below if you are not using media streaming.
# For sites being framing on the same domqin uncomment the line below.
#add_header X-Frame-Options SAMEORIGIN;
# For sites accepting to be framed in any context comment the
# line below.
add_header X-Frame-Options DENY;
## Block MIME type sniffing on IE.
add_header X-Content-Options nosniff;
############################################################################ Logging
log_format custom '$remote_addr - $remote_user [$time_local] '
'"$request" $status $body_bytes_sent '
'"$http_referer" "$http_user_agent"';
#log_format varnish_log '$http_x_forwarded_for - $remote_user [$time_local] ' '"$request" $status $body_bytes_sent "$http_referer" ' ;
#log_format main '$remote_addr - $remote_user [$time_local] "$request" '
# '$status $body_bytes_sent "$http_referer" '
# '"$http_user_agent" "$http_x_forwarded_for"';
access_log /var/log/nginx/access.log;
error_log /var/log/nginx/error.log;
############################################################################ Pagespeed
# Edit this file to add your domain.
# https://developers.google.com/speed/pagespeed/module/domains
# include conf.d/pagespeed/pagespeed.conf;
# Virtual Host Configs
include conf.d/*.conf;
# include sites-enabled/*;
############################################################################ CLOUDFLARE GET REALIP PROBE
# include nomad-conf/realip.add;
}

View File

@ -1,4 +1,6 @@
#!/bin/bash #!/bin/bash
GIT_SERVER=
GIT_FRONTEND=
NVM="$HOME/.nvm" NVM="$HOME/.nvm"
NVM_VERSION="5.7.0" NVM_VERSION="5.7.0"
DEV="$HOME/dev" DEV="$HOME/dev"
@ -7,13 +9,20 @@ STAGING="$HOME/staging"
SERVER="O-BrandServer" SERVER="O-BrandServer"
FRONT="O-Brand" FRONT="O-Brand"
SWAP="/swapfile" SWAP="/swapfile"
DBSETUP="obrand-admin-server/dbrebuild.sh" DBSETUP="$DEV/$SERVER/dbrebuild.sh"
PKG_MANAGER=$( command -v yum || command -v apt-get ) || echo "Neither yum nor apt-get found" PKG_MANAGER=$( command -v yum || command -v apt-get ) || echo "Neither yum nor apt-get found"
PKG_DEVICE=$(basename $PKG_MANAGER) PKG_DEVICE=$(basename $PKG_MANAGER)
pidof systemd && SYSTEMDCALL=1 || SYSTEMDCALL=0
UPDATE=no UPDATE=no
DATABASE=no DATABASE=no
NGINX=no NGINX=no
RED=`tput setaf 1`
GREEN=`tput setaf 2`
YELLOW=`tput setaf 3`
PURPLE=`tput setaf 5`
RESET=`tput sgr0`
fancy_echo() { fancy_echo() {
local fmt="$1"; shift local fmt="$1"; shift
@ -36,6 +45,12 @@ case $i in
NGINX=YES NGINX=YES
shift # past argument=value shift # past argument=value
;; ;;
-i|--install)
UPDATE=YES
NGINX=YES
DATABASE=YES
shift # past argument=value
;;
--default) --default)
DEFAULT=YES DEFAULT=YES
@ -48,10 +63,14 @@ esac
done done
fancy_echo "Installing Obrand Admin Server ..." fancy_echo "${YELLOW}Installing Obrand Admin Server ...${RESET}"
## Update initial packages ## Update initial packages
fancy_echo Cleaning... read -s -p "Enter Password for sudo: " sudoPW
# Download files.
fancy_echo "${RED}Cleaning...${RESET}"
if [ ! -d "$DEV" ]; then if [ ! -d "$DEV" ]; then
mkdir -p $DEV mkdir -p $DEV
@ -69,27 +88,34 @@ else
fi fi
if [[ $UPDATE = "yes" ]]; then if [[ $UPDATE = "YES" ]]; then
fancy_echo "${PURPLE}Updating system packages${RESET}"
if [ $(basename $PKG_MANAGER) = "yum" ]; then if [ $(basename $PKG_MANAGER) = "yum" ]; then
sudo yum --assumeyes upgrade echo $sudoPW | sudo -S yum --assumeyes upgrade
sudo yum --assumeyes install git make automake gcc gcc-c++ kernel-devel nginx htop screen wget curl postgresql postgresql-contrib echo $sudoPW | sudo -S yum --assumeyes install deltarpm psmisc
echo $sudoPW | sudo -S yum --assumeyes install epel-release git make automake gcc gcc-c++ kernel-devel nginx htop screen wget curl postgresql postgresql-server postgresql-contrib
else else
sudo apt-get -y -q --force-yes update echo $sudoPW | sudo -S apt-get -y -q --force-yes update
sudo apt-get -y -q --force-yes upgrade echo $sudoPW | sudo -S apt-get -y -q --force-yes upgrade
sudo apt-get --assume-yes install build-essential git nginx htop screen wget curl postgresql postgresql-contrib echo $sudoPW | sudo -S apt-get --assume-yes install build-essential git nginx htop screen wget curl postgresql postgresql-contrib
fi fi
fi fi
# set up and install swap file # set up and install swap file
if [[ ! -f "$SWAP" ]]; then if [[ ! -f "$SWAP" ]]; then
sudo fallocate -l 1G $SWAP fancy_echo "${YELLOW}Setting up swapfile...${RESET}"
sudo chmod 600 $SWAP
sudo mkswap $SWAP echo $sudoPW | sudo -S fallocate -l 1G $SWAP
sudo swapon $SWAP echo $sudoPW | sudo -S chmod 600 $SWAP
echo $sudoPW | sudo -S mkswap $SWAP
echo $sudoPW | sudo -S swapon $SWAP
fi fi
# setup node and npm # setup node and npm
if [ ! -d "$NVM" ]; then if [ ! -d "$NVM" ]; then
fancy_echo "${YELLOW}Installing Node...${RESET}"
# Will enter here if $DIRECTORY exists, even if it contains spaces # Will enter here if $DIRECTORY exists, even if it contains spaces
curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.31.0/install.sh | bash curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.31.0/install.sh | bash
@ -98,17 +124,25 @@ if [ ! -d "$NVM" ]; then
source $HOME/.bashrc source $HOME/.bashrc
source $NVM/nvm.sh source $NVM/nvm.sh
nvm install $NVM_VERSION
fi fi
nvm install $NVM_VERSION
# get source and build # get source and build
# Install global packages. # Install global packages.
fancy_echo "Installing global packages ..."
fancy_echo "${YELLOW}Installing Node Global Packages...${RESET}"
npm set progress=false npm set progress=false
npm install -g gulp bower pm2 npm-check npm-install-missing ember-cli phantomjs-prebuilt npm install -g gulp bower pm2 npm-check npm-install-missing ember-cli phantomjs-prebuilt
pm2 completion install
NPM_PATH=$(which npm)
echo $sudoPW | sudo -S su -c "env PATH=$PATH:${NPM_PATH%/npm} pm2 startup linux -u $USER --hp $HOME"
if [ ! -d "$LIVE" ]; then if [ ! -d "$LIVE" ]; then
mkdir $LIVE mkdir $LIVE
fi fi
@ -122,7 +156,7 @@ cd $DEV
# Get latest version of Obrand Admin # Get latest version of Obrand Admin
if [ ! -d "$DEV/$FRONT/.git" ]; then if [ ! -d "$DEV/$FRONT/.git" ]; then
git clone https://censis.visualstudio.com/DefaultCollection/_git/O-Brand git clone $GIT_FRONTEND
else else
cd $DEV/$FRONT cd $DEV/$FRONT
git pull origin master git pull origin master
@ -130,7 +164,7 @@ else
fi fi
if [ ! -d "$DEV/$SERVER/.git" ]; then if [ ! -d "$DEV/$SERVER/.git" ]; then
git clone https://censis.visualstudio.com/DefaultCollection/O-Brand/_git/O-BrandServer git clone $GIT_SERVER
else else
cd $DEV/$SERVER cd $DEV/$SERVER
git pull origin master git pull origin master
@ -158,28 +192,92 @@ cd $DEV/$FRONT/dist
cp -ra . $STAGING/wwwroot cp -ra . $STAGING/wwwroot
if [[ $DATABASE = "yes" ]]; then if [[ $DATABASE = "YES" ]]; then
fancy_echo "${PURPLE}Setting up Database server...${RESET}"
echo Setting up Database server... if [ $(basename $PKG_MANAGER) = "yum" ]; then
# sudo su - postgres -c "$DEV/$DBSETUP" PGHOME=/var/lib/pgsql
# node dbconfig.js if [ ! -d "$PGHOME" ]; then
PGHOME=/var/lib/pgsql92
fi
echo $sudoPW | sudo -S rsync -vua `echo $DEV/$SERVER/pg_hba.conf` `echo $PGHOME/data`;
echo $sudoPW | sudo -S chown postgres:postgres `echo $PGHOME/data/pg_hba.conf`
# if [ -e "/var/lib/pgsql9/data/pg_hba.conf" ]; then
if sudo -u postgres test -f "/var/lib/pgsql9/data/pg_hba.conf"; then
echo "${RED}Other...${RESET}"
echo $sudoPW | sudo -s cp `echo $DEV/$SERVER/pg_hba.conf` /var/lib/pgsql9/data/pg_hba.conf
fi
if [ $SYSTEMDCALL -eq 1 ]; then
echo $sudoPW | sudo -S systemctl enable postgresql
sudo -S postgresql-setup initdb
else
echo $sudoPW | sudo -S service postgresql initdb
echo $sudoPW | sudo -S service postgresql restart
fi
else
PGHOME=/var/lib/postgresql
echo $sudoPW | sudo -S rsync -vua `echo $DEV/$SERVER/pg_hba.conf` /etc/postgresql/9.3/main/pg_hba.conf;
echo $sudoPW | sudo -S service postgresql restart
fi
cd $DEV/$SERVER
node dbconfig.js
fi fi
echo Copying... fancy_echo "${YELLOW}Copying files to LIVE...${RESET}"
rsync -uav --exclude .git $STAGING/ $LIVE rsync -uav --exclude .git $STAGING/ $LIVE
# Configure nginx # Configure nginx
if [[ $NGINX = "yes" ]]; then if [[ $NGINX = "YES" ]]; then
fancy_echo "${PURPLE}Setting up NGinx...${RESET}"
echo $sudoPW | sudo -S fuser -k 80/tcp
sudo fuser -k 80/tcp echo $sudoPW | sudo -S cp /etc/nginx/nginx.conf /etc/nginx/nginx.conf.$(date "+%b_%d_%Y_%H.%M.%S")
sudo wget https://dl.dropboxusercontent.com/u/233909/obrand/obrand.nginx -O /etc/nginx/sites-available/obrand && sudo ln -s /etc/nginx/sites-available/obrand /etc/nginx/sites-enabled/obrand if [ $(basename $PKG_MANAGER) = "yum" ]; then
sudo rm /etc/nginx/sites-enabled/default if [ $SYSTEMDCALL -eq 1 ]; then
echo $sudoPW | sudo -S systemctl start nginx
else
echo $sudoPW | sudo -S service nginx start
fi
wget https://dl.dropboxusercontent.com/u/233909/obrand/obrand.nginx -O $HOME/obrand.nginx
echo $sudoPW | sudo -S cp $HOME/obrand.nginx /etc/nginx/conf.d/obrand.conf
wget https://dl.dropboxusercontent.com/u/233909/obrand/nginx.conf -O $HOME/nginx.conf
echo $sudoPW | sudo -S cp $HOME/nginx.conf /etc/nginx/nginx.conf
if [ -f "/etc/nginx/conf.d/virtual.conf" ]; then
echo $sudoPW | sudo -S mv /etc/nginx/conf.d/virtual.conf /etc/nginx
fi
if [ -d "/var/cache/nginx/proxy" ]; then
echo $sudoPW | sudo -S mkdir -p /var/cache/nginx/proxy
fi
if [ $SYSTEMDCALL -eq 1 ]; then
echo $sudoPW | sudo -S systemctl restart nginx
else
echo $sudoPW | sudo -S service nginx restart
fi
else
echo $sudoPW | sudo -S wget https://dl.dropboxusercontent.com/u/233909/obrand/obrand.nginx -O /etc/nginx/sites-available/obrand && sudo ln -s /etc/nginx/sites-available/obrand /etc/nginx/sites-enabled/obrand
echo $sudoPW | sudo -S rm /etc/nginx/sites-enabled/default
echo $sudoPW | sudo -S /etc/init.d/nginx restart
fi
fi
npm set progress=true npm set progress=true
sudo /etc/init.d/nginx restart
fi

View File

@ -9,10 +9,18 @@ FRONT="SODashServer"
SWAP="/swapfile" SWAP="/swapfile"
PKG_MANAGER=$( command -v yum || command -v apt-get ) || echo "Neither yum nor apt-get found" PKG_MANAGER=$( command -v yum || command -v apt-get ) || echo "Neither yum nor apt-get found"
PKG_DEVICE=$(basename $PKG_MANAGER) PKG_DEVICE=$(basename $PKG_MANAGER)
pidof systemd && SYSTEMDCALL=1 || SYSTEMDCALL=0
UPDATE=no UPDATE=no
DATABASE=no DATABASE=no
NGINX=no NGINX=no
RED=`tput setaf 1`
GREEN=`tput setaf 2`
YELLOW=`tput setaf 3`
PURPLE=`tput setaf 5`
RESET=`tput sgr0`
fancy_echo() { fancy_echo() {
local fmt="$1"; shift local fmt="$1"; shift
@ -35,7 +43,12 @@ case $i in
NGINX=YES NGINX=YES
shift # past argument=value shift # past argument=value
;; ;;
-i|--install)
UPDATE=YES
NGINX=YES
DATABASE=YES
shift # past argument=value
;;
--default) --default)
DEFAULT=YES DEFAULT=YES
shift # past argument with no value shift # past argument with no value
@ -47,10 +60,12 @@ esac
done done
fancy_echo "Installing Smart Office Console Server ..." fancy_echo "${YELLOW}Installing Smart Office Console Server ...${RESET}"
## Update initial packages ## Update initial packages
fancy_echo Cleaning... read -s -p "Enter Password for sudo: " sudoPW
fancy_echo "${RED}Cleaning...${RESET}"
if [ ! -d "$DEV" ]; then if [ ! -d "$DEV" ]; then
mkdir -p $DEV mkdir -p $DEV
@ -69,26 +84,33 @@ fi
if [[ $UPDATE = "YES" ]]; then if [[ $UPDATE = "YES" ]]; then
fancy_echo "${PURPLE}Updating system packages${RESET}"
if [ $(basename $PKG_MANAGER) = "yum" ]; then if [ $(basename $PKG_MANAGER) = "yum" ]; then
sudo yum --assumeyes upgrade echo $sudoPW | sudo -S yum --assumeyes upgrade
sudo yum --assumeyes install git make automake gcc gcc-c++ kernel-devel nginx htop screen wget curl postgresql postgresql-contrib echo $sudoPW | sudo -S yum --assumeyes install deltarpm psmisc
echo $sudoPW | sudo -S yum --assumeyes install git make automake gcc gcc-c++ kernel-devel nginx htop screen wget curl
else else
sudo apt-get -y -q --force-yes update echo $sudoPW | sudo -S apt-get -y -q --force-yes update
sudo apt-get -y -q --force-yes upgrade echo $sudoPW | sudo -S apt-get -y -q --force-yes upgrade
sudo apt-get --assume-yes install build-essential git nginx htop screen wget curl postgresql postgresql-contrib echo $sudoPW | sudo -S apt-get --assume-yes install build-essential git nginx htop screen wget curl
fi fi
fi fi
# set up and install swap file # set up and install swap file
if [[ ! -f "$SWAP" ]]; then if [[ ! -f "$SWAP" ]]; then
sudo fallocate -l 1G $SWAP fancy_echo "${YELLOW}Setting up swapfile...${RESET}"
sudo chmod 600 $SWAP
sudo mkswap $SWAP echo $sudoPW | sudo -S fallocate -l 1G $SWAP
sudo swapon $SWAP echo $sudoPW | sudo -S chmod 600 $SWAP
echo $sudoPW | sudo -S mkswap $SWAP
echo $sudoPW | sudo -S swapon $SWAP
fi fi
# setup node and npm # setup node and npm
if [ ! -d "$NVM" ]; then if [ ! -d "$NVM" ]; then
fancy_echo "${YELLOW}Installing Node...${RESET}"
# Will enter here if $DIRECTORY exists, even if it contains spaces # Will enter here if $DIRECTORY exists, even if it contains spaces
curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.31.0/install.sh | bash curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.31.0/install.sh | bash
@ -97,32 +119,23 @@ if [ ! -d "$NVM" ]; then
source $HOME/.bashrc source $HOME/.bashrc
source $NVM/nvm.sh source $NVM/nvm.sh
nvm install $NVM_VERSION
fi fi
nvm install $NVM_VERSION
# get source and build # get source and build
# Install global packages. # Install global packages.
npm set progress=false npm set progress=false
if [[ $UPDATE = "YES" ]]; then if [[ $UPDATE = "YES" ]]; then
fancy_echo "Installing global packages ..." fancy_echo "${YELLOW}Installing Node Global Packages...${RESET}"
npm install -g gulp bower pm2 npm-check npm-install-missing ember-cli phantomjs-prebuilt npm install -g gulp bower pm2@latest npm-check npm-install-missing ember-cli phantomjs-prebuilt
fi pm2 update
if [ ! -d "$LIVE" ]; then
mkdir $LIVE
fi
if [ ! -d "$DEV" ]; then
mkdir $DEV
fi fi
cd $DEV cd $DEV
# Get latest version of Obrand Admin # Get latest version of smartoffice Admin Server
if [ ! -d "$DEV/$FRONT/.git" ]; then if [ ! -d "$DEV/$FRONT/.git" ]; then
git clone http://gitlab.silvrtree.co.uk/martind2000/SODashServer.git git clone http://gitlab.silvrtree.co.uk/martind2000/SODashServer.git
else else
@ -131,32 +144,57 @@ else
fi fi
cd $DEV/$FRONT
# Get latest version of Obrand Admin Server
cd $DEV/$FRONT
npm install . && npm-install-missing npm install . && npm-install-missing
bower install bower install
gulp default gulp default
rsync -uav --exclude .git $DEV/$FRONT/ $STAGING rsync -uav --exclude .git $DEV/$FRONT/ $STAGING
fancy_echo "${YELLOW}Copying files to LIVE...${RESET}"
echo Copying...
rsync -uav --exclude .git $STAGING/ $LIVE rsync -uav --exclude .git $STAGING/ $LIVE
npm set progress=true npm set progress=true
# Configure nginx # Configure nginx
if [[ $NGINX = "YES" ]]; then if [[ $NGINX = "YES" ]]; then
fancy_echo "${PURPLE}Setting up NGinx...${RESET}"
echo $sudoPW | sudo -S fuser -k 80/tcp
sudo fuser -k 80/tcp echo $sudoPW | sudo -S cp /etc/nginx/nginx.conf /etc/nginx/nginx.conf.$(date "+%b_%d_%Y_%H.%M.%S")
sudo wget https://dl.dropboxusercontent.com/u/233909/smartoffice/smartoffice.nginx -O /etc/nginx/sites-available/smartoffice.nginx && sudo ln -s /etc/nginx/sites-available/smartoffice.nginx /etc/nginx/sites-enabled/smartoffice.nginx if [ $(basename $PKG_MANAGER) = "yum" ]; then
sudo rm /etc/nginx/sites-enabled/default if [ $SYSTEMDCALL -eq 1 ]; then
echo $sudoPW | sudo -S systemctl start nginx
else
echo $sudoPW | sudo -S service nginx start
fi
sudo /etc/init.d/nginx restart wget https://dl.dropboxusercontent.com/u/233909/smartoffice/smartoffice.nginx -O $HOME/smartoffice.nginx
echo $sudoPW | sudo -S cp $HOME/smartoffice.nginx /etc/nginx/conf.d/smartoffice.conf
fi wget https://dl.dropboxusercontent.com/u/233909/smartoffice/nginx.conf -O $HOME/nginx.conf
echo $sudoPW | sudo -S cp $HOME/nginx.conf /etc/nginx/nginx.conf
if [ -f "/etc/nginx/conf.d/virtual.conf" ]; then
echo $sudoPW | sudo -S mv /etc/nginx/conf.d/virtual.conf /etc/nginx
fi
if [ -d "/var/cache/nginx/proxy" ]; then
echo $sudoPW | sudo -S mkdir -p /var/cache/nginx/proxy
fi
if [ $SYSTEMDCALL -eq 1 ]; then
echo $sudoPW | sudo -S systemctl restart nginx
else
echo $sudoPW | sudo -S service nginx restart
fi
else
echo $sudoPW | sudo -S wget https://dl.dropboxusercontent.com/u/233909/smartoffice/smartoffice.nginx -O /etc/nginx/sites-available/smartoffice.conf && sudo ln -s /etc/nginx/sites-available/smartoffice.conf /etc/nginx/sites-enabled/smartoffice.conf
echo $sudoPW | sudo -S rm /etc/nginx/sites-enabled/default
echo $sudoPW | sudo -S /etc/init.d/nginx restart
fi
fi

View File

@ -41,3 +41,12 @@ export PATH="$PATH:$HOME/android-sdk-macosx/tools:$HOME/android-sdk-macosx/platf
[[ -s /Users/martin/.nvm/nvm.sh ]] && . /Users/martin/.nvm/nvm.sh # This loads NVM [[ -s /Users/martin/.nvm/nvm.sh ]] && . /Users/martin/.nvm/nvm.sh # This loads NVM
##
# Your previous /Users/martin/.bash_profile file was backed up as /Users/martin/.bash_profile.macports-saved_2016-05-04_at_13:31:48
##
# MacPorts Installer addition on 2016-05-04_at_13:31:48: adding an appropriate PATH variable for use with MacPorts.
export PATH="/opt/local/bin:/opt/local/sbin:$PATH"
# Finished adapting your PATH environment variable for use with MacPorts.

View File

@ -24,22 +24,26 @@ prompt_git() {
# Check for uncommitted changes in the index. # Check for uncommitted changes in the index.
if ! $(git diff --quiet --ignore-submodules --cached); then if ! $(git diff --quiet --ignore-submodules --cached); then
s+='+'; # s+='+';
s+=' 🚧';
fi; fi;
# Check for unstaged changes. # Check for unstaged changes.
if ! $(git diff-files --quiet --ignore-submodules --); then if ! $(git diff-files --quiet --ignore-submodules --); then
s+='!'; # s+='!';
s+=' ❗️';
fi; fi;
# Check for untracked files. # Check for untracked files.
if [ -n "$(git ls-files --others --exclude-standard)" ]; then if [ -n "$(git ls-files --others --exclude-standard)" ]; then
s+='?'; # s+='?';
s+=' 🚩';
fi; fi;
# Check for stashed files. # Check for stashed files.
if $(git rev-parse --verify refs/stash &>/dev/null); then if $(git rev-parse --verify refs/stash &>/dev/null); then
s+='$'; # s+='$';
s+=' 📤';
fi; fi;
fi; fi;
@ -51,7 +55,7 @@ prompt_git() {
git rev-parse --short HEAD 2> /dev/null || \ git rev-parse --short HEAD 2> /dev/null || \
echo '(unknown)')"; echo '(unknown)')";
[ -n "${s}" ] && s=" [${s}]"; [ -n "${s}" ] && s=" ${s} ";
echo -e "${1}${branchName}${2}${s}"; echo -e "${1}${branchName}${2}${s}";
else else
@ -113,7 +117,8 @@ PS1+="\[${white}\] in ";
PS1+="\[${green}\]\w"; # working directory full path PS1+="\[${green}\]\w"; # working directory full path
PS1+="\$(prompt_git \"\[${white}\] on \[${violet}\]\" \"\[${blue}\]\")"; # Git repository details PS1+="\$(prompt_git \"\[${white}\] on \[${violet}\]\" \"\[${blue}\]\")"; # Git repository details
PS1+="\n"; PS1+="\n";
PS1+="\[${white}\]\$ \[${reset}\]"; # `$` (and reset color) #PS1+="\[${white}\]\$ \[${reset}\]"; # `$` (and reset color)
PS1+="\[${white}\]\$ \[${reset}\]"; # ${s} (and reset color)
export PS1; export PS1;
PS2="\[${yellow}\]→ \[${reset}\]"; PS2="\[${yellow}\]→ \[${reset}\]";