Gentoo Websites Logo
Go to: Gentoo Home Documentation Forums Lists Bugs Planet Store Wiki Get Gentoo!

Bug 613344

Summary: net-libs/nodejs: add libressl support
Product: Gentoo Linux Reporter: Nick Wallingford <nick>
Component: Current packagesAssignee: No maintainer - Look at https://wiki.gentoo.org/wiki/Project:Proxy_Maintainers if you want to take care of it <maintainer-needed>
Status: RESOLVED UPSTREAM    
Severity: normal CC: ao, cedk, fluffysheap, jstein, libressl, marien.zwart, meheschmid, mhkbst, nikulinpi, petross404, roehner, sandino, spiderx, tsmksubc
Priority: Normal Keywords: PullRequest
Version: unspecified   
Hardware: All   
OS: Linux   
See Also: https://github.com/nodejs/node/issues/428
https://github.com/gentoo/gentoo/pull/14460
Whiteboard:
Package list:
Runtime testing required: ---
Bug Depends on:    
Bug Blocks: 561854    
Attachments: Use bundle openssl when compile against libressl
ebuild with support for bundled-ssl
experimental libressl patch

Description Nick Wallingford 2017-03-20 20:28:42 UTC
net-libs/nodejs has a hard dependency on openssl, and www-client/chromium has a hard dependency on nodejs. This means it is currently impossible to continue to update chromium on a system with libressl. Even disabling the ssl USE flag still pulls in openssl.

Unfortunately it appears that it's not a simple matter of updating the USE flags. I'm still looking into it, but at first glance it appears we'll need to do extra work.
Comment 1 Gled 2017-03-24 20:49:23 UTC
I confirm the extra work needed.

I have in my repo a version with the libressl keyword, but it's obviously not compiling.

Good news is that there's a PR for that:
https://github.com/nodejs/node/pull/9376

and a bunch of bug reports:
https://github.com/voidlinux/void-packages/issues/5555

https://github.com/nodejs/node/issues/428

I'll continue tracking those and hopefully provide a working PR for the libressl overlay till it's solved upstream.
Comment 2 Matthew Marchese Gentoo Infrastructure gentoo-dev 2017-04-25 22:51:18 UTC
Glad there's a already a bug open for this. I add my support to this request. I'm running into the same issue as well wrt the bindist USE flag...
Comment 3 Sandino Araico Sanchez 2017-11-21 17:48:11 UTC
Libressl overlay has an ebuild with a required USE flag bundled-openssl when compiling with USE=libressl

