From fdd44e9796f3f918131ad39be6633eb9cc292435 Mon Sep 17 00:00:00 2001 From: "J. Ryan Stinnett" Date: Fri, 3 Apr 2020 23:20:56 +0100 Subject: [PATCH] Extract dep versions out to hak.json --- hak/matrix-seshat/build.js | 9 ++++++--- hak/matrix-seshat/fetchDeps.js | 18 +++++++++--------- hak/matrix-seshat/hak.json | 6 +++++- 3 files changed, 20 insertions(+), 13 deletions(-) diff --git a/hak/matrix-seshat/build.js b/hak/matrix-seshat/build.js index ababbd5..84fd22f 100644 --- a/hak/matrix-seshat/build.js +++ b/hak/matrix-seshat/build.js @@ -31,7 +31,8 @@ module.exports = async function(hakEnv, moduleInfo) { }; async function buildOpenSslWin(hakEnv, moduleInfo) { - const openSslDir = path.join(moduleInfo.moduleDotHakDir, 'openssl-1.1.1d'); + const version = moduleInfo.dependencies.openssl; + const openSslDir = path.join(moduleInfo.moduleDotHakDir, `openssl-${version}`); const openSslArch = hakEnv.arch === 'x64' ? 'VC-WIN64A' : 'VC-WIN32'; @@ -132,7 +133,8 @@ async function buildOpenSslWin(hakEnv, moduleInfo) { } async function buildSqlCipherWin(hakEnv, moduleInfo) { - const sqlCipherDir = path.join(moduleInfo.moduleDotHakDir, 'sqlcipher-4.3.0'); + const version = moduleInfo.dependencies.sqlcipher; + const sqlCipherDir = path.join(moduleInfo.moduleDotHakDir, `sqlcipher-${version}`); const buildDir = path.join(sqlCipherDir, 'bld'); await mkdirp(buildDir); @@ -168,7 +170,8 @@ async function buildSqlCipherWin(hakEnv, moduleInfo) { } async function buildSqlCipherUnix(hakEnv, moduleInfo) { - const sqlCipherDir = path.join(moduleInfo.moduleDotHakDir, 'sqlcipher-4.3.0'); + const version = moduleInfo.dependencies.sqlcipher; + const sqlCipherDir = path.join(moduleInfo.moduleDotHakDir, `sqlcipher-${version}`); const args = [ '--prefix=' + moduleInfo.depPrefix + '', diff --git a/hak/matrix-seshat/fetchDeps.js b/hak/matrix-seshat/fetchDeps.js index 8119426..354a352 100644 --- a/hak/matrix-seshat/fetchDeps.js +++ b/hak/matrix-seshat/fetchDeps.js @@ -33,7 +33,8 @@ module.exports = async function(hakEnv, moduleInfo) { }; async function getSqlCipher(hakEnv, moduleInfo) { - const sqlCipherDir = path.join(moduleInfo.moduleDotHakDir, 'sqlcipher-4.3.0'); + const version = moduleInfo.dependencies.sqlcipher; + const sqlCipherDir = path.join(moduleInfo.moduleDotHakDir, `sqlcipher-${version}`); let haveSqlcipher; try { @@ -45,7 +46,7 @@ async function getSqlCipher(hakEnv, moduleInfo) { if (haveSqlcipher) return; - const sqlCipherTarball = path.join(moduleInfo.moduleDotHakDir, 'sqlcipher-4.3.0.tar.gz'); + const sqlCipherTarball = path.join(moduleInfo.moduleDotHakDir, `sqlcipher-${version}.tar.gz`); let haveSqlcipherTar; try { await fsProm.stat(sqlCipherTarball); @@ -54,7 +55,7 @@ async function getSqlCipher(hakEnv, moduleInfo) { haveSqlcipherTar = false; } if (!haveSqlcipherTar) { - const bob = needle('get', 'https://github.com/sqlcipher/sqlcipher/archive/v4.3.0.tar.gz', { + const bob = needle('get', `https://github.com/sqlcipher/sqlcipher/archive/v${version}.tar.gz`, { follow: 10, output: sqlCipherTarball, }); @@ -70,7 +71,7 @@ async function getSqlCipher(hakEnv, moduleInfo) { // On Windows, we need to patch the makefile because it forces TEMP_STORE to // default to files (1) but the README specifically says you '*must*' set it // set it to 2 (default to memory). - const patchFile = path.join(moduleInfo.moduleHakDir, 'sqlcipher-4.3.0-win.patch'); + const patchFile = path.join(moduleInfo.moduleHakDir, `sqlcipher-${version}-win.patch`); await new Promise((resolve, reject) => { const readStream = fs.createReadStream(patchFile); @@ -92,9 +93,8 @@ async function getSqlCipher(hakEnv, moduleInfo) { } async function getOpenSsl(hakEnv, moduleInfo) { - const osslVersion = '1.1.1f'; - - const openSslDir = path.join(moduleInfo.moduleDotHakDir, 'openssl-' + osslVersion); + const version = moduleInfo.dependencies.openssl; + const openSslDir = path.join(moduleInfo.moduleDotHakDir, `openssl-${version}`); let haveOpenSsl; try { @@ -106,7 +106,7 @@ async function getOpenSsl(hakEnv, moduleInfo) { if (haveOpenSsl) return; - const openSslTarball = path.join(moduleInfo.moduleDotHakDir, 'openssl-' + osslVersion + '.tar.gz'); + const openSslTarball = path.join(moduleInfo.moduleDotHakDir, `openssl-${version}.tar.gz`); let haveOpenSslTar; try { await fsProm.stat(openSslTarball); @@ -115,7 +115,7 @@ async function getOpenSsl(hakEnv, moduleInfo) { haveOpenSslTar = false; } if (!haveOpenSslTar) { - await needle('get', 'https://www.openssl.org/source/openssl-' + osslVersion + '.tar.gz', { + await needle('get', `https://www.openssl.org/source/openssl-${version}.tar.gz`, { follow: 10, output: openSslTarball, }); diff --git a/hak/matrix-seshat/hak.json b/hak/matrix-seshat/hak.json index 675225e..7188570 100644 --- a/hak/matrix-seshat/hak.json +++ b/hak/matrix-seshat/hak.json @@ -5,5 +5,9 @@ "build": "build.js" }, "prune": "native", - "copy": "native/index.node" + "copy": "native/index.node", + "dependencies": { + "openssl": "1.1.1f", + "sqlcipher": "4.3.0" + } }