Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Update npm packges versions to eliminate vulnerabilities #610

Open
2 tasks
turvas opened this issue Jan 1, 2024 · 20 comments
Open
2 tasks

Update npm packges versions to eliminate vulnerabilities #610

turvas opened this issue Jan 1, 2024 · 20 comments

Comments

@turvas
Copy link

turvas commented Jan 1, 2024

🎉 Minimize vulnerabilities

So that no Critical and High severity vulerabilities exist at released images.

💪 Currenltly praeco npm dependencies have more than 100 vulnearabilities, including 16 critical and 41 high severity ones, reported by Docker Scout.

It's important to eliminate High and Critical vulnerabilities ASAP.

📖 Reference (optional)

Below is Docker Scout vulnerabilities (first page of 7) view at build step COPY:
Docker Scout first page view at step COPY

📆 Schedule (optional)

TBD

📎 Tasks (optional)

  • Get rid of critical ones
  • Get rid of High severity ones
@turvas turvas added the enhancement New feature or request label Jan 1, 2024
@turvas turvas changed the title Upade npm packges versions to eliminate vulnerabilities Update npm packges versions to eliminate vulnerabilities Jan 1, 2024
@nsano-rururu nsano-rururu added task and removed enhancement New feature or request labels Jan 2, 2024
@nsano-rururu
Copy link
Collaborator

@turvas
There is no obligation to respond. If you're in a hurry, you should do it.

@nsano-rururu
Copy link
Collaborator

It is necessary to adapt from Vue 2 to 3, and it is not possible to adapt everything at once.

@nsano-rururu
Copy link
Collaborator

Library changes and program modifications should also occur. Recognition is not an easy task.

@nsano-rururu
Copy link
Collaborator

In some cases, it may be difficult to resolve because other modules specify a vulnerable version due to dependencies. So it's not easy.

@nsano-rururu
Copy link
Collaborator

investigating

"vue-native-websocket": "2.0.15"
to
"vue-native-websocket": "github:nsano-rururu/vue-native-websocket#master",

current

77 vulnerabilities (4 low, 22 moderate, 40 high, 11 critical)

fix

11 vulnerabilities (6 moderate, 4 high, 1 critical)

@nsano-rururu
Copy link
Collaborator

  • Review and update the libraries you are using
  • Node version upgrade (16→ 18 ro 20)
  • Change the docker image used in dockerfile
  • Migration from vue2 to vue3

@nsano-rururu
Copy link
Collaborator

Since it's an OSS, it's natural that you won't receive any money by responding to this issue, but if they are not cooperative, we will lower the priority of responding to that issue. Because time is not infinite

@nsano-rururu
Copy link
Collaborator

nsano-rururu commented Jan 2, 2024

We have released Docker image 1.8.17, which changes vue-native-websocket from 2.0.15 to github:nsano-rururu/vue-native-websocket#master.
https://hub.docker.com/r/praecoapp/praeco/tags

In 1.8.18, we plan to do the following: Vue3 support continues in a separate repository
https://github.com/johnsusek/praeco/milestone/18

  • Update the library used by sano-rururu/vue-native-websocket
  • Other npm library updates
  • Base docker image change due to update from node 16 to 18

@turvas
Copy link
Author

turvas commented Jan 2, 2024

1 Review and update the libraries you are using
2 Node version upgrade (16→ 18 ro 20)
3 Change the docker image used in dockerfile
4 Migration from vue2 to vue3

I have done 2) and 3) from above list. if you are interesed, I can share my Dockerfile, where High and Critical OS level vulns are removed.

@nsano-rururu
Copy link
Collaborator

@turvas
Please share.

@turvas
Copy link
Author

turvas commented Jan 2, 2024

Dockerfile:
`
FROM node:lts-hydrogen AS base

RUN apt update &&
export DEBIAN_FRONTEND=noninteractive &&
apt install -y nginx

RUN mkdir -p /tmp/nginx/praeco
RUN mkdir -p /var/log/nginx
RUN mkdir -p /var/www/html
RUN chown www-data:www-data /var/www/html
WORKDIR /tmp/nginx/praeco
COPY package.json .

RUN apt install -y openssh-client curl postgresql-15 libde265-0
RUN apt remove -y aom-tools

FROM base AS dependencies
RUN npm install --legacy-peer-deps --loglevel error

FROM base AS release
COPY --from=dependencies /tmp/nginx/praeco/node_modules ./node_modules
COPY . .

RUN npm run build
RUN cp -r dist/* /var/www/html
EXPOSE 8080
ENTRYPOINT ["./entrypoint.sh"]
`

@nsano-rururu
Copy link
Collaborator

RUN apt install -y openssh-client curl postgresql-15 libde265-0

What is this used for? I feel like it's not necessary

@turvas
Copy link
Author

turvas commented Jan 2, 2024

node:lts-hydrogen contains 5 critical vulns, and those 2 lines update 4 vulnearable packages and uninstall the last one, which does not have fix

@nsano-rururu
Copy link
Collaborator

Thank you for your answer. We will use this as a reference when making the next release compatible with node18.

@nsano-rururu
Copy link
Collaborator

docker run aquasec/trivy image praecoapp/praeco:1.8.16

praecoapp/praeco:1.8.16 (debian 10.13)
======================================
Total: 3020 (UNKNOWN: 32, LOW: 1420, MEDIUM: 989, HIGH: 542, CRITICAL: 37)

~~~~~~~~~~~~~~~~~~~~~~~

