Skip to content

Commit 4c374e5

Browse files
authored
fix: npm: refactor for v2.13.x (#8870)
1 parent 258b2c8 commit 4c374e5

File tree

2 files changed

+89
-91
lines changed

2 files changed

+89
-91
lines changed

ct/nginxproxymanager.sh

Lines changed: 59 additions & 52 deletions
Original file line numberDiff line numberDiff line change
@@ -1,15 +1,15 @@
11
#!/usr/bin/env bash
22
source <(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/misc/build.func)
3-
# Copyright (c) 2021-2025 tteck
4-
# Author: tteck (tteckster)
3+
# Copyright (c) 2021-2025 Community-Script ORG
4+
# Author: tteck (tteckster) | Co-Author: CrazyWolf13
55
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
66
# Source: https://nginxproxymanager.com/
77

88
APP="Nginx Proxy Manager"
99
var_tags="${var_tags:-proxy}"
1010
var_cpu="${var_cpu:-2}"
11-
var_ram="${var_ram:-1024}"
12-
var_disk="${var_disk:-4}"
11+
var_ram="${var_ram:-2048}"
12+
var_disk="${var_disk:-8}"
1313
var_os="${var_os:-debian}"
1414
var_version="${var_version:-13}"
1515
var_unprivileged="${var_unprivileged:-1}"
@@ -42,60 +42,47 @@ function update_script() {
4242
fi
4343

4444
NODE_VERSION="22" NODE_MODULE="yarn" setup_nodejs
45-
export NODE_OPTIONS="--openssl-legacy-provider"
4645

4746
RELEASE=$(curl -fsSL https://api.github.com/repos/NginxProxyManager/nginx-proxy-manager/releases/latest |
4847
grep "tag_name" |
4948
awk '{print substr($2, 3, length($2)-4) }')
5049

51-
msg_info "Downloading NPM v${RELEASE}"
52-
curl -fsSL "https://codeload.github.com/NginxProxyManager/nginx-proxy-manager/tar.gz/v${RELEASE}" | tar -xz
53-
cd nginx-proxy-manager-"${RELEASE}" || exit
54-
msg_ok "Downloaded NPM v${RELEASE}"
55-
56-
msg_info "Building Frontend"
57-
(
58-
sed -i "s|\"version\": \"0.0.0\"|\"version\": \"$RELEASE\"|" backend/package.json
59-
sed -i "s|\"version\": \"0.0.0\"|\"version\": \"$RELEASE\"|" frontend/package.json
60-
cd ./frontend || exit
61-
# Replace node-sass with sass in package.json before installation
62-
sed -i 's/"node-sass".*$/"sass": "^1.92.1",/g' package.json
63-
$STD yarn install --network-timeout 600000
64-
$STD yarn build
65-
)
66-
msg_ok "Built Frontend"
50+
fetch_and_deploy_gh_release "nginxproxymanager" "NginxProxyManager/nginx-proxy-manager"
6751

6852
msg_info "Stopping Services"
6953
systemctl stop openresty
7054
systemctl stop npm
7155
msg_ok "Stopped Services"
7256

73-
msg_info "Cleaning Old Files"
74-
rm -rf /app \
57+
msg_info "Cleaning old files"
58+
$STD rm -rf /app \
7559
/var/www/html \
7660
/etc/nginx \
7761
/var/log/nginx \
7862
/var/lib/nginx \
79-
"$STD" /var/cache/nginx
80-
msg_ok "Cleaned Old Files"
63+
/var/cache/nginx
64+
msg_ok "Cleaned old files"
8165

8266
msg_info "Setting up Environment"
8367
ln -sf /usr/bin/python3 /usr/bin/python
84-
ln -sf /opt/certbot/bin/certbot /usr/local/bin/certbot
8568
ln -sf /usr/local/openresty/nginx/sbin/nginx /usr/sbin/nginx
8669
ln -sf /usr/local/openresty/nginx/ /etc/nginx
87-
sed -i 's+^daemon+#daemon+g' docker/rootfs/etc/nginx/nginx.conf
88-
NGINX_CONFS=$(find "$(pwd)" -type f -name "*.conf")
70+
sed -i "s|\"version\": \"2.0.0\"|\"version\": \"$RELEASE\"|" /opt/nginxproxymanager/backend/package.json
71+
sed -i "s|\"version\": \"2.0.0\"|\"version\": \"$RELEASE\"|" /opt/nginxproxymanager/frontend/package.json
72+
sed -i 's+^daemon+#daemon+g' /opt/nginxproxymanager/docker/rootfs/etc/nginx/nginx.conf
73+
NGINX_CONFS=$(find /opt/nginxproxymanager -type f -name "*.conf")
8974
for NGINX_CONF in $NGINX_CONFS; do
9075
sed -i 's+include conf.d+include /etc/nginx/conf.d+g' "$NGINX_CONF"
9176
done
77+
9278
mkdir -p /var/www/html /etc/nginx/logs
93-
cp -r docker/rootfs/var/www/html/* /var/www/html/
94-
cp -r docker/rootfs/etc/nginx/* /etc/nginx/
95-
cp docker/rootfs/etc/letsencrypt.ini /etc/letsencrypt.ini
96-
cp docker/rootfs/etc/logrotate.d/nginx-proxy-manager /etc/logrotate.d/nginx-proxy-manager
79+
cp -r /opt/nginxproxymanager/docker/rootfs/var/www/html/* /var/www/html/
80+
cp -r /opt/nginxproxymanager/docker/rootfs/etc/nginx/* /etc/nginx/
81+
cp /opt/nginxproxymanager/docker/rootfs/etc/letsencrypt.ini /etc/letsencrypt.ini
82+
cp /opt/nginxproxymanager/docker/rootfs/etc/logrotate.d/nginx-proxy-manager /etc/logrotate.d/nginx-proxy-manager
9783
ln -sf /etc/nginx/nginx.conf /etc/nginx/conf/nginx.conf
9884
rm -f /etc/nginx/conf.d/dev.conf
85+
9986
mkdir -p /tmp/nginx/body \
10087
/run/nginx \
10188
/data/nginx \
@@ -112,27 +99,33 @@ function update_script() {
11299
/var/lib/nginx/cache/public \
113100
/var/lib/nginx/cache/private \
114101
/var/cache/nginx/proxy_temp
102+
115103
chmod -R 777 /var/cache/nginx
116104
chown root /tmp/nginx
105+
117106
echo resolver "$(awk 'BEGIN{ORS=" "} $1=="nameserver" {print ($2 ~ ":")? "["$2"]": $2}' /etc/resolv.conf);" >/etc/nginx/conf.d/include/resolvers.conf
107+
118108
if [ ! -f /data/nginx/dummycert.pem ] || [ ! -f /data/nginx/dummykey.pem ]; then
119109
$STD openssl req -new -newkey rsa:2048 -days 3650 -nodes -x509 -subj "/O=Nginx Proxy Manager/OU=Dummy Certificate/CN=localhost" -keyout /data/nginx/dummykey.pem -out /data/nginx/dummycert.pem
120110
fi
121-
mkdir -p /app/global /app/frontend/images
122-
cp -r frontend/dist/* /app/frontend
123-
cp -r frontend/app-images/* /app/frontend/images
124-
cp -r backend/* /app
125-
cp -r global/* /app/global
126111

127-
# Update Certbot and plugins in virtual environment
128-
if [ -d /opt/certbot ]; then
129-
$STD /opt/certbot/bin/pip install --upgrade pip setuptools wheel
130-
$STD /opt/certbot/bin/pip install --upgrade certbot certbot-dns-cloudflare
131-
fi
132-
msg_ok "Setup Environment"
112+
mkdir -p /app/frontend/images
113+
cp -r /opt/nginxproxymanager/backend/* /app
114+
msg_ok "Set up Environment"
115+
116+
msg_info "Building Frontend"
117+
export NODE_OPTIONS="--max_old_space_size=2048 --openssl-legacy-provider"
118+
cd /opt/nginxproxymanager/frontend
119+
# Replace node-sass with sass in package.json before installation
120+
sed -E -i 's/"node-sass" *: *"([^"]*)"/"sass": "\1"/g' package.json
121+
$STD yarn install --network-timeout 600000
122+
$STD yarn build
123+
cp -r /opt/nginxproxymanager/frontend/dist/* /app/frontend
124+
cp -r /opt/nginxproxymanager/frontend/public/images/* /app/frontend/images
125+
msg_ok "Built Frontend"
133126

134127
msg_info "Initializing Backend"
135-
$STD rm -rf /app/config/default.json
128+
rm -rf /app/config/default.json
136129
if [ ! -f /app/config/production.json ]; then
137130
cat <<'EOF' >/app/config/production.json
138131
{
@@ -148,23 +141,37 @@ function update_script() {
148141
}
149142
EOF
150143
fi
151-
cd /app || exit
152-
export NODE_OPTIONS="--openssl-legacy-provider"
144+
cd /app
153145
$STD yarn install --network-timeout 600000
154146
msg_ok "Initialized Backend"
147+
148+
msg_info "Updating Certbot"
149+
[ -f /etc/apt/trusted.gpg.d/openresty-archive-keyring.gpg ] && rm -f /etc/apt/trusted.gpg.d/openresty-archive-keyring.gpg
150+
[ -f /etc/apt/sources.list.d/openresty.list ] && rm -f /etc/apt/sources.list.d/openresty.list
151+
[ ! -f /etc/apt/trusted.gpg.d/openresty.gpg ] && curl -fsSL https://openresty.org/package/pubkey.gpg | gpg --dearmor --yes -o /etc/apt/trusted.gpg.d/openresty.gpg
152+
[ ! -f /etc/apt/sources.list.d/openresty.sources ] && cat <<'EOF' >/etc/apt/sources.list.d/openresty.sources
153+
Types: deb
154+
URIs: http://openresty.org/package/debian/
155+
Suites: bookworm
156+
Components: openresty
157+
Signed-By: /etc/apt/trusted.gpg.d/openresty.gpg
158+
EOF
159+
$STD apt update
160+
$STD apt -y install openresty
161+
if [ -d /opt/certbot ]; then
162+
$STD /opt/certbot/bin/pip install --upgrade pip setuptools wheel
163+
$STD /opt/certbot/bin/pip install --upgrade certbot certbot-dns-cloudflare
164+
fi
165+
msg_ok "Updated Certbot"
155166

156167
msg_info "Starting Services"
157168
sed -i 's/user npm/user root/g; s/^pid/#pid/g' /usr/local/openresty/nginx/conf/nginx.conf
158-
sed -i 's/su npm npm/su root root/g' /etc/logrotate.d/nginx-proxy-manager
159-
sed -i 's/include-system-site-packages = false/include-system-site-packages = true/g' /opt/certbot/pyvenv.cfg
169+
sed -r -i 's/^([[:space:]]*)su npm npm/\1#su npm npm/g;' /etc/logrotate.d/nginx-proxy-manager
160170
systemctl enable -q --now openresty
161171
systemctl enable -q --now npm
172+
systemctl restart openresty
162173
msg_ok "Started Services"
163174

164-
msg_info "Cleaning up"
165-
rm -rf ~/nginx-proxy-manager-*
166-
msg_ok "Cleaned"
167-
168175
msg_ok "Updated successfully!"
169176
exit
170177
}

install/nginxproxymanager-install.sh

Lines changed: 30 additions & 39 deletions
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,7 @@
11
#!/usr/bin/env bash
22

3-
# Copyright (c) 2021-2025 tteck
4-
# Author: tteck (tteckster)
3+
# Copyright (c) 2021-2025 Community-Scripts ORG
4+
# Author: tteck (tteckster) | Co-Author: CrazyWolf13
55
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
66
# Source: https://nginxproxymanager.com/
77

@@ -39,18 +39,15 @@ $STD /opt/certbot/bin/pip install certbot certbot-dns-cloudflare
3939
ln -sf /opt/certbot/bin/certbot /usr/local/bin/certbot
4040
msg_ok "Set up Certbot"
4141

42-
VERSION="$(awk -F'=' '/^VERSION_CODENAME=/{ print $NF }' /etc/os-release)"
43-
4442
msg_info "Installing Openresty"
45-
curl -fsSL "https://openresty.org/package/pubkey.gpg" | gpg --dearmor -o /etc/apt/trusted.gpg.d/openresty-archive-keyring.gpg
46-
case "$VERSION" in
47-
trixie)
48-
echo -e "deb http://openresty.org/package/debian bookworm openresty" >/etc/apt/sources.list.d/openresty.list
49-
;;
50-
*)
51-
echo -e "deb http://openresty.org/package/debian $VERSION openresty" >/etc/apt/sources.list.d/openresty.list
52-
;;
53-
esac
43+
curl -fsSL "https://openresty.org/package/pubkey.gpg" | gpg --dearmor -o /etc/apt/trusted.gpg.d/openresty.gpg
44+
cat <<'EOF' >/etc/apt/sources.list.d/openresty.sources
45+
Types: deb
46+
URIs: http://openresty.org/package/debian/
47+
Suites: bookworm
48+
Components: openresty
49+
Signed-By: /etc/apt/trusted.gpg.d/openresty.gpg
50+
EOF
5451
$STD apt update
5552
$STD apt -y install openresty
5653
msg_ok "Installed Openresty"
@@ -61,28 +58,25 @@ RELEASE=$(curl -fsSL https://api.github.com/repos/NginxProxyManager/nginx-proxy-
6158
grep "tag_name" |
6259
awk '{print substr($2, 3, length($2)-4) }')
6360

64-
msg_info "Downloading Nginx Proxy Manager v${RELEASE}"
65-
curl -fsSL "https://codeload.github.com/NginxProxyManager/nginx-proxy-manager/tar.gz/v${RELEASE}" | tar -xz
66-
cd ./nginx-proxy-manager-"${RELEASE}"
67-
msg_ok "Downloaded Nginx Proxy Manager v${RELEASE}"
61+
fetch_and_deploy_gh_release "nginxproxymanager" "NginxProxyManager/nginx-proxy-manager"
6862

6963
msg_info "Setting up Environment"
7064
ln -sf /usr/bin/python3 /usr/bin/python
7165
ln -sf /usr/local/openresty/nginx/sbin/nginx /usr/sbin/nginx
7266
ln -sf /usr/local/openresty/nginx/ /etc/nginx
73-
sed -i "s|\"version\": \"0.0.0\"|\"version\": \"$RELEASE\"|" backend/package.json
74-
sed -i "s|\"version\": \"0.0.0\"|\"version\": \"$RELEASE\"|" frontend/package.json
75-
sed -i 's+^daemon+#daemon+g' docker/rootfs/etc/nginx/nginx.conf
76-
NGINX_CONFS=$(find "$(pwd)" -type f -name "*.conf")
67+
sed -i "s|\"version\": \"2.0.0\"|\"version\": \"$RELEASE\"|" /opt/nginxproxymanager/backend/package.json
68+
sed -i "s|\"version\": \"2.0.0\"|\"version\": \"$RELEASE\"|" /opt/nginxproxymanager/frontend/package.json
69+
sed -i 's+^daemon+#daemon+g' /opt/nginxproxymanager/docker/rootfs/etc/nginx/nginx.conf
70+
NGINX_CONFS=$(find /opt/nginxproxymanager -type f -name "*.conf")
7771
for NGINX_CONF in $NGINX_CONFS; do
7872
sed -i 's+include conf.d+include /etc/nginx/conf.d+g' "$NGINX_CONF"
7973
done
8074

8175
mkdir -p /var/www/html /etc/nginx/logs
82-
cp -r docker/rootfs/var/www/html/* /var/www/html/
83-
cp -r docker/rootfs/etc/nginx/* /etc/nginx/
84-
cp docker/rootfs/etc/letsencrypt.ini /etc/letsencrypt.ini
85-
cp docker/rootfs/etc/logrotate.d/nginx-proxy-manager /etc/logrotate.d/nginx-proxy-manager
76+
cp -r /opt/nginxproxymanager/docker/rootfs/var/www/html/* /var/www/html/
77+
cp -r /opt/nginxproxymanager/docker/rootfs/etc/nginx/* /etc/nginx/
78+
cp /opt/nginxproxymanager/docker/rootfs/etc/letsencrypt.ini /etc/letsencrypt.ini
79+
cp /opt/nginxproxymanager/docker/rootfs/etc/logrotate.d/nginx-proxy-manager /etc/logrotate.d/nginx-proxy-manager
8680
ln -sf /etc/nginx/nginx.conf /etc/nginx/conf/nginx.conf
8781
rm -f /etc/nginx/conf.d/dev.conf
8882

@@ -109,23 +103,22 @@ chown root /tmp/nginx
109103
echo resolver "$(awk 'BEGIN{ORS=" "} $1=="nameserver" {print ($2 ~ ":")? "["$2"]": $2}' /etc/resolv.conf);" >/etc/nginx/conf.d/include/resolvers.conf
110104

111105
if [ ! -f /data/nginx/dummycert.pem ] || [ ! -f /data/nginx/dummykey.pem ]; then
112-
openssl req -new -newkey rsa:2048 -days 3650 -nodes -x509 -subj "/O=Nginx Proxy Manager/OU=Dummy Certificate/CN=localhost" -keyout /data/nginx/dummykey.pem -out /data/nginx/dummycert.pem &>/dev/null
106+
$STD openssl req -new -newkey rsa:2048 -days 3650 -nodes -x509 -subj "/O=Nginx Proxy Manager/OU=Dummy Certificate/CN=localhost" -keyout /data/nginx/dummykey.pem -out /data/nginx/dummycert.pem
113107
fi
114108

115-
mkdir -p /app/global /app/frontend/images
116-
cp -r backend/* /app
117-
cp -r global/* /app/global
109+
mkdir -p /app/frontend/images
110+
cp -r /opt/nginxproxymanager/backend/* /app
118111
msg_ok "Set up Environment"
119112

120113
msg_info "Building Frontend"
121-
cd ./frontend
122-
export NODE_OPTIONS="--openssl-legacy-provider"
114+
export NODE_OPTIONS="--max_old_space_size=2048 --openssl-legacy-provider"
115+
cd /opt/nginxproxymanager/frontend
123116
# Replace node-sass with sass in package.json before installation
124-
sed -i 's/"node-sass".*$/"sass": "^1.92.1",/g' package.json
117+
sed -E -i 's/"node-sass" *: *"([^"]*)"/"sass": "\1"/g' package.json
125118
$STD yarn install --network-timeout 600000
126119
$STD yarn build
127-
cp -r dist/* /app/frontend
128-
cp -r app-images/* /app/frontend/images
120+
cp -r /opt/nginxproxymanager/frontend/dist/* /app/frontend
121+
cp -r /opt/nginxproxymanager/frontend/public/images/* /app/frontend/images
129122
msg_ok "Built Frontend"
130123

131124
msg_info "Initializing Backend"
@@ -146,7 +139,6 @@ if [ ! -f /app/config/production.json ]; then
146139
EOF
147140
fi
148141
cd /app
149-
export NODE_OPTIONS="--openssl-legacy-provider"
150142
$STD yarn install --network-timeout 600000
151143
msg_ok "Initialized Backend"
152144

@@ -170,18 +162,17 @@ WantedBy=multi-user.target
170162
EOF
171163
msg_ok "Created Service"
172164

173-
motd_ssh
174-
customize
175-
176165
msg_info "Starting Services"
177166
sed -i 's/user npm/user root/g; s/^pid/#pid/g' /usr/local/openresty/nginx/conf/nginx.conf
178167
sed -r -i 's/^([[:space:]]*)su npm npm/\1#su npm npm/g;' /etc/logrotate.d/nginx-proxy-manager
179168
systemctl enable -q --now openresty
180169
systemctl enable -q --now npm
181170
msg_ok "Started Services"
182171

172+
motd_ssh
173+
customize
174+
183175
msg_info "Cleaning up"
184-
rm -rf ../nginx-proxy-manager-*
185176
systemctl restart openresty
186177
$STD apt -y autoremove
187178
$STD apt -y autoclean

0 commit comments

Comments
 (0)