commit 3e3166622ac8d5868727d2eca580b7a0d2948a40 Author: CentOS Sources Date: Tue May 17 04:42:19 2022 -0400 import nodejs-16.14.0-4.el9_0 diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..a873a8a --- /dev/null +++ b/.gitignore @@ -0,0 +1,2 @@ +SOURCES/icu4c-70_1-src.tgz +SOURCES/node-v16.14.0-stripped.tar.gz diff --git a/.nodejs.metadata b/.nodejs.metadata new file mode 100644 index 0000000..56c0395 --- /dev/null +++ b/.nodejs.metadata @@ -0,0 +1,2 @@ +f7c1363edee6be7de8b624ffbb801892b3417d4e SOURCES/icu4c-70_1-src.tgz +31555f8ebd7aaf06fe98409799e6a873a855ad3a SOURCES/node-v16.14.0-stripped.tar.gz diff --git a/SOURCES/0001-Disable-running-gyp-on-shared-deps.patch b/SOURCES/0001-Disable-running-gyp-on-shared-deps.patch new file mode 100644 index 0000000..361ea08 --- /dev/null +++ b/SOURCES/0001-Disable-running-gyp-on-shared-deps.patch @@ -0,0 +1,29 @@ +From b0b4d1ddbc720db73fb8ab13cdbbf1ce6524eebd Mon Sep 17 00:00:00 2001 +From: Zuzana Svetlikova +Date: Fri, 17 Apr 2020 12:59:44 +0200 +Subject: [PATCH 1/2] Disable running gyp on shared deps + +--- + Makefile | 2 +- + 1 file changed, 1 insertion(+), 1 deletion(-) + +diff --git a/Makefile b/Makefile +index 93d63110ae2e3928a95d24036b86d11885ab240f..79caaec2112cefa8f6a1c947375b517e9676f176 100644 +--- a/Makefile ++++ b/Makefile +@@ -136,11 +136,11 @@ endif + .PHONY: test-code-cache + with-code-cache test-code-cache: + $(warning '$@' target is a noop) + + out/Makefile: config.gypi common.gypi node.gyp \ +- deps/uv/uv.gyp deps/llhttp/llhttp.gyp deps/zlib/zlib.gyp \ ++ deps/llhttp/llhttp.gyp \ + tools/v8_gypfiles/toolchain.gypi tools/v8_gypfiles/features.gypi \ + tools/v8_gypfiles/inspector.gypi tools/v8_gypfiles/v8.gyp + $(PYTHON) tools/gyp_node.py -f make + + # node_version.h is listed because the N-API version is taken from there +-- +2.29.2 + diff --git a/SOURCES/0001-fix-ci-lock-file-validation.patch b/SOURCES/0001-fix-ci-lock-file-validation.patch new file mode 100644 index 0000000..81ff06a --- /dev/null +++ b/SOURCES/0001-fix-ci-lock-file-validation.patch @@ -0,0 +1,397 @@ +From 730dd78c897a28c3df0468ed1fc42d5817badefe Mon Sep 17 00:00:00 2001 +From: Ruy Adorno +Date: Wed, 2 Feb 2022 22:10:22 -0500 +Subject: [PATCH] fix(ci): lock file validation +MIME-Version: 1.0 +Content-Type: text/plain; charset=UTF-8 +Content-Transfer-Encoding: 8bit + +Make sure to validate any lock file (either package-lock.json or +npm-shrinkwrap.json) against the current install. This will properly +throw an error in case any of the dependencies being installed don't +match the dependencies that are currently listed in the lock file. + +Fixes: https://github.com/npm/cli/issues/2701 +Fixes: https://github.com/npm/cli/issues/3947 +Signed-off-by: Jan Staněk +--- + deps/npm/lib/commands/ci.js | 23 ++++++ + deps/npm/lib/utils/validate-lockfile.js | 29 +++++++ + .../smoke-tests/index.js.test.cjs | 11 +++ + .../test/lib/commands/ci.js.test.cjs | 13 +++ + .../lib/utils/validate-lockfile.js.test.cjs | 35 ++++++++ + deps/npm/test/lib/commands/ci.js | 82 +++++++++++++++++++ + deps/npm/test/lib/utils/validate-lockfile.js | 82 +++++++++++++++++++ + 7 files changed, 275 insertions(+) + create mode 100644 deps/npm/lib/utils/validate-lockfile.js + create mode 100644 deps/npm/tap-snapshots/test/lib/commands/ci.js.test.cjs + create mode 100644 deps/npm/tap-snapshots/test/lib/utils/validate-lockfile.js.test.cjs + create mode 100644 deps/npm/test/lib/utils/validate-lockfile.js + +diff --git a/deps/npm/lib/commands/ci.js b/deps/npm/lib/commands/ci.js +index 2c2f8da..376a85d 100644 +--- a/deps/npm/lib/commands/ci.js ++++ b/deps/npm/lib/commands/ci.js +@@ -6,6 +6,7 @@ const runScript = require('@npmcli/run-script') + const fs = require('fs') + const readdir = util.promisify(fs.readdir) + const log = require('../utils/log-shim.js') ++const validateLockfile = require('../utils/validate-lockfile.js') + + const removeNodeModules = async where => { + const rimrafOpts = { glob: false } +@@ -55,6 +56,28 @@ class CI extends ArboristWorkspaceCmd { + }), + removeNodeModules(where), + ]) ++ ++ // retrieves inventory of packages from loaded virtual tree (lock file) ++ const virtualInventory = new Map(arb.virtualTree.inventory) ++ ++ // build ideal tree step needs to come right after retrieving the virtual ++ // inventory since it's going to erase the previous ref to virtualTree ++ await arb.buildIdealTree() ++ ++ // verifies that the packages from the ideal tree will match ++ // the same versions that are present in the virtual tree (lock file) ++ // throws a validation error in case of mismatches ++ const errors = validateLockfile(virtualInventory, arb.idealTree.inventory) ++ if (errors.length) { ++ throw new Error( ++ '`npm ci` can only install packages when your package.json and ' + ++ 'package-lock.json or npm-shrinkwrap.json are in sync. Please ' + ++ 'update your lock file with `npm install` ' + ++ 'before continuing.\n\n' + ++ errors.join('\n') + '\n' ++ ) ++ } ++ + await arb.reify(opts) + + const ignoreScripts = this.npm.config.get('ignore-scripts') +diff --git a/deps/npm/lib/utils/validate-lockfile.js b/deps/npm/lib/utils/validate-lockfile.js +new file mode 100644 +index 0000000..29161ec +--- /dev/null ++++ b/deps/npm/lib/utils/validate-lockfile.js +@@ -0,0 +1,29 @@ ++// compares the inventory of package items in the tree ++// that is about to be installed (idealTree) with the inventory ++// of items stored in the package-lock file (virtualTree) ++// ++// Returns empty array if no errors found or an array populated ++// with an entry for each validation error found. ++function validateLockfile (virtualTree, idealTree) { ++ const errors = [] ++ ++ // loops through the inventory of packages resulted by ideal tree, ++ // for each package compares the versions with the version stored in the ++ // package-lock and adds an error to the list in case of mismatches ++ for (const [key, entry] of idealTree.entries()) { ++ const lock = virtualTree.get(key) ++ ++ if (!lock) { ++ errors.push(`Missing: ${entry.name}@${entry.version} from lock file`) ++ continue ++ } ++ ++ if (entry.version !== lock.version) { ++ errors.push(`Invalid: lock file's ${lock.name}@${lock.version} does ` + ++ `not satisfy ${entry.name}@${entry.version}`) ++ } ++ } ++ return errors ++} ++ ++module.exports = validateLockfile +diff --git a/deps/npm/tap-snapshots/smoke-tests/index.js.test.cjs b/deps/npm/tap-snapshots/smoke-tests/index.js.test.cjs +index c1316e0..5fa3977 100644 +--- a/deps/npm/tap-snapshots/smoke-tests/index.js.test.cjs ++++ b/deps/npm/tap-snapshots/smoke-tests/index.js.test.cjs +@@ -40,6 +40,17 @@ Configuration fields: npm help 7 config + + npm {CWD} + ++` ++ ++exports[`smoke-tests/index.js TAP npm ci > should throw mismatch deps in lock file error 1`] = ` ++npm ERR! \`npm ci\` can only install packages when your package.json and package-lock.json or npm-shrinkwrap.json are in sync. Please update your lock file with \`npm install\` before continuing. ++npm ERR! ++npm ERR! Invalid: lock file's abbrev@1.0.4 does not satisfy abbrev@1.1.1 ++npm ERR! ++ ++npm ERR! A complete log of this run can be found in: ++ ++ + ` + + exports[`smoke-tests/index.js TAP npm diff > should have expected diff output 1`] = ` +diff --git a/deps/npm/tap-snapshots/test/lib/commands/ci.js.test.cjs b/deps/npm/tap-snapshots/test/lib/commands/ci.js.test.cjs +new file mode 100644 +index 0000000..d6a7471 +--- /dev/null ++++ b/deps/npm/tap-snapshots/test/lib/commands/ci.js.test.cjs +@@ -0,0 +1,13 @@ ++/* IMPORTANT ++ * This snapshot file is auto-generated, but designed for humans. ++ * It should be checked into source control and tracked carefully. ++ * Re-generate by setting TAP_SNAPSHOT=1 and running tests. ++ * Make sure to inspect the output below. Do not ignore changes! ++ */ ++'use strict' ++exports[`test/lib/commands/ci.js TAP should throw error when ideal inventory mismatches virtual > must match snapshot 1`] = ` ++\`npm ci\` can only install packages when your package.json and package-lock.json or npm-shrinkwrap.json are in sync. Please update your lock file with \`npm install\` before continuing. ++ ++Invalid: lock file's foo@1.0.0 does not satisfy foo@2.0.0 ++ ++` +diff --git a/deps/npm/tap-snapshots/test/lib/utils/validate-lockfile.js.test.cjs b/deps/npm/tap-snapshots/test/lib/utils/validate-lockfile.js.test.cjs +new file mode 100644 +index 0000000..98a5126 +--- /dev/null ++++ b/deps/npm/tap-snapshots/test/lib/utils/validate-lockfile.js.test.cjs +@@ -0,0 +1,35 @@ ++/* IMPORTANT ++ * This snapshot file is auto-generated, but designed for humans. ++ * It should be checked into source control and tracked carefully. ++ * Re-generate by setting TAP_SNAPSHOT=1 and running tests. ++ * Make sure to inspect the output below. Do not ignore changes! ++ */ ++'use strict' ++exports[`test/lib/utils/validate-lockfile.js TAP extra inventory items on idealTree > should have missing entries error 1`] = ` ++Array [ ++ "Missing: baz@3.0.0 from lock file", ++] ++` ++ ++exports[`test/lib/utils/validate-lockfile.js TAP extra inventory items on virtualTree > should have no errors if finding virtualTree extra items 1`] = ` ++Array [] ++` ++ ++exports[`test/lib/utils/validate-lockfile.js TAP identical inventory for both idealTree and virtualTree > should have no errors on identical inventories 1`] = ` ++Array [] ++` ++ ++exports[`test/lib/utils/validate-lockfile.js TAP mismatching versions on inventory > should have errors for each mismatching version 1`] = ` ++Array [ ++ "Invalid: lock file's foo@1.0.0 does not satisfy foo@2.0.0", ++ "Invalid: lock file's bar@2.0.0 does not satisfy bar@3.0.0", ++] ++` ++ ++exports[`test/lib/utils/validate-lockfile.js TAP missing virtualTree inventory > should have errors for each mismatching version 1`] = ` ++Array [ ++ "Missing: foo@1.0.0 from lock file", ++ "Missing: bar@2.0.0 from lock file", ++ "Missing: baz@3.0.0 from lock file", ++] ++` +diff --git a/deps/npm/test/lib/commands/ci.js b/deps/npm/test/lib/commands/ci.js +index 537d078..e077c99 100644 +--- a/deps/npm/test/lib/commands/ci.js ++++ b/deps/npm/test/lib/commands/ci.js +@@ -19,6 +19,17 @@ t.test('should ignore scripts with --ignore-scripts', async t => { + this.reify = () => { + REIFY_CALLED = true + } ++ this.buildIdealTree = () => {} ++ this.virtualTree = { ++ inventory: new Map([ ++ ['foo', { name: 'foo', version: '1.0.0' }], ++ ]), ++ } ++ this.idealTree = { ++ inventory: new Map([ ++ ['foo', { name: 'foo', version: '1.0.0' }], ++ ]), ++ } + }, + }) + +@@ -99,6 +110,17 @@ t.test('should use Arborist and run-script', async t => { + this.reify = () => { + t.ok(true, 'reify is called') + } ++ this.buildIdealTree = () => {} ++ this.virtualTree = { ++ inventory: new Map([ ++ ['foo', { name: 'foo', version: '1.0.0' }], ++ ]), ++ } ++ this.idealTree = { ++ inventory: new Map([ ++ ['foo', { name: 'foo', version: '1.0.0' }], ++ ]), ++ } + }, + rimraf: (path, ...args) => { + actualRimrafs++ +@@ -138,6 +160,17 @@ t.test('should pass flatOptions to Arborist.reify', async t => { + this.reify = async (options) => { + t.equal(options.production, true, 'should pass flatOptions to Arborist.reify') + } ++ this.buildIdealTree = () => {} ++ this.virtualTree = { ++ inventory: new Map([ ++ ['foo', { name: 'foo', version: '1.0.0' }], ++ ]), ++ } ++ this.idealTree = { ++ inventory: new Map([ ++ ['foo', { name: 'foo', version: '1.0.0' }], ++ ]), ++ } + }, + }) + const npm = mockNpm({ +@@ -218,6 +251,17 @@ t.test('should remove existing node_modules before installing', async t => { + const nodeModules = contents.filter((path) => path.startsWith('node_modules')) + t.same(nodeModules, ['node_modules'], 'should only have the node_modules directory') + } ++ this.buildIdealTree = () => {} ++ this.virtualTree = { ++ inventory: new Map([ ++ ['foo', { name: 'foo', version: '1.0.0' }], ++ ]), ++ } ++ this.idealTree = { ++ inventory: new Map([ ++ ['foo', { name: 'foo', version: '1.0.0' }], ++ ]), ++ } + }, + }) + +@@ -231,3 +275,41 @@ t.test('should remove existing node_modules before installing', async t => { + + await ci.exec(null) + }) ++ ++t.test('should throw error when ideal inventory mismatches virtual', async t => { ++ const CI = t.mock('../../../lib/commands/ci.js', { ++ '../../../lib/utils/reify-finish.js': async () => {}, ++ '@npmcli/run-script': ({ event }) => {}, ++ '@npmcli/arborist': function () { ++ this.loadVirtual = async () => {} ++ this.reify = () => {} ++ this.buildIdealTree = () => {} ++ this.virtualTree = { ++ inventory: new Map([ ++ ['foo', { name: 'foo', version: '1.0.0' }], ++ ]), ++ } ++ this.idealTree = { ++ inventory: new Map([ ++ ['foo', { name: 'foo', version: '2.0.0' }], ++ ]), ++ } ++ }, ++ }) ++ ++ const npm = mockNpm({ ++ globalDir: 'path/to/node_modules/', ++ prefix: 'foo', ++ config: { ++ global: false, ++ 'ignore-scripts': true, ++ }, ++ }) ++ const ci = new CI(npm) ++ ++ try { ++ await ci.exec([]) ++ } catch (err) { ++ t.matchSnapshot(err.message) ++ } ++}) +diff --git a/deps/npm/test/lib/utils/validate-lockfile.js b/deps/npm/test/lib/utils/validate-lockfile.js +new file mode 100644 +index 0000000..25939c5 +--- /dev/null ++++ b/deps/npm/test/lib/utils/validate-lockfile.js +@@ -0,0 +1,82 @@ ++const t = require('tap') ++const validateLockfile = require('../../../lib/utils/validate-lockfile.js') ++ ++t.test('identical inventory for both idealTree and virtualTree', async t => { ++ t.matchSnapshot( ++ validateLockfile( ++ new Map([ ++ ['foo', { name: 'foo', version: '1.0.0' }], ++ ['bar', { name: 'bar', version: '2.0.0' }], ++ ]), ++ new Map([ ++ ['foo', { name: 'foo', version: '1.0.0' }], ++ ['bar', { name: 'bar', version: '2.0.0' }], ++ ]) ++ ), ++ 'should have no errors on identical inventories' ++ ) ++}) ++ ++t.test('extra inventory items on idealTree', async t => { ++ t.matchSnapshot( ++ validateLockfile( ++ new Map([ ++ ['foo', { name: 'foo', version: '1.0.0' }], ++ ['bar', { name: 'bar', version: '2.0.0' }], ++ ]), ++ new Map([ ++ ['foo', { name: 'foo', version: '1.0.0' }], ++ ['bar', { name: 'bar', version: '2.0.0' }], ++ ['baz', { name: 'baz', version: '3.0.0' }], ++ ]) ++ ), ++ 'should have missing entries error' ++ ) ++}) ++ ++t.test('extra inventory items on virtualTree', async t => { ++ t.matchSnapshot( ++ validateLockfile( ++ new Map([ ++ ['foo', { name: 'foo', version: '1.0.0' }], ++ ['bar', { name: 'bar', version: '2.0.0' }], ++ ['baz', { name: 'baz', version: '3.0.0' }], ++ ]), ++ new Map([ ++ ['foo', { name: 'foo', version: '1.0.0' }], ++ ['bar', { name: 'bar', version: '2.0.0' }], ++ ]) ++ ), ++ 'should have no errors if finding virtualTree extra items' ++ ) ++}) ++ ++t.test('mismatching versions on inventory', async t => { ++ t.matchSnapshot( ++ validateLockfile( ++ new Map([ ++ ['foo', { name: 'foo', version: '1.0.0' }], ++ ['bar', { name: 'bar', version: '2.0.0' }], ++ ]), ++ new Map([ ++ ['foo', { name: 'foo', version: '2.0.0' }], ++ ['bar', { name: 'bar', version: '3.0.0' }], ++ ]) ++ ), ++ 'should have errors for each mismatching version' ++ ) ++}) ++ ++t.test('missing virtualTree inventory', async t => { ++ t.matchSnapshot( ++ validateLockfile( ++ new Map([]), ++ new Map([ ++ ['foo', { name: 'foo', version: '1.0.0' }], ++ ['bar', { name: 'bar', version: '2.0.0' }], ++ ['baz', { name: 'baz', version: '3.0.0' }], ++ ]) ++ ), ++ 'should have errors for each mismatching version' ++ ) ++}) +-- +2.35.1 + diff --git a/SOURCES/0002-Install-both-binaries-and-use-libdir.patch b/SOURCES/0002-Install-both-binaries-and-use-libdir.patch new file mode 100644 index 0000000..4abfc3e --- /dev/null +++ b/SOURCES/0002-Install-both-binaries-and-use-libdir.patch @@ -0,0 +1,61 @@ +diff --git a/configure.py b/configure.py +index 895a0869cb..791c3e4a62 100755 +--- a/configure.py ++++ b/configure.py +@@ -722,6 +722,12 @@ parser.add_argument('--shared', + help='compile shared library for embedding node in another project. ' + + '(This mode is not officially supported for regular applications)') + ++parser.add_argument('--libdir', ++ action='store', ++ dest='libdir', ++ default='lib', ++ help='a directory to install the shared library into') ++ + parser.add_argument('--without-v8-platform', + action='store_true', + dest='without_v8_platform', +@@ -1293,6 +1299,7 @@ def configure_node(o): + o['variables']['node_no_browser_globals'] = b(options.no_browser_globals) + + o['variables']['node_shared'] = b(options.shared) ++ o['variables']['libdir'] = options.libdir + node_module_version = getmoduleversion.get_version() + + if options.dest_os == 'android': +diff --git a/tools/install.py b/tools/install.py +index 045d406d84..b3ef454199 100755 +--- a/tools/install.py ++++ b/tools/install.py +@@ -121,22 +121,19 @@ def subdir_files(path, dest, action): + + def files(action): + is_windows = sys.platform == 'win32' +- output_file = 'node' + output_prefix = 'out/Release/' ++ output_libprefix = output_prefix + +- if 'false' == variables.get('node_shared'): +- if is_windows: +- output_file += '.exe' ++ if is_windows: ++ output_bin = 'node.exe' ++ output_lib = 'node.dll' + else: +- if is_windows: +- output_file += '.dll' +- else: +- output_file = 'lib' + output_file + '.' + variables.get('shlib_suffix') ++ output_bin = 'node' ++ output_lib = 'libnode.' + variables.get('shlib_suffix') + +- if 'false' == variables.get('node_shared'): +- action([output_prefix + output_file], 'bin/' + output_file) +- else: +- action([output_prefix + output_file], 'lib/' + output_file) ++ action([output_prefix + output_bin], 'bin/' + output_bin) ++ if 'true' == variables.get('node_shared'): ++ action([output_libprefix + output_lib], variables.get('libdir') + '/' + output_lib) + + if 'true' == variables.get('node_use_dtrace'): + action(['out/Release/node.d'], 'lib/dtrace/node.d') diff --git a/SOURCES/btest402.js b/SOURCES/btest402.js new file mode 100644 index 0000000..277319c --- /dev/null +++ b/SOURCES/btest402.js @@ -0,0 +1,151 @@ +// Copyright (C) 2014 IBM Corporation and Others. All Rights Reserved. +// This file is part of the Node.JS ICU enablement work +// https://github.com/joyent/node/pull/7719 +// and is under the same license. +// +// This is a very, very, very basic test of es402 +// +// URL: https://github.com/srl295/btest402 +// Author: Steven R. Loomis +// +// for a complete test, see http://test262.ecmascript.org +// +// Usage: node btest402.js + +try { + console.log("You have console.log."); +} catch(e) { + // this works on d8 + console = { log: print }; + console.log("Now you have console.log."); +} + +function runbtest() { + var summary = {}; + + try { + var i = Intl; + summary.haveIntl = true; + console.log("+ Congrats, you have the Intl object."); + } catch(e) { + console.log("You don't have the Intl object: " + e); + } + + if(summary.haveIntl) { + var locs = [ "en", "mt", "ja","tlh"]; + var d = new Date(196400000); + for ( var n=0; n 0 ) { + lsummary.haveSlo = true; + } + } catch (e) { + console.log("SLO err: " + e); + } + var dstr = "ERR"; + try { + lsummary.dstr = d.toLocaleString(loc,{month: "long",day:"numeric",weekday:"long",year:"numeric"}); + console.log(" date: (supported:"+sl+") " + lsummary.dstr); + } catch (e) { + console.log(" Date Format err: " + e); + } + try { + new Intl.v8BreakIterator(); + console.log(" Intl.v8BreakIterator:" + + Intl.v8BreakIterator.supportedLocalesOf(loc) + " Supported, first()==" + + new Intl.v8BreakIterator(loc).first() ); + lsummary.brkOk = true; + } catch ( e) { + console.log(" Intl.v8BreakIterator error (NOT part of EcmaScript402): " + e); + } + console.log(); + } + } + + // print summary + console.log(); + console.log("--------- Analysis ---------"); + stxt = ""; + if( summary.haveIntl ) { + console.log("* You have the 'Intl' object. Congratulations! You have the possibility of being EcmaScript 402 compliant."); + stxt += "Have Intl, "; + + if ( !summary.en.haveSlo ) { + stxt += "Date:no EN, "; + console.log("* English isn't a supported language by the date formatter. Perhaps the data isn't installed properly?"); + } + if ( !summary.tlh.haveSlo ) { + stxt += "Date:no 'tlh', "; + console.log("* Klingon isn't a supported language by the date formatter. It is without honor!"); + } + // now, what is it actually saying + if( summary.en.dstr.indexOf("1970") == -1) { + stxt += "Date:bad 'en', "; + console.log("* the English date format text looks bad to me. Doesn't even have the year."); + } else { + if( summary.en.dstr.indexOf("Jan") == -1) { + stxt += "Date:bad 'en', "; + console.log("* The English date format text looks bad to me. Doesn't have the right month."); + } + } + + if( summary.mt.dstr == summary.en.dstr ) { + stxt += "Date:'mt'=='en', "; + console.log("* The English and Maltese look the same to me. Probably a 'small' build."); + } else if( summary.mt.dstr.indexOf("1970") == -1) { + stxt += "Date:bad 'mt', "; + console.log("* the Maltese date format text looks bad to me. Doesn't even have the year. (This data is missing from the Chromium ICU build)"); + } else { + if( summary.mt.dstr.indexOf("Jann") == -1) { + stxt += "Date:bad 'mt', "; + console.log("* The Maltese date format text looks bad to me. Doesn't have the right month. (This data is missing from the Chromium ICU build)"); + } + } + + if ( !summary.ja.haveSlo ) { + stxt += "Date:no 'ja', "; + console.log("* Japanese isn't a supported language by the date formatter. Could be a 'small' build."); + } else { + if( summary.ja.dstr.indexOf("1970") == -1) { + stxt += "Date:bad 'ja', "; + console.log("* the Japanese date format text looks bad to me. Doesn't even have the year."); + } else { + if( summary.ja.dstr.indexOf("日") == -1) { + stxt += "Date:bad 'ja', "; + console.log("* The Japanese date format text looks bad to me."); + } + } + } + if ( summary.en.brkOk ) { + stxt += "FYI: v8Brk:have 'en', "; + console.log("* You have Intl.v8BreakIterator support. (Note: not part of ES402.)"); + } + } else { + console.log("* You don't have the 'Intl' object. You aren't EcmaScript 402 compliant."); + stxt += " NO Intl. "; + } + + // 1-liner. + console.log(); + console.log("----------------"); + console.log( "SUMMARY:" + stxt ); +} + +var dorun = true; + +try { + if(btest402_noautorun) { + dorun = false; + } +} catch(e) {} + +if(dorun) { + console.log("Running btest.."); + runbtest(); +} diff --git a/SOURCES/nodejs-tarball.sh b/SOURCES/nodejs-tarball.sh new file mode 100755 index 0000000..f59d5c2 --- /dev/null +++ b/SOURCES/nodejs-tarball.sh @@ -0,0 +1,203 @@ +#!/bin/sh +# Uses Argbash to generate command argument parsing. To update +# arguments, make sure to call +# `argbash nodejs-tarball.sh -o nodejs-tarball.sh` + +# ARG_POSITIONAL_SINGLE([version],[Node.js release version],[""]) +# ARG_DEFAULTS_POS([]) +# ARG_HELP([Tool to aid in Node.js packaging of new releases]) +# ARGBASH_GO() +# needed because of Argbash --> m4_ignore([ +### START OF CODE GENERATED BY Argbash v2.8.1 one line above ### +# Argbash is a bash code generator used to get arguments parsing right. +# Argbash is FREE SOFTWARE, see https://argbash.io for more info + + +die() +{ + local _ret=$2 + test -n "$_ret" || _ret=1 + test "$_PRINT_HELP" = yes && print_help >&2 + echo "$1" >&2 + exit ${_ret} +} + + +begins_with_short_option() +{ + local first_option all_short_options='h' + first_option="${1:0:1}" + test "$all_short_options" = "${all_short_options/$first_option/}" && return 1 || return 0 +} + +# THE DEFAULTS INITIALIZATION - POSITIONALS +_positionals=() +_arg_version="" +# THE DEFAULTS INITIALIZATION - OPTIONALS + + +print_help() +{ + printf '%s\n' "Tool to aid in Node.js packaging of new releases" + printf 'Usage: %s [-h|--help] []\n' "$0" + printf '\t%s\n' ": Node.js release version (default: '""')" + printf '\t%s\n' "-h, --help: Prints help" +} + + +parse_commandline() +{ + _positionals_count=0 + while test $# -gt 0 + do + _key="$1" + case "$_key" in + -h|--help) + print_help + exit 0 + ;; + -h*) + print_help + exit 0 + ;; + *) + _last_positional="$1" + _positionals+=("$_last_positional") + _positionals_count=$((_positionals_count + 1)) + ;; + esac + shift + done +} + + +handle_passed_args_count() +{ + test "${_positionals_count}" -le 1 || _PRINT_HELP=yes die "FATAL ERROR: There were spurious positional arguments --- we expect between 0 and 1, but got ${_positionals_count} (the last one was: '${_last_positional}')." 1 +} + + +assign_positional_args() +{ + local _positional_name _shift_for=$1 + _positional_names="_arg_version " + + shift "$_shift_for" + for _positional_name in ${_positional_names} + do + test $# -gt 0 || break + eval "$_positional_name=\${1}" || die "Error during argument parsing, possibly an Argbash bug." 1 + shift + done +} + +parse_commandline "$@" +handle_passed_args_count +assign_positional_args 1 "${_positionals[@]}" + +# OTHER STUFF GENERATED BY Argbash + +### END OF CODE GENERATED BY Argbash (sortof) ### ]) +# [ <-- needed because of Argbash + + +set -e + +echo $_arg_version + +if [ x$_arg_version != x ]; then + version=$_arg_version +else + version=$(rpm -q --specfile --qf='%{version}\n' nodejs.spec | head -n1) +fi + +rm -f node-v${version}.tar.gz node-v${version}-stripped.tar.gz +wget http://nodejs.org/dist/v${version}/node-v${version}.tar.gz \ + http://nodejs.org/dist/v${version}/SHASUMS256.txt +sha256sum -c SHASUMS256.txt --ignore-missing +tar -zxf node-v${version}.tar.gz +rm -rf node-v${version}/deps/openssl +tar -zcf node-v${version}-stripped.tar.gz node-v${version} + +# Download the matching version of ICU +rm -f icu4c*-src.tgz icu.md5 +ICUMD5=$(cat node-v${version}/tools/icu/current_ver.dep |jq -r '.[0].md5') +wget $(cat node-v${version}/tools/icu/current_ver.dep |jq -r '.[0].url') +ICUTARBALL=$(ls -1 icu4c*-src.tgz) +echo "$ICUMD5 $ICUTARBALL" > icu.md5 +md5sum -c icu.md5 +rm -f icu.md5 SHASUMS256.txt + +#fedpkg new-sources node-v${version}-stripped.tar.gz icu4c*-src.tgz + +rm -f node-v${version}.tar.gz + +set +e + +# Determine the bundled versions of the various packages +echo "Bundled software versions" +echo "-------------------------" +echo +echo "libnode shared object version" +echo "=========================" +grep "define NODE_MODULE_VERSION" node-v${version}/src/node_version.h +echo +echo "V8" +echo "=========================" +grep "define V8_MAJOR_VERSION" node-v${version}/deps/v8/include/v8-version.h +grep "define V8_MINOR_VERSION" node-v${version}/deps/v8/include/v8-version.h +grep "define V8_BUILD_NUMBER" node-v${version}/deps/v8/include/v8-version.h +grep "define V8_PATCH_LEVEL" node-v${version}/deps/v8/include/v8-version.h +echo +echo "c-ares" +echo "=========================" +grep "define ARES_VERSION_MAJOR" node-v${version}/deps/cares/include/ares_version.h +grep "define ARES_VERSION_MINOR" node-v${version}/deps/cares/include/ares_version.h +grep "define ARES_VERSION_PATCH" node-v${version}/deps/cares/include/ares_version.h +echo +echo "llhttp" +echo "=========================" +grep "define LLHTTP_VERSION_MAJOR" node-v${version}/deps/llhttp/include/llhttp.h +grep "define LLHTTP_VERSION_MINOR" node-v${version}/deps/llhttp/include/llhttp.h +grep "define LLHTTP_VERSION_PATCH" node-v${version}/deps/llhttp/include/llhttp.h +echo +echo "libuv" +echo "=========================" +grep "define UV_VERSION_MAJOR" node-v${version}/deps/uv/include/uv/version.h +grep "define UV_VERSION_MINOR" node-v${version}/deps/uv/include/uv/version.h +grep "define UV_VERSION_PATCH" node-v${version}/deps/uv/include/uv/version.h +echo +echo "nghttp2" +echo "=========================" +grep "define NGHTTP2_VERSION " node-v${version}/deps/nghttp2/lib/includes/nghttp2/nghttp2ver.h +echo +echo "nghttp3" +echo "=========================" +grep "define NGHTTP3_VERSION " node-v${version}/deps/ngtcp2/nghttp3/lib/includes/nghttp3/version.h +echo +echo "ngtcp2" +echo "=========================" +grep "define NGTCP2_VERSION " node-v${version}/deps/ngtcp2/ngtcp2/lib/includes/ngtcp2/version.h +echo +echo "ICU" +echo "=========================" +grep "url" node-v${version}/tools/icu/current_ver.dep +echo +echo "punycode" +echo "=========================" +grep "'version'" node-v${version}/lib/punycode.js +echo +echo "uvwasi" +echo "=========================" +grep "define UVWASI_VERSION_MAJOR" node-v${version}/deps/uvwasi/include/uvwasi.h +grep "define UVWASI_VERSION_MINOR" node-v${version}/deps/uvwasi/include/uvwasi.h +grep "define UVWASI_VERSION_PATCH" node-v${version}/deps/uvwasi/include/uvwasi.h +echo +echo "npm" +echo "=========================" +grep "\"version\":" node-v${version}/deps/npm/package.json +echo +echo "Make sure these versions match what is in the RPM spec file" + +rm -rf node-v${version} +# ] <-- needed because of Argbash diff --git a/SOURCES/nodejs_native.attr b/SOURCES/nodejs_native.attr new file mode 100644 index 0000000..0527af6 --- /dev/null +++ b/SOURCES/nodejs_native.attr @@ -0,0 +1,2 @@ +%__nodejs_native_requires %{_rpmconfigdir}/nodejs_native.req +%__nodejs_native_path ^/usr/lib.*/node_modules/.*\\.node$ diff --git a/SOURCES/npmrc b/SOURCES/npmrc new file mode 100644 index 0000000..50be1d1 --- /dev/null +++ b/SOURCES/npmrc @@ -0,0 +1,2 @@ +prefix=/usr/local +python=/usr/bin/python3 diff --git a/SPECS/nodejs.spec b/SPECS/nodejs.spec new file mode 100644 index 0000000..c37a909 --- /dev/null +++ b/SPECS/nodejs.spec @@ -0,0 +1,1261 @@ +# bundle dependencies that are not available as Fedora modules +%bcond_without bootstrap +%global __bootstrap %{nil} + +%if 0%{?rhel} && 0%{?rhel} < 9 +%bcond_without python3_fixup +%else +%bcond_with python3_fixup +%endif + +# LTO is currently broken on Node.js builds +%define _lto_cflags %{nil} + +# Heavy-handed approach to avoiding issues with python +# bytecompiling files in the node_modules/ directory +%global __python %{__python3} + +# == Master Relase == +# This is used by both the nodejs package and the npm subpackage that +# has a separate version - the name is special so that rpmdev-bumpspec +# will bump this rather than adding .1 to the end. +%global baserelease 4 + +%{?!_pkgdocdir:%global _pkgdocdir %{_docdir}/%{name}-%{version}} + +# == Node.js Version == +# Note: Fedora should only ship LTS versions of Node.js (currently expected +# to be major versions with even numbers). The odd-numbered versions are new +# feature releases that are only supported for nine months, which is shorter +# than a Fedora release lifecycle. +%global nodejs_epoch 1 +%global nodejs_major 16 +%global nodejs_minor 14 +%global nodejs_patch 0 +%global nodejs_abi %{nodejs_major}.%{nodejs_minor} +# nodejs_soversion - from NODE_MODULE_VERSION in src/node_version.h +%global nodejs_soversion 93 +%global nodejs_version %{nodejs_major}.%{nodejs_minor}.%{nodejs_patch} +%global nodejs_release %{baserelease} + +%global nodejs_datadir %{_datarootdir}/nodejs + +# == Bundled Dependency Versions == +# v8 - from deps/v8/include/v8-version.h +# Epoch is set to ensure clean upgrades from the old v8 package +%global v8_epoch 2 +%global v8_major 9 +%global v8_minor 4 +%global v8_build 146 +%global v8_patch 24 +# V8 presently breaks ABI at least every x.y release while never bumping SONAME +%global v8_abi %{v8_major}.%{v8_minor} +%global v8_version %{v8_major}.%{v8_minor}.%{v8_build}.%{v8_patch} +%global v8_release %{nodejs_epoch}.%{nodejs_major}.%{nodejs_minor}.%{nodejs_patch}.%{nodejs_release} + +# c-ares - from deps/cares/include/ares_version.h +# https://github.com/nodejs/node/pull/9332 +%global c_ares_version 1.18.1 + +# llhttp - from deps/llhttp/include/llhttp.h +%global llhttp_version 6.0.4 + +# libuv - from deps/uv/include/uv/version.h +%global libuv_version 1.43.0 + +# nghttp2 - from deps/nghttp2/lib/includes/nghttp2/nghttp2ver.h +%global nghttp2_version 1.45.1 + +# nghttp3 - from deps/ngtcp2/nghttp3/lib/includes/nghttp3/version.h +%global nghttp3_major 0 +%global nghttp3_minor 1 +%global nghttp3_patch 0-DEV +%global nghttp3_version %{nghttp3_major}.%{nghttp3_minor}.%{nghttp3_patch} + +# ngtcp2 from deps/ngtcp2/ngtcp2/lib/includes/ngtcp2/version.h +%global ngtcp2_major 0 +%global ngtcp2_minor 1 +%global ngtcp2_patch 0-DEV +%global ngtcp2_version %{ngtcp2_major}.%{ngtcp2_minor}.%{ngtcp2_patch} + +# ICU - from tools/icu/current_ver.dep +%global icu_major 70 +%global icu_minor 1 +%global icu_version %{icu_major}.%{icu_minor} + +%global icudatadir %{nodejs_datadir}/icudata +%{!?little_endian: %global little_endian %(%{__python3} -c "import sys;print (0 if sys.byteorder=='big' else 1)")} +# " this line just fixes syntax highlighting for vim that is confused by the above and continues literal + +%global sys_icu_version %(/usr/bin/icu-config --version) + +%if "%{sys_icu_version}" >= "%{icu_version}" +%global bundled_icu 0 +%global icu_flag system-icu +%else +%global bundled_icu 1 +%global icu_flag full-icu +%endif + +# OpenSSL minimum version +%global openssl_minimum 1:1.1.1 + +# punycode - from lib/punycode.js +# Note: this was merged into the mainline since 0.6.x +# Note: this will be unmerged in an upcoming major release +%global punycode_version 2.1.0 + +# npm - from deps/npm/package.json +%global npm_epoch 1 +%global npm_version 8.3.1 + +# In order to avoid needing to keep incrementing the release version for the +# main package forever, we will just construct one for npm that is guaranteed +# to increment safely. Changing this can only be done during an update when the +# base npm version number is increasing. +%global npm_release %{nodejs_epoch}.%{nodejs_major}.%{nodejs_minor}.%{nodejs_patch}.%{nodejs_release} + +# uvwasi - from deps/uvwasi/include/uvwasi.h +%global uvwasi_version 0.0.12 + +# histogram_c - assumed from timestamps +%global histogram_version 0.9.7 + +# Node.js 16.9.1 and later comes with an experimental package management tool +%global corepack_version 0.10.0 + +Name: nodejs +Epoch: %{nodejs_epoch} +Version: %{nodejs_version} +Release: %{nodejs_release}%{?dist} +Summary: JavaScript runtime +License: MIT and ASL 2.0 and ISC and BSD +Group: Development/Languages +URL: http://nodejs.org/ + +ExclusiveArch: %{nodejs_arches} + +# nodejs bundles openssl, but we use the system version in Fedora +# because openssl contains prohibited code, we remove openssl completely from +# the tarball, using the script in Source100 +Source0: node-v%{nodejs_version}-stripped.tar.gz +Source1: npmrc +Source2: btest402.js +Source3: https://github.com/unicode-org/icu/releases/download/release-%{icu_major}-%{icu_minor}/icu4c-%{icu_major}_%{icu_minor}-src.tgz +Source100: %{name}-tarball.sh + +# The native module Requires generator remains in the nodejs SRPM, so it knows +# the nodejs and v8 versions. The remainder has migrated to the +# nodejs-packaging SRPM. +Source7: nodejs_native.attr + +# Disable running gyp on bundled deps we don't use +Patch1: 0001-Disable-running-gyp-on-shared-deps.patch + +# Patch to install both node and libnode.so, using the correct libdir +Patch2: 0002-Install-both-binaries-and-use-libdir.patch + +# CVE-2021-43616 +Patch3: 0001-fix-ci-lock-file-validation.patch + +BuildRequires: make +BuildRequires: python3-devel +BuildRequires: python3-setuptools +BuildRequires: python3-jinja2 +%if !%{with python3_fixup} +BuildRequires: python-unversioned-command +%endif +BuildRequires: zlib-devel +BuildRequires: brotli-devel +BuildRequires: gcc >= 8.3.0 +BuildRequires: gcc-c++ >= 8.3.0 +BuildRequires: jq +# needed to generate bundled provides for npm dependencies +# https://src.fedoraproject.org/rpms/nodejs/pull-request/2 +# https://pagure.io/nodejs-packaging/pull-request/10 +BuildRequires: nodejs-packaging +BuildRequires: chrpath +BuildRequires: libatomic +BuildRequires: systemtap-sdt-devel + +%if %{with bootstrap} +Provides: bundled(libuv) = %{libuv_version} +Provides: bundled(nghttp2) = %{nghttp2_version} +%else +BuildRequires: libuv-devel >= 1:%{libuv_version} +Requires: libuv >= 1:%{libuv_version} +%if 0%{?fedora} || 0%{?rhel} >= 9 +BuildRequires: libnghttp2-devel >= %{nghttp2_version} +Requires: libnghttp2 >= %{nghttp2_version} +%else +%define nghttp2_configure %{nil} +Provides: bundled(nghttp2) = %{nghttp2_version} +%endif +%endif + +# Temporarily bundle llhttp because the upstream doesn't +# provide releases for it. +Provides: bundled(llhttp) = %{llhttp_version} +Provides: bundled(nghttp3) = %{nghttp3_version} +Provides: bundled(ngtcp2) = %{ngtcp2_version} + +BuildRequires: openssl-devel >= %{openssl_minimum} +Requires: openssl >= %{openssl_minimum} + +# we need the system certificate store +Requires: ca-certificates + +Requires: nodejs-libs%{?_isa} = %{nodejs_epoch}:%{version}-%{release} + +# Pull in the full-icu data by default +Recommends: nodejs-full-i18n%{?_isa} = %{nodejs_epoch}:%{version}-%{release} + +# we need ABI virtual provides where SONAMEs aren't enough/not present so deps +# break when binary compatibility is broken +Provides: nodejs(abi) = %{nodejs_abi} +Provides: nodejs(abi%{nodejs_major}) = %{nodejs_abi} +Provides: nodejs(v8-abi) = %{v8_abi} +Provides: nodejs(v8-abi%{v8_major}) = %{v8_abi} + +# this corresponds to the "engine" requirement in package.json +Provides: nodejs(engine) = %{nodejs_version} + +# Node.js currently has a conflict with the 'node' package in Fedora +# The ham-radio group has agreed to rename their binary for us, but +# in the meantime, we're setting an explicit Conflicts: here +Conflicts: node <= 0.3.2-12 + +# The punycode module was absorbed into the standard library in v0.6. +# It still exists as a seperate package for the benefit of users of older +# versions. Since we've never shipped anything older than v0.10 in Fedora, +# we don't need the seperate nodejs-punycode package, so we Provide it here so +# dependent packages don't need to override the dependency generator. +# See also: RHBZ#11511811 +# UPDATE: punycode will be deprecated and so we should unbundle it in Node v8 +# and use upstream module instead +# https://github.com/nodejs/node/commit/29e49fc286080215031a81effbd59eac092fff2f +Provides: nodejs-punycode = %{punycode_version} +Provides: npm(punycode) = %{punycode_version} + +# Node.js has forked c-ares from upstream in an incompatible way, so we need +# to carry the bundled version internally. +# See https://github.com/nodejs/node/commit/766d063e0578c0f7758c3a965c971763f43fec85 +Provides: bundled(c-ares) = %{c_ares_version} + +# Node.js is closely tied to the version of v8 that is used with it. It makes +# sense to use the bundled version because upstream consistently breaks ABI +# even in point releases. Node.js upstream has now removed the ability to build +# against a shared system version entirely. +# See https://github.com/nodejs/node/commit/d726a177ed59c37cf5306983ed00ecd858cfbbef +Provides: bundled(v8) = %{v8_version} + +# Node.js is bound to a specific version of ICU which may not match the OS +# We cannot pin the OS to this version of ICU because every update includes +# an ABI-break, so we'll use the bundled copy. +Provides: bundled(icu) = %{icu_version} + +# Upstream added new dependencies, but so far they are not available in Fedora +# or there's no option to built it as a shared dependency, so we bundle them +Provides: bundled(uvwasi) = %{uvwasi_version} +Provides: bundled(histogram) = %{histogram_version} +Provides: bundled(corepack) = %{corepack_version} + +%if 0%{?fedora} +# Make sure to pull in the appropriate packaging macros when building RPMs +Requires: (nodejs-packaging if rpm-build) +%endif + +# Make sure we keep NPM up to date when we update Node.js +Recommends: npm >= %{npm_epoch}:%{npm_version}-%{npm_release}%{?dist} + +%description +Node.js is a platform built on Chrome's JavaScript runtime +for easily building fast, scalable network applications. +Node.js uses an event-driven, non-blocking I/O model that +makes it lightweight and efficient, perfect for data-intensive +real-time applications that run across distributed devices. + + +%package devel +Summary: JavaScript runtime - development headers +Group: Development/Languages +Requires: %{name}%{?_isa} = %{epoch}:%{nodejs_version}-%{nodejs_release}%{?dist} +Requires: openssl-devel%{?_isa} +Requires: zlib-devel%{?_isa} +Requires: brotli-devel%{?_isa} +Requires: nodejs-packaging + +%if %{with bootstrap} +# deps are bundled +%else +Requires: libuv-devel%{?_isa} +%endif + +%description devel +Development headers for the Node.js JavaScript runtime. + + +%package libs +Summary: Node.js and v8 libraries + +# Compatibility for obsolete v8 package +%if 0%{?__isa_bits} == 64 +Provides: libv8.so.%{v8_major}()(64bit) +Provides: libv8_libbase.so.%{v8_major}()(64bit) +Provides: libv8_libplatform.so.%{v8_major}()(64bit) +%else +# 32-bits +Provides: libv8.so.%{v8_major} +Provides: libv8_libbase.so.%{v8_major} +Provides: libv8_libplatform.so.%{v8_major} +%endif + +Provides: v8 = %{v8_epoch}:%{v8_version}-%{nodejs_release}%{?dist} +Provides: v8%{?_isa} = %{v8_epoch}:%{v8_version}-%{nodejs_release}%{?dist} +Obsoletes: v8 < 1:6.7.17-10 + +%description libs +Libraries to support Node.js and provide stable v8 interfaces. + + +%package full-i18n +Summary: Non-English locale data for Node.js +Requires: %{name}%{?_isa} = %{nodejs_epoch}:%{nodejs_version}-%{nodejs_release}%{?dist} + +%description full-i18n +Optional data files to provide full-icu support for Node.js. Remove this +package to save space if non-English locales are not needed. + + +%package -n v8-devel +Summary: v8 - development headers +Epoch: %{v8_epoch} +Version: %{v8_version} +Release: %{v8_release}%{?dist} +Requires: %{name}-devel%{?_isa} = %{nodejs_epoch}:%{nodejs_version}-%{nodejs_release}%{?dist} + +%description -n v8-devel +Development headers for the v8 runtime. + + +%package -n npm +Summary: Node.js Package Manager +Epoch: %{npm_epoch} +Version: %{npm_version} +Release: %{npm_release}%{?dist} + +# We used to ship npm separately, but it is so tightly integrated with Node.js +# (and expected to be present on all Node.js systems) that we ship it bundled +# now. +Obsoletes: npm < 0:3.5.4-6 +Provides: npm = %{npm_epoch}:%{npm_version} +Requires: nodejs = %{nodejs_epoch}:%{nodejs_version}-%{nodejs_release}%{?dist} +Recommends: nodejs-docs = %{nodejs_epoch}:%{nodejs_version}-%{nodejs_release}%{?dist} + +# Do not add epoch to the virtual NPM provides or it will break +# the automatic dependency-generation script. +Provides: npm(npm) = %{npm_version} + +%description -n npm +npm is a package manager for node.js. You can use it to install and publish +your node programs. It manages dependencies and does other cool stuff. + + +%package docs +Summary: Node.js API documentation +Group: Documentation +BuildArch: noarch + +# We don't require that the main package be installed to +# use the docs, but if it is installed, make sure the +# version always matches +Conflicts: %{name} > %{nodejs_epoch}:%{nodejs_version}-%{nodejs_release}%{?dist} +Conflicts: %{name} < %{nodejs_epoch}:%{nodejs_version}-%{nodejs_release}%{?dist} + +%description docs +The API documentation for the Node.js JavaScript runtime. + + +%prep +%autosetup -p1 -n node-v%{nodejs_version} + +# remove bundled dependencies that we aren't building +rm -rf deps/zlib +rm -rf deps/brotli +rm -rf deps/v8/third_party/jinja2 +rm -rf tools/inspector_protocol/jinja2 + +# Replace any instances of unversioned python' with python3 +%if %{with python3_fixup} +pathfix.py -i %{__python3} -pn $(find -type f ! -name "*.js") +find . -type f -exec sed -i "s~/usr\/bin\/env python~/usr/bin/python3~" {} \; +find . -type f -exec sed -i "s~/usr\/bin\/python\W~/usr/bin/python3~" {} \; +sed -i "s~usr\/bin\/python2~usr\/bin\/python3~" ./deps/v8/tools/gen-inlining-tests.py +sed -i "s~usr\/bin\/python.*$~usr\/bin\/python3~" ./deps/v8/tools/mb/mb_unittest.py +find . -type f -exec sed -i "s~python -c~python3 -c~" {} \; +%endif + +%build +# When compiled on armv7hl this package generates an out of range +# reference to the literal pool. This is most likely a GCC issue. +%ifarch armv7hl +%define _lto_cflags %{nil} +%endif + +%ifarch s390 s390x %{arm} %ix86 +# Decrease debuginfo verbosity to reduce memory consumption during final +# library linking +%global optflags %(echo %{optflags} | sed 's/-g /-g1 /') +%endif + +export CC='%{__cc}' +export CXX='%{__cxx}' +%{?with_python3_fixup:export NODE_GYP_FORCE_PYTHON=%{__python3}} + +# build with debugging symbols and add defines from libuv (#892601) +# Node's v8 breaks with GCC 6 because of incorrect usage of methods on +# NULL objects. We need to pass -fno-delete-null-pointer-checks +export CFLAGS='%{optflags} \ + -D_LARGEFILE_SOURCE \ + -D_FILE_OFFSET_BITS=64 \ + -DZLIB_CONST \ + -fno-delete-null-pointer-checks' +export CXXFLAGS='%{optflags} \ + -D_LARGEFILE_SOURCE \ + -D_FILE_OFFSET_BITS=64 \ + -DZLIB_CONST \ + -fno-delete-null-pointer-checks' + +# Explicit new lines in C(XX)FLAGS can break naive build scripts +export CFLAGS="$(echo ${CFLAGS} | tr '\n\\' ' ')" +export CXXFLAGS="$(echo ${CXXFLAGS} | tr '\n\\' ' ')" + +export LDFLAGS="%{build_ldflags}" + +%if %{with bootstrap} +%{__python3} configure.py --prefix=%{_prefix} \ + --shared \ + --libdir=%{_lib} \ + --shared-openssl \ + --shared-zlib \ + --shared-brotli \ + --with-dtrace \ + --with-intl=small-icu \ + --openssl-use-def-ca-store \ + --openssl-default-cipher-list=PROFILE=SYSTEM +%else +%{__python3} configure.py --prefix=%{_prefix} \ + --shared \ + --libdir=%{_lib} \ + --shared-openssl \ + --shared-zlib \ + --shared-brotli \ + --shared-libuv \ + --shared-nghttp2 \ + --with-dtrace \ + --with-intl=small-icu \ + --with-icu-default-data-dir=%{icudatadir} \ + --openssl-use-def-ca-store \ + --openssl-default-cipher-list=PROFILE=SYSTEM +%endif + +make BUILDTYPE=Release %{?_smp_mflags} + +# Extract the ICU data and convert it to the appropriate endianness +pushd deps/ +tar xfz %SOURCE3 + +pushd icu/source + +mkdir -p converted +%if 0%{?little_endian} +# The little endian data file is included in the ICU sources +install -Dpm0644 data/in/icudt%{icu_major}l.dat converted/ + +%else +# For the time being, we need to build ICU and use the included `icupkg` tool +# to convert the little endian data file into a big-endian one. +# At some point in the future, ICU releases will start including both data +# files and we should switch to those. +mkdir -p data/out/tmp + +%configure +%make_build + +icu_root=$(pwd) +LD_LIBRARY_PATH=./lib ./bin/icupkg -tb data/in/icudt%{icu_major}l.dat \ + converted/icudt%{icu_major}b.dat +%endif + +popd # icu/source +popd # deps + + +%install +rm -rf %{buildroot} + +./tools/install.py install %{buildroot} %{_prefix} + +# Set the binary permissions properly +chmod 0755 %{buildroot}/%{_bindir}/node +chrpath --delete %{buildroot}%{_bindir}/node + +# Install library symlink +ln -s libnode.so.%{nodejs_soversion} %{buildroot}%{_libdir}/libnode.so + +# Install v8 compatibility symlinks +for header in %{buildroot}%{_includedir}/node/libplatform %{buildroot}%{_includedir}/node/v8*.h; do + header=$(basename ${header}) + ln -s ./node/${header} %{buildroot}%{_includedir}/${header} +done +ln -s ./node/cppgc %{buildroot}%{_includedir}/cppgc +for soname in libv8 libv8_libbase libv8_libplatform; do + ln -s libnode.so.%{nodejs_soversion} %{buildroot}%{_libdir}/${soname}.so + ln -s libnode.so.%{nodejs_soversion} %{buildroot}%{_libdir}/${soname}.so.%{v8_major} +done + +# own the sitelib directory +mkdir -p %{buildroot}%{_prefix}/lib/node_modules + +# ensure Requires are added to every native module that match the Provides from +# the nodejs build in the buildroot +install -Dpm0644 %{SOURCE7} %{buildroot}%{_rpmconfigdir}/fileattrs/nodejs_native.attr +cat << EOF > %{buildroot}%{_rpmconfigdir}/nodejs_native.req +#!/bin/sh +echo 'nodejs(abi%{nodejs_major}) >= %nodejs_abi' +echo 'nodejs(v8-abi%{v8_major}) >= %v8_abi' +EOF +chmod 0755 %{buildroot}%{_rpmconfigdir}/nodejs_native.req + +# install documentation +mkdir -p %{buildroot}%{_pkgdocdir}/html +cp -pr doc/* %{buildroot}%{_pkgdocdir}/html +rm -f %{buildroot}%{_pkgdocdir}/html/nodejs.1 + +# node-gyp needs common.gypi too +mkdir -p %{buildroot}%{_datadir}/node +cp -p common.gypi %{buildroot}%{_datadir}/node + +# Install the GDB init tool into the documentation directory +mv %{buildroot}/%{_datadir}/doc/node/gdbinit %{buildroot}/%{_pkgdocdir}/gdbinit + +# install NPM docs to mandir +mkdir -p %{buildroot}%{_mandir} \ + %{buildroot}%{_pkgdocdir}/npm + +cp -pr deps/npm/man/* %{buildroot}%{_mandir}/ +rm -rf %{buildroot}%{_prefix}/lib/node_modules/npm/man +ln -sf %{_mandir} %{buildroot}%{_prefix}/lib/node_modules/npm/man + +# Install Gatsby HTML documentation to %%{_pkgdocdir} +cp -pr deps/npm/docs %{buildroot}%{_pkgdocdir}/npm/ +rm -rf %{buildroot}%{_prefix}/lib/node_modules/npm/docs + +ln -sf %{_pkgdocdir}/npm %{buildroot}%{_prefix}/lib/node_modules/npm/docs + +# Node tries to install some python files into a documentation directory +# (and not the proper one). Remove them for now until we figure out what to +# do with them. +rm -f %{buildroot}/%{_defaultdocdir}/node/lldb_commands.py \ + %{buildroot}/%{_defaultdocdir}/node/lldbinit + +# Some NPM bundled deps are executable but should not be. This causes +# unnecessary automatic dependencies to be added. Make them not executable. +# Skip the npm bin directory or the npm binary will not work. +find %{buildroot}%{_prefix}/lib/node_modules/npm \ + -not -path "%{buildroot}%{_prefix}/lib/node_modules/npm/bin/*" \ + -executable -type f \ + -exec chmod -x {} \; + +# The above command is a little overzealous. Add a few permissions back. +chmod 0755 %{buildroot}%{_prefix}/lib/node_modules/npm/node_modules/@npmcli/run-script/lib/node-gyp-bin/node-gyp +chmod 0755 %{buildroot}%{_prefix}/lib/node_modules/npm/node_modules/node-gyp/bin/node-gyp.js + +# Corepack contains a number of executable"shims", including some for Windows +# PowerShell. Drop the executable bit for those so we don't pick up an +# automatic dependency on /usr/bin/pwsh that we cannot satisfy. +chmod -x %{buildroot}%{_prefix}/lib/node_modules/corepack/shims/*.ps1 + +# Drop the NPM default configuration in place +mkdir -p %{buildroot}%{_sysconfdir} +cp %{SOURCE1} %{buildroot}%{_sysconfdir}/npmrc + +# NPM upstream expects it to be in /usr/etc/npmrc, so we'll put a symlink here +# This is done in the interests of keeping /usr read-only. +mkdir -p %{buildroot}%{_prefix}/etc +ln -s %{_sysconfdir}/npmrc %{buildroot}%{_prefix}/etc/npmrc + +# Install the full-icu data files +install -Dpm0644 -t %{buildroot}%{icudatadir} deps/icu/source/converted/* + + +%check +# Fail the build if the versions don't match +LD_LIBRARY_PATH=%{buildroot}%{_libdir} %{buildroot}/%{_bindir}/node -e "require('assert').equal(process.versions.node, '%{nodejs_version}')" +LD_LIBRARY_PATH=%{buildroot}%{_libdir} %{buildroot}/%{_bindir}/node -e "require('assert').equal(process.versions.v8.replace(/-node\.\d+$/, ''), '%{v8_version}')" +LD_LIBRARY_PATH=%{buildroot}%{_libdir} %{buildroot}/%{_bindir}/node -e "require('assert').equal(process.versions.ares.replace(/-DEV$/, ''), '%{c_ares_version}')" + +# Ensure we have punycode and that the version matches +LD_LIBRARY_PATH=%{buildroot}%{_libdir} %{buildroot}/%{_bindir}/node -e "require(\"assert\").equal(require(\"punycode\").version, '%{punycode_version}')" + +# Ensure we have npm and that the version matches +LD_LIBRARY_PATH=%{buildroot}%{_libdir} %{buildroot}%{_bindir}/node %{buildroot}%{_bindir}/npm version --json |jq -e '.npm == "%{npm_version}"' + +# Make sure i18n support is working +NODE_PATH=%{buildroot}%{_prefix}/lib/node_modules:%{buildroot}%{_prefix}/lib/node_modules/npm/node_modules LD_LIBRARY_PATH=%{buildroot}%{_libdir} %{buildroot}/%{_bindir}/node --icu-data-dir=%{buildroot}%{icudatadir} %{SOURCE2} + + +%pretrans -n npm -p +-- Replace the npm man directory with a symlink +-- Drop this scriptlet when F31 is EOL +path = "%{_prefix}/lib/node_modules/npm/man" +st = posix.stat(path) +if st and st.type == "directory" then + status = os.rename(path, path .. ".rpmmoved") + if not status then + suffix = 0 + while not status do + suffix = suffix + 1 + status = os.rename(path .. ".rpmmoved", path .. ".rpmmoved." .. suffix) + end + os.rename(path, path .. ".rpmmoved") + end +end + + +%files +%{_bindir}/node +%dir %{_prefix}/lib/node_modules +%dir %{_datadir}/node +%dir %{_datadir}/systemtap +%dir %{_datadir}/systemtap/tapset +%{_datadir}/systemtap/tapset/node.stp + +# corepack +%{_bindir}/corepack +%{_prefix}/lib/node_modules/corepack + +%dir %{_usr}/lib/dtrace +%{_usr}/lib/dtrace/node.d + +%{_rpmconfigdir}/fileattrs/nodejs_native.attr +%{_rpmconfigdir}/nodejs_native.req +%doc AUTHORS CHANGELOG.md onboarding.md GOVERNANCE.md README.md +%doc %{_mandir}/man1/node.1* + + +%files devel +%{_includedir}/node +%{_libdir}/libnode.so +%{_datadir}/node/common.gypi +%{_pkgdocdir}/gdbinit + + +%files full-i18n +%dir %{icudatadir} +%{icudatadir}/icudt%{icu_major}*.dat + + +%files libs +%license LICENSE +%{_libdir}/libnode.so.%{nodejs_soversion} +%{_libdir}/libv8.so.%{v8_major} +%{_libdir}/libv8_libbase.so.%{v8_major} +%{_libdir}/libv8_libplatform.so.%{v8_major} +%dir %{nodejs_datadir}/ + + +%files -n v8-devel +%{_includedir}/libplatform +%{_includedir}/v8*.h +%{_includedir}/cppgc +%{_libdir}/libv8.so +%{_libdir}/libv8_libbase.so +%{_libdir}/libv8_libplatform.so + + +%files -n npm +%{_bindir}/npm +%{_bindir}/npx +%{_prefix}/lib/node_modules/npm +%config(noreplace) %{_sysconfdir}/npmrc +%{_prefix}/etc/npmrc +%ghost %{_sysconfdir}/npmignore +%doc %{_mandir}/man1/npm*.1* +%doc %{_mandir}/man1/npx.1* +%doc %{_mandir}/man5/folders.5* +%doc %{_mandir}/man5/install.5* +%doc %{_mandir}/man5/npmrc.5* +%doc %{_mandir}/man5/package-json.5* +%doc %{_mandir}/man5/package-lock-json.5* +%doc %{_mandir}/man5/npm-shrinkwrap-json.5* +%doc %{_mandir}/man7/config.7* +%doc %{_mandir}/man7/developers.7* +%doc %{_mandir}/man7/orgs.7* +%doc %{_mandir}/man7/logging.7* +%doc %{_mandir}/man7/registry.7* +%doc %{_mandir}/man7/removal.7* +%doc %{_mandir}/man7/scope.7* +%doc %{_mandir}/man7/scripts.7* +%doc %{_mandir}/man7/workspaces.7* + + +%files docs +%doc doc +%dir %{_pkgdocdir} +%{_pkgdocdir}/html +%{_pkgdocdir}/npm/docs + + +%changelog +* Tue Apr 05 2022 Jan Staněk - 16.14.0-4 +- Apply lock file validation fixes + Resolves: CVE-2021-43616 + +* Mon Mar 07 2022 Zuzana Svetlikova - 1:16.14.0-3 +- Resolves: #2059949 +- Make Brew not append ~bootstrap when the macro is used + +* Sun Feb 13 2022 Zuzana Svetlikova - 1:16.14.0-2 +- Build with bootstrap by default due to old versions of dependencies available +- Resolves: #2042995, #2042970, #2042981, #2042989 +- Resolves: #2029936, #2024890, #2014499, #2014135 +- Resolves: #2013834, #1945299 + +* Fri Feb 11 2022 Zuzana Svetlikova - 1:16.14.0-1 +- Update to latest version +- Use jinja and jq +- Don't fix python3 +- Resolves: CVE-2022-21824, CVE-2021-44531, CVE-2021-44532, CVE-2021-44533 +- Resolves CVE-2020-15095 +- Resolves: CVE-2021-3918, CVE-2021-22959, CVE-2021-22960 +- Resolves: CVE-2021-3807, CVE-2021-27290 + +* Wed Sep 29 2021 Zuzana Svetlikova - 1:16.10.0-1 +- Rebase to 16.10.0, add corepack, fix PowerShell dependency +- Resolves: RHBZ#2000539, #2000548, #2000549, #2002177 + +* Thu Aug 12 2021 Jan Staněk - 1:16.6.2-1 +- Rebase to 16.6.2 + Resolves: CVE-2021-22931 CVE-2021-22939 CVE-2021-22940 + +* Mon Aug 09 2021 Mohan Boddu - 1:16.5.0-3 +- Rebuilt for IMA sigs, glibc 2.34, aarch64 flags + Related: rhbz#1991688 + +* Thu Jul 22 2021 Zuzana Svetlikova - 1:16.5.0-1 +- Rebase to 16.5.0 +- Fixes CVE-2021-22918(libuv) +- Resolves: RHBZ#1979926 + +* Wed Jun 16 2021 Mohan Boddu - 1:16.3.0-2 +- Rebuilt for RHEL 9 BETA for openssl 3.0 + Related: rhbz#1971065 + +* Tue Jun 01 2021 Zuzana Svetlikova - 1:16.3.0-1 +- Resolves: RHBZ#1953491 +- Rebase to 16.3.0 +- includes https://github.com/nodejs/node/pull/38732 + +* Thu May 20 2021 Zuzana Svetlikova - 1:16.2.0-1 +- Resolves: RHBZ#1953491 +- Rebase to 16.2.0 +- includes https://github.com/nodejs/node/pull/38633 (FIPS for OpenSSL 3.0) + +* Wed May 19 2021 Zuzana Svetlikova - 1:16.1.0-1 +- Resolves: RHBZ#1953491 +- Support for OpenSSL 3.0.0 +- Rebase to v16.x +- Update version of gcc and gcc-c++ needed +- Bundle nghttp3 and ngtcp2 + +* Fri Apr 16 2021 Mohan Boddu +- Rebuilt for RHEL 9 BETA on Apr 15th 2021. Related: rhbz#1947937 + +* Tue Mar 30 2021 Jonathan Wakely - 1:14.16.0-4 +- Rebuilt for removed libstdc++ symbol (#1937698) + +* Tue Mar 09 2021 Zuzana Svetlikova - 1:14.16.0-3 +- Only require nodejs-packaging on Fedora +- remove --debug-nghttp2 (#1930775) +- always build with systemtap + +* Tue Jan 26 2021 Fedora Release Engineering - 1:14.15.4-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_34_Mass_Rebuild + +* Mon Jan 04 2021 Stephen Gallagher - 1:14.15.4-1 +- Update to 14.15.4 + +* Wed Dec 02 2020 Stephen Gallagher - 1:14.15.1-1 +- Update to 14.15.1 + +* Tue Oct 20 2020 Stephen Gallagher - 1:14.14.0-2 +- Don't build with LTO on aarch64 + +* Mon Oct 19 2020 Stephen Gallagher - 1:14.14.0-1 +- Update to 14.14.0 + +* Fri Oct 09 2020 Stephen Gallagher - 1:14.13.1-1 +- Update to 14.13.1 + +* Thu Oct 01 2020 Stephen Gallagher - 1:14.13.0-1 +- Update to 14.13.0 + +* Wed Sep 16 2020 Stephen Gallagher - 1:14.11.0-1 +- Update to 14.11.0 + +* Tue Sep 08 2020 Stephen Gallagher - 1:14.10.0-1 +- Update to 14.10.0 + +* Fri Aug 21 2020 Jeff Law - 1:14.7.0-2 +- Narrow LTO opt-out to just armv7hl + +* Fri Jul 31 2020 Stephen Gallagher - 1:14.7.0-1 +- Update to 14.7.0 + +* Tue Jul 28 2020 Fedora Release Engineering - 1:14.5.0-2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_33_Mass_Rebuild + +* Tue Jul 07 2020 Stephen Gallagher - 1:14.5.0-1 +- Update to 14.5.0 + +* Tue Jul 07 2020 Stephen Gallagher - 1:14.4.0-3 +- Update for new packaging guidelines + +* Tue Jun 30 2020 Jeff Law - 1:14.4.0-2 +- Disable LTO + +* Wed Jun 03 2020 Zuzana Svetlikova - 1:14.4.0-1 +- Security update to 14.4.0 + +* Thu May 21 2020 Stephen Gallagher - 1:14.3.0-1 +- Update to 14.3.0 + +* Wed May 06 2020 Stephen Gallagher - 1:14.2.0-1 +- Update to 14.2.0 + +* Wed Apr 29 2020 Stephen Gallagher - 1:14.1.0-1 +- Update to 14.1.0 + +* Fri Apr 24 2020 Zuzana Svetlikova - 1:14.0.0-2 +- Keep the fix scripts for Koji + +* Thu Apr 23 2020 Zuzana Svetlikova - 1:14.0.0-1 +- Update to 14.0.0 +- v14.x should be python3 compatible, so commented out py sed scripts + +* Wed Apr 15 2020 Zuzana Svetlikova - 1:13.13.0-1 +- Update to 13.13.0 +- Add bundled uvwasi and histogram_c provides +- Add shared brotli dependency +- Remove icustrip.py patch, which was merged in upstream + +* Tue Mar 17 2020 Stephen Gallagher - 1:13.11.0-2 +- Fix python3 issue in icustrip.py + +* Mon Mar 16 2020 Stephen Gallagher - 1:13.11.0-1 +- Update to 13.11.0 + +* Wed Feb 26 2020 Stephen Gallagher - 1:13.9.0-2 +- Build with python 3 only + +* Tue Feb 25 2020 Stephen Gallagher - 1:13.9.0-1 +- Release Node.js 13.9.0 + +* Tue Feb 25 2020 Stephen Gallagher - 1:12.16.1-1 +- Update to 12.16.1 +- Fixes six regressions introduced in 12.16.0 + +* Fri Feb 14 2020 Stephen Gallagher - 1:12.16.0-1 +- Update to 12.16.0 +- Drop upstreamed patch + +* Thu Feb 06 2020 Stephen Gallagher - 1:12.15.0-1 +- Update to 12.15.0 + +* Wed Jan 29 2020 Fedora Release Engineering - 1:12.14.1-4 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_32_Mass_Rebuild + +* Mon Jan 13 2020 Stephen Gallagher - 1:12.14.1-3 +- Fix issue with header symlinks in v8-devel + +* Tue Jan 07 2020 Stephen Gallagher - 1:12.14.1-2 +- Drop unneeded dependency on http-parser-devel + +* Tue Jan 07 2020 Stephen Gallagher - 1:12.14.1-1 +- Update to 12.14.1 +- https://github.com/nodejs/node/blob/v12.14.1/doc/changelogs/CHANGELOG_V12.md + +* Mon Jan 06 2020 Stephen Gallagher - 1:12.14.0-2 +- Update to 12.14.0 +- https://github.com/nodejs/node/blob/v12.14.0/doc/changelogs/CHANGELOG_V12.md +- Add new subpackage nodejs-full-i18n to enable optional non-English locale + support +- Update documentation packaging for NPM + +* Mon Dec 02 2019 Stephen Gallagher - 1:12.13.1-1 +- Update to 12.13.1 +- https://github.com/nodejs/node/blob/v12.13.1/doc/changelogs/CHANGELOG_V12.md + +* Tue Oct 29 2019 Stephen Gallagher - 1:12.13.0-6 +- Add proper i18n support + +* Tue Oct 29 2019 Stephen Gallagher - 1:12.13.0-5 +- Fix issue with NPM docs being replaced with a symlink + +* Mon Oct 28 2019 Stephen Gallagher - 1:12.13.0-2 +- Simplify npmrc default configuration + +* Mon Oct 28 2019 Stephen Gallagher - 1:12.13.0-1 +- Update to 12.13.0 (LTS) +- https://github.com/nodejs/node/blob/v12.13.0/doc/changelogs/CHANGELOG_V12.md +- NPM no longer clobbers RPM-installed Node.js modules +- Drop no-longer needed patch to suppress `npm update -g npm` message + +* Wed Sep 04 2019 Stephen Gallagher - 1:12.10.0-1 +- Update to 12.10.0 +- https://github.com/nodejs/node/blob/v12.10.0/doc/changelogs/CHANGELOG_V12.md#12.10.0 + +* Wed Aug 21 2019 Stephen Gallagher - 1:12.9.0-1 +- Update to 12.9.0 +- https://github.com/nodejs/node/blob/v12.9.0/doc/changelogs/CHANGELOG_V12.md#12.9.0 + +* Thu Aug 15 2019 Stephen Gallagher - 1:12.8.2-1 +- Update to 12.8.1 +- Resolves: CVE-2019-9511 "Data Dribble" +- Resolves: CVE-2019-9512 "Ping Flood" +- Resolves: CVE-2019-9513 "Resource Loop" +- Resolves: CVE-2019-9514 "Reset Flood" +- Resolves: CVE-2019-9515 "Settings Flood" +- Resolves: CVE-2019-9516 "0-Length Headers Leak" +- Resolves: CVE-2019-9517 "Internal Data Buffering" +- Resolves: CVE-2019-9518 "Empty Frames Flood" +- https://github.com/nodejs/node/blob/v12.8.1/doc/changelogs/CHANGELOG_V12.md#12.8.1 + +* Mon Aug 05 2019 Stephen Gallagher - 1:12.7.0-3 +- Fix epoch dependencies +- Carry data files for ICU + +* Fri Aug 02 2019 Stephen Gallagher - 1:12.7.0-2 +- Change v8-devel release field to avoid duplicated package names + +* Thu Aug 01 2019 Stephen Gallagher - 1:12.7.0-1 +- Update to 12.7.0 +- https://nodejs.org/en/blog/release/v12.7.0/ + +* Tue Jul 30 2019 Tom Hughes - 1:12.6.0-2 +- Bump release to fix dependencies + +* Thu Jul 25 2019 Fedora Release Engineering - 1:12.6.0-1.1 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_31_Mass_Rebuild + +* Thu Jun 27 2019 Stephen Gallagher - 1:12.6.0-1 +- Update to 12.6.0 +- https://nodejs.org/en/blog/release/v12.6.0/ +- https://nodejs.org/en/blog/release/v12.5.0/ + +* Tue Jun 04 2019 Stephen Gallagher - 1:12.4.0-1 +- Update to 12.4.0 +- https://nodejs.org/en/blog/release/v12.4.0/ + +* Fri May 24 2019 Stephen Gallagher - 1:12.3.1-1 +- Update to 12.3.1 +- https://nodejs.org/en/blog/release/v12.3.1/ +- https://nodejs.org/en/blog/release/v12.3.0/ + +* Wed May 15 2019 Stephen Gallagher - 1:12.2.0-1 +- Update to 12.2.0 +- https://nodejs.org/en/blog/release/v12.2.0/ + +* Tue Apr 30 2019 Stephen Gallagher - 1:12.1.0-1 +- Update to 12.1.0 +- https://nodejs.org/en/blog/release/v12.1.0/ + +* Wed Apr 24 2019 Stephen Gallagher - 1:12.0.0-3 +- Fix upgrade bug for v8-devel (BZ #1702609) + +* Tue Apr 23 2019 Stephen Gallagher - 1:12.0.0-2 +- Node.js 12.x requires OpenSSL 1.1.1+ + +* Tue Apr 23 2019 Stephen Gallagher - 1:12.0.0-1 +- Release 12.0.0 +- https://nodejs.org/en/blog/release/v12.0.0/ + +* Thu Apr 11 2019 Stephen Gallagher - 1:11.13.0-1 +- Update to 11.13.0 +- https://nodejs.org/en/blog/release/v11.13.0/ +- https://nodejs.org/en/blog/release/v11.12.0/ +- https://nodejs.org/en/blog/release/v11.11.0/ + +* Fri Mar 01 2019 Stephen Gallagher - 1:11.10.1-1 +- Update to 11.10.1 +- https://nodejs.org/en/blog/release/v11.10.1/ +- https://nodejs.org/en/blog/release/v11.10.0/ +- https://nodejs.org/en/blog/release/v11.9.0/ +- https://nodejs.org/en/blog/release/v11.8.0/ + +* Fri Jan 18 2019 Stephen Gallagher - 1:11.7.0-1 +- Update to 11.7.0 +- https://nodejs.org/en/blog/release/v11.7.0/ +- https://nodejs.org/en/blog/release/v11.6.0/ +- https://nodejs.org/en/blog/release/v11.5.0/ +- https://nodejs.org/en/blog/release/v11.4.0/ + +* Thu Nov 29 2018 Stephen Gallagher - 1:11.3.0-1 +- Update to 11.3.0 +- https://nodejs.org/en/blog/release/v11.2.0/ +- https://nodejs.org/en/blog/release/v11.3.0/ + +* Fri Nov 02 2018 Stephen Gallagher - 1:11.1.0-1 +- Update to 11.1.0 +- https://nodejs.org/en/blog/release/v11.1.0/ + +* Thu Nov 01 2018 Stephen Gallagher - 1:11.0.0-1 +- Update to 11.0.0 +- https://nodejs.org/en/blog/release/v11.0.0/ + +* Thu Nov 01 2018 Stephen Gallagher - 1:10.13.0-1 +- Update to 10.13.0 +- https://nodejs.org/en/blog/release/v10.13.0/ + +* Thu Oct 11 2018 Stephen Gallagher - 1:10.12.0-1 +- Update to 10.12.0 +- https://nodejs.org/en/blog/release/v10.12.0/ + +* Wed Oct 10 2018 Jan Staněk - 1:10.11.0-2 +- Add non-bootstrap BR for nodejs-packaging + +* Thu Sep 20 2018 Stephen Gallagher - 1:10.11.0-1 +- Update to 10.11.0 +- https://nodejs.org/en/blog/release/v10.11.0/ + +* Wed Sep 19 2018 Stephen Gallagher - 1:10.10.0-2 +- Really, finally fix npm dep executable permissions + +* Tue Sep 11 2018 Stephen Gallagher - 1:10.10.0-1 +- Update to 10.10.0 +- https://nodejs.org/en/blog/release/v10.10.0/ +- Fix issue with npm permissions + +* Tue Aug 21 2018 Stephen Gallagher - 1:10.9.0-2 +- Clean up automatic dependencies for npm + +* Thu Aug 16 2018 Stephen Gallagher - 1:10.9.0-1 +- Update to 10.9.0 +- https://nodejs.org/en/blog/release/v10.9.0/ + +* Tue Aug 07 2018 Stephen Gallagher - 1:10.8.0-1 +- Update to 10.8.0 +- https://nodejs.org/en/blog/release/v10.8.0/ + +* Fri Jul 20 2018 Stephen Gallagher - 1:10.7.0-4 +- Fix npm upgrade scriptlet +- Fix unexpected trailing .1 in npm release field + +* Fri Jul 20 2018 Stephen Gallagher - 1:10.7.0-3 +- Restore annotations to binaries +- Fix unexpected trailing .1 in release field + +* Thu Jul 19 2018 Stephen Gallagher - 1:10.7.0-2 +- Update to 10.7.0 +- https://nodejs.org/en/blog/release/v10.7.0/ +- https://nodejs.org/en/blog/release/v10.6.0/ + +* Fri Jul 13 2018 Fedora Release Engineering - 1:10.5.0-1.1 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_29_Mass_Rebuild + +* Thu Jun 21 2018 Stephen Gallagher - 1:10.5.0-1 +- Update to 10.5.0 +- https://nodejs.org/en/blog/release/v10.5.0/ + +* Thu Jun 14 2018 Stephen Gallagher - 1:10.4.1-1 +- Update to 10.4.1 to address security issues +- https://nodejs.org/en/blog/release/v10.4.1/ +- Resolves: rhbz#1590801 +- Resolves: rhbz#1591014 +- Resolves: rhbz#1591019 + +* Thu Jun 07 2018 Stephen Gallagher - 1:10.4.0-1 +- Update to 10.4.0 +- https://nodejs.org/en/blog/release/v10.4.0/ + +* Wed May 30 2018 Stephen Gallagher - 1:10.3.0-1 +- Update to 10.3.0 +- Update npm to 6.1.0 +- https://nodejs.org/en/blog/release/v10.3.0/ + +* Tue May 29 2018 Stephen Gallagher - 1:10.2.1-2 +- Fix up bare 'python' to be python2 +- Drop redundant entry in docs section + +* Fri May 25 2018 Stephen Gallagher - 1:10.2.1-1 +- Update to 10.2.1 +- https://nodejs.org/en/blog/release/v10.2.1/ + +* Wed May 23 2018 Stephen Gallagher - 1:10.2.0-1 +- Update to 10.2.0 +- https://nodejs.org/en/blog/release/v10.2.0/ + +* Thu May 10 2018 Stephen Gallagher - 1:10.1.0-3 +- Fix incorrect rpm macro + +* Thu May 10 2018 Stephen Gallagher - 1:10.1.0-2 +- Include upstream v8 fix for ppc64[le] +- Disable debug build on ppc64[le] and s390x + +* Wed May 09 2018 Stephen Gallagher - 1:10.1.0-1 +- Update to 10.1.0 +- https://nodejs.org/en/blog/release/v10.1.0/ +- Reenable node_g binary + +* Thu Apr 26 2018 Stephen Gallagher - 1:10.0.0-1 +- Update to 10.0.0 +- https://nodejs.org/en/blog/release/v10.0.0/ +- Drop workaround patch +- Temporarily drop node_g binary due to + https://gcc.gnu.org/bugzilla/show_bug.cgi?id=85587 + +* Fri Apr 13 2018 Rafael dos Santos - 1:9.11.1-2 +- Use standard Fedora linker flags (bug #1543859) + +* Thu Apr 05 2018 Stephen Gallagher - 1:9.11.1-1 +- Update to 9.11.1 +- https://nodejs.org/en/blog/release/v9.11.0/ +- https://nodejs.org/en/blog/release/v9.11.1/ + +* Wed Mar 28 2018 Stephen Gallagher - 1:9.10.0-1 +- Update to 9.10.0 +- https://nodejs.org/en/blog/release/v9.10.0/ + +* Wed Mar 21 2018 Stephen Gallagher - 1:9.9.0-1 +- Update to 9.9.0 +- https://nodejs.org/en/blog/release/v9.9.0/ + +* Thu Mar 08 2018 Stephen Gallagher - 1:9.8.0-1 +- Update to 9.8.0 +- https://nodejs.org/en/blog/release/v9.8.0/ + +* Thu Mar 01 2018 Stephen Gallagher - 1:9.7.0-1 +- Update to 9.7.0 +- https://nodejs.org/en/blog/release/v9.7.0/ +- Work around F28 build issue + +* Sun Feb 25 2018 Stephen Gallagher - 1:9.6.1-1 +- Update to 9.6.1 +- https://nodejs.org/en/blog/release/v9.6.1/ +- https://nodejs.org/en/blog/release/v9.6.0/ + +* Mon Feb 05 2018 Stephen Gallagher - 1:9.5.0-1 +- Package Node.js 9.5.0 + +* Thu Jan 11 2018 Stephen Gallagher - 1:8.9.4-2 +- Fix incorrect Requires: + +* Thu Jan 11 2018 Stephen Gallagher - 1:8.9.4-1 +- Update to 8.9.4 +- https://nodejs.org/en/blog/release/v8.9.4/ +- Switch to system copy of nghttp2 + +* Fri Dec 08 2017 Stephen Gallagher - 1:8.9.3-2 +- Update to 8.9.3 +- https://nodejs.org/en/blog/release/v8.9.3/ +- https://nodejs.org/en/blog/release/v8.9.2/ + +* Thu Nov 30 2017 Pete Walter - 1:8.9.1-2 +- Rebuild for ICU 60.1 + +* Thu Nov 09 2017 Zuzana Svetlikova - 1:8.9.1-1 +- Update to 8.9.1 + +* Tue Oct 31 2017 Stephen Gallagher - 1:8.9.0-1 +- Update to 8.9.0 +- Drop upstreamed patch + +* Thu Oct 26 2017 Stephen Gallagher - 1:8.8.1-1 +- Update to 8.8.1 to fix a regression + +* Wed Oct 25 2017 Zuzana Svetlikova - 1:8.8.0-1 +- Security update to 8.8.0 +- https://nodejs.org/en/blog/release/v8.8.0/ + +* Sun Oct 15 2017 Zuzana Svetlikova - 1:8.7.0-1 +- Update to 8.7.0 +- https://nodejs.org/en/blog/release/v8.7.0/ + +* Fri Oct 06 2017 Zuzana Svetlikova - 1:8.6.0-2 +- Use bcond macro instead of bootstrap conditional + +* Wed Sep 27 2017 Zuzana Svetlikova - 1:8.6.0-1 +- Fix nghttp2 version +- Update to 8.6.0 +- https://nodejs.org/en/blog/release/v8.6.0/ + +* Wed Sep 20 2017 Zuzana Svetlikova - 1:8.5.0-3 +- Build with bootstrap + bundle libuv for modularity +- backport patch for aarch64 debug build + +* Wed Sep 13 2017 Stephen Gallagher - 1:8.5.0-2 +- Disable debug builds on aarch64 due to https://github.com/nodejs/node/issues/15395 + +* Tue Sep 12 2017 Stephen Gallagher - 1:8.5.0-1 +- Update to v8.5.0 +- https://nodejs.org/en/blog/release/v8.5.0/ + +* Thu Sep 07 2017 Zuzana Svetlikova - 1:8.4.0-2 +- Refactor openssl BR + +* Wed Aug 16 2017 Zuzana Svetlikova - 1:8.4.0-1 +- Update to v8.4.0 +- https://nodejs.org/en/blog/release/v8.4.0/ +- http2 is now supported, add bundled nghttp2 +- remove openssl 1.0.1 patches, we won't be using them in fedora + +* Thu Aug 10 2017 Zuzana Svetlikova - 1:8.3.0-1 +- Update to v8.3.0 +- https://nodejs.org/en/blog/release/v8.3.0/ +- update V8 to 6.0 +- update minimal gcc and g++ requirements to 4.9.4 + +* Wed Aug 09 2017 Tom Hughes - 1:8.2.1-2 +- Bump release to fix broken dependencies + +* Thu Aug 03 2017 Fedora Release Engineering - 1:8.2.1-1.2 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_27_Binutils_Mass_Rebuild + +* Wed Jul 26 2017 Fedora Release Engineering - 1:8.2.1-1.1 +- Rebuilt for https://fedoraproject.org/wiki/Fedora_27_Mass_Rebuild + +* Fri Jul 21 2017 Stephen Gallagher - 1:8.2.1-1 +- Update to v8.2.1 +- https://nodejs.org/en/blog/release/v8.2.1/ + +* Thu Jul 20 2017 Stephen Gallagher - 1:8.2.0-1 +- Update to v8.2.0 +- https://nodejs.org/en/blog/release/v8.2.0/ +- Update npm to 5.3.0 +- Adds npx command + +* Tue Jul 18 2017 Igor Gnatenko - 1:8.1.4-3 +- s/BuildRequires/Requires/ for http-parser-devel%%{?_isa} + +* Mon Jul 17 2017 Zuzana Svetlikova - 1:8.1.4-2 +- Rename python-devel to python2-devel +- own %%{_pkgdocdir}/npm + +* Tue Jul 11 2017 Stephen Gallagher - 1:8.1.4-1 +- Update to v8.1.4 +- https://nodejs.org/en/blog/release/v8.1.4/ +- Drop upstreamed c-ares patch + +* Thu Jun 29 2017 Zuzana Svetlikova - 1:8.1.3-1 +- Update to v8.1.3 +- https://nodejs.org/en/blog/release/v8.1.3/ + +* Wed Jun 28 2017 Zuzana Svetlikova - 1:8.1.2-1 +- Update to v8.1.2 +- remove GCC 7 patch, as it is now fixed in node >= 6.12 +