Node.js (node-pkg)
==================
Total: 127 (UNKNOWN: 0, LOW: 6, MEDIUM: 46, HIGH: 57, CRITICAL: 18)

docker run aquasec/trivy image praecoapp/praeco:1.8.17

praecoapp/praeco:1.8.17 (debian 10.13)
======================================
Total: 3018 (UNKNOWN: 32, LOW: 1420, MEDIUM: 987, HIGH: 542, CRITICAL: 37)

~~~~~~~~~~~~~~~~~~~~~~~

Node.js (node-pkg)
==================
Total: 5 (UNKNOWN: 0, LOW: 0, MEDIUM: 3, HIGH: 2, CRITICAL: 0)

docker run aquasec/trivy image praecoapp/praeco:1.8.18

node 16 to 18

praecoapp/praeco:1.8.18 (debian 12.4)
=====================================
Total: 767 (UNKNOWN: 0, LOW: 491, MEDIUM: 223, HIGH: 51, CRITICAL: 2)

~~~~~~~~~~~~~~~~~~~~~~~

Node.js (node-pkg)
==================
Total: 3 (UNKNOWN: 0, LOW: 0, MEDIUM: 2, HIGH: 1, CRITICAL: 0)

@nsano-rururu
Copy link
Collaborator

docker run aquasec/trivy image praecoapp/elastalert-server:20231126

praecoapp/elastalert-server:20231126 (alpine 3.18.3)
====================================================
Total: 0 (UNKNOWN: 0, LOW: 0, MEDIUM: 0, HIGH: 0, CRITICAL: 0)

2024-01-03T17:36:05.145Z	INFO	Table result includes only package filenames. Use '--format json' option to get the full path to the package file.

Node.js (node-pkg)
==================
Total: 1 (UNKNOWN: 0, LOW: 0, MEDIUM: 1, HIGH: 0, CRITICAL: 0)

┌───────────────────────┬────────────────┬──────────┬────────┬───────────────────┬─────────────────────┬─────────────────────────────────────────────────────┐
│        Library        │ Vulnerability  │ Severity │ Status │ Installed Version │    Fixed Version    │                        Title                        │
├───────────────────────┼────────────────┼──────────┼────────┼───────────────────┼─────────────────────┼─────────────────────────────────────────────────────┤
│ semver (package.json) │ CVE-2022-25883 │ MEDIUM   │ fixed  │ 7.3.7             │ 7.5.2, 6.3.1, 5.7.2 │ nodejs-semver: Regular expression denial of service │
│                       │                │          │        │                   │                     │ https://avd.aquasec.com/nvd/cve-2022-25883          │
└───────────────────────┴────────────────┴──────────┴────────┴───────────────────┴─────────────────────┴─────────────────────────────────────────────────────┘

Python (python-pkg)
===================
Total: 1 (UNKNOWN: 0, LOW: 0, MEDIUM: 1, HIGH: 0, CRITICAL: 0)

┌─────────────────────────┬────────────────┬──────────┬────────┬───────────────────┬───────────────┬──────────────────────────────────────────────────────────┐
│         Library         │ Vulnerability  │ Severity │ Status │ Installed Version │ Fixed Version │                          Title                           │
├─────────────────────────┼────────────────┼──────────┼────────┼───────────────────┼───────────────┼──────────────────────────────────────────────────────────┤
│ cryptography (METADATA) │ CVE-2023-49083 │ MEDIUM   │ fixed  │ 41.0.5            │ 41.0.6        │ python-cryptography: NULL-dereference when loading PKCS7 │
│                         │                │          │        │                   │               │ certificates                                             │
│                         │                │          │        │                   │               │ https://avd.aquasec.com/nvd/cve-2023-49083               │
└─────────────────────────┴────────────────┴──────────┴────────┴───────────────────┴───────────────┴──────────────────────────────────────────────────────────┘

@nsano-rururu
Copy link
Collaborator

nsano-rururu commented Jan 3, 2024

Praeco

  • node 16 to 18
  • webpack 5.88.2 to 5.90.3
  • node 18 to 20
  • vue 2.7.16 to 3.x
  • node 20 to 22
  • change-case 4.1.2 to 5.x
  • debounce 1.2.1 to 2.x
  • Vue CLI 5.0.8 to vite
  • @vue/test-utils, chai, nyc,coverage-istanbul-loader etc to vitest

elastalert-server

  • npm library update
  • node 16 to 18
  • node 18 to 20
  • node 20 to 22

@nsano-rururu nsano-rururu self-assigned this Jan 3, 2024
@turvas
Copy link
Author

turvas commented Jan 4, 2024

thank you, great progress

@nsano-rururu
Copy link
Collaborator

docker run aquasec/trivy image praecoapp/elastalert-server:20240104

node 16 to 18

praecoapp/elastalert-server:20240104 (alpine 3.19.0)
====================================================
Total: 0 (UNKNOWN: 0, LOW: 0, MEDIUM: 0, HIGH: 0, CRITICAL: 0)

/home/node/.local/lib/python3.11/site-packages/PyJWT-2.8.0.dist-info/METADATA (secrets)
=======================================================================================
Total: 1 (UNKNOWN: 0, LOW: 0, MEDIUM: 1, HIGH: 0, CRITICAL: 0)

@nsano-rururu
Copy link
Collaborator

All versions of vue2 have XSS vulnerabilities. We plan to prioritize support for vue3.
https://www.cve.org/CVERecord?id=CVE-2024-6783

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

2 participants