Page MenuHomeDevCentral

D2534.id6398.diff
No OneTemporary

D2534.id6398.diff

diff --git a/Dockerfile b/Dockerfile
--- a/Dockerfile
+++ b/Dockerfile
@@ -13,16 +13,19 @@
WORKDIR /var/wwwroot/default
-RUN setup-nodesource-deb && apt-get install -y nodejs && \
+RUN setup-nodesource-deb && apt-get install -y nodejs python2 g++ && \
apt-get clean && rm -rf /var/lib/apt/lists/* && \
git clone https://devcentral.nasqueron.org/source/auth-grove.git . && \
- composer install --no-dev -o && \
- npm install -g gulp && \
- npm install && \
chown -R app:app /var/wwwroot/default
+USER app
+RUN composer install --no-dev --no-scripts -o && \
+ npm install && \
+ npm run production
+
#
# Run the container
#
+USER root
CMD ["/usr/local/sbin/init-container"]
diff --git a/files/usr/local/sbin/setup-nodesource-deb b/files/usr/local/sbin/setup-nodesource-deb
--- a/files/usr/local/sbin/setup-nodesource-deb
+++ b/files/usr/local/sbin/setup-nodesource-deb
@@ -3,17 +3,28 @@
# Discussion, issues and change requests at:
# https://github.com/nodesource/distributions
#
-# Script to install the NodeSource Node.js v6.x repo onto a
+# Script to install the NodeSource Node.js 17.x repo onto a
# Debian or Ubuntu system.
#
# Run as root or insert `sudo -E` before `bash`:
#
-# curl -sL https://deb.nodesource.com/setup_6.x | bash -
+# curl -sL https://deb.nodesource.com/setup_17.x | bash -
# or
-# wget -qO- https://deb.nodesource.com/setup_6.x | bash -
+# wget -qO- https://deb.nodesource.com/setup_17.x | bash -
#
+# CONTRIBUTIONS TO THIS SCRIPT
+#
+# This script is built from a template in
+# https://github.com/nodesource/distributions/tree/master/deb/src
+# please don't submit pull requests against the built scripts.
+#
+
export DEBIAN_FRONTEND=noninteractive
+SCRSUFFIX="_17.x"
+NODENAME="Node.js 17.x"
+NODEREPO="node_17.x"
+NODEPKG="nodejs"
print_status() {
echo
@@ -21,6 +32,41 @@
echo
}
+if test -t 1; then # if terminal
+ ncolors=$(which tput > /dev/null && tput colors) # supports color
+ if test -n "$ncolors" && test $ncolors -ge 8; then
+ termcols=$(tput cols)
+ bold="$(tput bold)"
+ underline="$(tput smul)"
+ standout="$(tput smso)"
+ normal="$(tput sgr0)"
+ black="$(tput setaf 0)"
+ red="$(tput setaf 1)"
+ green="$(tput setaf 2)"
+ yellow="$(tput setaf 3)"
+ blue="$(tput setaf 4)"
+ magenta="$(tput setaf 5)"
+ cyan="$(tput setaf 6)"
+ white="$(tput setaf 7)"
+ fi
+fi
+
+print_bold() {
+ title="$1"
+ text="$2"
+
+ echo
+ echo "${red}================================================================================${normal}"
+ echo "${red}================================================================================${normal}"
+ echo
+ echo -e " ${bold}${yellow}${title}${normal}"
+ echo
+ echo -en " ${text}"
+ echo
+ echo "${red}================================================================================${normal}"
+ echo "${red}================================================================================${normal}"
+}
+
bail() {
echo 'Error executing command, exiting'
exit 1
@@ -35,9 +81,95 @@
exec_cmd_nobail "$1" || bail
}
+node_deprecation_warning() {
+ if [[ "X${NODENAME}" == "Xio.js 1.x" ||
+ "X${NODENAME}" == "Xio.js 2.x" ||
+ "X${NODENAME}" == "Xio.js 3.x" ||
+ "X${NODENAME}" == "XNode.js 0.10" ||
+ "X${NODENAME}" == "XNode.js 0.12" ||
+ "X${NODENAME}" == "XNode.js 4.x LTS Argon" ||
+ "X${NODENAME}" == "XNode.js 5.x" ||
+ "X${NODENAME}" == "XNode.js 6.x LTS Boron" ||
+ "X${NODENAME}" == "XNode.js 7.x" ||
+ "X${NODENAME}" == "XNode.js 8.x LTS Carbon" ||
+ "X${NODENAME}" == "XNode.js 9.x" ||
+ "X${NODENAME}" == "XNode.js 10.x" ||
+ "X${NODENAME}" == "XNode.js 11.x" ||
+ "X${NODENAME}" == "XNode.js 13.x" ||
+ "X${NODENAME}" == "XNode.js 15.x" ]]; then
+
+ print_bold \
+" DEPRECATION WARNING " "\
+${bold}${NODENAME} is no longer actively supported!${normal}
+
+ ${bold}You will not receive security or critical stability updates${normal} for this version.
+
+ You should migrate to a supported version of Node.js as soon as possible.
+ Use the installation script that corresponds to the version of Node.js you
+ wish to install. e.g.
+
+ * ${green}https://deb.nodesource.com/setup_12.x — Node.js 12 LTS \"Erbium\"${normal}
+ * ${green}https://deb.nodesource.com/setup_14.x — Node.js 14 LTS \"Fermium\"${normal} (recommended)
+ * ${green}https://deb.nodesource.com/setup_16.x — Node.js 16 \"Gallium\"${normal}
+ * ${green}https://deb.nodesource.com/setup_17.x — Node.js 17 \"Seventeen\"${normal} (current)
+
+ Please see ${bold}https://github.com/nodejs/Release${normal} for details about which
+ version may be appropriate for you.
+
+ The ${bold}NodeSource${normal} Node.js distributions repository contains
+ information both about supported versions of Node.js and supported Linux
+ distributions. To learn more about usage, see the repository:
+ ${bold}https://github.com/nodesource/distributions${normal}
+"
+ echo
+ echo "Continuing in 20 seconds ..."
+ echo
+ sleep 20
+ fi
+}
+
+script_deprecation_warning() {
+ if [ "X${SCRSUFFIX}" == "X" ]; then
+ print_bold \
+" SCRIPT DEPRECATION WARNING " "\
+This script, located at ${bold}https://deb.nodesource.com/setup${normal}, used to
+ install Node.js 0.10, is deprecated and will eventually be made inactive.
+
+ You should use the script that corresponds to the version of Node.js you
+ wish to install. e.g.
-print_status "Installing the NodeSource Node.js v6.x repo..."
+ * ${green}https://deb.nodesource.com/setup_12.x — Node.js 12 LTS \"Erbium\"${normal}
+ * ${green}https://deb.nodesource.com/setup_14.x — Node.js 14 LTS \"Fermium\"${normal} (recommended)
+ * ${green}https://deb.nodesource.com/setup_16.x — Node.js 16 \"Gallium\"${normal}
+ * ${green}https://deb.nodesource.com/setup_17.x — Node.js 17 \"Seventeen\"${normal} (current)
+ Please see ${bold}https://github.com/nodejs/Release${normal} for details about which
+ version may be appropriate for you.
+
+ The ${bold}NodeSource${normal} Node.js Linux distributions GitHub repository contains
+ information about which versions of Node.js and which Linux distributions
+ are supported and how to use the install scripts.
+ ${bold}https://github.com/nodesource/distributions${normal}
+"
+
+ echo
+ echo "Continuing in 20 seconds (press Ctrl-C to abort) ..."
+ echo
+ sleep 20
+ fi
+}
+
+setup() {
+
+script_deprecation_warning
+node_deprecation_warning
+
+print_status "Installing the NodeSource ${NODENAME} repo..."
+
+if $(uname -m | grep -Eq ^armv6); then
+ print_status "You appear to be running on ARMv6 hardware. Unfortunately this is not currently supported by the NodeSource Linux distributions. Please use the 'linux-armv6l' binary tarballs available directly from nodejs.org for Node.js 4 and later."
+ exit 1
+fi
PRE_INSTALL_PKGS=""
@@ -56,6 +188,12 @@
PRE_INSTALL_PKGS="${PRE_INSTALL_PKGS} curl"
fi
+# Used by apt-key to add new keys
+
+if [ ! -x /usr/bin/gpg ]; then
+ PRE_INSTALL_PKGS="${PRE_INSTALL_PKGS} gnupg"
+fi
+
# Populating Cache
print_status "Populating apt-get cache..."
exec_cmd 'apt-get update'
@@ -67,6 +205,12 @@
exec_cmd "apt-get install -y${PRE_INSTALL_PKGS} > /dev/null 2>&1"
fi
+IS_PRERELEASE=$(lsb_release -d | grep 'Ubuntu .*development' >& /dev/null; echo $?)
+if [[ $IS_PRERELEASE -eq 0 ]]; then
+ print_status "Your distribution, identified as \"$(lsb_release -d -s)\", is a pre-release version of Ubuntu. NodeSource does not maintain official support for Ubuntu versions until they are formally released. You can try using the manual installation instructions available at https://github.com/nodesource/distributions and use the latest supported Ubuntu version name as the distribution identifier, although this is not guaranteed to work."
+ exit 1
+fi
+
DISTRO=$(lsb_release -c -s)
check_alt() {
@@ -78,21 +222,71 @@
fi
}
+check_alt "SolydXK" "solydxk-9" "Debian" "stretch"
check_alt "Kali" "sana" "Debian" "jessie"
-check_alt "Debian" "stretch" "Debian" "jessie"
+check_alt "Kali" "kali-rolling" "Debian" "bullseye"
+check_alt "Sparky Linux" "Tyche" "Debian" "stretch"
+check_alt "Sparky Linux" "Nibiru" "Debian" "buster"
+check_alt "Sparky Linux" "Po-Tolo" "Debian" "bullseye"
+check_alt "MX Linux 17" "Horizon" "Debian" "stretch"
+check_alt "MX Linux 18" "Continuum" "Debian" "stretch"
+check_alt "MX Linux 19" "patito feo" "Debian" "buster"
+check_alt "MX Linux 21" "wildflower" "Debian" "bullseye"
check_alt "Linux Mint" "maya" "Ubuntu" "precise"
check_alt "Linux Mint" "qiana" "Ubuntu" "trusty"
check_alt "Linux Mint" "rafaela" "Ubuntu" "trusty"
check_alt "Linux Mint" "rebecca" "Ubuntu" "trusty"
check_alt "Linux Mint" "rosa" "Ubuntu" "trusty"
+check_alt "Linux Mint" "sarah" "Ubuntu" "xenial"
+check_alt "Linux Mint" "serena" "Ubuntu" "xenial"
+check_alt "Linux Mint" "sonya" "Ubuntu" "xenial"
+check_alt "Linux Mint" "sylvia" "Ubuntu" "xenial"
+check_alt "Linux Mint" "tara" "Ubuntu" "bionic"
+check_alt "Linux Mint" "tessa" "Ubuntu" "bionic"
+check_alt "Linux Mint" "tina" "Ubuntu" "bionic"
+check_alt "Linux Mint" "tricia" "Ubuntu" "bionic"
+check_alt "Linux Mint" "ulyana" "Ubuntu" "focal"
+check_alt "Linux Mint" "ulyssa" "Ubuntu" "focal"
+check_alt "Linux Mint" "uma" "Ubuntu" "focal"
+check_alt "Linux Mint" "una" "Ubuntu" "focal"
check_alt "LMDE" "betsy" "Debian" "jessie"
+check_alt "LMDE" "cindy" "Debian" "stretch"
+check_alt "LMDE" "debbie" "Debian" "buster"
check_alt "elementaryOS" "luna" "Ubuntu" "precise"
check_alt "elementaryOS" "freya" "Ubuntu" "trusty"
+check_alt "elementaryOS" "loki" "Ubuntu" "xenial"
+check_alt "elementaryOS" "juno" "Ubuntu" "bionic"
+check_alt "elementaryOS" "hera" "Ubuntu" "bionic"
+check_alt "elementaryOS" "odin" "Ubuntu" "focal"
+check_alt "elementaryOS" "jolnir" "Ubuntu" "focal"
check_alt "Trisquel" "toutatis" "Ubuntu" "precise"
check_alt "Trisquel" "belenos" "Ubuntu" "trusty"
+check_alt "Trisquel" "flidas" "Ubuntu" "xenial"
+check_alt "Trisquel" "etiona" "Ubuntu" "bionic"
+check_alt "Uruk GNU/Linux" "lugalbanda" "Ubuntu" "xenial"
check_alt "BOSS" "anokha" "Debian" "wheezy"
+check_alt "BOSS" "anoop" "Debian" "jessie"
+check_alt "BOSS" "drishti" "Debian" "stretch"
+check_alt "BOSS" "unnati" "Debian" "buster"
check_alt "bunsenlabs" "bunsen-hydrogen" "Debian" "jessie"
-check_alt "Tanglu" "chromodoris" "Debian" "jessie"
+check_alt "bunsenlabs" "helium" "Debian" "stretch"
+check_alt "bunsenlabs" "lithium" "Debian" "buster"
+check_alt "Tanglu" "chromodoris" "Debian" "jessie"
+check_alt "PureOS" "green" "Debian" "sid"
+check_alt "PureOS" "amber" "Debian" "buster"
+check_alt "PureOS" "byzantium" "Debian" "bullseye"
+check_alt "Devuan" "jessie" "Debian" "jessie"
+check_alt "Devuan" "ascii" "Debian" "stretch"
+check_alt "Devuan" "beowulf" "Debian" "buster"
+check_alt "Devuan" "chimaera" "Debian" "bullseye"
+check_alt "Devuan" "ceres" "Debian" "sid"
+check_alt "Deepin" "panda" "Debian" "sid"
+check_alt "Deepin" "unstable" "Debian" "sid"
+check_alt "Deepin" "stable" "Debian" "buster"
+check_alt "Pardus" "onyedi" "Debian" "stretch"
+check_alt "Liquid Lemur" "lemur-3" "Debian" "stretch"
+check_alt "Astra Linux" "orel" "Debian" "stretch"
+check_alt "Ubilinux" "dolcetto" "Debian" "stretch"
if [ "X${DISTRO}" == "Xdebian" ]; then
print_status "Unknown Debian-based distribution, checking /etc/debian_version..."
@@ -108,10 +302,10 @@
print_status "Confirming \"${DISTRO}\" is supported..."
if [ -x /usr/bin/curl ]; then
- exec_cmd_nobail "curl -sLf -o /dev/null 'https://deb.nodesource.com/node_6.x/dists/${DISTRO}/Release'"
+ exec_cmd_nobail "curl -sLf -o /dev/null 'https://deb.nodesource.com/${NODEREPO}/dists/${DISTRO}/Release'"
RC=$?
else
- exec_cmd_nobail "wget -qO /dev/null -o /dev/null 'https://deb.nodesource.com/node_6.x/dists/${DISTRO}/Release'"
+ exec_cmd_nobail "wget -qO /dev/null -o /dev/null 'https://deb.nodesource.com/${NODEREPO}/dists/${DISTRO}/Release'"
RC=$?
fi
@@ -128,20 +322,39 @@
fi
print_status 'Adding the NodeSource signing key to your keyring...'
+keyring='/usr/share/keyrings'
+node_key_url="https://deb.nodesource.com/gpgkey/nodesource.gpg.key"
+local_node_key="$keyring/nodesource.gpg"
if [ -x /usr/bin/curl ]; then
- exec_cmd 'curl -s https://deb.nodesource.com/gpgkey/nodesource.gpg.key | apt-key add -'
+ exec_cmd "curl -s $node_key_url | gpg --dearmor | tee $local_node_key >/dev/null"
else
- exec_cmd 'wget -qO- https://deb.nodesource.com/gpgkey/nodesource.gpg.key | apt-key add -'
+ exec_cmd "wget -q -O - $node_key_url | gpg --dearmor | tee $local_node_key >/dev/null"
fi
-print_status 'Creating apt sources list file for the NodeSource Node.js v6.x repo...'
+print_status "Creating apt sources list file for the NodeSource ${NODENAME} repo..."
-exec_cmd "echo 'deb https://deb.nodesource.com/node_6.x ${DISTRO} main' > /etc/apt/sources.list.d/nodesource.list"
-exec_cmd "echo 'deb-src https://deb.nodesource.com/node_6.x ${DISTRO} main' >> /etc/apt/sources.list.d/nodesource.list"
+exec_cmd "echo 'deb [signed-by=$local_node_key] https://deb.nodesource.com/${NODEREPO} ${DISTRO} main' > /etc/apt/sources.list.d/nodesource.list"
+exec_cmd "echo 'deb-src [signed-by=$local_node_key] https://deb.nodesource.com/${NODEREPO} ${DISTRO} main' >> /etc/apt/sources.list.d/nodesource.list"
print_status 'Running `apt-get update` for you...'
exec_cmd 'apt-get update'
-print_status 'Run `apt-get install nodejs` (as root) to install Node.js v6.x and npm'
+yarn_site='https://dl.yarnpkg.com/debian'
+yarn_key_url="$yarn_site/pubkey.gpg"
+local_yarn_key="$keyring/yarnkey.gpg"
+
+print_status """Run \`${bold}sudo apt-get install -y ${NODEPKG}${normal}\` to install ${NODENAME} and npm
+## You may also need development tools to build native addons:
+ sudo apt-get install gcc g++ make
+## To install the Yarn package manager, run:
+ curl -sL $yarn_key_url | gpg --dearmor | sudo tee $local_yarn_key >/dev/null
+ echo \"deb [signed-by=$local_yarn_key] $yarn_site stable main\" | sudo tee /etc/apt/sources.list.d/yarn.list
+ sudo apt-get update && sudo apt-get install yarn
+"""
+
+}
+
+## Defer setup until we have the complete script
+setup

File Metadata

Mime Type
text/plain
Expires
Fri, Dec 27, 08:16 (9 h, 52 m)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
2316094
Default Alt Text
D2534.id6398.diff (14 KB)

Event Timeline