https://github.com/gentoo/libressl/blob/master/net-libs/nodejs/nodejs-6.9.4.ebuild
Comment 4 Jeroen Roovers (RETIRED) gentoo-dev 2017-11-21 18:27:16 UTC
(In reply to Sandino Araico Sanchez from comment #3)
> Libressl overlay has an ebuild with a required USE flag bundled-openssl when

That's "bundled-ssl" apparently.

> compiling with USE=libressl

It does not ever appear to compile against dev-libs/libressl. USE=libressl unexpectedly requires USE=bundled-ssl in that ebuild. But the bundled crypto library is openssl, not libressl.


We don't use the bundled version of openssl to begin with and we shouldn't start doing it now.

> 
> https://github.com/gentoo/libressl/blob/master/net-libs/nodejs/nodejs-6.9.4.
> ebuild

That version should be going away soon.
Comment 5 Sandino Araico Sanchez 2017-11-21 19:03:25 UTC
Upstream seems not willing to incorporate libressl support https://github.com/nodejs/node/issues/428

The choice of compiling nodejs with USE=bundled-openssl is better (for some) than  not compiling at all with libressl.
Comment 6 Jeroen Roovers (RETIRED) gentoo-dev 2017-11-21 19:43:59 UTC
(In reply to Sandino Araico Sanchez from comment #5)
> The choice of compiling nodejs with USE=bundled-openssl is better (for some)
> than  not compiling at all with libressl.

Please forget about "bundled". This is Gentoo. We unbundle stuff. We already have a libcrypto and libssl on the system, so we don't want to have another one hiding in /usr/bin/node. Forget "bundled".
Comment 7 Nick Wallingford 2017-11-22 21:34:45 UTC
(In reply to Jeroen Roovers from comment #6)
> Please forget about "bundled". This is Gentoo. We unbundle stuff.

What's the difference between bundling openssl in nodejs and bundling harfbuzz, graphite2, libjpeg-turbo, libevent, libvpx, and sqlite in Firefox? Or ffmpeg, icu, and libvpx in Chromium? Or harfbuzz, graphite2, icu, libjpeg-turbo, libevent, libvpx, and sqlite in Thunderbird? Or jsoncpp in CMake?

Certainly, in a perfect world, we'd unbundle stuff and stuff would work. But unfortunately, nodejs does not work without bundling openssl. Upstream has given us a choice between ideological purity and working software... I'm not sure we've made the correct decision.
Comment 8 Sandino Araico Sanchez 2017-11-23 01:29:44 UTC
nodejs 8.1.1 from libressl overlay compiles against libressl 2.6.3
https://github.com/gentoo/libressl/tree/master/net-libs/nodejs
Comment 9 Cédric Krier gentoo-dev 2018-08-18 20:34:37 UTC
As it seems nodejs will not support libressl in the near future and that even OpenBSD does not try to build nodejs against libressl. Why not use the bundled openssl when nodejs is build with ssl and libressl?
Comment 10 Cédric Krier gentoo-dev 2018-08-18 20:35:39 UTC
Created attachment 543960 [details, diff]
Use bundle openssl when compile against libressl
Comment 11 Stefan Strogin gentoo-dev 2018-10-23 14:43:05 UTC
Since 63.0 www-client/firefox depends on nodejs too. It seems setting USE="-npm -ssl" for net-libs/nodejs is a workaround to build firefox.
Comment 12 Stefan Strogin gentoo-dev 2018-10-25 23:54:39 UTC
I also have a dream to see LibreSSL supported by nodejs team. But for now I completely support Cédric's proposal. And I have added net-libs/nodejs-8.12.0 and 9.11.2 ebuilds with USE=bundled-ssl to libressl overlay.
Is there any chance for this approach to be accepted it the main tree?
Comment 13 Jeroen Roovers (RETIRED) gentoo-dev 2019-03-03 10:47:42 UTC
*** Bug 679302 has been marked as a duplicate of this bug. ***
Comment 14 Jeroen Roovers (RETIRED) gentoo-dev 2020-01-26 16:01:50 UTC
Comment on attachment 543960 [details, diff]
Use bundle openssl when compile against libressl

"Use bundle openssl when compile against libressl" <= What does that mean? It does not make any sense to me, especially seeing what the patch actually does.

nodejs should not build or use its bundled openssl version and your patch does not change that.
Comment 15 Sandino Araico Sanchez 2020-01-30 02:46:36 UTC
(In reply to Jeroen Roovers from comment #14)
> 
> nodejs should not build or use its bundled openssl version and your patch
> does not change that.

Should we then mask nodejs until upstream fixes libressl compatibility?
Comment 16 Jeroen Roovers (RETIRED) gentoo-dev 2020-01-30 09:27:46 UTC
(In reply to Sandino Araico Sanchez from comment #15)
> Should we then mask nodejs until upstream fixes libressl compatibility?

You can locally mask whatever you want - I just don't see why it should be done for everyone else, too.
Comment 17 Sandino Araico Sanchez 2020-01-31 05:46:26 UTC
(In reply to Jeroen Roovers from comment #16)
> (In reply to Sandino Araico Sanchez from comment #15)
> > Should we then mask nodejs until upstream fixes libressl compatibility?
> 
> You can locally mask whatever you want - I just don't see why it should be
> done for everyone else, too.

nodejs should be masked because it is broken and no one cares fixing it. 
nodejs should be masked because upstream is not willing to fix it. https://github.com/nodejs/node/issues/428

Quoting from Gentoo development guide: 
> ...or to prevent merging of packages that are broken or break something else.
https://devmanual.gentoo.org/profiles/package.mask/index.html

An exception for not needing to mask nodejs is allowing the use of bundled openssl library when USE=libressl. This exception does not fix nodejs. It is a workaround for the meantime until we find a permanent or maintainable fix.
Comment 18 Jeroen Roovers (RETIRED) gentoo-dev 2020-01-31 15:40:33 UTC
(In reply to Sandino Araico Sanchez from comment #17)
> nodejs should be masked because it is broken and no one cares fixing it. 
> nodejs should be masked because upstream is not willing to fix it.
> https://github.com/nodejs/node/issues/428

net-libs/nodejs is not broken where openssl is installable.

> An exception for not needing to mask nodejs is allowing the use of bundled
> openssl library when USE=libressl. This exception does not fix nodejs. It is
> a workaround for the meantime until we find a permanent or maintainable fix.

Just curious: how can you have a strong opinion on using libressl over openssl and still allow yourself to use bundled openssl?
Comment 19 Sandino Araico Sanchez 2020-02-01 00:26:20 UTC
I don't know how to conditional mask only on combinations known to be broken:
a) mask libressl use flag only in net-libs/nodejs but leave it unmasked on the rest
b) mask net-libs/nodejs only when libressl use flag is present, but leave it unmasked when using openssl.

It's not comfortable for me to allow bundled openssl as an excemption. It's not the right thing. I wish I had the time to patch nodejs for libressl compatibility but in the meantime I need to have it installed as a dependency for other packages like firefox and chromium.
Comment 20 Sandino Araico Sanchez 2020-02-01 05:46:25 UTC
Created attachment 610150 [details]
ebuild with support for bundled-ssl

In tis ebuild I added exactly one of ( openssl libressl bundled-ssl) when USE=ssl
This way the user has the choice of using the bundled OpenSSL library
In this version an error has been added to src_pretend when USE=libressl indicating broken libressl support.
Comment 21 Sandino Araico Sanchez 2020-02-06 12:21:28 UTC
Created attachment 612078 [details, diff]
experimental libressl patch

This patch is not complete yet. It's just a quick and dirty patch to make nodejs compile against libressl. 
Some functions are just commented out, others need to be reprogramed or find a place to return meaningful "not supported" errors.
Comment 22 Larry the Git Cow gentoo-dev 2020-02-06 19:32:46 UTC
The bug has been referenced in the following commit(s):

https://gitweb.gentoo.org/repo/proj/libressl.git/commit/?id=3f0dbde0268de63e110a81ca0a9cb2408ba35584

commit 3f0dbde0268de63e110a81ca0a9cb2408ba35584
Author:     Stefan Strogin <steils@gentoo.org>
AuthorDate: 2020-02-06 18:21:04 +0000
Commit:     Stefan Strogin <steils@gentoo.org>
CommitDate: 2020-02-06 18:21:04 +0000

    net-libs/nodejs: version bump to 10.19.0, 12.15.0, 13.8.0
    
    Bug: https://bugs.gentoo.org/613344
    Package-Manager: Portage-2.3.87, Repoman-2.3.20
    Signed-off-by: Stefan Strogin <steils@gentoo.org>

 net-libs/nodejs/Manifest              |   3 +
 net-libs/nodejs/nodejs-10.19.0.ebuild | 204 ++++++++++++++++++++++++++++++++
 net-libs/nodejs/nodejs-12.15.0.ebuild | 212 ++++++++++++++++++++++++++++++++++
 net-libs/nodejs/nodejs-13.8.0.ebuild  | 208 +++++++++++++++++++++++++++++++++
 4 files changed, 627 insertions(+)
Comment 23 Larry the Git Cow gentoo-dev 2020-02-16 07:03:17 UTC
The bug has been referenced in the following commit(s):

https://gitweb.gentoo.org/repo/proj/libressl.git/commit/?id=33c9f12ce5444104b4164bf00db99e584bc0b777

commit 33c9f12ce5444104b4164bf00db99e584bc0b777
Author:     Stefan Strogin <steils@gentoo.org>
AuthorDate: 2020-02-16 07:02:08 +0000
Commit:     Stefan Strogin <steils@gentoo.org>
CommitDate: 2020-02-16 07:02:08 +0000

    net-libs/nodejs: version bump to 12.16.0
    
    Bug: https://bugs.gentoo.org/613344
    Package-Manager: Portage-2.3.89, Repoman-2.3.20
    Signed-off-by: Stefan Strogin <steils@gentoo.org>

 net-libs/nodejs/Manifest              |   1 +
 net-libs/nodejs/nodejs-12.16.0.ebuild | 212 ++++++++++++++++++++++++++++++++++
 2 files changed, 213 insertions(+)
Comment 24 Larry the Git Cow gentoo-dev 2020-02-19 21:43:11 UTC
The bug has been referenced in the following commit(s):

https://gitweb.gentoo.org/repo/proj/libressl.git/commit/?id=c2acac6548a6de94d1ca21fea942cb9c1c7e9923

commit c2acac6548a6de94d1ca21fea942cb9c1c7e9923
Author:     Stefan Strogin <steils@gentoo.org>
AuthorDate: 2020-02-19 21:41:20 +0000
Commit:     Stefan Strogin <steils@gentoo.org>
CommitDate: 2020-02-19 21:41:20 +0000

    net-libs/nodejs: version bump to 12.16.1, 13.9.0
    
    Bug: https://bugs.gentoo.org/613344
    Package-Manager: Portage-2.3.89, Repoman-2.3.20
    Signed-off-by: Stefan Strogin <steils@gentoo.org>

 net-libs/nodejs/Manifest              |   2 +
 net-libs/nodejs/nodejs-12.16.1.ebuild | 212 ++++++++++++++++++++++++++++++++++
 net-libs/nodejs/nodejs-13.9.0.ebuild  | 208 +++++++++++++++++++++++++++++++++
 3 files changed, 422 insertions(+)
Comment 25 Larry the Git Cow gentoo-dev 2020-02-25 05:19:15 UTC
The bug has been referenced in the following commit(s):

https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=c26bf678ea85fdbbbe8d3d14908cd25ca94397c4

commit c26bf678ea85fdbbbe8d3d14908cd25ca94397c4
Author:     Stefan Strogin <steils@gentoo.org>
AuthorDate: 2020-01-26 14:34:35 +0000
Commit:     Stefan Strogin <steils@gentoo.org>
CommitDate: 2020-02-25 05:17:13 +0000

    net-libs/nodejs: add USE=+system-ssl
    
    For now net-libs/nodejs fails to build on LibreSSL systems.
    Add USE=+system-ssl which can be explicitly disabled in order to use
    bundled OpenSSL.
    
    Bug: https://bugs.gentoo.org/613344
    Closes: https://github.com/gentoo/gentoo/pull/14460
    Package-Manager: Portage-2.3.85, Repoman-2.3.20
    Signed-off-by: Stefan Strogin <steils@gentoo.org>

 net-libs/nodejs/metadata.xml           | 1 +
 net-libs/nodejs/nodejs-10.19.0.ebuild  | 7 ++++---
 net-libs/nodejs/nodejs-12.16.1.ebuild  | 7 ++++---
 net-libs/nodejs/nodejs-13.9.0.ebuild   | 7 ++++---
 net-libs/nodejs/nodejs-99999999.ebuild | 7 ++++---
 5 files changed, 17 insertions(+), 12 deletions(-)
Comment 26 Stefan Strogin gentoo-dev 2020-02-25 05:25:14 UTC
Now LibreSSL users can install net-libs/nodejs[-system-ssl] from the main tree.

Make sure you have set USE=-system-ssl for net-libs/nodejs package.
Comment 27 hkBst 2020-03-20 12:52:38 UTC
The previous workaround of USE=-ssl still seems to work, but now forces to set system-ssl as well.
Comment 28 Larry the Git Cow gentoo-dev 2020-05-22 01:29:03 UTC
The bug has been referenced in the following commit(s):

https://gitweb.gentoo.org/repo/proj/libressl.git/commit/?id=f0aa428ad16df1d60822ef9d6007dd5b43945070

commit f0aa428ad16df1d60822ef9d6007dd5b43945070
Author:     Stefan Strogin <steils@gentoo.org>
AuthorDate: 2020-05-22 01:24:03 +0000
Commit:     Stefan Strogin <steils@gentoo.org>
CommitDate: 2020-05-22 01:24:03 +0000

    net-libs/nodejs: drop as gentoo.git now supports USE=-system-ssl
    
    Users can build nodejs with USE=-system-ssl from the main tree instead
    of USE=bundled-ssl from this overlay.
    
    Bug: https://bugs.gentoo.org/613344
    Signed-off-by: Stefan Strogin <steils@gentoo.org>

 net-libs/nodejs/Manifest                           |   6 -
 .../files/nodejs-10.3.0-global-npm-config.patch    |  20 --
 .../nodejs/files/nodejs-13.2.0-paxmarking.patch    |  71 -------
 net-libs/nodejs/files/nodejs-99999999-llhttp.patch |  20 --
 net-libs/nodejs/metadata.xml                       |  24 ---
 net-libs/nodejs/nodejs-10.19.0.ebuild              | 204 --------------------
 net-libs/nodejs/nodejs-12.14.0.ebuild              | 212 ---------------------
 net-libs/nodejs/nodejs-12.16.0.ebuild              | 212 ---------------------
 net-libs/nodejs/nodejs-12.16.1.ebuild              | 212 ---------------------
 net-libs/nodejs/nodejs-13.8.0.ebuild               | 208 --------------------
 net-libs/nodejs/nodejs-13.9.0.ebuild               | 208 --------------------
 11 files changed, 1397 deletions(-)
Comment 29 Marek Szuba (RETIRED) archtester gentoo-dev 2020-11-09 16:03:55 UTC
Let upstream sort this out, meanwhile with USE=-system-ssl NodeJS no longer blocks LibreSSL.